2022-04-19 07:51:07 -04:00
|
|
|
<?php
|
|
|
|
/**
|
|
|
|
* Server-side rendering of the `core/cover` block.
|
|
|
|
*
|
|
|
|
* @package WordPress
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Renders the `core/cover` block on server.
|
|
|
|
*
|
2022-09-20 11:44:38 -04:00
|
|
|
* @param array $attributes The block attributes.
|
|
|
|
* @param string $content The block rendered content.
|
2022-04-19 07:51:07 -04:00
|
|
|
*
|
|
|
|
* @return string Returns the cover block markup, if useFeaturedImage is true.
|
|
|
|
*/
|
|
|
|
function render_block_core_cover( $attributes, $content ) {
|
2022-05-10 11:57:28 -04:00
|
|
|
if ( 'image' !== $attributes['backgroundType'] || false === $attributes['useFeaturedImage'] ) {
|
2022-04-19 07:51:07 -04:00
|
|
|
return $content;
|
|
|
|
}
|
|
|
|
|
2022-05-10 11:57:28 -04:00
|
|
|
if ( ! ( $attributes['hasParallax'] || $attributes['isRepeated'] ) ) {
|
|
|
|
$attr = array(
|
|
|
|
'class' => 'wp-block-cover__image-background',
|
|
|
|
'data-object-fit' => 'cover',
|
2022-04-19 07:51:07 -04:00
|
|
|
);
|
|
|
|
|
|
|
|
if ( isset( $attributes['focalPoint'] ) ) {
|
2022-05-10 11:57:28 -04:00
|
|
|
$object_position = round( $attributes['focalPoint']['x'] * 100 ) . '%' . ' ' . round( $attributes['focalPoint']['y'] * 100 ) . '%';
|
|
|
|
$attr['data-object-position'] = $object_position;
|
|
|
|
$attr['style'] = 'object-position: ' . $object_position;
|
2022-04-19 07:51:07 -04:00
|
|
|
}
|
|
|
|
|
2022-05-10 11:57:28 -04:00
|
|
|
$image = get_the_post_thumbnail( null, 'post-thumbnail', $attr );
|
2022-04-19 07:51:07 -04:00
|
|
|
|
2022-07-04 14:15:15 -04:00
|
|
|
/*
|
|
|
|
* Inserts the featured image between the (1st) cover 'background' `span` and 'inner_container' `div`,
|
|
|
|
* and removes eventual withespace 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 );
|
|
|
|
}
|
2022-05-10 11:57:28 -04:00
|
|
|
} else {
|
|
|
|
if ( in_the_loop() ) {
|
|
|
|
update_post_thumbnail_cache();
|
|
|
|
}
|
|
|
|
$current_featured_image = get_the_post_thumbnail_url();
|
2022-09-20 11:44:38 -04:00
|
|
|
|
|
|
|
$styles = 'background-image:url(' . esc_url( $current_featured_image ) . '); ';
|
|
|
|
|
|
|
|
if ( isset( $attributes['minHeight'] ) ) {
|
|
|
|
$height_unit = empty( $attributes['minHeightUnit'] ) ? 'px' : $attributes['minHeightUnit'];
|
|
|
|
$height = " min-height:{$attributes['minHeight']}{$height_unit}";
|
|
|
|
|
|
|
|
$styles .= $height;
|
|
|
|
}
|
|
|
|
|
|
|
|
$content = preg_replace(
|
2022-05-10 11:57:28 -04:00
|
|
|
'/class=\".*?\"/',
|
2022-09-20 11:44:38 -04:00
|
|
|
'${0} style="' . $styles . '"',
|
2022-05-10 11:57:28 -04:00
|
|
|
$content,
|
|
|
|
1
|
|
|
|
);
|
2022-04-19 07:51:07 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
return $content;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Registers the `core/cover` block renderer on server.
|
|
|
|
*/
|
|
|
|
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' );
|