/var/www/html_us/wp-includes/blocks/cover.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
<?php
/**
 * Server-side rendering of the `core/cover` block.
 *
 * @package WordPress
 */

/**
 * Renders the `core/cover` block on server.
 *
 * @since 6.0.0
 *
 * @param array  $attributes The block attributes.
 * @param string $content    The block rendered content.
 *
 * @return string Returns the cover block markup, if useFeaturedImage is true.
 */
function render_block_core_cover$attributes$content ) {
    if ( 
'image' !== $attributes['backgroundType'] || false === $attributes['useFeaturedImage'] ) {
        return 
$content;
    }

    
$object_position = isset( $attributes['focalPoint'] )
        ? 
round$attributes['focalPoint']['x'] * 100 ) . '% ' round$attributes['focalPoint']['y'] * 100 ) . '%'
        
null;

    if ( ! ( 
$attributes['hasParallax'] || $attributes['isRepeated'] ) ) {
        
$attr = array(
            
'class'           => 'wp-block-cover__image-background',
            
'data-object-fit' => 'cover',
        );

        if ( 
$object_position ) {
            
$attr['data-object-position'] = $object_position;
            
$attr['style']                = 'object-position:' $object_position ';';
        }

        
$image get_the_post_thumbnailnull$attributes['sizeSlug'] ?? 'post-thumbnail'$attr );
    } else {
        if ( 
in_the_loop() ) {
            
update_post_thumbnail_cache();
        }
        
$current_featured_image get_the_post_thumbnail_urlnull$attributes['sizeSlug'] ?? null );
        if ( ! 
$current_featured_image ) {
            return 
$content;
        }

        
$current_thumbnail_id get_post_thumbnail_id();

        
$processor = new WP_HTML_Tag_Processor'<div></div>' );
        
$processor->next_tag();

        
$current_alt trimstrip_tagsget_post_meta$current_thumbnail_id'_wp_attachment_image_alt'true ) ) );
        if ( 
$current_alt ) {
            
$processor->set_attribute'role''img' );
            
$processor->set_attribute'aria-label'$current_alt );
        }

        
$processor->add_class'wp-block-cover__image-background' );
        
$processor->add_class'wp-image-' $current_thumbnail_id );
        if ( 
$attributes['hasParallax'] ) {
            
$processor->add_class'has-parallax' );
        }
        if ( 
$attributes['isRepeated'] ) {
            
$processor->add_class'is-repeated' );
        }

        
$styles  'background-position:' . ( $object_position ?? '50% 50%' ) . ';';
        
$styles .= 'background-image:url(' esc_url$current_featured_image ) . ');';
        
$processor->set_attribute'style'$styles );

        
$image $processor->get_updated_html();
    }

    
/*
     * Inserts the featured image between the (1st) cover 'background' `span` and 'inner_container' `div`,
     * and removes eventual whitespace characters between the two (typically introduced at template level)
     */
    
$inner_container_start '/<div\b[^>]+wp-block-cover__inner-container[\s|"][^>]*>/U';
    if ( 
=== preg_match$inner_container_start$content$matchesPREG_OFFSET_CAPTURE ) ) {
        
$offset  $matches[0][1];
        
$content substr$content0$offset ) . $image substr$content$offset );
    }

    return 
$content;
}

/**
 * Registers the `core/cover` block renderer on server.
 *
 * @since 6.0.0
 */
function register_block_core_cover() {
    
register_block_type_from_metadata(
        
__DIR__ '/cover',
        array(
            
'render_callback' => 'render_block_core_cover',
        )
    );
}
add_action'init''register_block_core_cover' );