add wp-rocket
This commit is contained in:
97
wp-content/plugins/wp-rocket/inc/ThirdParty/Themes/Bridge.php
vendored
Normal file
97
wp-content/plugins/wp-rocket/inc/ThirdParty/Themes/Bridge.php
vendored
Normal file
@@ -0,0 +1,97 @@
|
||||
<?php
|
||||
namespace WP_Rocket\ThirdParty\Themes;
|
||||
|
||||
use WP_Rocket\Admin\Options_Data;
|
||||
use WP_Rocket\Event_Management\Subscriber_Interface;
|
||||
|
||||
/**
|
||||
* Compatibility class for Bridge theme
|
||||
*
|
||||
* @since 3.3.1
|
||||
* @author Remy Perona
|
||||
*/
|
||||
class Bridge implements Subscriber_Interface {
|
||||
/**
|
||||
* Options instance
|
||||
*
|
||||
* @var Options_Data
|
||||
*/
|
||||
private $options;
|
||||
|
||||
/**
|
||||
* Return an array of events that this subscriber wants to listen to.
|
||||
*
|
||||
* @since 3.3.1
|
||||
* @author Remy Perona
|
||||
*
|
||||
* @return array
|
||||
*/
|
||||
public static function get_subscribed_events() {
|
||||
$current_theme = wp_get_theme();
|
||||
|
||||
if ( 'Bridge' !== $current_theme->get( 'Name' ) ) {
|
||||
return [];
|
||||
}
|
||||
|
||||
return [
|
||||
'rocket_lazyload_background_images' => 'disable_lazyload_background_images',
|
||||
'update_option_qode_options_proya' => [ 'maybe_clear_cache', 10, 2 ],
|
||||
];
|
||||
}
|
||||
|
||||
/**
|
||||
* Constructor
|
||||
*
|
||||
* @param Options_Data $options WP Rocket options instance.
|
||||
*/
|
||||
public function __construct( Options_Data $options ) {
|
||||
$this->options = $options;
|
||||
}
|
||||
|
||||
/**
|
||||
* Disable lazyload for background images when using Bridge theme
|
||||
*
|
||||
* @since 3.3.1
|
||||
* @author Remy Perona
|
||||
*
|
||||
* @return bool
|
||||
*/
|
||||
public function disable_lazyload_background_images() {
|
||||
return false;
|
||||
}
|
||||
|
||||
/**
|
||||
* Maybe clear WP Rocket cache when Bridge custom CSS/JS is updated
|
||||
*
|
||||
* @since 3.3.7
|
||||
* @author Remy Perona
|
||||
*
|
||||
* @param array $old_value Previous option values.
|
||||
* @param array $new_value New option values.
|
||||
* @return void
|
||||
*/
|
||||
public function maybe_clear_cache( $old_value, $new_value ) {
|
||||
$clear = false;
|
||||
|
||||
if ( $this->options->get( 'minify_css', 0 ) ) {
|
||||
if ( isset( $old_value['custom_css'], $new_value['custom_css'] ) && $old_value['custom_css'] !== $new_value['custom_css'] ) {
|
||||
$clear = true;
|
||||
}
|
||||
|
||||
if ( isset( $old_value['custom_svg_css'], $new_value['custom_svg_css'] ) && $old_value['custom_svg_css'] !== $new_value['custom_svg_css'] ) {
|
||||
$clear = true;
|
||||
}
|
||||
}
|
||||
|
||||
if ( $this->options->get( 'minify_js', 0 ) ) {
|
||||
if ( isset( $old_value['custom_js'], $new_value['custom_js'] ) && $old_value['custom_js'] !== $new_value['custom_js'] ) {
|
||||
$clear = true;
|
||||
}
|
||||
}
|
||||
|
||||
if ( $clear ) {
|
||||
rocket_clean_domain();
|
||||
rocket_clean_minify();
|
||||
}
|
||||
}
|
||||
}
|
Reference in New Issue
Block a user