Upgarded to 4.17.4
This commit is contained in:
@ -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
|
||||
);
|
||||
}
|
||||
}
|
||||
|
Reference in New Issue
Block a user