Allow is_tag()
to accept term_id
, slug
, 'term_name or array of any. Many other
is_*()` funcs already do this. Adds unit tests.
Props ramiy. Fixes #18746. git-svn-id: https://develop.svn.wordpress.org/trunk@25287 602fd350-edb4-49c9-b593-d223f7449a82
This commit is contained in:
parent
c4068bc95b
commit
0474a18863
@ -246,10 +246,10 @@ function is_category( $category = '' ) {
|
||||
* @since 2.3.0
|
||||
* @uses $wp_query
|
||||
*
|
||||
* @param mixed $slug Optional. Tag slug or array of slugs.
|
||||
* @param mixed $tag Optional. Tag ID, name, slug, or array of Tag IDs, names, and slugs.
|
||||
* @return bool
|
||||
*/
|
||||
function is_tag( $slug = '' ) {
|
||||
function is_tag( $tag = '' ) {
|
||||
global $wp_query;
|
||||
|
||||
if ( ! isset( $wp_query ) ) {
|
||||
@ -257,7 +257,7 @@ function is_tag( $slug = '' ) {
|
||||
return false;
|
||||
}
|
||||
|
||||
return $wp_query->is_tag( $slug );
|
||||
return $wp_query->is_tag( $tag );
|
||||
}
|
||||
|
||||
/**
|
||||
@ -3238,21 +3238,25 @@ class WP_Query {
|
||||
*
|
||||
* @since 3.1.0
|
||||
*
|
||||
* @param mixed $slug Optional. Tag slug or array of slugs.
|
||||
* @param mixed $tag Optional. Tag ID, name, slug, or array of Tag IDs, names, and slugs.
|
||||
* @return bool
|
||||
*/
|
||||
function is_tag( $slug = '' ) {
|
||||
if ( !$this->is_tag )
|
||||
function is_tag( $tag = '' ) {
|
||||
if ( ! $this->is_tag )
|
||||
return false;
|
||||
|
||||
if ( empty( $slug ) )
|
||||
if ( empty( $tag ) )
|
||||
return true;
|
||||
|
||||
$tag_obj = $this->get_queried_object();
|
||||
|
||||
$slug = (array) $slug;
|
||||
$tag = (array) $tag;
|
||||
|
||||
if ( in_array( $tag_obj->slug, $slug ) )
|
||||
if ( in_array( $tag_obj->term_id, $tag ) )
|
||||
return true;
|
||||
elseif ( in_array( $tag_obj->name, $tag ) )
|
||||
return true;
|
||||
elseif ( in_array( $tag_obj->slug, $tag ) )
|
||||
return true;
|
||||
|
||||
return false;
|
||||
|
@ -428,9 +428,20 @@ class Tests_Query_Conditionals extends WP_UnitTestCase {
|
||||
|
||||
// 'tag/(.+?)/?$' => 'index.php?tag=$matches[1]',
|
||||
function test_tag() {
|
||||
$this->factory->term->create( array( 'name' => 'tag-a', 'taxonomy' => 'post_tag' ) );
|
||||
$term_id = $this->factory->term->create( array( 'name' => 'Tag Named A', 'slug' => 'tag-a', 'taxonomy' => 'post_tag' ) );
|
||||
$this->go_to('/tag/tag-a/');
|
||||
$this->assertQueryTrue('is_archive', 'is_tag');
|
||||
|
||||
$tag = get_term( $term_id, 'post_tag' );
|
||||
|
||||
$this->assertTrue( is_tag() );
|
||||
$this->assertTrue( is_tag( $tag->name ) );
|
||||
$this->assertTrue( is_tag( $tag->slug ) );
|
||||
$this->assertTrue( is_tag( $tag->term_id ) );
|
||||
$this->assertTrue( is_tag( array() ) );
|
||||
$this->assertTrue( is_tag( array( $tag->name ) ) );
|
||||
$this->assertTrue( is_tag( array( $tag->slug ) ) );
|
||||
$this->assertTrue( is_tag( array( $tag->term_id ) ) );
|
||||
}
|
||||
|
||||
// 'author/([^/]+)/feed/(feed|rdf|rss|rss2|atom)/?$' => 'index.php?author_name=$matches[1]&feed=$matches[2]',
|
||||
|
Loading…
Reference in New Issue
Block a user