1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
|
<?php /** * Server-side rendering of the `core/categories` block. * * @package WordPress */
/** * 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' => '', );
if ( ! empty( $attributes['displayAsDropdown'] ) ) { $id = 'wp-block-categories-' . $block_id; $args['id'] = $id; $args['show_option_none'] = __( 'Select Category' ); $wrapper_markup = '<div class="%1$s">%2$s</div>'; $items_markup = wp_dropdown_categories( $args ); $type = 'dropdown';
if ( ! is_admin() ) { $wrapper_markup .= build_dropdown_script_block_core_categories( $id ); } } else { $wrapper_markup = '<ul class="%1$s">%2$s</ul>'; $items_markup = wp_list_categories( $args ); $type = 'list'; }
$class = "wp-block-categories wp-block-categories-{$type}";
if ( isset( $attributes['align'] ) ) { $class .= " align{$attributes['align']}"; }
if ( isset( $attributes['className'] ) ) { $class .= " {$attributes['className']}"; }
$block_content = sprintf( $wrapper_markup, esc_attr( $class ), $items_markup );
return $block_content; }
/** * 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[ */ ( function() { var dropdown = document.getElementById( '<?php echo esc_js( $dropdown_id ); ?>' ); function onCatChange() { if ( dropdown.options[ dropdown.selectedIndex ].value > 0 ) { location.href = "<?php echo home_url(); ?>/?cat=" + dropdown.options[ dropdown.selectedIndex ].value; } } dropdown.onchange = onCatChange; })(); /* ]]> */ </script> <?php return ob_get_clean(); }
/** * Registers the `core/categories` block on server. */ function register_block_core_categories() { register_block_type( 'core/categories', array( 'render_callback' => 'render_block_core_categories', ) ); }
add_action( 'init', 'register_block_core_categories' );
|