You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
114 lines
3.3 KiB
PHP
114 lines
3.3 KiB
PHP
<?php
|
|
/**
|
|
* Page Content Retriever is used to get Page related Contents from WordPress.
|
|
*
|
|
* @since 4.11.0
|
|
*
|
|
* @package Divi
|
|
* @sub-package Builder
|
|
*/
|
|
|
|
namespace Feature\ContentRetriever;
|
|
|
|
/**
|
|
* PageContentRetriever Trait.
|
|
*/
|
|
trait PageContentRetriever {
|
|
|
|
/**
|
|
* Holds a Cache reference for every page content retrieved.
|
|
*
|
|
* @var array
|
|
*/
|
|
private $_cache = [];
|
|
|
|
/**
|
|
* Gets the entire page content, including TB Header, TB Body Layout, Post Content and TB Footer.
|
|
*
|
|
* Parameter $post must be given as a variable, since it is passed by reference.
|
|
* If $post is not given, It then uses global $post if available.
|
|
*
|
|
* @since 4.11.0
|
|
* @since 4.14.5 Return empty string on failure instead of null.
|
|
*
|
|
* @param WP_Post|int $post Optional. WP_Post instance or Post ID. Default null.
|
|
*
|
|
* @return string Empty string on failure.
|
|
*/
|
|
public function get_entire_page_content( $post = null ) {
|
|
|
|
/**
|
|
* Validation Checks.
|
|
*/
|
|
$is_using_global_post = false;
|
|
|
|
if ( empty( $post ) && isset( $GLOBALS['post'] ) ) {
|
|
$post = $GLOBALS['post'];
|
|
$is_using_global_post = true;
|
|
}
|
|
|
|
if ( $post instanceof \WP_Post ) {
|
|
$wp_post = $post;
|
|
} else {
|
|
$wp_post = \WP_Post::get_instance( $post );
|
|
}
|
|
|
|
// Return empty string on failure because the return value is mostly used along with
|
|
// PHP PCRE or String functions that require non-nullable value.
|
|
if ( ! $wp_post ) {
|
|
return '';
|
|
}
|
|
|
|
/**
|
|
* Core mechanics for retrieving content.
|
|
*/
|
|
if ( $this->_cache && isset( $this->_cache[ $wp_post->ID ] ) ) {
|
|
return $this->_cache[ $wp_post->ID ];
|
|
}
|
|
|
|
if ( $is_using_global_post ) {
|
|
$layouts = et_theme_builder_get_template_layouts();
|
|
} else {
|
|
$layouts = et_theme_builder_get_template_layouts( \ET_Theme_Builder_Request::from_post( $wp_post->ID ) );
|
|
}
|
|
|
|
$entire_page_content = '';
|
|
$enabled_layout_ids = [
|
|
ET_THEME_BUILDER_HEADER_LAYOUT_POST_TYPE => null,
|
|
ET_THEME_BUILDER_BODY_LAYOUT_POST_TYPE => null,
|
|
'content' => 'content',
|
|
ET_THEME_BUILDER_FOOTER_LAYOUT_POST_TYPE => null,
|
|
];
|
|
|
|
foreach ( $layouts as $key => $layout ) {
|
|
$is_layout_enabled = isset( $layout['enabled'], $layout['override'] ) && true === $layout['enabled'] && true === $layout['override'];
|
|
$enabled_layout_ids[ $key ] = ( array_key_exists( $key, $enabled_layout_ids ) && $is_layout_enabled ) ? $layout['id'] : null;
|
|
}
|
|
|
|
$enabled_layout_ids = array_filter( $enabled_layout_ids );
|
|
|
|
/**
|
|
* $enabled_layout_ids will be in the following order, (assuming each are present):
|
|
* header, body, footer.
|
|
* We're intentionally adding the post content so that it's appended
|
|
* right after the body layout, making the final order of $entire_page_content:
|
|
* header, body, post content, footer.
|
|
* They need to be in order for Critical CSS. Otherwise we don't know what
|
|
* content comes first and is above the fold.
|
|
*/
|
|
foreach ( $enabled_layout_ids as $key => $layout_id ) {
|
|
if ( 'content' === $layout_id ) {
|
|
$entire_page_content .= $wp_post->post_content;
|
|
} else {
|
|
$layout = get_post( $layout_id );
|
|
$entire_page_content .= $layout->post_content;
|
|
}
|
|
}
|
|
|
|
$this->_cache = array_replace( $this->_cache, [ $wp_post->ID => $entire_page_content ] );
|
|
|
|
return $entire_page_content;
|
|
}
|
|
|
|
}
|