396 lines
9.3 KiB
PHP
396 lines
9.3 KiB
PHP
<?php
|
|
/**
|
|
* Handle Dynamic Assets
|
|
*
|
|
* @package Builder
|
|
*/
|
|
|
|
/**
|
|
* Gets the assets directory.
|
|
*
|
|
* @param bool $url check if url.
|
|
*
|
|
* @return string
|
|
* @since 4.10.0
|
|
*/
|
|
function et_get_dynamic_assets_path( $url = false ) {
|
|
$is_builder_active = et_is_builder_plugin_active();
|
|
|
|
$template_address = $url ? get_template_directory_uri() : get_template_directory();
|
|
|
|
if ( $is_builder_active ) {
|
|
$template_address = $url ? ET_BUILDER_PLUGIN_URI : ET_BUILDER_PLUGIN_DIR;
|
|
}
|
|
|
|
return apply_filters( 'et_dynamic_assets_prefix', $template_address . '/includes/builder/feature/dynamic-assets/assets' );
|
|
}
|
|
|
|
/**
|
|
* Checks if current post/page is built-in.
|
|
*
|
|
* @return bool
|
|
* @since 4.10.0
|
|
*/
|
|
function et_is_cpt() {
|
|
static $is_cpt = null;
|
|
|
|
if ( null === $is_cpt ) {
|
|
global $post;
|
|
|
|
$custom_post_types = get_post_types( array( '_builtin' => false ) );
|
|
$custom_types = array();
|
|
$is_cpt = false;
|
|
|
|
if ( ! empty( $custom_post_types ) ) {
|
|
$custom_types = array_keys( $custom_post_types );
|
|
}
|
|
|
|
$post_type = get_post_type( $post );
|
|
|
|
if ( in_array( $post_type, $custom_types, true ) && is_singular() && 'project' !== $post_type ) {
|
|
$is_cpt = true;
|
|
}
|
|
}
|
|
|
|
return $is_cpt;
|
|
}
|
|
|
|
/**
|
|
* Extracts gutter width values from post/page content.
|
|
*
|
|
* @param array $matches matched gutters.
|
|
*
|
|
* @return array
|
|
* @since 4.10.0
|
|
*/
|
|
function et_get_content_gutter_widths( $matches ) {
|
|
$gutters = array();
|
|
|
|
foreach ( $matches as $match ) {
|
|
preg_match_all( '/"([^"]+)"/', $match, $matches );
|
|
$gutters = array_merge( $gutters, $matches[1] );
|
|
}
|
|
|
|
// Convert strings to integers.
|
|
$gutters = array_map( 'intval', $gutters );
|
|
|
|
return $gutters;
|
|
}
|
|
|
|
/**
|
|
* Check if any widgets are currently active.
|
|
*
|
|
* @return bool
|
|
* @since 4.10.0
|
|
*/
|
|
function et_pb_are_widgets_used() {
|
|
global $wp_registered_sidebars;
|
|
|
|
$sidebars = get_option( 'sidebars_widgets' );
|
|
|
|
foreach ( $wp_registered_sidebars as $sidebar_key => $sidebar_options ) {
|
|
if ( ! empty( $sidebars[ $sidebar_key ] ) ) {
|
|
return true;
|
|
}
|
|
}
|
|
|
|
return false;
|
|
}
|
|
|
|
/**
|
|
* Check if a specific value is "on" on the page.
|
|
*
|
|
* @param array $values matched values.
|
|
*
|
|
* @return bool
|
|
* @since 4.10.0
|
|
*/
|
|
function et_check_if_particular_value_is_on( $values ) {
|
|
foreach ( $values as $match ) {
|
|
preg_match_all( '/"([^"]+)"/', $match, $matches );
|
|
if ( in_array( 'on', $matches[1], true ) ) {
|
|
return true;
|
|
};
|
|
}
|
|
|
|
return false;
|
|
}
|
|
|
|
/**
|
|
* Get if a non-default preset value.
|
|
*
|
|
* @param array $values Matched values.
|
|
*
|
|
* @return array
|
|
* @since 4.10.0
|
|
*/
|
|
function et_get_non_default_preset_ids( $values ) {
|
|
$result = array();
|
|
|
|
foreach ( $values as $match ) {
|
|
|
|
preg_match_all( '/"([^"]+)"/', $match, $matches );
|
|
|
|
if ( ! in_array( 'default', $matches[1], true ) ) {
|
|
$result = array_merge( $result, $matches[1] );
|
|
}
|
|
}
|
|
|
|
return $result;
|
|
}
|
|
|
|
/**
|
|
* Check to see if this is a front end request applicable to Dynamic Assets.
|
|
*
|
|
* @since 4.10.0
|
|
*
|
|
* @return bool
|
|
*/
|
|
function et_is_dynamic_front_end_request() {
|
|
static $is_dynamic_front_end_request = null;
|
|
|
|
if ( null === $is_dynamic_front_end_request ) {
|
|
if (
|
|
// Disable for WordPress admin requests.
|
|
! is_admin()
|
|
&& ! wp_doing_ajax()
|
|
&& ! wp_doing_cron()
|
|
// Disable when in preview modes.
|
|
&& ! is_customize_preview()
|
|
&& ! is_et_pb_preview()
|
|
&& ! ET_GB_Block_Layout::is_layout_block_preview()
|
|
&& ! is_preview()
|
|
// Disable when using the visual builder.
|
|
&& ! et_fb_is_enabled()
|
|
// Disable on paginated index pages when blog style mode is enabled and when using the Divi Builder plugin.
|
|
&& ! ( is_paged() && ( 'on' === et_get_option( 'divi_blog_style', 'off' ) || et_is_builder_plugin_active() ) )
|
|
) {
|
|
$is_dynamic_front_end_request = true;
|
|
}
|
|
}
|
|
|
|
return $is_dynamic_front_end_request;
|
|
}
|
|
|
|
/**
|
|
* Check to see if this is a front end request.
|
|
*
|
|
* @since 4.10.0
|
|
*
|
|
* @return bool
|
|
*/
|
|
function et_is_front_end_request() {
|
|
static $et_is_front_end_request = null;
|
|
|
|
if ( null === $et_is_front_end_request ) {
|
|
if (
|
|
// Disable for WordPress admin requests.
|
|
! is_admin()
|
|
&& ! wp_doing_ajax()
|
|
&& ! wp_doing_cron()
|
|
) {
|
|
$et_is_front_end_request = true;
|
|
}
|
|
}
|
|
|
|
return $et_is_front_end_request;
|
|
}
|
|
|
|
/**
|
|
* Check if the current request should generate Dynamic Assets.
|
|
* We only generate dynamic assets on the front end and when cache dir is writable.
|
|
*
|
|
* @since 4.10.0
|
|
*
|
|
* @return bool
|
|
*/
|
|
function et_should_generate_dynamic_assets() {
|
|
static $should_generate_assets = null;
|
|
|
|
if ( null === $should_generate_assets ) {
|
|
if (
|
|
// Cache directory must be writable.
|
|
et_core_cache_dir()->can_write
|
|
// Request must be an applicable front-end request.
|
|
&& et_is_dynamic_front_end_request()
|
|
) {
|
|
$should_generate_assets = true;
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Filters whether to generate dynamic assets.
|
|
*
|
|
* @since 4.10.6
|
|
*
|
|
* @param bool $should_generate_assets
|
|
*/
|
|
return apply_filters( 'et_should_generate_dynamic_assets', (bool) $should_generate_assets );
|
|
}
|
|
|
|
/**
|
|
* Check if Dynamic CSS is enabled.
|
|
*
|
|
* @return bool
|
|
* @since 4.10.0
|
|
*/
|
|
function et_use_dynamic_css() {
|
|
global $shortname;
|
|
static $et_use_dynamic_css = null;
|
|
|
|
if ( null === $et_use_dynamic_css ) {
|
|
if ( et_is_builder_plugin_active() ) {
|
|
$options = get_option( 'et_pb_builder_options', array() );
|
|
$dynamic_css = isset( $options['performance_main_dynamic_css'] ) ? $options['performance_main_dynamic_css'] : 'on';
|
|
} else {
|
|
$dynamic_css = et_get_option( $shortname . '_dynamic_css', 'on' );
|
|
}
|
|
|
|
if ( 'on' === $dynamic_css && et_should_generate_dynamic_assets() ) {
|
|
$et_use_dynamic_css = true;
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Filters whether to use dynamic CSS.
|
|
*
|
|
* @since 4.10.6
|
|
*
|
|
* @param bool $et_use_dynamic_css
|
|
*/
|
|
return apply_filters( 'et_use_dynamic_css', (bool) $et_use_dynamic_css );
|
|
}
|
|
|
|
/**
|
|
* Check if Dynamic Icons are enabled.
|
|
*
|
|
* @since 4.10.0
|
|
*/
|
|
function et_use_dynamic_icons() {
|
|
global $shortname;
|
|
$child_theme_active = is_child_theme();
|
|
|
|
if ( et_is_builder_plugin_active() ) {
|
|
$options = get_option( 'et_pb_builder_options', array() );
|
|
$dynamic_icons = isset( $options['performance_main_dynamic_icons'] ) ? $options['performance_main_dynamic_icons'] : et_dynamic_icons_default_value();
|
|
} else {
|
|
$dynamic_icons = et_get_option( $child_theme_active ? $shortname . '_dynamic_icons_child_theme' : $shortname . '_dynamic_icons', et_dynamic_icons_default_value() );
|
|
}
|
|
|
|
return $dynamic_icons;
|
|
}
|
|
|
|
/**
|
|
* Check if JavaScript On Demand is enabled.
|
|
*
|
|
* @return bool
|
|
* @since 4.10.0
|
|
*/
|
|
function et_disable_js_on_demand() {
|
|
global $shortname;
|
|
static $et_disable_js_on_demand = null;
|
|
|
|
if ( null === $et_disable_js_on_demand ) {
|
|
if ( et_is_builder_plugin_active() ) {
|
|
$options = get_option( 'et_pb_builder_options', array() );
|
|
$dynamic_js_libraries = isset( $options['performance_main_dynamic_js_libraries'] ) ? $options['performance_main_dynamic_js_libraries'] : 'on';
|
|
} else {
|
|
$dynamic_js_libraries = et_get_option( $shortname . '_dynamic_js_libraries', 'on' );
|
|
}
|
|
|
|
if (
|
|
// Disable when theme option not enabled.
|
|
'on' !== $dynamic_js_libraries
|
|
// Disable when not an applicable front-end request.
|
|
|| ! et_is_dynamic_front_end_request()
|
|
) {
|
|
$et_disable_js_on_demand = true;
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Filters whether to disable JS on demand.
|
|
*
|
|
* @since 4.10.6
|
|
*
|
|
* @param bool $et_disable_js_on_demand
|
|
*/
|
|
return apply_filters( 'et_disable_js_on_demand', (bool) $et_disable_js_on_demand );
|
|
}
|
|
|
|
/**
|
|
* Disable dynamic icons if TP modules are present.
|
|
*
|
|
* @since 4.10.0
|
|
*/
|
|
function et_dynamic_icons_default_value() {
|
|
$tp_extensions = DiviExtensions::get( 'all' );
|
|
$child_theme_active = is_child_theme();
|
|
|
|
if ( ! empty( $tp_extensions ) || ( $child_theme_active && ! et_is_builder_plugin_active() ) ) {
|
|
return 'off';
|
|
}
|
|
|
|
return 'on';
|
|
}
|
|
|
|
/**
|
|
* Get all active block widgets.
|
|
*
|
|
* This method will collect all active block widgets first. Later on, the result will be
|
|
* cached to improve the performance.
|
|
*
|
|
* @since 4.10.5
|
|
*
|
|
* @return array List of active block widgets.
|
|
*/
|
|
function et_get_active_block_widgets() {
|
|
global $wp_version;
|
|
static $active_block_widgets = null;
|
|
|
|
$wp_major_version = substr( $wp_version, 0, 3 );
|
|
|
|
// Bail early if were pre WP 5.8, when block widgets were introduced.
|
|
if ( version_compare( $wp_major_version, '5.8', '<' ) ) {
|
|
return array();
|
|
}
|
|
|
|
global $wp_widget_factory;
|
|
|
|
$active_block_widgets = array();
|
|
$block_instance = $wp_widget_factory->get_widget_object( 'block' );
|
|
$block_settings = $block_instance->get_settings();
|
|
|
|
// Bail early if there is no active block widgets.
|
|
if ( empty( $block_settings ) ) {
|
|
return $active_block_widgets;
|
|
}
|
|
|
|
// Collect all active blocks.
|
|
foreach ( $block_settings as $block_number => $block_setting ) {
|
|
$block_content = et_()->array_get( $block_setting, 'content' );
|
|
$block_parsed = parse_blocks( $block_content );
|
|
$block_name = et_()->array_get( $block_parsed, array( '0', 'blockName' ) );
|
|
|
|
// Save and cache there result.
|
|
if ( ! in_array( $block_name, $active_block_widgets, true ) ) {
|
|
array_push( $active_block_widgets, $block_name );
|
|
}
|
|
}
|
|
|
|
return $active_block_widgets;
|
|
}
|
|
|
|
/**
|
|
* Check whether current block widget is active or not.
|
|
*
|
|
* @since 4.10.5
|
|
*
|
|
* @param string $block_widget_name Block widget name.
|
|
*
|
|
* @return boolean Whether current block widget is active or not.
|
|
*/
|
|
function et_is_active_block_widget( $block_widget_name ) {
|
|
return in_array( $block_widget_name, et_get_active_block_widgets(), true );
|
|
}
|