<?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_thumbnail( null, 'post-thumbnail', $attr ); 
    } else { 
        if ( in_the_loop() ) { 
            update_post_thumbnail_cache(); 
        } 
        $current_featured_image = get_the_post_thumbnail_url(); 
        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 = trim( strip_tags( get_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 ( 1 === preg_match( $inner_container_start, $content, $matches, PREG_OFFSET_CAPTURE ) ) { 
        $offset  = $matches[0][1]; 
        $content = substr( $content, 0, $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' ); 
 
 |