mirror of
https://github.com/WordPress/WordPress.git
synced 2025-01-20 15:21:28 +01:00
Themes: Skip wrapping block template for singular content with a main query loop when the template was injected from outside the current theme.
As a follow up to [56507], this fixes a bug that could occur for instance when plugins hijack the block template detection process to inject their own block template with entirely custom logic. Props afragen, hellofromTonya, costdev, mukesh27, huzaifaalmesbah, flixos90. Fixes #59736. See #58154. Built from https://develop.svn.wordpress.org/trunk@57019 git-svn-id: http://core.svn.wordpress.org/trunk@56530 1a063a9b-81f0-0310-95a4-ce76da25c4cd
This commit is contained in:
parent
50d5a07812
commit
06237953dd
@ -208,6 +208,7 @@ function _block_template_render_title_tag() {
|
|||||||
* @access private
|
* @access private
|
||||||
* @since 5.8.0
|
* @since 5.8.0
|
||||||
*
|
*
|
||||||
|
* @global string $_wp_current_template_id
|
||||||
* @global string $_wp_current_template_content
|
* @global string $_wp_current_template_content
|
||||||
* @global WP_Embed $wp_embed
|
* @global WP_Embed $wp_embed
|
||||||
* @global WP_Query $wp_query
|
* @global WP_Query $wp_query
|
||||||
@ -215,7 +216,7 @@ function _block_template_render_title_tag() {
|
|||||||
* @return string Block template markup.
|
* @return string Block template markup.
|
||||||
*/
|
*/
|
||||||
function get_the_block_template_html() {
|
function get_the_block_template_html() {
|
||||||
global $_wp_current_template_content, $wp_embed, $wp_query;
|
global $_wp_current_template_id, $_wp_current_template_content, $wp_embed, $wp_query;
|
||||||
|
|
||||||
if ( ! $_wp_current_template_content ) {
|
if ( ! $_wp_current_template_content ) {
|
||||||
if ( is_user_logged_in() ) {
|
if ( is_user_logged_in() ) {
|
||||||
@ -242,8 +243,18 @@ function get_the_block_template_html() {
|
|||||||
* Even if the block template contained a `core/query` and `core/post-template` block referencing the main query
|
* Even if the block template contained a `core/query` and `core/post-template` block referencing the main query
|
||||||
* loop, it would not cause errors since it would use a cloned instance and go through the same loop of a single
|
* loop, it would not cause errors since it would use a cloned instance and go through the same loop of a single
|
||||||
* post, within the actual main query loop.
|
* post, within the actual main query loop.
|
||||||
|
*
|
||||||
|
* This special logic should be skipped if the current template does not come from the current theme, in which case
|
||||||
|
* it has been injected by a plugin by hijacking the block template loader mechanism. In that case, entirely custom
|
||||||
|
* logic may be applied which is unpredictable and therefore safer to omit this special handling on.
|
||||||
*/
|
*/
|
||||||
if ( is_singular() && 1 === $wp_query->post_count && have_posts() ) {
|
if (
|
||||||
|
$_wp_current_template_id &&
|
||||||
|
str_starts_with( $_wp_current_template_id, get_stylesheet() . '//' ) &&
|
||||||
|
is_singular() &&
|
||||||
|
1 === $wp_query->post_count &&
|
||||||
|
have_posts()
|
||||||
|
) {
|
||||||
while ( have_posts() ) {
|
while ( have_posts() ) {
|
||||||
the_post();
|
the_post();
|
||||||
$content = do_blocks( $content );
|
$content = do_blocks( $content );
|
||||||
|
@ -16,7 +16,7 @@
|
|||||||
*
|
*
|
||||||
* @global string $wp_version
|
* @global string $wp_version
|
||||||
*/
|
*/
|
||||||
$wp_version = '6.5-alpha-57018';
|
$wp_version = '6.5-alpha-57019';
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Holds the WordPress DB revision, increments when changes are made to the WordPress DB schema.
|
* Holds the WordPress DB revision, increments when changes are made to the WordPress DB schema.
|
||||||
|
Loading…
Reference in New Issue
Block a user