Upgarded to 4.17.4
This commit is contained in:
@ -62,15 +62,17 @@ class ET_Builder_Module_Field_Border extends ET_Builder_Module_Field_Base {
|
||||
if ( $template->is_enabled() && ! $template->has( 'border' ) ) {
|
||||
$template_placeholders = $template->placeholders(
|
||||
array(
|
||||
'suffix' => null,
|
||||
'label_prefix' => null,
|
||||
'tab_slug' => null,
|
||||
'toggle_slug' => null,
|
||||
'color_type' => null,
|
||||
'depends_on' => null,
|
||||
'depends_show_if' => null,
|
||||
'sub_toggle' => null,
|
||||
'defaults' => array(
|
||||
'suffix' => null,
|
||||
'label_prefix' => null,
|
||||
'tab_slug' => null,
|
||||
'toggle_slug' => null,
|
||||
'color_type' => null,
|
||||
'depends_on' => null,
|
||||
'depends_show_if_not' => null,
|
||||
'depends_show_if' => null,
|
||||
'use_radius' => null,
|
||||
'sub_toggle' => null,
|
||||
'defaults' => array(
|
||||
'border_radii' => null,
|
||||
'border_styles' => array(
|
||||
'width' => null,
|
||||
@ -98,16 +100,17 @@ class ET_Builder_Module_Field_Border extends ET_Builder_Module_Field_Base {
|
||||
public function get_fields( array $args = array(), $return_template_id = false ) {
|
||||
$settings = shortcode_atts(
|
||||
array(
|
||||
'suffix' => '',
|
||||
'label_prefix' => '',
|
||||
'tab_slug' => 'advanced',
|
||||
'toggle_slug' => 'border',
|
||||
'color_type' => 'color-alpha',
|
||||
'depends_on' => null,
|
||||
'depends_show_if' => null,
|
||||
'sub_toggle' => null,
|
||||
'use_radius' => true,
|
||||
'defaults' => array(
|
||||
'suffix' => '',
|
||||
'label_prefix' => '',
|
||||
'tab_slug' => 'advanced',
|
||||
'toggle_slug' => 'border',
|
||||
'color_type' => 'color-alpha',
|
||||
'depends_on' => null,
|
||||
'depends_show_if_not' => null,
|
||||
'depends_show_if' => null,
|
||||
'sub_toggle' => null,
|
||||
'use_radius' => true,
|
||||
'defaults' => array(
|
||||
'border_radii' => 'on||||',
|
||||
'border_styles' => array(
|
||||
'width' => '0px',
|
||||
@ -426,8 +429,9 @@ class ET_Builder_Module_Field_Border extends ET_Builder_Module_Field_Base {
|
||||
// Add options dependency
|
||||
if ( ! is_null( $settings['depends_on'] ) ) {
|
||||
foreach ( $additional_options as &$option ) {
|
||||
$option['depends_on'] = $settings['depends_on'];
|
||||
$option['depends_show_if'] = $settings['depends_show_if'];
|
||||
$option['depends_on'] = $settings['depends_on'];
|
||||
$option['depends_show_if'] = $settings['depends_show_if'];
|
||||
$option['depends_show_if_not'] = $settings['depends_show_if_not'];
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -36,6 +36,9 @@ require_once __DIR__ . '/display-conditions/Cookie.php';
|
||||
require_once __DIR__ . '/display-conditions/CategoryPage.php';
|
||||
require_once __DIR__ . '/display-conditions/TagPage.php';
|
||||
require_once __DIR__ . '/display-conditions/NumberOfViews.php';
|
||||
require_once __DIR__ . '/display-conditions/CustomField.php';
|
||||
require_once __DIR__ . '/display-conditions/UrlParameter.php';
|
||||
require_once __DIR__ . '/display-conditions/ProductStock.php';
|
||||
|
||||
/**
|
||||
* Import class dependencies
|
||||
@ -72,6 +75,9 @@ class ET_Builder_Module_Field_DisplayConditions extends ET_Builder_Module_Field_
|
||||
use CategoryPageCondition;
|
||||
use TagPageCondition;
|
||||
use NumberOfViewsCondition;
|
||||
use CustomFieldCondition;
|
||||
use UrlParameterCondition;
|
||||
use ProductStockCondition;
|
||||
|
||||
/**
|
||||
* Custom current date.
|
||||
@ -157,11 +163,6 @@ class ET_Builder_Module_Field_DisplayConditions extends ET_Builder_Module_Field_
|
||||
* @return boolean Conditions final result.
|
||||
*/
|
||||
public function is_displayable( $display_conditions, $only_return_status = false ) {
|
||||
// Bail out and just display the module if below WordPress 5.3.
|
||||
if ( version_compare( get_bloginfo( 'version' ), '5.3', '<' ) ) {
|
||||
return true;
|
||||
}
|
||||
|
||||
// Bail out and just display the module if $display_conditions is not array.
|
||||
if ( ! is_array( $display_conditions ) ) {
|
||||
return true;
|
||||
@ -290,6 +291,15 @@ class ET_Builder_Module_Field_DisplayConditions extends ET_Builder_Module_Field_
|
||||
case 'numberOfViews':
|
||||
return $this->_process_number_of_views_condition( $condition_id, $condition_settings );
|
||||
|
||||
case 'customField':
|
||||
return $this->_process_custom_field_condition( $condition_settings );
|
||||
|
||||
case 'urlParameter':
|
||||
return $this->_process_url_parameter_condition( $condition_settings );
|
||||
|
||||
case 'productStock':
|
||||
return $this->_process_product_stock_condition( $condition_settings );
|
||||
|
||||
default:
|
||||
if ( isset( $condition_settings['dynamicPosts'] ) ) {
|
||||
return $this->_process_dynamic_posts_condition( $condition_settings );
|
||||
@ -341,6 +351,20 @@ class ET_Builder_Module_Field_DisplayConditions extends ET_Builder_Module_Field_
|
||||
break;
|
||||
}
|
||||
|
||||
// Exception! "Custom Field" Condition can have multiple conditions.
|
||||
$is_custom_field = 'customField' === $condition['condition'];
|
||||
if ( $is_custom_field ) {
|
||||
$is_conflicted = false;
|
||||
break;
|
||||
}
|
||||
|
||||
// Exception! "URL Parameter" Condition can have multiple conditions.
|
||||
$is_url_parameter = 'urlParameter' === $condition['condition'];
|
||||
if ( $is_url_parameter ) {
|
||||
$is_conflicted = false;
|
||||
break;
|
||||
}
|
||||
|
||||
/**
|
||||
* When operator is set to "OR/ANY" and we have more than one condition, all other conditions
|
||||
* will be set as conflicted, giving the priority to the latest condition in the list.
|
||||
|
@ -448,23 +448,12 @@ class ET_Builder_Module_Field_Divider extends ET_Builder_Module_Field_Base {
|
||||
// z-index - determined by arrangement.
|
||||
$declaration['z-index'] = ( 'on' === $fullwidth || 'above_content' === $arrangement ) ? 10 : 1;
|
||||
|
||||
$flip_styles = array();
|
||||
// flipping the svg x|y
|
||||
if ( in_array( 'horizontal', $flip ) ) {
|
||||
$flip_styles[] = 'rotateY(180deg)';
|
||||
} elseif ( '' !== $breakpoint ) {
|
||||
$flip_styles[] = 'rotateY(0)';
|
||||
}
|
||||
$flip_styles = array(
|
||||
in_array( 'horizontal', $flip, true ) ? '-1' : '1',
|
||||
in_array( 'vertical', $flip, true ) ? '-1' : '1',
|
||||
);
|
||||
|
||||
if ( in_array( 'vertical', $flip ) ) {
|
||||
$flip_styles[] = 'rotateX(180deg)';
|
||||
} elseif ( '' !== $breakpoint ) {
|
||||
$flip_styles[] = 'rotateX(0)';
|
||||
}
|
||||
|
||||
if ( ! empty( $flip_styles ) ) {
|
||||
$declaration['transform'] = implode( ' ', $flip_styles );
|
||||
}
|
||||
$declaration['transform'] = 'scale(' . implode( ', ', $flip_styles ) . ')';
|
||||
|
||||
// finally create our CSS declaration.
|
||||
$css = '';
|
||||
|
@ -241,6 +241,9 @@ class ET_Builder_Module_Field_MarginPadding extends ET_Builder_Module_Field_Base
|
||||
'sub_toggle' => $sub_toggle,
|
||||
'priority' => $config['priority'],
|
||||
);
|
||||
if ( isset( $config['depends_on'] ) && '' !== $config['depends_on'] ) {
|
||||
$fields[ $custom_padding ]['depends_on'] = $config['depends_on'];
|
||||
}
|
||||
$fields[ $custom_padding_tablet ] = array(
|
||||
'type' => 'skip',
|
||||
'tab_slug' => $tab_slug,
|
||||
|
@ -30,7 +30,8 @@ trait AuthorCondition {
|
||||
return false;
|
||||
}
|
||||
|
||||
$display_rule = isset( $condition_settings['authorDisplay'] ) ? $condition_settings['authorDisplay'] : '';
|
||||
$legacy_display_rule = isset( $condition_settings['authorDisplay'] ) ? $condition_settings['authorDisplay'] : 'is';
|
||||
$display_rule = isset( $condition_settings['displayRule'] ) ? $condition_settings['displayRule'] : $legacy_display_rule;
|
||||
$authors_raw = isset( $condition_settings['authors'] ) ? $condition_settings['authors'] : [];
|
||||
$authors_ids = array_map(
|
||||
function( $item ) {
|
||||
|
@ -25,9 +25,11 @@ trait BrowserCondition {
|
||||
* @return boolean Condition output.
|
||||
*/
|
||||
protected function _process_browser_condition( $condition_settings ) {
|
||||
$display_rule = isset( $condition_settings['browserDisplay'] ) ? $condition_settings['browserDisplay'] : 'is';
|
||||
$browsers_raw = isset( $condition_settings['browsers'] ) ? $condition_settings['browsers'] : '';
|
||||
$browsers = explode( '|', $browsers_raw );
|
||||
// Checks for additional display rule for compatibility with Conditional Display older versions which didn't use `displayRule` key.
|
||||
$legacy_display_rule = isset( $condition_settings['browserDisplay'] ) ? $condition_settings['browserDisplay'] : 'is';
|
||||
$display_rule = isset( $condition_settings['displayRule'] ) ? $condition_settings['displayRule'] : $legacy_display_rule;
|
||||
$browsers_raw = isset( $condition_settings['browsers'] ) ? $condition_settings['browsers'] : '';
|
||||
$browsers = explode( '|', $browsers_raw );
|
||||
// phpcs:ignore ET.Sniffs.ValidatedSanitizedInput -- User Agent is not stored or displayed therefore XSS safe.
|
||||
$useragent = ( isset( $_SERVER['HTTP_USER_AGENT'] ) ) ? $_SERVER['HTTP_USER_AGENT'] : '';
|
||||
$is_old_edge = preg_match( '/edge\//i', $useragent );
|
||||
|
@ -28,15 +28,18 @@ trait CartContentsCondition {
|
||||
if ( ! class_exists( 'WooCommerce' ) ) {
|
||||
return false;
|
||||
}
|
||||
$display_rule = isset( $condition_settings['cartContentsDisplay'] ) ? $condition_settings['cartContentsDisplay'] : 'hasProducts';
|
||||
$products_raw = isset( $condition_settings['products'] ) ? $condition_settings['products'] : [];
|
||||
$products_ids = array_map(
|
||||
|
||||
// Checks for additional display rule for compatibility with Conditional Display older versions which didn't use `displayRule` key.
|
||||
$legacy_display_rule = isset( $condition_settings['cartContentsDisplay'] ) ? $condition_settings['cartContentsDisplay'] : 'hasProducts';
|
||||
$display_rule = isset( $condition_settings['displayRule'] ) ? $condition_settings['displayRule'] : $legacy_display_rule;
|
||||
$products_raw = isset( $condition_settings['products'] ) ? $condition_settings['products'] : [];
|
||||
$products_ids = array_map(
|
||||
function( $item ) {
|
||||
return isset( $item['value'] ) ? $item['value'] : '';
|
||||
},
|
||||
$products_raw
|
||||
);
|
||||
$is_cart_empty = WC()->cart->is_empty();
|
||||
$is_cart_empty = WC()->cart->is_empty();
|
||||
|
||||
switch ( $display_rule ) {
|
||||
case 'hasProducts':
|
||||
|
@ -31,8 +31,9 @@ trait CategoriesCondition {
|
||||
return false;
|
||||
}
|
||||
|
||||
// Get condition's settings.
|
||||
$display_rule = isset( $condition_settings['categoriesDisplay'] ) ? $condition_settings['categoriesDisplay'] : 'is';
|
||||
// Checks for additional display rule for compatibility with Conditional Display older versions which didn't use `displayRule` key.
|
||||
$legacy_display_rule = isset( $condition_settings['categoriesDisplay'] ) ? $condition_settings['categoriesDisplay'] : 'is';
|
||||
$display_rule = isset( $condition_settings['displayRule'] ) ? $condition_settings['displayRule'] : $legacy_display_rule;
|
||||
$categories_raw = isset( $condition_settings['categories'] ) ? $condition_settings['categories'] : [];
|
||||
$categories = array_map(
|
||||
function( $item ) {
|
||||
|
@ -31,8 +31,9 @@ trait CategoryPageCondition {
|
||||
return false;
|
||||
}
|
||||
|
||||
// Get condition's settings.
|
||||
$display_rule = isset( $condition_settings['categoryPageDisplay'] ) ? $condition_settings['categoryPageDisplay'] : 'is';
|
||||
// Checks for additional display rule for compatibility with Conditional Display older versions which didn't use `displayRule` key.
|
||||
$legacy_display_rule = isset( $condition_settings['categoryPageDisplay'] ) ? $condition_settings['categoryPageDisplay'] : 'is';
|
||||
$display_rule = isset( $condition_settings['displayRule'] ) ? $condition_settings['displayRule'] : $legacy_display_rule;
|
||||
$categories_raw = isset( $condition_settings['categories'] ) ? $condition_settings['categories'] : [];
|
||||
$queried_object = get_queried_object();
|
||||
$is_queried_object_valid = $queried_object instanceof \WP_Term && property_exists( $queried_object, 'taxonomy' );
|
||||
|
@ -25,7 +25,9 @@ trait CookieCondition {
|
||||
* @return boolean Condition output.
|
||||
*/
|
||||
protected function _process_cookie_condition( $condition_settings ) {
|
||||
$display_rule = isset( $condition_settings['cookieDisplay'] ) ? $condition_settings['cookieDisplay'] : 'cookieExists';
|
||||
// Checks for additional display rule for compatibility with Conditional Display older versions which didn't use `displayRule` key.
|
||||
$legacy_display_rule = isset( $condition_settings['cookieDisplay'] ) ? $condition_settings['cookieDisplay'] : 'cookieExists';
|
||||
$display_rule = isset( $condition_settings['displayRule'] ) ? $condition_settings['displayRule'] : $legacy_display_rule;
|
||||
$cookie_name = isset( $condition_settings['cookieName'] ) ? $condition_settings['cookieName'] : '';
|
||||
$cookie_value = isset( $condition_settings['cookieValue'] ) ? $condition_settings['cookieValue'] : '';
|
||||
$is_cookie_set = ( isset( $_COOKIE[ $cookie_name ] ) ) ? true : false;
|
||||
|
@ -0,0 +1,89 @@
|
||||
<?php
|
||||
/**
|
||||
* Custom Field's logic swiftly crafted.
|
||||
*
|
||||
* @since 4.11.0
|
||||
*
|
||||
* @package Divi
|
||||
* @sub-package Builder
|
||||
*/
|
||||
|
||||
namespace Module\Field\DisplayConditions;
|
||||
|
||||
/**
|
||||
* Custom Field Condition Trait
|
||||
*/
|
||||
trait CustomFieldCondition {
|
||||
|
||||
/**
|
||||
* Evaluates "Custom Field" condition.
|
||||
*
|
||||
* @since 4.14.3
|
||||
*
|
||||
* @param array $condition_settings The Condition settings containing:
|
||||
* 'selectConditionalMetaField' => base64_data.
|
||||
*
|
||||
* @return boolean Returns `true` if the condition evaluation is true, `false` otherwise.
|
||||
*/
|
||||
protected function _process_custom_field_condition( $condition_settings ) {
|
||||
// Only check for Posts.
|
||||
if ( ! is_singular() ) {
|
||||
return false;
|
||||
}
|
||||
|
||||
// Only check if queried object id is valid.
|
||||
$queried_object_id = get_queried_object_id();
|
||||
if ( ! \WP_Post::get_instance( $queried_object_id ) ) {
|
||||
return false;
|
||||
}
|
||||
|
||||
// Decodes the base64 data and runs validations.
|
||||
$meta_field_settings_base64 = isset( $condition_settings['selectConditionalMetaField'] ) ? $condition_settings['selectConditionalMetaField'] : '';
|
||||
$meta_field_settings_json = base64_decode( $meta_field_settings_base64 ); // phpcs:ignore WordPress.PHP.DiscouragedPHPFunctions.obfuscation_base64_decode -- The returned data is an array and necessary validation checks are performed.
|
||||
$meta_field_settings = false !== $meta_field_settings_json ? json_decode( $meta_field_settings_json, true ) : [];
|
||||
|
||||
// Gets meta fields settings.
|
||||
$display_rule = isset( $meta_field_settings['displayRule'] ) ? $meta_field_settings['displayRule'] : 'is';
|
||||
$selected_field_name = isset( $meta_field_settings['selectedFieldName'] ) ? $meta_field_settings['selectedFieldName'] : 'manualCustomFieldName';
|
||||
$custom_field_name = isset( $meta_field_settings['customFieldName'] ) ? $meta_field_settings['customFieldName'] : '';
|
||||
$selected_field_value = isset( $meta_field_settings['selectedFieldValue'] ) ? $meta_field_settings['selectedFieldValue'] : 'manualCustomFieldValue';
|
||||
$custom_field_value = isset( $meta_field_settings['customFieldValue'] ) ? $meta_field_settings['customFieldValue'] : '';
|
||||
|
||||
$field_name = 'manualCustomFieldName' === $selected_field_name ? $custom_field_name : $selected_field_name;
|
||||
$has_custom_field_value = 'manualCustomFieldValue' === $selected_field_value ? true : false;
|
||||
|
||||
// Checks whether the specified custom fields actually exist.
|
||||
$has_field_name_metadata = metadata_exists( 'post', $queried_object_id, $field_name );
|
||||
$has_selected_field_value_metadata = $has_custom_field_value ? true : metadata_exists( 'post', $queried_object_id, $selected_field_value );
|
||||
|
||||
// Bailout if specified custom fields don't exist.
|
||||
if ( ! $has_field_name_metadata || ! $has_selected_field_value_metadata ) {
|
||||
return false;
|
||||
}
|
||||
|
||||
$field_name_meta = (string) get_post_meta( $queried_object_id, $field_name, true );
|
||||
$field_value_meta = $has_custom_field_value ? (string) $custom_field_value : (string) get_post_meta( $queried_object_id, $selected_field_value, true );
|
||||
|
||||
// The PHP 7.4 and below will throw warning if we pass empty string on the 2nd arg
|
||||
// of `strpos`. We have to avoid this issue and make sure the `Contains` condition
|
||||
// threat $field_value_meta empty value as invalid condition (no match).
|
||||
$contains = false;
|
||||
if ( ! empty( $field_value_meta ) ) {
|
||||
$contains = strpos( $field_name_meta, $field_value_meta );
|
||||
}
|
||||
|
||||
$output = [
|
||||
'is' => $field_name_meta === $field_value_meta,
|
||||
'isNot' => $field_name_meta !== $field_value_meta,
|
||||
'contains' => false !== $contains,
|
||||
'doesNotContain' => false === $contains,
|
||||
'isAnyValue' => strlen( $field_name_meta ) > 0,
|
||||
'hasNoValue' => strlen( $field_name_meta ) === 0,
|
||||
'isGreaterThan' => (float) $field_name_meta > (float) $field_value_meta,
|
||||
'isLessThan' => (float) $field_name_meta < (float) $field_value_meta,
|
||||
];
|
||||
|
||||
return isset( $output[ $display_rule ] ) ? $output[ $display_rule ] : false;
|
||||
}
|
||||
|
||||
}
|
@ -22,17 +22,19 @@ trait DateArchiveCondition {
|
||||
*
|
||||
* @since 4.11.0
|
||||
*
|
||||
* @param array $all_settings Containing all settings of the condition.
|
||||
* @param array $condition_settings Containing all settings of the condition.
|
||||
*
|
||||
* @return boolean Condition output.
|
||||
*/
|
||||
protected function _process_date_archive_condition( $all_settings ) {
|
||||
protected function _process_date_archive_condition( $condition_settings ) {
|
||||
if ( ! is_date() ) {
|
||||
return false;
|
||||
}
|
||||
|
||||
$display_rule = isset( $all_settings['dateArchiveDisplay'] ) ? $all_settings['dateArchiveDisplay'] : 'isAfter';
|
||||
$date = isset( $all_settings['dateArchive'] ) ? $all_settings['dateArchive'] : '';
|
||||
// Checks for additional display rule for compatibility with Conditional Display older versions which didn't use `displayRule` key.
|
||||
$legacy_display_rule = isset( $condition_settings['dateArchiveDisplay'] ) ? $condition_settings['dateArchiveDisplay'] : 'isAfter';
|
||||
$display_rule = isset( $condition_settings['displayRule'] ) ? $condition_settings['displayRule'] : $legacy_display_rule;
|
||||
$date = isset( $condition_settings['dateArchive'] ) ? $condition_settings['dateArchive'] : '';
|
||||
|
||||
$year = get_query_var( 'year' );
|
||||
$monthnum = get_query_var( 'monthnum' ) === 0 ? 1 : get_query_var( 'monthnum' );
|
||||
|
@ -27,7 +27,9 @@ trait DateTimeCondition {
|
||||
* @return boolean Condition output.
|
||||
*/
|
||||
protected function _process_date_time_condition( $condition_settings ) {
|
||||
$display_rule = isset( $condition_settings['dateTimeDisplay'] ) ? $condition_settings['dateTimeDisplay'] : 'isAfter';
|
||||
// Checks for additional display rule for compatibility with Conditional Display older versions which didn't use `displayRule` key.
|
||||
$legacy_display_rule = isset( $condition_settings['dateTimeDisplay'] ) ? $condition_settings['dateTimeDisplay'] : 'isAfter';
|
||||
$display_rule = isset( $condition_settings['displayRule'] ) ? $condition_settings['displayRule'] : $legacy_display_rule;
|
||||
$date = isset( $condition_settings['date'] ) ? $condition_settings['date'] : '';
|
||||
$time = isset( $condition_settings['time'] ) ? $condition_settings['time'] : '';
|
||||
$all_day = isset( $condition_settings['allDay'] ) ? $condition_settings['allDay'] : '';
|
||||
@ -132,6 +134,9 @@ trait DateTimeCondition {
|
||||
* @return boolean Condition repetition result.
|
||||
*/
|
||||
protected function _is_datetime_condition_repeated( $condition_settings, $is_on_specific_date, $current_datetime, $target_datetime ) {
|
||||
// Checks for additional display rule for compatibility with Conditional Display older versions which didn't use `displayRule` key.
|
||||
$legacy_display_rule = isset( $condition_settings['dateTimeDisplay'] ) ? $condition_settings['dateTimeDisplay'] : 'isAfter';
|
||||
$display_rule = isset( $condition_settings['displayRule'] ) ? $condition_settings['displayRule'] : $legacy_display_rule;
|
||||
$repeat = isset( $condition_settings['repeat'] ) ? $condition_settings['repeat'] : '';
|
||||
$repeat_frequency = isset( $condition_settings['repeatFrequency'] ) ? $condition_settings['repeatFrequency'] : '';
|
||||
$repeat_frequency_specific_days = isset( $condition_settings['repeatFrequencySpecificDays'] ) ? $condition_settings['repeatFrequencySpecificDays'] : '';
|
||||
@ -142,7 +147,7 @@ trait DateTimeCondition {
|
||||
$from_time = isset( $condition_settings['fromTime'] ) ? $condition_settings['fromTime'] : '';
|
||||
$until_time = isset( $condition_settings['untilTime'] ) ? $condition_settings['untilTime'] : '';
|
||||
$is_repeated = false;
|
||||
$is_on_specific_days = 'isOnSpecificDays' === $condition_settings['dateTimeDisplay'];
|
||||
$is_on_specific_days = 'isOnSpecificDays' === $display_rule;
|
||||
|
||||
if ( $is_on_specific_days || ( 'on' === $repeat && ! $is_on_specific_date ) ) {
|
||||
if ( $is_on_specific_days ) {
|
||||
|
@ -30,16 +30,18 @@ trait DynamicPostsCondition {
|
||||
return false;
|
||||
}
|
||||
|
||||
$display_rule = isset( $condition_settings['dynamicPostsDisplay'] ) ? $condition_settings['dynamicPostsDisplay'] : '';
|
||||
$dynamic_posts_raw = isset( $condition_settings['dynamicPosts'] ) ? $condition_settings['dynamicPosts'] : [];
|
||||
$dynamic_posts_ids = array_map(
|
||||
// Checks for additional display rule for compatibility with Conditional Display older versions which didn't use `displayRule` key.
|
||||
$legacy_display_rule = isset( $condition_settings['dynamicPostsDisplay'] ) ? $condition_settings['dynamicPostsDisplay'] : 'is';
|
||||
$display_rule = isset( $condition_settings['displayRule'] ) ? $condition_settings['displayRule'] : $legacy_display_rule;
|
||||
$dynamic_posts_raw = isset( $condition_settings['dynamicPosts'] ) ? $condition_settings['dynamicPosts'] : [];
|
||||
$dynamic_posts_ids = array_map(
|
||||
function( $item ) {
|
||||
return isset( $item['value'] ) ? $item['value'] : '';
|
||||
},
|
||||
$dynamic_posts_raw
|
||||
);
|
||||
$is_on_shop_page = class_exists( 'WooCommerce' ) && is_shop();
|
||||
$current_page_id = $is_on_shop_page ? wc_get_page_id( 'shop' ) : get_queried_object_id();
|
||||
$is_on_shop_page = class_exists( 'WooCommerce' ) && is_shop();
|
||||
$current_page_id = $is_on_shop_page ? wc_get_page_id( 'shop' ) : get_queried_object_id();
|
||||
|
||||
$should_display = array_intersect( $dynamic_posts_ids, (array) $current_page_id ) ? true : false;
|
||||
|
||||
|
@ -25,26 +25,12 @@ trait LoggedInStatusCondition {
|
||||
* @return boolean Condition output.
|
||||
*/
|
||||
protected function _process_logged_in_status_condition( $condition_settings ) {
|
||||
$logged_in_status = isset( $condition_settings['loggedInStatus'] ) ? $condition_settings['loggedInStatus'] : 'loggedIn';
|
||||
$should_display = ( is_user_logged_in() ) ? true : false;
|
||||
return ( 'loggedIn' === $logged_in_status ) ? $should_display : ! $should_display;
|
||||
}
|
||||
// Checks for additional display rule for compatibility with Conditional Display older versions which didn't use `displayRule` key.
|
||||
$legacy_display_rule = isset( $condition_settings['loggedInStatus'] ) ? $condition_settings['loggedInStatus'] : 'loggedIn';
|
||||
$display_rule = isset( $condition_settings['displayRule'] ) ? $condition_settings['displayRule'] : $legacy_display_rule;
|
||||
$should_display = ( is_user_logged_in() ) ? true : false;
|
||||
|
||||
/**
|
||||
* Checks logged in status for possible conflicts.
|
||||
*
|
||||
* @param string $current_value Curent setting value.
|
||||
* @param string $prev_value Previous setting value.
|
||||
* @param array $conflicting_value Defined conflicting value.
|
||||
* @return boolean
|
||||
*/
|
||||
protected function _is_logged_in_status_conflicted( $current_value, $prev_value, $conflicting_value ) {
|
||||
$is_current_value_conflicted = in_array( $current_value, $conflicting_value, true );
|
||||
$is_prev_value_conflicted = in_array( $prev_value, $conflicting_value, true );
|
||||
if ( $is_current_value_conflicted && $is_prev_value_conflicted ) {
|
||||
return true;
|
||||
}
|
||||
return false;
|
||||
return ( 'loggedIn' === $display_rule ) ? $should_display : ! $should_display;
|
||||
}
|
||||
|
||||
}
|
||||
|
@ -25,7 +25,9 @@ trait OperatingSystemCondition {
|
||||
* @return boolean Condition output.
|
||||
*/
|
||||
protected function _process_operating_system_condition( $condition_settings ) {
|
||||
$display_rule = isset( $condition_settings['operatingSystemDisplay'] ) ? $condition_settings['operatingSystemDisplay'] : 'is';
|
||||
// Checks for additional display rule for compatibility with Conditional Display older versions which didn't use `displayRule` key.
|
||||
$legacy_display_rule = isset( $condition_settings['operatingSystemDisplay'] ) ? $condition_settings['operatingSystemDisplay'] : 'is';
|
||||
$display_rule = isset( $condition_settings['displayRule'] ) ? $condition_settings['displayRule'] : $legacy_display_rule;
|
||||
$operating_systems_raw = isset( $condition_settings['operatingSystems'] ) ? $condition_settings['operatingSystems'] : '';
|
||||
$operating_systems = explode( '|', $operating_systems_raw );
|
||||
$current_os = $this->_get_os();
|
||||
|
@ -25,7 +25,9 @@ trait PageVisitCondition {
|
||||
* @return boolean Condition output.
|
||||
*/
|
||||
protected function _process_page_visit_condition( $condition_settings ) {
|
||||
$display_rule = isset( $condition_settings['pageVisitDisplay'] ) ? $condition_settings['pageVisitDisplay'] : 'hasVisitedSpecificPage';
|
||||
// Checks for additional display rule for compatibility with Conditional Display older versions which didn't use `displayRule` key.
|
||||
$legacy_display_rule = isset( $condition_settings['pageVisitDisplay'] ) ? $condition_settings['pageVisitDisplay'] : 'hasVisitedSpecificPage';
|
||||
$display_rule = isset( $condition_settings['displayRule'] ) ? $condition_settings['displayRule'] : $legacy_display_rule;
|
||||
$pages_raw = isset( $condition_settings['pages'] ) ? $condition_settings['pages'] : [];
|
||||
$pages_ids = array_map(
|
||||
function( $item ) {
|
||||
@ -34,10 +36,13 @@ trait PageVisitCondition {
|
||||
$pages_raw
|
||||
);
|
||||
$has_visited_specific_page = false;
|
||||
$cookie = [];
|
||||
|
||||
if ( isset( $_COOKIE['divi_post_visit'] ) ) {
|
||||
// phpcs:ignore ET.Sniffs.ValidatedSanitizedInput, WordPress.PHP.DiscouragedPHPFunctions.obfuscation_base64_decode -- Cookie is not stored or displayed therefore XSS safe, base64_decode returned data is an array and necessary validation checks are performed.
|
||||
$cookie = json_decode( base64_decode( $_COOKIE['divi_post_visit'] ), true );
|
||||
$cookie = json_decode( base64_decode( $_COOKIE['divi_post_visit'] ), true );
|
||||
}
|
||||
if ( $cookie && is_array( $cookie ) ) {
|
||||
$col = array_column( $cookie, 'id' );
|
||||
$has_visited_specific_page = array_intersect( $pages_ids, $col ) ? true : false;
|
||||
}
|
||||
|
@ -30,17 +30,19 @@ trait PostTypeCondition {
|
||||
return false;
|
||||
}
|
||||
|
||||
$display_rule = isset( $condition_settings['postTypeDisplay'] ) ? $condition_settings['postTypeDisplay'] : '';
|
||||
$post_types_raw = isset( $condition_settings['postTypes'] ) ? $condition_settings['postTypes'] : [];
|
||||
$post_types_values = array_map(
|
||||
// Checks for additional display rule for compatibility with Conditional Display older versions which didn't use `displayRule` key.
|
||||
$legacy_display_rule = isset( $condition_settings['postTypeDisplay'] ) ? $condition_settings['postTypeDisplay'] : 'is';
|
||||
$display_rule = isset( $condition_settings['displayRule'] ) ? $condition_settings['displayRule'] : $legacy_display_rule;
|
||||
$post_types_raw = isset( $condition_settings['postTypes'] ) ? $condition_settings['postTypes'] : [];
|
||||
$post_types_values = array_map(
|
||||
function( $item ) {
|
||||
return $item['value'];
|
||||
},
|
||||
$post_types_raw
|
||||
);
|
||||
$is_on_shop_page = class_exists( 'WooCommerce' ) && is_shop();
|
||||
$current_queried_id = $is_on_shop_page ? wc_get_page_id( 'shop' ) : get_queried_object_id();
|
||||
$post_type = get_post_type( $current_queried_id );
|
||||
$is_on_shop_page = class_exists( 'WooCommerce' ) && is_shop();
|
||||
$current_queried_id = $is_on_shop_page ? wc_get_page_id( 'shop' ) : get_queried_object_id();
|
||||
$post_type = get_post_type( $current_queried_id );
|
||||
|
||||
$should_display = array_intersect( $post_types_values, (array) $post_type ) ? true : false;
|
||||
|
||||
|
@ -29,10 +29,12 @@ trait ProductPurchaseCondition {
|
||||
return false;
|
||||
}
|
||||
|
||||
$display_rule = isset( $condition_settings['productPurchaseDisplay'] ) ? $condition_settings['productPurchaseDisplay'] : 'hasBoughtProduct';
|
||||
$products_raw = isset( $condition_settings['products'] ) ? $condition_settings['products'] : [];
|
||||
$current_user = wp_get_current_user();
|
||||
$products_ids = array_map(
|
||||
// Checks for additional display rule for compatibility with Conditional Display older versions which didn't use `displayRule` key.
|
||||
$legacy_display_rule = isset( $condition_settings['productPurchaseDisplay'] ) ? $condition_settings['productPurchaseDisplay'] : 'hasBoughtProduct';
|
||||
$display_rule = isset( $condition_settings['displayRule'] ) ? $condition_settings['displayRule'] : $legacy_display_rule;
|
||||
$products_raw = isset( $condition_settings['products'] ) ? $condition_settings['products'] : [];
|
||||
$current_user = wp_get_current_user();
|
||||
$products_ids = array_map(
|
||||
function( $item ) {
|
||||
return isset( $item['value'] ) ? $item['value'] : '';
|
||||
},
|
||||
|
@ -0,0 +1,61 @@
|
||||
<?php
|
||||
/**
|
||||
* Product Stock Condition logic swiftly crafted.
|
||||
*
|
||||
* @since 4.14.3
|
||||
*
|
||||
* @package Divi
|
||||
* @sub-package Builder
|
||||
*/
|
||||
|
||||
namespace Module\Field\DisplayConditions;
|
||||
|
||||
/**
|
||||
* Product Stock Condition Trait.
|
||||
*/
|
||||
trait ProductStockCondition {
|
||||
|
||||
/**
|
||||
* Processes "Product Stock" condition.
|
||||
*
|
||||
* @since 4.14.3
|
||||
*
|
||||
* @param array $condition_settings The Condition settings containing:
|
||||
* 'displayRule' => string,
|
||||
* 'products' => array.
|
||||
*
|
||||
* @return boolean Returns `true` if the condition evaluation is true, `false` otherwise.
|
||||
*/
|
||||
protected function _process_product_stock_condition( $condition_settings ) {
|
||||
if ( ! class_exists( 'WooCommerce' ) ) {
|
||||
return false;
|
||||
}
|
||||
|
||||
$display_rule = isset( $condition_settings['displayRule'] ) ? $condition_settings['displayRule'] : 'isInStock';
|
||||
$products_raw = isset( $condition_settings['products'] ) ? $condition_settings['products'] : [];
|
||||
$products_ids = array_map(
|
||||
function( $item ) {
|
||||
return isset( $item['value'] ) ? (int) $item['value'] : '';
|
||||
},
|
||||
$products_raw
|
||||
);
|
||||
$products_ids = array_filter( $products_ids );
|
||||
|
||||
$products = wc_get_products(
|
||||
[
|
||||
'limit' => -1,
|
||||
'include' => $products_ids,
|
||||
'stock_status' => 'instock',
|
||||
'return' => 'ids',
|
||||
]
|
||||
);
|
||||
|
||||
$output = [
|
||||
'isInStock' => count( $products ) > 0,
|
||||
'isOutOfStock' => count( $products ) === 0,
|
||||
];
|
||||
|
||||
return isset( $output[ $display_rule ] ) ? $output[ $display_rule ] : false;
|
||||
}
|
||||
|
||||
}
|
@ -30,7 +30,9 @@ trait SearchResultsCondition {
|
||||
return false;
|
||||
}
|
||||
|
||||
$display_rule = isset( $condition_settings['searchResultsDisplay'] ) ? $condition_settings['searchResultsDisplay'] : 'is';
|
||||
// Checks for additional display rule for compatibility with Conditional Display older versions which didn't use `displayRule` key.
|
||||
$legacy_display_rule = isset( $condition_settings['searchResultsDisplay'] ) ? $condition_settings['searchResultsDisplay'] : 'specificSearchQueries';
|
||||
$display_rule = isset( $condition_settings['displayRule'] ) ? $condition_settings['displayRule'] : $legacy_display_rule;
|
||||
$specific_search_queries_raw = isset( $condition_settings['specificSearchQueries'] ) ? $condition_settings['specificSearchQueries'] : '';
|
||||
$excluded_search_queries_raw = isset( $condition_settings['excludedSearchQueries'] ) ? $condition_settings['excludedSearchQueries'] : '';
|
||||
$specific_search_queries = explode( ',', $specific_search_queries_raw );
|
||||
|
@ -31,8 +31,9 @@ trait TagPageCondition {
|
||||
return false;
|
||||
}
|
||||
|
||||
// Get condition's settings.
|
||||
$display_rule = isset( $condition_settings['tagPageDisplay'] ) ? $condition_settings['tagPageDisplay'] : 'is';
|
||||
// Checks for additional display rule for compatibility with Conditional Display older versions which didn't use `displayRule` key.
|
||||
$legacy_display_rule = isset( $condition_settings['tagPageDisplay'] ) ? $condition_settings['tagPageDisplay'] : 'is';
|
||||
$display_rule = isset( $condition_settings['displayRule'] ) ? $condition_settings['displayRule'] : $legacy_display_rule;
|
||||
$tags_raw = isset( $condition_settings['tags'] ) ? $condition_settings['tags'] : [];
|
||||
$queried_object = get_queried_object();
|
||||
$is_queried_object_valid = $queried_object instanceof \WP_Term && property_exists( $queried_object, 'taxonomy' );
|
||||
|
@ -31,8 +31,9 @@ trait TagsCondition {
|
||||
return false;
|
||||
}
|
||||
|
||||
// Get condition's settings.
|
||||
$display_rule = isset( $condition_settings['tagsDisplay'] ) ? $condition_settings['tagsDisplay'] : 'is';
|
||||
// Checks for additional display rule for compatibility with Conditional Display older versions which didn't use `displayRule` key.
|
||||
$legacy_display_rule = isset( $condition_settings['tagsDisplay'] ) ? $condition_settings['tagsDisplay'] : 'is';
|
||||
$display_rule = isset( $condition_settings['displayRule'] ) ? $condition_settings['displayRule'] : $legacy_display_rule;
|
||||
$tags_raw = isset( $condition_settings['tags'] ) ? $condition_settings['tags'] : [];
|
||||
$tags = array_map(
|
||||
function( $item ) {
|
||||
|
@ -0,0 +1,100 @@
|
||||
<?php
|
||||
/**
|
||||
* URL Parameter Condition logic swiftly crafted.
|
||||
*
|
||||
* @since 4.14.3
|
||||
*
|
||||
* @package Divi
|
||||
* @sub-package Builder
|
||||
*/
|
||||
|
||||
namespace Module\Field\DisplayConditions;
|
||||
|
||||
/**
|
||||
* URL Parameter Condition Trait.
|
||||
*/
|
||||
trait UrlParameterCondition {
|
||||
|
||||
/**
|
||||
* Processes "URL Parameter" condition.
|
||||
*
|
||||
* @since 4.14.3
|
||||
*
|
||||
* @param array $condition_settings The Condition settings containing:
|
||||
* 'displayRule' => string,
|
||||
* 'selectUrlParameter' => string,
|
||||
* 'urlParameterName' => string,
|
||||
* 'urlParameterValue' => string.
|
||||
*
|
||||
* @return boolean Returns `true` if the condition evaluation is true, `false` otherwise.
|
||||
*/
|
||||
protected function _process_url_parameter_condition( $condition_settings ) {
|
||||
$display_rule = isset( $condition_settings['displayRule'] ) ? $condition_settings['displayRule'] : 'equals';
|
||||
$select_url_parameter = isset( $condition_settings['selectUrlParameter'] ) ? $condition_settings['selectUrlParameter'] : 'specificUrlParameter';
|
||||
$url_parameter_name = isset( $condition_settings['urlParameterName'] ) ? (string) $condition_settings['urlParameterName'] : '';
|
||||
$url_parameter_value = isset( $condition_settings['urlParameterValue'] ) ? (string) $condition_settings['urlParameterValue'] : '';
|
||||
|
||||
$get_url_parameter = isset( $_GET[ $url_parameter_name ] ) ? sanitize_text_field( $_GET[ $url_parameter_name ] ) : ''; // phpcs:ignore WordPress.Security.NonceVerification.Recommended -- No need to use nonce as there is no form processing.
|
||||
$is_url_parameter_set = isset( $_GET[ $url_parameter_name ] ); // phpcs:ignore WordPress.Security.NonceVerification.Recommended -- No need to use nonce as there is no form processing.
|
||||
|
||||
if ( 'anyUrlParameter' === $select_url_parameter ) {
|
||||
$parameter_values = $this->_get_all_parameter_values();
|
||||
$output = [
|
||||
'equals' => count( $parameter_values ) > 0 && array_intersect( $parameter_values, (array) $url_parameter_value ),
|
||||
'exist' => count( $parameter_values ) > 0,
|
||||
'doesNotExist' => count( $parameter_values ) === 0,
|
||||
'doesNotEqual' => count( $parameter_values ) > 0 && ! array_intersect( $parameter_values, (array) $url_parameter_value ),
|
||||
'contains' => count( $parameter_values ) > 0 && $this->_array_contains_string( $parameter_values, $url_parameter_value ),
|
||||
'doesNotContain' => count( $parameter_values ) > 0 && ! $this->_array_contains_string( $parameter_values, $url_parameter_value ),
|
||||
];
|
||||
} else {
|
||||
$output = [
|
||||
'equals' => $is_url_parameter_set && $get_url_parameter === $url_parameter_value,
|
||||
'exist' => $is_url_parameter_set,
|
||||
'doesNotExist' => ! $is_url_parameter_set,
|
||||
'doesNotEqual' => $is_url_parameter_set && $get_url_parameter !== $url_parameter_value,
|
||||
'contains' => $is_url_parameter_set && strpos( $get_url_parameter, $url_parameter_value ) !== false,
|
||||
'doesNotContain' => $is_url_parameter_set && strpos( $get_url_parameter, $url_parameter_value ) === false,
|
||||
];
|
||||
}
|
||||
|
||||
return isset( $output[ $display_rule ] ) ? $output[ $display_rule ] : false;
|
||||
}
|
||||
|
||||
/**
|
||||
* Returns all parameter values.
|
||||
*
|
||||
* @since 4.14.3
|
||||
*
|
||||
* @return array
|
||||
*/
|
||||
protected function _get_all_parameter_values() {
|
||||
return array_map(
|
||||
function( $value ) {
|
||||
return $value;
|
||||
},
|
||||
$_GET // phpcs:ignore WordPress.Security.NonceVerification.Recommended -- No need to use nonce.
|
||||
);
|
||||
}
|
||||
|
||||
/**
|
||||
* Checks if `$haystack` items contain `$needle` in their values.
|
||||
*
|
||||
* @since 4.14.3
|
||||
*
|
||||
* @param array $haystack The array to search in.
|
||||
* @param string $needle The string needle to search for.
|
||||
*
|
||||
* @return boolean
|
||||
*/
|
||||
protected function _array_contains_string( $haystack, $needle ) {
|
||||
$filtered_array = array_filter(
|
||||
$haystack,
|
||||
function( $value ) use ( $needle ) {
|
||||
return strpos( $value, $needle ) !== false;
|
||||
}
|
||||
);
|
||||
return count( $filtered_array ) > 0 ? true : false;
|
||||
}
|
||||
|
||||
}
|
@ -25,17 +25,19 @@ trait UserRoleCondition {
|
||||
* @return boolean Condition output.
|
||||
*/
|
||||
protected function _process_user_role_condition( $condition_settings ) {
|
||||
$display_rule = isset( $condition_settings['userRoleDisplay'] ) ? $condition_settings['userRoleDisplay'] : 'is';
|
||||
$roles_raw = isset( $condition_settings['userRoles'] ) ? $condition_settings['userRoles'] : [];
|
||||
$ids_raw = isset( $condition_settings['userIds'] ) ? $condition_settings['userIds'] : '';
|
||||
$roles = array_map(
|
||||
// Checks for additional display rule for compatibility with Conditional Display older versions which didn't use `displayRule` key.
|
||||
$legacy_display_rule = isset( $condition_settings['userRoleDisplay'] ) ? $condition_settings['userRoleDisplay'] : 'is';
|
||||
$display_rule = isset( $condition_settings['displayRule'] ) ? $condition_settings['displayRule'] : $legacy_display_rule;
|
||||
$roles_raw = isset( $condition_settings['userRoles'] ) ? $condition_settings['userRoles'] : [];
|
||||
$ids_raw = isset( $condition_settings['userIds'] ) ? $condition_settings['userIds'] : '';
|
||||
$roles = array_map(
|
||||
function( $item ) {
|
||||
return $item['value'];
|
||||
},
|
||||
$roles_raw
|
||||
);
|
||||
$ids = isset( $ids_raw ) ? array_map( 'trim', array_filter( explode( ',', $ids_raw ) ) ) : array();
|
||||
$user = wp_get_current_user();
|
||||
$ids = isset( $ids_raw ) ? array_map( 'trim', array_filter( explode( ',', $ids_raw ) ) ) : array();
|
||||
$user = wp_get_current_user();
|
||||
|
||||
$should_display_based_on_roles = array_intersect( $roles, (array) $user->roles ) ? true : false;
|
||||
$should_display_based_on_ids = array_intersect( $ids, (array) $user->ID ) ? true : false;
|
||||
|
Reference in New Issue
Block a user