/var/www/html/wp-includes/blocks/post-terms.php


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
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
<?php
/**
 * Server-side rendering of the `core/post-terms` block.
 *
 * @package WordPress
 */

/**
 * Renders the `core/post-terms` block on the server.
 *
 * @since 5.8.0
 *
 * @param array    $attributes Block attributes.
 * @param string   $content    Block default content.
 * @param WP_Block $block      Block instance.
 * @return string Returns the filtered post terms for the current post wrapped inside "a" tags.
 */
function render_block_core_post_terms$attributes$content$block ) {
    if ( ! isset( 
$block->context['postId'] ) || ! isset( $attributes['term'] ) ) {
        return 
'';
    }

    if ( ! 
is_taxonomy_viewable$attributes['term'] ) ) {
        return 
'';
    }

    
$post_terms get_the_terms$block->context['postId'], $attributes['term'] );
    if ( 
is_wp_error$post_terms ) || empty( $post_terms ) ) {
        return 
'';
    }

    
$classes = array( 'taxonomy-' $attributes['term'] );
    if ( isset( 
$attributes['textAlign'] ) ) {
        
$classes[] = 'has-text-align-' $attributes['textAlign'];
    }
    if ( isset( 
$attributes['style']['elements']['link']['color']['text'] ) ) {
        
$classes[] = 'has-link-color';
    }

    
$separator = empty( $attributes['separator'] ) ? ' ' $attributes['separator'];

    
$wrapper_attributes get_block_wrapper_attributes( array( 'class' => implode' '$classes ) ) );

    
$prefix "<div $wrapper_attributes>";
    if ( isset( 
$attributes['prefix'] ) && $attributes['prefix'] ) {
        
$prefix .= '<span class="wp-block-post-terms__prefix">' $attributes['prefix'] . '</span>';
    }

    
$suffix '</div>';
    if ( isset( 
$attributes['suffix'] ) && $attributes['suffix'] ) {
        
$suffix '<span class="wp-block-post-terms__suffix">' $attributes['suffix'] . '</span>' $suffix;
    }

    return 
get_the_term_list(
        
$block->context['postId'],
        
$attributes['term'],
        
wp_kses_post$prefix ),
        
'<span class="wp-block-post-terms__separator">' esc_html$separator ) . '</span>',
        
wp_kses_post$suffix )
    );
}

/**
 * Returns the available variations for the `core/post-terms` block.
 *
 * @since 6.5.0
 *
 * @return array The available variations for the block.
 */
function block_core_post_terms_build_variations() {
    
$taxonomies get_taxonomies(
        array(
            
'publicly_queryable' => true,
            
'show_in_rest'       => true,
        ),
        
'objects'
    
);

    
// Split the available taxonomies to `built_in` and custom ones,
    // in order to prioritize the `built_in` taxonomies at the
    // search results.
    
$built_ins         = array();
    
$custom_variations = array();

    
// Create and register the eligible taxonomies variations.
    
foreach ( $taxonomies as $taxonomy ) {
        
$variation = array(
            
'name'        => $taxonomy->name,
            
'title'       => $taxonomy->label,
            
'description' => sprintf(
                
/* translators: %s: taxonomy's label */
                
__'Display a list of assigned terms from the taxonomy: %s' ),
                
$taxonomy->label
            
),
            
'attributes'  => array(
                
'term' => $taxonomy->name,
            ),
            
'isActive'    => array( 'term' ),
            
'scope'       => array( 'inserter''transform' ),
        );
        
// Set the category variation as the default one.
        
if ( 'category' === $taxonomy->name ) {
            
$variation['isDefault'] = true;
        }
        if ( 
$taxonomy->_builtin ) {
            
$built_ins[] = $variation;
        } else {
            
$custom_variations[] = $variation;
        }
    }

    return 
array_merge$built_ins$custom_variations );
}

/**
 * Registers the `core/post-terms` block on the server.
 *
 * @since 5.8.0
 */
function register_block_core_post_terms() {
    
register_block_type_from_metadata(
        
__DIR__ '/post-terms',
        array(
            
'render_callback'    => 'render_block_core_post_terms',
            
'variation_callback' => 'block_core_post_terms_build_variations',
        )
    );
}
add_action'init''register_block_core_post_terms' );