2018-12-13 17:22:38 -05:00
|
|
|
<?php
|
|
|
|
/**
|
|
|
|
* Server-side rendering of the `core/categories` block.
|
|
|
|
*
|
2018-12-17 14:06:59 -05:00
|
|
|
* @package WordPress
|
2018-12-13 17:22:38 -05:00
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Renders the `core/categories` block on server.
|
|
|
|
*
|
|
|
|
* @param array $attributes The block attributes.
|
|
|
|
*
|
|
|
|
* @return string Returns the categories list/dropdown markup.
|
|
|
|
*/
|
|
|
|
function render_block_core_categories( $attributes ) {
|
|
|
|
static $block_id = 0;
|
|
|
|
$block_id++;
|
|
|
|
|
|
|
|
$args = array(
|
|
|
|
'echo' => false,
|
|
|
|
'hierarchical' => ! empty( $attributes['showHierarchy'] ),
|
|
|
|
'orderby' => 'name',
|
|
|
|
'show_count' => ! empty( $attributes['showPostCounts'] ),
|
|
|
|
'title_li' => '',
|
2022-09-20 11:43:29 -04:00
|
|
|
'hide_empty' => empty( $attributes['showEmpty'] ),
|
2018-12-13 17:22:38 -05:00
|
|
|
);
|
2021-11-08 09:29:21 -05:00
|
|
|
if ( ! empty( $attributes['showOnlyTopLevel'] ) && $attributes['showOnlyTopLevel'] ) {
|
|
|
|
$args['parent'] = 0;
|
|
|
|
}
|
2018-12-13 17:22:38 -05:00
|
|
|
|
|
|
|
if ( ! empty( $attributes['displayAsDropdown'] ) ) {
|
|
|
|
$id = 'wp-block-categories-' . $block_id;
|
|
|
|
$args['id'] = $id;
|
2018-12-17 14:06:59 -05:00
|
|
|
$args['show_option_none'] = __( 'Select Category' );
|
2022-04-12 11:12:47 -04:00
|
|
|
$wrapper_markup = '<div %1$s><label class="screen-reader-text" for="' . esc_attr( $id ) . '">' . __( 'Categories' ) . '</label>%2$s</div>';
|
2018-12-13 17:22:38 -05:00
|
|
|
$items_markup = wp_dropdown_categories( $args );
|
|
|
|
$type = 'dropdown';
|
|
|
|
|
|
|
|
if ( ! is_admin() ) {
|
2020-10-13 09:10:30 -04:00
|
|
|
// Inject the dropdown script immediately after the select dropdown.
|
|
|
|
$items_markup = preg_replace(
|
|
|
|
'#(?<=</select>)#',
|
|
|
|
build_dropdown_script_block_core_categories( $id ),
|
|
|
|
$items_markup,
|
|
|
|
1
|
|
|
|
);
|
2018-12-13 17:22:38 -05:00
|
|
|
}
|
|
|
|
} else {
|
2020-10-20 09:36:16 -04:00
|
|
|
$wrapper_markup = '<ul %1$s>%2$s</ul>';
|
2018-12-13 17:22:38 -05:00
|
|
|
$items_markup = wp_list_categories( $args );
|
|
|
|
$type = 'list';
|
|
|
|
}
|
|
|
|
|
2020-10-20 09:36:16 -04:00
|
|
|
$wrapper_attributes = get_block_wrapper_attributes( array( 'class' => "wp-block-categories-{$type}" ) );
|
2018-12-13 17:22:38 -05:00
|
|
|
|
2019-09-19 11:19:18 -04:00
|
|
|
return sprintf(
|
2018-12-13 17:22:38 -05:00
|
|
|
$wrapper_markup,
|
2020-10-20 09:36:16 -04:00
|
|
|
$wrapper_attributes,
|
2018-12-13 17:22:38 -05:00
|
|
|
$items_markup
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Generates the inline script for a categories dropdown field.
|
|
|
|
*
|
|
|
|
* @param string $dropdown_id ID of the dropdown field.
|
|
|
|
*
|
|
|
|
* @return string Returns the dropdown onChange redirection script.
|
|
|
|
*/
|
|
|
|
function build_dropdown_script_block_core_categories( $dropdown_id ) {
|
|
|
|
ob_start();
|
|
|
|
?>
|
|
|
|
<script type='text/javascript'>
|
|
|
|
/* <![CDATA[ */
|
2018-12-18 22:16:48 -05:00
|
|
|
( function() {
|
2018-12-13 17:22:38 -05:00
|
|
|
var dropdown = document.getElementById( '<?php echo esc_js( $dropdown_id ); ?>' );
|
|
|
|
function onCatChange() {
|
|
|
|
if ( dropdown.options[ dropdown.selectedIndex ].value > 0 ) {
|
2022-09-20 11:43:29 -04:00
|
|
|
location.href = "<?php echo esc_url( home_url() ); ?>/?cat=" + dropdown.options[ dropdown.selectedIndex ].value;
|
2018-12-13 17:22:38 -05:00
|
|
|
}
|
|
|
|
}
|
|
|
|
dropdown.onchange = onCatChange;
|
|
|
|
})();
|
|
|
|
/* ]]> */
|
|
|
|
</script>
|
|
|
|
<?php
|
|
|
|
return ob_get_clean();
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Registers the `core/categories` block on server.
|
|
|
|
*/
|
|
|
|
function register_block_core_categories() {
|
2020-06-26 09:33:47 -04:00
|
|
|
register_block_type_from_metadata(
|
|
|
|
__DIR__ . '/categories',
|
2018-12-13 17:22:38 -05:00
|
|
|
array(
|
|
|
|
'render_callback' => 'render_block_core_categories',
|
|
|
|
)
|
|
|
|
);
|
|
|
|
}
|
|
|
|
add_action( 'init', 'register_block_core_categories' );
|