Accept nooped plurals in wp_generate_tag_cloud() / wp_tag_cloud().

Renders topic_count_text_callback more or less obsolete. It can still be used, but passing a plural is easier.

fixes #27262. see #7989, #14424.

Built from https://develop.svn.wordpress.org/trunk@27376


git-svn-id: http://core.svn.wordpress.org/trunk@27225 1a063a9b-81f0-0310-95a4-ce76da25c4cd
This commit is contained in:
Andrew Nacin 2014-03-03 17:29:15 +00:00
parent 849ce35cb9
commit cfc20a5f64
2 changed files with 51 additions and 36 deletions

View File

@ -515,8 +515,11 @@ function wp_list_categories( $args = '' ) {
* The 'number' argument is how many tags to return. By default, the limit will * The 'number' argument is how many tags to return. By default, the limit will
* be to return the top 45 tags in the tag cloud list. * be to return the top 45 tags in the tag cloud list.
* *
* The 'topic_count_text_callback' argument is a function, which, given the count * The 'topic_count_text' argument is a nooped plural from _n_noop() to generate the
* of the posts with that tag, returns a text for the tooltip of the tag link. * text for the tooltip of the tag link.
*
* The 'topic_count_text_callback' argument is a function, which given the count
* of the posts with that tag returns a text for the tooltip of the tag link.
* *
* The 'exclude' and 'include' arguments are used for the {@link get_tags()} * The 'exclude' and 'include' arguments are used for the {@link get_tags()}
* function. Only one should be used, because only one will be used and the * function. Only one should be used, because only one will be used and the
@ -562,16 +565,6 @@ function wp_tag_cloud( $args = '' ) {
echo $return; echo $return;
} }
/**
* Default text for tooltip for tag links
*
* @param integer $count number of posts with that tag
* @return string text for the tooltip of a tag link.
*/
function default_topic_count_text( $count ) {
return sprintf( _n('%s topic', '%s topics', $count), number_format_i18n( $count ) );
}
/** /**
* Default topic count scaling for tag links * Default topic count scaling for tag links
* *
@ -603,8 +596,11 @@ function default_topic_count_scale( $count ) {
* The 'number' argument is how many tags to return. By default, the limit will * The 'number' argument is how many tags to return. By default, the limit will
* be to return the entire tag cloud list. * be to return the entire tag cloud list.
* *
* The 'topic_count_text' argument is a nooped plural from _n_noop() to generate the
* text for the tooltip of the tag link.
*
* The 'topic_count_text_callback' argument is a function, which given the count * The 'topic_count_text_callback' argument is a function, which given the count
* of the posts with that tag returns a text for the tooltip of the tag link. * of the posts with that tag returns a text for the tooltip of the tag link.
* *
* @todo Complete functionality. * @todo Complete functionality.
* @since 2.3.0 * @since 2.3.0
@ -617,20 +613,35 @@ function wp_generate_tag_cloud( $tags, $args = '' ) {
$defaults = array( $defaults = array(
'smallest' => 8, 'largest' => 22, 'unit' => 'pt', 'number' => 0, 'smallest' => 8, 'largest' => 22, 'unit' => 'pt', 'number' => 0,
'format' => 'flat', 'separator' => "\n", 'orderby' => 'name', 'order' => 'ASC', 'format' => 'flat', 'separator' => "\n", 'orderby' => 'name', 'order' => 'ASC',
'topic_count_text_callback' => 'default_topic_count_text', 'topic_count_text' => null, 'topic_count_text_callback' => null,
'topic_count_scale_callback' => 'default_topic_count_scale', 'filter' => 1, 'topic_count_scale_callback' => 'default_topic_count_scale', 'filter' => 1,
); );
if ( !isset( $args['topic_count_text_callback'] ) && isset( $args['single_text'] ) && isset( $args['multiple_text'] ) ) {
$args['topic_count_text_callback'] = '_plugin_topic_count';
}
$args = wp_parse_args( $args, $defaults ); $args = wp_parse_args( $args, $defaults );
extract( $args ); extract( $args, EXTR_SKIP );
if ( empty( $tags ) ) if ( empty( $tags ) )
return; return;
// Juggle topic count tooltips:
if ( isset( $args['topic_count_text'] ) ) {
// First look for nooped plural support via topic_count_text.
$translate_nooped_plural = $args['topic_count_text'];
} elseif ( ! empty( $args['topic_count_text_callback'] ) ) {
// Look for the alternative callback style. Ignore the previous default.
if ( $args['topic_count_text_callback'] === 'default_topic_count_text' ) {
$translate_nooped_plural = _n_noop( '%s topic', '%s topics' );
} else {
$translate_nooped_plural = false;
}
} elseif ( isset( $args['single_text'] ) && isset( $args['multiple_text'] ) ) {
// If no callback exists, look for the old-style single_text and multiple_text arguments.
$translate_nooped_plural = _n_noop( $args['single_text'], $args['multiple_text'] );
} else {
// This is the default for when no callback, plural, or argument is passed in.
$translate_nooped_plural = _n_noop( '%s topic', '%s topics' );
}
$tags_sorted = apply_filters( 'tag_cloud_sort', $tags, $args ); $tags_sorted = apply_filters( 'tag_cloud_sort', $tags, $args );
if ( $tags_sorted != $tags ) { // the tags have been sorted by a plugin if ( $tags_sorted != $tags ) { // the tags have been sorted by a plugin
$tags = $tags_sorted; $tags = $tags_sorted;
@ -677,7 +688,14 @@ function wp_generate_tag_cloud( $tags, $args = '' ) {
$tag_link = '#' != $tag->link ? esc_url( $tag->link ) : '#'; $tag_link = '#' != $tag->link ? esc_url( $tag->link ) : '#';
$tag_id = isset($tags[ $key ]->id) ? $tags[ $key ]->id : $key; $tag_id = isset($tags[ $key ]->id) ? $tags[ $key ]->id : $key;
$tag_name = $tags[ $key ]->name; $tag_name = $tags[ $key ]->name;
$a[] = "<a href='$tag_link' class='tag-link-$tag_id' title='" . esc_attr( call_user_func( $topic_count_text_callback, $real_count, $tag, $args ) ) . "' style='font-size: " .
if ( $translate_nooped_plural ) {
$title_attribute = sprintf( translate_nooped_plural( $translate_nooped_plural, $real_count ), number_format_i18n( $real_count ) );
} else {
$title_attribute = call_user_func( $topic_count_text_callback, $real_count, $tag, $args );
}
$a[] = "<a href='$tag_link' class='tag-link-$tag_id' title='" . esc_attr( $title_attribute ) . "' style='font-size: " .
str_replace( ',', '.', ( $smallest + ( ( $count - $min_count ) * $font_step ) ) ) str_replace( ',', '.', ( $smallest + ( ( $count - $min_count ) * $font_step ) ) )
. "$unit;'>$tag_name</a>"; . "$unit;'>$tag_name</a>";
} }
@ -722,21 +740,6 @@ function _wp_object_count_sort_cb( $a, $b ) {
return ( $a->count > $b->count ); return ( $a->count > $b->count );
} }
/**
* Default text for tooltip for tag links
*
* @since 3.9.0
* @access private
*
* @param integer $count Number of posts with that tag.
* @param object $tag Tag object.
* @param array $args Arguments for the tag cloud.
* @return string Text for the tooltip of a tag link.
*/
function _plugin_topic_count( $count, $tag, $args ) {
return sprintf( 1 == $count? $args['single_text'] : $args['multiple_text'], number_format_i18n( $count ) );
}
// //
// Helper functions // Helper functions
// //

View File

@ -3417,4 +3417,16 @@ function rich_edit_exists() {
* @since 2.6.0 * @since 2.6.0
* @deprecated 3.9.0 * @deprecated 3.9.0
*/ */
function wp_style_loader_src() {} function wp_style_loader_src() {}
/**
* Old callback for tag link tooltips.
*
* @since 2.7.0
* @deprecated 3.9.0
* @access private
*/
function default_topic_count_text( $count ) {
return $count;
}