Files
wordpress/wp-includes/blocks/term-count.php
ellatrix c2bd5cd429 Editor: update packages.
Updates the packages to match Gutenberg version 21.9.0 RC2.

Also updates the sync script to work with the new `package-lock.json` format.
Some reusable block tests were adjusted to work with more render arguments.
Added `core-data` to the ignore list for `verify:source-maps` because Yjs has been bundled by accident. To be removed in a follow-up. See https://core.trac.wordpress.org/ticket/64120. See https://github.com/WordPress/gutenberg/pull/72503.

See: https://github.com/WordPress/wordpress-develop/pull/10355.
See: https://core.trac.wordpress.org/ticket/64117.

Props ellatrix, dmsnell.
Fixes #64117.
Built from https://develop.svn.wordpress.org/trunk@61009


git-svn-id: http://core.svn.wordpress.org/trunk@60345 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2025-10-21 07:14:02 +00:00

81 lines
1.8 KiB
PHP

<?php
/**
* Server-side rendering of the `core/term-count` block.
*
* @package WordPress
*/
/**
* Renders the `core/term-count` block on the server.
*
* @since 6.9.0
*
* @param array $attributes Block attributes.
* @param string $content Block default content.
* @param WP_Block $block Block instance.
*
* @return string Returns the count of the current taxonomy term wrapped inside a heading tag.
*/
function render_block_core_term_count( $attributes, $content, $block ) {
// Get term from context or from the current query.
if ( isset( $block->context['termId'] ) && isset( $block->context['taxonomy'] ) ) {
$term = get_term( $block->context['termId'], $block->context['taxonomy'] );
} else {
$term = get_queried_object();
if ( ! $term instanceof WP_Term ) {
$term = null;
}
}
if ( ! $term || is_wp_error( $term ) ) {
return '';
}
$term_count = $term->count;
// Format the term count based on bracket type.
switch ( $attributes['bracketType'] ) {
case 'none':
// No formatting needed.
break;
case 'round':
$term_count = "({$term_count})";
break;
case 'square':
$term_count = "[{$term_count}]";
break;
case 'curly':
$term_count = "{{$term_count}}";
break;
case 'angle':
$term_count = "<{$term_count}>";
break;
default:
// Default to no formatting for unknown types.
break;
}
$wrapper_attributes = get_block_wrapper_attributes();
return sprintf(
'<div %1$s>%2$s</div>',
$wrapper_attributes,
$term_count
);
}
/**
* Registers the `core/term-count` block on the server.
*
* @since 6.9.0
*/
function register_block_core_term_count() {
register_block_type_from_metadata(
__DIR__ . '/term-count',
array(
'render_callback' => 'render_block_core_term_count',
)
);
}
add_action( 'init', 'register_block_core_term_count' );