This repository has been archived on 2022-06-23. You can view files and clone it, but cannot push or open issues or pull requests.
divi/includes/builder/feature/dynamic-assets/dynamic-assets.php
2021-12-07 11:08:05 +00:00

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 );
}