Upgarded to 4.17.4

This commit is contained in:
2022-06-23 13:17:18 +01:00
parent 80f1e87db9
commit a04fb0c7af
404 changed files with 54683 additions and 4417 deletions

View File

@ -20,19 +20,17 @@ if ( ! defined( 'ABSPATH' ) ) {
*/
class ET_Builder_Plugin_Compat_SiteGround_Optimizer extends ET_Builder_Plugin_Compat_Base {
/**
* Stylesheet handle.
* Excluded stylesheets.
*
* @var null
*/
private $_stylesheet_handle = null;
private $_excluded = [];
/**
* Constructor
*/
public function __construct() {
$this->plugin_id = 'sg-cachepress/sg-cachepress.php';
$this->_stylesheet_handle = ET_Dynamic_Assets::init()->get_style_css_handle();
$this->plugin_id = 'sg-cachepress/sg-cachepress.php';
$this->init_hooks();
}
@ -42,42 +40,80 @@ class ET_Builder_Plugin_Compat_SiteGround_Optimizer extends ET_Builder_Plugin_Co
* @return void
*/
public function init_hooks() {
if ( ! is_plugin_active( $this->plugin_id ) ) {
return;
}
add_filter( 'sgo_css_combine_exclude', array( $this, 'exclude_inline_styles_from_siteground_cache' ) );
// Do nothing if it's not on frontend.
if ( ! et_builder_is_frontend() ) {
return;
}
// Do nothing if Dynamic CSS and Critical CSS are disabled.
if ( ! ( et_use_dynamic_css() || et_builder_is_critical_enabled() ) ) {
return;
}
add_filter( 'et_core_page_resource_tag', [ $this, 'get_page_resource_handles' ], 10, 3 );
add_filter( 'sgo_css_combine_exclude', [ $this, 'exclude_inline_styles_from_siteground_cache' ], 11 );
}
/**
* Get PageResource handles.
*
* @param string $tag HTML tag.
* @param string $handle Resource handle.
* @param string $src Resource src.
*
* @since 4.14.3
*
* @return string
*/
public function get_page_resource_handles( $tag, $handle, $src ) {
if ( empty( $src ) ) {
return;
}
// Some styles we enqueue too late for wp_enqueue_style so the markup is printed directly.
// However, SG Optimizer can only exclude registered styles, hence we do it now.
if ( ! wp_style_is( $handle, 'registered' ) ) {
$handle .= '-cachepress';
wp_register_style( $handle, $src, [], ET_BUILDER_VERSION );
}
$this->_excluded[] = $handle;
return $tag;
}
/**
* Exclude styles from being combined in SiteGround cache.
*
* @param array $excluded_stylesheets Excluded styles from being combined.
* @param array $excluded Excluded styles from being combined.
*/
public function exclude_inline_styles_from_siteground_cache( $excluded_stylesheets ) {
global $shortname;
public function exclude_inline_styles_from_siteground_cache( $excluded ) {
global $wp_styles, $shortname;
$is_critical_enabled = apply_filters( 'et_builder_critical_css_enabled', false );
// If Critical CSS is enabled, we don't need to process further.
if ( $is_critical_enabled ) {
return $excluded_stylesheets;
}
$style_prefix = 'divi-builder';
$prefix = 'divi-builder';
if ( 'divi' === $shortname ) {
$style_prefix = 'divi';
$prefix = 'divi';
} elseif ( 'extra' === $shortname ) {
$style_prefix = 'extra';
$prefix = 'extra';
}
$style_prefix = $style_prefix . '-dynamic';
$registered = array_keys( $wp_styles->registered );
foreach ( $registered as $handle ) {
// Exclude all our styles.
if ( false !== strpos( $handle, $prefix ) ) {
$excluded[] = $handle;
}
}
return array_merge(
$excluded_stylesheets,
array( $this->_stylesheet_handle, $style_prefix )
$this->_excluded,
$excluded
);
}
}