2021-12-07 11:08:05 +00:00
< ? php
require_once 'helpers/Slider.php' ;
class ET_Builder_Module_Slider_Item extends ET_Builder_Module {
function init () {
$this -> name = et_builder_i18n ( 'Slide' );
$this -> plural = esc_html__ ( 'Slides' , 'et_builder' );
$this -> slug = 'et_pb_slide' ;
$this -> vb_support = 'on' ;
$this -> type = 'child' ;
$this -> child_title_var = 'admin_title' ;
$this -> child_title_fallback_var = 'heading' ;
$this -> advanced_setting_title_text = esc_html__ ( 'New Slide' , 'et_builder' );
$this -> settings_text = esc_html__ ( 'Slide Settings' , 'et_builder' );
$this -> main_css_element = '%%order_class%%' ;
$this -> settings_modal_toggles = array (
'general' => array (
'toggles' => array (
'main_content' => et_builder_i18n ( 'Text' ),
'image_video' => esc_html__ ( 'Image & Video' , 'et_builder' ),
'player_pause' => esc_html__ ( 'Player Pause' , 'et_builder' ),
'admin_label' => array (
'title' => et_builder_i18n ( 'Admin Label' ),
'priority' => 99 ,
),
),
),
'advanced' => array (
'toggles' => array (
'overlay' => et_builder_i18n ( 'Overlay' ),
'navigation' => esc_html__ ( 'Navigation' , 'et_builder' ),
'image' => array (
'title' => et_builder_i18n ( 'Image' ),
),
'text' => array (
'title' => et_builder_i18n ( 'Text' ),
'priority' => 49 ,
),
),
),
'custom_css' => array (
'toggles' => array (
'attributes' => array (
'title' => esc_html__ ( 'Attributes' , 'et_builder' ),
'priority' => 95 ,
),
),
),
);
$this -> advanced_fields = array (
'fonts' => array (
'header' => array (
'label' => et_builder_i18n ( 'Title' ),
'css' => array (
'main' => " .et_pb_slider { $this -> main_css_element } .et_pb_slide .et_pb_slide_description .et_pb_slide_title " ,
'limited_main' => " .et_pb_slider { $this -> main_css_element } .et_pb_slide .et_pb_slide_description .et_pb_slide_title, .et_pb_slider { $this -> main_css_element } .et_pb_slide .et_pb_slide_description .et_pb_slide_title a " ,
'important' => 'all' ,
),
'line_height' => array (
'range_settings' => array (
'min' => '1' ,
'max' => '100' ,
'step' => '0.1' ,
),
),
'header_level' => array (
'default' => 'h2' ,
),
),
'body' => array (
'label' => et_builder_i18n ( 'Body' ),
'css' => array (
'main' => " .et_pb_slider.et_pb_module { $this -> main_css_element } .et_pb_slide .et_pb_slide_description .et_pb_slide_content " ,
'line_height' => " { $this -> main_css_element } p " ,
'important' => 'all' ,
),
'line_height' => array (
'range_settings' => array (
'min' => '1' ,
'max' => '100' ,
'step' => '0.1' ,
),
),
'block_elements' => array (
'tabbed_subtoggles' => true ,
'bb_icons_support' => true ,
),
),
),
'button' => array (
'button' => array (
'label' => et_builder_i18n ( 'Button' ),
'css' => array (
'main' => " .et_pb_slider { $this -> main_css_element } .et_pb_slide .et_pb_more_button.et_pb_button " ,
'limited_main' => " .et_pb_slider { $this -> main_css_element } .et_pb_slide .et_pb_more_button.et_pb_button " ,
'alignment' => " .et_pb_slider { $this -> main_css_element } .et_pb_slide_description .et_pb_button_wrapper " ,
),
'use_alignment' => true ,
'box_shadow' => array (
'css' => array (
'main' => '%%order_class%% .et_pb_button' ,
'important' => true ,
),
),
'margin_padding' => array (
'css' => array (
'important' => 'all' ,
),
),
),
),
'background' => array (
'css' => array (
'main' => '.et_pb_slider %%order_class%%' ,
),
'options' => array (
'background_color' => array (
'default' => et_builder_accent_color (),
'default_on_child' => true ,
),
),
),
'borders' => array (
'default' => false ,
'image' => array (
'css' => array (
'main' => array (
'border_radii' => '%%order_class%%.et_pb_slide .et_pb_slide_image img' ,
'border_styles' => '%%order_class%%.et_pb_slide .et_pb_slide_image img' ,
),
),
'label_prefix' => et_builder_i18n ( 'Image' ),
'tab_slug' => 'advanced' ,
'toggle_slug' => 'image' ,
'depends_show_if' => 'off' ,
'defaults' => array (
'border_radii' => 'on||||' ,
'border_styles' => array (
'width' => '0px' ,
'color' => '#333333' ,
'style' => 'solid' ,
),
),
),
),
'margin_padding' => array (
'use_margin' => false ,
'css' => array (
'padding' => '.et_pb_slider %%order_class%% .et_pb_slide_description, .et_pb_slider_fullwidth_off %%order_class%% .et_pb_slide_description' ,
'important' => array ( 'custom_padding' ), // Important is needed to overwrite parent and column-specific padding specificity
),
),
'text' => array (
'use_background_layout' => true ,
'css' => array (
'main' => implode (
', ' ,
array (
'%%order_class%% .et_pb_slide_description .et_pb_slide_title' ,
'%%order_class%% .et_pb_slide_description .et_pb_slide_title a' ,
'%%order_class%% .et_pb_slide_description .et_pb_slide_content' ,
'%%order_class%% .et_pb_slide_description .et_pb_slide_content .post-meta' ,
'%%order_class%% .et_pb_slide_description .et_pb_slide_content .post-meta a' ,
'%%order_class%% .et_pb_slide_description .et_pb_slide_content .et_pb_button' ,
)
),
'text_orientation' => '.et_pb_slides %%order_class%%.et_pb_slide .et_pb_slide_description' ,
'text_shadow' => '.et_pb_slides %%order_class%%.et_pb_slide .et_pb_slide_description' ,
),
'options' => array (
'background_layout' => array (
'default' => 'dark' ,
'default_on_child' => true ,
'hover' => 'tabs' ,
),
),
),
'box_shadow' => array (
'default' => false ,
'image' => array (
'label' => esc_html__ ( 'Image Box Shadow' , 'et_builder' ),
'option_category' => 'layout' ,
'tab_slug' => 'advanced' ,
'toggle_slug' => 'image' ,
'css' => array (
'main' => '%%order_class%%.et_pb_slide .et_pb_slide_image img' ,
),
'default_on_fronts' => array (
'color' => '' ,
'position' => '' ,
),
),
),
'filters' => array (
'child_filters_target' => array (
'tab_slug' => 'advanced' ,
'toggle_slug' => 'image' ,
),
),
'image' => array (
'css' => array (
'main' => array (
'%%order_class%% .et_pb_slide_image' ,
'%%order_class%% .et_pb_section_video_bg' ,
),
),
),
'max_width' => array (
'use_module_alignment' => false ,
'css' => array (
'main' => '.et_pb_slider %%order_class%%.et_pb_slide > .et_pb_container' ,
),
'options' => array (
'width' => array (
'label' => esc_html__ ( 'Content Width' , 'et_builder' ),
),
'max_width' => array (
'label' => esc_html__ ( 'Content Max Width' , 'et_builder' ),
),
),
),
'height' => false ,
'scroll_effects' => false ,
'position_fields' => false ,
'sticky' => false ,
);
$this -> custom_css_fields = array (
'slide_title' => array (
'label' => esc_html__ ( 'Slide Title' , 'et_builder' ),
'selector' => '.et_pb_slide_description .et_pb_slide_title' ,
),
'slide_container' => array (
'label' => esc_html__ ( 'Slide Description Container' , 'et_builder' ),
'selector' => '.et_pb_container' ,
),
'slide_description' => array (
'label' => esc_html__ ( 'Slide Description' , 'et_builder' ),
'selector' => '.et_pb_slide_description' ,
),
'slide_button' => array (
'label' => esc_html__ ( 'Slide Button' , 'et_builder' ),
'selector' => '.et_pb_slide .et_pb_container a.et_pb_more_button.et_pb_button' ,
'no_space_before_selector' => true ,
),
'slide_image' => array (
'label' => esc_html__ ( 'Slide Image' , 'et_builder' ),
'selector' => '.et_pb_slide_image' ,
),
);
$this -> help_videos = array (
array (
'id' => '-YeoR2xSLOY' ,
'name' => esc_html__ ( 'An introduction to the Slider module' , 'et_builder' ),
),
);
}
function get_fields () {
$fields = array (
'heading' => array (
'label' => et_builder_i18n ( 'Title' ),
'type' => 'text' ,
'option_category' => 'basic_option' ,
'description' => esc_html__ ( 'Define the title text for your slide.' , 'et_builder' ),
'toggle_slug' => 'main_content' ,
'dynamic_content' => 'text' ,
'mobile_options' => true ,
'hover' => 'tabs' ,
),
'button_text' => array (
'label' => et_builder_i18n ( 'Button' ),
'type' => 'text' ,
'option_category' => 'basic_option' ,
'description' => esc_html__ ( 'Define the text for the slide button' , 'et_builder' ),
'toggle_slug' => 'main_content' ,
'dynamic_content' => 'text' ,
'mobile_options' => true ,
'hover' => 'tabs' ,
),
'button_link' => array (
'label' => esc_html__ ( 'Button Link URL' , 'et_builder' ),
'type' => 'text' ,
'option_category' => 'basic_option' ,
'description' => esc_html__ ( 'Input a destination URL for the slide button.' , 'et_builder' ),
'toggle_slug' => 'link_options' ,
'default_on_front' => '#' ,
'dynamic_content' => 'url' ,
),
'url_new_window' => array (
'label' => esc_html__ ( 'Button Link Target' , 'et_builder' ),
'type' => 'select' ,
'option_category' => 'configuration' ,
'options' => array (
'off' => esc_html__ ( 'In The Same Window' , 'et_builder' ),
'on' => esc_html__ ( 'In The New Tab' , 'et_builder' ),
),
'toggle_slug' => 'link_options' ,
'description' => esc_html__ ( 'Here you can choose whether or not your link opens in a new window' , 'et_builder' ),
'default_on_front' => 'off' ,
),
'image' => array (
'label' => et_builder_i18n ( 'Image' ),
'type' => 'upload' ,
'option_category' => 'configuration' ,
'upload_button_text' => et_builder_i18n ( 'Upload an image' ),
'choose_text' => esc_attr__ ( 'Choose a Slide Image' , 'et_builder' ),
'update_text' => esc_attr__ ( 'Set As Slide Image' , 'et_builder' ),
'affects' => array (
'image_alt' ,
),
'description' => esc_html__ ( 'If defined, this slide image will appear to the left of your slide text. Upload an image, or leave blank for a text-only slide.' , 'et_builder' ),
'toggle_slug' => 'image_video' ,
'dynamic_content' => 'image' ,
'mobile_options' => true ,
'hover' => 'tabs' ,
),
'use_bg_overlay' => array (
'label' => esc_html__ ( 'Use Background Overlay' , 'et_builder' ),
'type' => 'yes_no_button' ,
'option_category' => 'configuration' ,
'options' => array (
'off' => et_builder_i18n ( 'No' ),
// Uses cached uppercase translation but keeps the lowercase not change definition content.
'on' => strtolower ( et_builder_i18n ( 'Yes' ) ),
),
'affects' => array (
'bg_overlay_color' ,
),
'default_on_front' => '' ,
'tab_slug' => 'advanced' ,
'toggle_slug' => 'overlay' ,
'description' => esc_html__ ( 'When enabled, a custom overlay color will be added above your background image and behind your slider content.' , 'et_builder' ),
),
'bg_overlay_color' => array (
'label' => esc_html__ ( 'Background Overlay Color' , 'et_builder' ),
'type' => 'color-alpha' ,
'custom_color' => true ,
'depends_show_if' => 'on' ,
'description' => esc_html__ ( 'Use the color picker to choose a color for the background overlay.' , 'et_builder' ),
'tab_slug' => 'advanced' ,
'toggle_slug' => 'overlay' ,
'mobile_options' => true ,
'sticky' => true ,
),
'use_text_overlay' => array (
'label' => esc_html__ ( 'Use Text Overlay' , 'et_builder' ),
'type' => 'yes_no_button' ,
'option_category' => 'configuration' ,
'options' => array (
'off' => et_builder_i18n ( 'No' ),
// Uses cached uppercase translation but keeps the lowercase not change definition content.
'on' => strtolower ( et_builder_i18n ( 'Yes' ) ),
),
'default_on_front' => '' ,
'affects' => array (
'text_overlay_color' ,
'text_border_radius' ,
),
'tab_slug' => 'advanced' ,
'toggle_slug' => 'overlay' ,
'description' => esc_html__ ( 'When enabled, a background color is added behind the slider text to make it more readable atop background images.' , 'et_builder' ),
),
'text_overlay_color' => array (
'label' => esc_html__ ( 'Text Overlay Color' , 'et_builder' ),
'type' => 'color-alpha' ,
'custom_color' => true ,
'depends_show_if' => 'on' ,
'tab_slug' => 'advanced' ,
'toggle_slug' => 'overlay' ,
'description' => esc_html__ ( 'Use the color picker to choose a color for the text overlay.' , 'et_builder' ),
'mobile_options' => true ,
'sticky' => true ,
),
'alignment' => array (
'label' => esc_html__ ( 'Image Alignment' , 'et_builder' ),
'type' => 'select' ,
'option_category' => 'layout' ,
'options' => array (
'center' => et_builder_i18n ( 'Center' ),
'bottom' => et_builder_i18n ( 'Bottom' ),
),
'default_on_front' => 'center' ,
'tab_slug' => 'advanced' ,
'toggle_slug' => 'image' ,
'description' => esc_html__ ( 'This setting determines the vertical alignment of your slide image. Your image can either be vertically centered, or aligned to the bottom of your slide.' , 'et_builder' ),
),
'video_url' => array (
'label' => esc_html__ ( 'Video' , 'et_builder' ),
'type' => 'upload' ,
'data_type' => 'video' ,
'upload_button_text' => esc_attr__ ( 'Upload a video' , 'et_builder' ),
'choose_text' => esc_attr__ ( 'Choose a Video WEBM File' , 'et_builder' ),
'update_text' => esc_attr__ ( 'Set As Video' , 'et_builder' ),
'option_category' => 'basic_option' ,
'description' => esc_html__ ( 'If defined, this video will appear to the left of your slide text. Enter youtube or vimeo page url, or leave blank for a text-only slide.' , 'et_builder' ),
'toggle_slug' => 'image_video' ,
'computed_affects' => array (
'__video_embed' ,
),
'mobile_options' => true ,
'hover' => 'tabs' ,
),
'image_alt' => array (
'label' => esc_html__ ( 'Image Alternative Text' , 'et_builder' ),
'type' => 'text' ,
'option_category' => 'basic_option' ,
'depends_show_if' => 'on' ,
'depends_on' => array (
'image' ,
),
'description' => esc_html__ ( 'If you have a slide image defined, input your HTML ALT text for the image here.' , 'et_builder' ),
'tab_slug' => 'custom_css' ,
'toggle_slug' => 'attributes' ,
'dynamic_content' => 'text' ,
),
'allow_player_pause' => array (
'label' => esc_html__ ( 'Pause Video When Another Video Plays' , 'et_builder' ),
'type' => 'yes_no_button' ,
'option_category' => 'configuration' ,
'options' => array (
'off' => et_builder_i18n ( 'No' ),
'on' => et_builder_i18n ( 'Yes' ),
),
'default_on_front' => '' ,
'toggle_slug' => 'player_pause' ,
'description' => esc_html__ ( 'Allow video to be paused by other players when they begin playing' , 'et_builder' ),
),
'content' => array (
'label' => et_builder_i18n ( 'Body' ),
'type' => 'tiny_mce' ,
'option_category' => 'basic_option' ,
'description' => esc_html__ ( 'Input your main slide text content here.' , 'et_builder' ),
'toggle_slug' => 'main_content' ,
'dynamic_content' => 'text' ,
'mobile_options' => true ,
'hover' => 'tabs' ,
),
'arrows_custom_color' => array (
'label' => esc_html__ ( 'Arrow Color' , 'et_builder' ),
'description' => esc_html__ ( 'Pick a color to use for the slider arrows that are used to navigate through each slide.' , 'et_builder' ),
'type' => 'color-alpha' ,
'custom_color' => true ,
'tab_slug' => 'advanced' ,
'toggle_slug' => 'navigation' ,
'mobile_options' => true ,
'sticky' => true ,
'hover' => 'tabs' ,
),
'dot_nav_custom_color' => array (
'label' => esc_html__ ( 'Dot Navigation Color' , 'et_builder' ),
'description' => esc_html__ ( 'Pick a color to use for the dot navigation that appears at the bottom of the slider to designate which slide is active.' , 'et_builder' ),
'type' => 'color-alpha' ,
'custom_color' => true ,
'tab_slug' => 'advanced' ,
'toggle_slug' => 'navigation' ,
'mobile_options' => true ,
'sticky' => true ,
'hover' => 'tabs' ,
),
'admin_title' => array (
'label' => et_builder_i18n ( 'Admin Label' ),
'type' => 'text' ,
'description' => esc_html__ ( 'This will change the label of the slide in the builder for easy identification.' , 'et_builder' ),
'toggle_slug' => 'admin_label' ,
),
'text_border_radius' => array (
'label' => esc_html__ ( 'Text Overlay Border Radius' , 'et_builder' ),
'description' => esc_html__ ( 'Increasing the border radius will increase the roundness of the overlay corners. Setting this value to 0 will result in squared corners.' , 'et_builder' ),
'type' => 'range' ,
'option_category' => 'layout' ,
'allowed_units' => array ( '%' , 'em' , 'rem' , 'px' , 'cm' , 'mm' , 'in' , 'pt' , 'pc' , 'ex' , 'vh' , 'vw' ),
'default' => '3' ,
'default_unit' => 'px' ,
'default_on_front' => '' ,
'range_settings' => array (
'min' => '0' ,
'max' => '100' ,
'step' => '1' ,
),
'depends_show_if' => 'on' ,
'tab_slug' => 'advanced' ,
'toggle_slug' => 'overlay' ,
'mobile_options' => true ,
'sticky' => true ,
),
'__video_embed' => array (
'type' => 'computed' ,
'computed_callback' => array ( 'ET_Builder_Module_Slider_Item' , 'get_video_embed' ),
'computed_depends_on' => array (
'video_url' ,
),
'computed_minimum' => array (
'video_url' ,
),
),
);
return $fields ;
}
public function get_transition_fields_css_props () {
$fields = parent :: get_transition_fields_css_props ();
$fields [ 'background_layout' ] = array (
'background-color' => '%%order_class%% .et_pb_slide_overlay_container, %%order_class%% .et_pb_text_overlay_wrapper' ,
'color' => self :: $_ -> array_get ( $this -> advanced_fields , 'text.css.main' , '%%order_class%%' ),
);
$fields [ 'bg_overlay_color' ] = array ( 'background-color' => '%%order_class%%.et_pb_slide .et_pb_slide_overlay_container' );
$fields [ 'text_overlay_color' ] = array ( 'background-color' => '%%order_class%%.et_pb_slide .et_pb_text_overlay_wrapper' );
$fields [ 'text_border_radius' ] = array ( 'border-radius' => '%%order_class%%.et_pb_slide .et_pb_text_overlay_wrapper' );
$fields [ 'dot_nav_custom_color' ] = array ( 'background-color' => et_pb_slider_options () -> get_dots_selector () );
$fields [ 'arrows_custom_color' ] = array ( 'all' => et_pb_slider_options () -> get_arrows_selector () );
return $fields ;
}
static function get_video_embed ( $args = array (), $conditonal_args = array (), $current_page = array () ) {
global $wp_embed ;
$video_url = esc_url ( $args [ 'video_url' ] );
// Bail early if video URL is empty.
if ( empty ( $video_url ) ) {
return '' ;
}
$autoembed = $wp_embed -> autoembed ( $video_url );
$is_local_video = has_shortcode ( $autoembed , 'video' );
$video_embed = '' ;
if ( $is_local_video ) {
$video_embed = wp_video_shortcode ( array ( 'src' => $video_url ) );
} else {
$video_embed = et_builder_get_oembed ( $video_url );
$video_embed = preg_replace ( '/<embed /' , '<embed wmode="transparent" ' , $video_embed );
$video_embed = preg_replace ( '/<\/object>/' , '<param name="wmode" value="transparent" /></object>' , $video_embed );
}
return $video_embed ;
}
function maybe_inherit_values () {
// Inheriting slider attribute
global $et_pb_slider ;
// Helper, makes things neater.
$sticky = et_pb_sticky_options ();
// Check if current slide item version is made before Divi v3.2 (UI Improvement release). v3.2 changed default
// background color for slide item for usability and inheritance mechanism requires custom treatment on FE and VB
$is_prior_v32 = version_compare ( self :: $_ -> array_get ( $this -> props , '_builder_version' , '3.0.47' ), '3.2' , '<' );
// Attribute inheritance should be done on front-end / published page only.
// Don't run attribute inheritance in VB and Backend to avoid attribute inheritance accidentally being saved on VB / BB
if ( ! empty ( $et_pb_slider ) && ! is_admin () && ! et_fb_is_enabled () ) {
$view_modes = array ( '' , '__hover' , '_phone' , '_tablet' );
foreach ( $et_pb_slider as $slider_attr => $slider_attr_value ) {
$maybe_next_slider_attr = false ;
foreach ( $view_modes as $mode ) {
$current_view_bc_enable_attr = 'background_enable_color' . $mode ;
if ( $slider_attr === $current_view_bc_enable_attr ) {
// Do not inherit the background color off from the parent slider
$this -> props [ $current_view_bc_enable_attr ] = isset ( $this -> props [ $current_view_bc_enable_attr ] ) && 'off' === $this -> props [ $current_view_bc_enable_attr ] ? 'off' : 'on' ;
$maybe_next_slider_attr = true ;
}
}
if ( $maybe_next_slider_attr ) {
continue ;
}
// Get default value
$default = isset ( $this -> fields_unprocessed [ $slider_attr ][ 'default' ] ) ? $this -> fields_unprocessed [ $slider_attr ][ 'default' ] : '' ;
// Slide item isn't empty nor default
if ( ! in_array ( self :: $_ -> array_get ( $this -> props , $slider_attr , '' ), array ( '' , $default ) ) ) {
continue ;
}
// Slider value is equal to empty or slide item's default
if ( in_array ( $slider_attr_value , array ( '' , $default ) ) ) {
continue ;
}
// Overwrite slider item's empty / default value
$this -> props [ $slider_attr ] = $slider_attr_value ;
}
}
// In VB, inheritance is done in VB side. However in migrating changing default that is affected by inheritance, the value
// needs to be modified before being set to avoid sudden color change when _builder_version is bumped when settings modal
// is opened. This making prior saved value changed but it is the safest option considering old Divi doesn't trim background_color
if ( ! empty ( $et_pb_slider ) && ( is_admin () || et_core_is_fb_enabled () ) && $is_prior_v32 ) {
$slider_background_color = self :: $_ -> array_get ( $et_pb_slider , 'background_color' , '' );
$is_slide_background_color_empty = in_array ( $this -> props [ 'background_color' ], array ( '' , '#ffffff' , et_builder_accent_color () ) );
$is_slider_background_color_filled = '' !== $slider_background_color ;
if ( $is_slide_background_color_empty && $is_slider_background_color_filled ) {
$this -> props [ 'background_color' ] = '' ;
}
}
// For background, text overlay, arrow, and dot colors, we have to consider about the
// responsive settings status to inherit the value. If it's disabled on slider item, we
// have to use the value from slider instead.
if ( ! empty ( $et_pb_slider ) ) {
// Background Overlay Color.
$is_bg_overlay_color_slider_responsive = et_pb_responsive_options () -> is_responsive_enabled ( $et_pb_slider , 'bg_overlay_color_slider' );
$is_bg_overlay_color_responsive = et_pb_responsive_options () -> is_responsive_enabled ( $this -> props , 'bg_overlay_color' );
if ( ! $is_bg_overlay_color_responsive && $is_bg_overlay_color_slider_responsive ) {
$this -> props [ 'bg_overlay_color_tablet' ] = ! empty ( $et_pb_slider [ 'bg_overlay_color_tablet' ] ) ? $et_pb_slider [ 'bg_overlay_color_tablet' ] : $this -> props [ 'bg_overlay_color_tablet' ];
$this -> props [ 'bg_overlay_color_phone' ] = ! empty ( $et_pb_slider [ 'bg_overlay_color_phone' ] ) ? $et_pb_slider [ 'bg_overlay_color_phone' ] : $this -> props [ 'bg_overlay_color_phone' ];
$this -> props [ 'bg_overlay_color_last_edited' ] = ! empty ( $et_pb_slider [ 'bg_overlay_color_slider_last_edited' ] ) ? $et_pb_slider [ 'bg_overlay_color_slider_last_edited' ] : $this -> props [ 'bg_overlay_color_last_edited' ];
}
// Inherit value from parent if current sticky value is empty.
$slide_bg_overlay_color__sticky = $sticky -> get_value ( 'bg_overlay_color' , $this -> props , '' );
if ( '' === $slide_bg_overlay_color__sticky && ! empty ( $et_pb_slider [ 'bg_overlay_color__sticky' ] ) ) {
$this -> props [ 'bg_overlay_color__sticky_enabled' ] = 'on' ;
$this -> props [ 'bg_overlay_color__sticky' ] = $et_pb_slider [ 'bg_overlay_color__sticky' ];
}
// Text Overlay Color.
$is_text_overlay_color_slider_responsive = et_pb_responsive_options () -> is_responsive_enabled ( $et_pb_slider , 'text_overlay_color_slider' );
$is_text_overlay_color_responsive = et_pb_responsive_options () -> is_responsive_enabled ( $this -> props , 'text_overlay_color' );
if ( ! $is_text_overlay_color_responsive && $is_text_overlay_color_slider_responsive ) {
$this -> props [ 'text_overlay_color_tablet' ] = ! empty ( $et_pb_slider [ 'text_overlay_color_tablet' ] ) ? $et_pb_slider [ 'text_overlay_color_tablet' ] : $this -> props [ 'text_overlay_color_tablet' ];
$this -> props [ 'text_overlay_color_phone' ] = ! empty ( $et_pb_slider [ 'text_overlay_color_phone' ] ) ? $et_pb_slider [ 'text_overlay_color_phone' ] : $this -> props [ 'text_overlay_color_phone' ];
$this -> props [ 'text_overlay_color_last_edited' ] = ! empty ( $et_pb_slider [ 'text_overlay_color_slider_last_edited' ] ) ? $et_pb_slider [ 'text_overlay_color_slider_last_edited' ] : $this -> props [ 'text_overlay_color_last_edited' ];
}
// Inherit value from parent if current sticky value is empty.
$slide_text_overlay_color__sticky = $sticky -> get_value ( 'text_overlay_color' , $this -> props , '' );
if ( '' === $slide_text_overlay_color__sticky && ! empty ( $et_pb_slider [ 'text_overlay_color__sticky' ] ) ) {
$this -> props [ 'text_overlay_color__sticky_enabled' ] = 'on' ;
$this -> props [ 'text_overlay_color__sticky' ] = $et_pb_slider [ 'text_overlay_color__sticky' ];
}
// Text Border Radius.
$is_text_border_radius_slider_responsive = et_pb_responsive_options () -> is_responsive_enabled ( $et_pb_slider , 'text_border_radius_slider' );
$is_text_border_radius_responsive = et_pb_responsive_options () -> is_responsive_enabled ( $this -> props , 'text_border_radius' );
if ( ! $is_text_border_radius_responsive && $is_text_border_radius_slider_responsive ) {
$this -> props [ 'text_border_radius_tablet' ] = ! empty ( $et_pb_slider [ 'text_border_radius_tablet' ] ) ? $et_pb_slider [ 'text_border_radius_tablet' ] : $this -> props [ 'text_border_radius_tablet' ];
$this -> props [ 'text_border_radius_phone' ] = ! empty ( $et_pb_slider [ 'text_border_radius_phone' ] ) ? $et_pb_slider [ 'text_border_radius_phone' ] : $this -> props [ 'text_border_radius_phone' ];
$this -> props [ 'text_border_radius_last_edited' ] = ! empty ( $et_pb_slider [ 'text_border_radius_slider_last_edited' ] ) ? $et_pb_slider [ 'text_border_radius_slider_last_edited' ] : $this -> props [ 'text_border_radius_last_edited' ];
}
// Inherit value from parent if current sticky value is empty.
$slide_text_border_radius__sticky = $sticky -> get_value ( 'text_border_radius' , $this -> props , '' );
if ( '' === $slide_text_border_radius__sticky && ! empty ( $et_pb_slider [ 'text_border_radius__sticky' ] ) ) {
$this -> props [ 'text_border_radius__sticky_enabled' ] = 'on' ;
$this -> props [ 'text_border_radius__sticky' ] = $et_pb_slider [ 'text_border_radius__sticky' ];
}
// Arrow Custom Color.
$is_arrows_custom_color_slider_responsive = et_pb_responsive_options () -> is_responsive_enabled ( $et_pb_slider , 'arrows_custom_color_slider' );
$is_arrows_custom_color_responsive = et_pb_responsive_options () -> is_responsive_enabled ( $this -> props , 'arrows_custom_color' );
if ( ! $is_arrows_custom_color_responsive && $is_arrows_custom_color_slider_responsive ) {
$this -> props [ 'arrows_custom_color_tablet' ] = ! empty ( $et_pb_slider [ 'arrows_custom_color_tablet' ] ) ? $et_pb_slider [ 'arrows_custom_color_tablet' ] : $this -> props [ 'arrows_custom_color_tablet' ];
$this -> props [ 'arrows_custom_color_phone' ] = ! empty ( $et_pb_slider [ 'arrows_custom_color_phone' ] ) ? $et_pb_slider [ 'arrows_custom_color_phone' ] : $this -> props [ 'arrows_custom_color_phone' ];
$this -> props [ 'arrows_custom_color_last_edited' ] = ! empty ( $et_pb_slider [ 'arrows_custom_color_slider_last_edited' ] ) ? $et_pb_slider [ 'arrows_custom_color_slider_last_edited' ] : $this -> props [ 'arrows_custom_color_last_edited' ];
}
// Inherit value from parent if current sticky value is empty.
$slide_arrows_custom_color__sticky = $sticky -> get_value ( 'arrows_custom_color' , $this -> props , '' );
if ( '' === $slide_arrows_custom_color__sticky && ! empty ( $et_pb_slider [ 'arrows_custom_color__sticky' ] ) ) {
$this -> props [ 'arrows_custom_color__sticky_enabled' ] = 'on' ;
$this -> props [ 'arrows_custom_color__sticky' ] = $et_pb_slider [ 'arrows_custom_color__sticky' ];
}
// Dot Navigation Color.
$is_dot_nav_custom_color_slider_responsive = et_pb_responsive_options () -> is_responsive_enabled ( $et_pb_slider , 'dot_nav_custom_color_slider' );
$is_dot_nav_custom_color_responsive = et_pb_responsive_options () -> is_responsive_enabled ( $this -> props , 'dot_nav_custom_color' );
if ( ! $is_dot_nav_custom_color_responsive && $is_dot_nav_custom_color_slider_responsive ) {
$this -> props [ 'dot_nav_custom_color_tablet' ] = ! empty ( $et_pb_slider [ 'dot_nav_custom_color_tablet' ] ) ? $et_pb_slider [ 'dot_nav_custom_color_tablet' ] : $this -> props [ 'dot_nav_custom_color_tablet' ];
$this -> props [ 'dot_nav_custom_color_phone' ] = ! empty ( $et_pb_slider [ 'dot_nav_custom_color_phone' ] ) ? $et_pb_slider [ 'dot_nav_custom_color_phone' ] : $this -> props [ 'dot_nav_custom_color_phone' ];
$this -> props [ 'dot_nav_custom_color_last_edited' ] = ! empty ( $et_pb_slider [ 'dot_nav_custom_color_slider_last_edited' ] ) ? $et_pb_slider [ 'dot_nav_custom_color_slider_last_edited' ] : $this -> props [ 'dot_nav_custom_color_last_edited' ];
}
// Inherit value from parent if current sticky value is empty.
$slide_dot_nav_custom_color__sticky = $sticky -> get_value ( 'dot_nav_custom_color' , $this -> props , '' );
if ( '' === $slide_dot_nav_custom_color__sticky && ! empty ( $et_pb_slider [ 'dot_nav_custom_color__sticky' ] ) ) {
$this -> props [ 'dot_nav_custom_color__sticky_enabled' ] = 'on' ;
$this -> props [ 'dot_nav_custom_color__sticky' ] = $et_pb_slider [ 'dot_nav_custom_color__sticky' ];
}
// Module item has no sticky option hence sticky_transition which is needed to setup
// transition needs to be inherited from parent (slider) module.
if ( ! empty ( $et_pb_slider [ 'sticky_transition' ] ) ) {
$this -> props [ 'sticky_transition' ] = $et_pb_slider [ 'sticky_transition' ];
}
}
}
/**
* Get slider item normal or global background color .
*
* @ since 4.9 . 0
*
* @ return string
*/
public function get_slider_item_background_color () {
$background_color = $this -> props [ 'background_color' ];
if ( strpos ( $background_color , 'gcid-' ) === 0 ) {
$global_color_info = et_builder_get_global_color_info ( $background_color );
return esc_attr ( $global_color_info [ 'color' ] );
}
return $background_color ;
}
/**
* Renders the module output .
*
* @ param array $attrs List of attributes .
* @ param string $content Content being processed .
* @ param string $render_slug Slug of module that is used for rendering output .
*
* @ return string
*/
public function render ( $attrs , $content , $render_slug ) {
$multi_view = et_pb_multi_view_options ( $this );
$alignment = $this -> props [ 'alignment' ];
// Allowing full html for backwards compatibility.
$heading = $this -> _esc_attr ( 'heading' , 'full' );
$button_text = $this -> _esc_attr ( 'button_text' , 'limited' );
$button_link = $this -> props [ 'button_link' ];
$url_new_window = $this -> props [ 'url_new_window' ];
$image = $this -> props [ 'image' ];
$image_alt = $this -> props [ 'image_alt' ];
$video_url = $this -> props [ 'video_url' ];
$button_custom = $this -> props [ 'custom_button' ];
$button_rel = $this -> props [ 'button_rel' ];
$use_bg_overlay = $this -> props [ 'use_bg_overlay' ];
$use_text_overlay = $this -> props [ 'use_text_overlay' ];
$header_level = $this -> props [ 'header_level' ];
$video_background = $this -> video_background ();
$parallax_image_background = $this -> get_parallax_image_background ();
2022-06-23 12:17:18 +00:00
$pattern_background = $this -> background_pattern ();
$mask_background = $this -> background_mask ();
2021-12-07 11:08:05 +00:00
$background_color = $this -> get_slider_item_background_color ();
$custom_icon_values = et_pb_responsive_options () -> get_property_values ( $this -> props , 'button_icon' );
$custom_icon = isset ( $custom_icon_values [ 'desktop' ] ) ? $custom_icon_values [ 'desktop' ] : '' ;
$custom_icon_tablet = isset ( $custom_icon_values [ 'tablet' ] ) ? $custom_icon_values [ 'tablet' ] : '' ;
$custom_icon_phone = isset ( $custom_icon_values [ 'phone' ] ) ? $custom_icon_values [ 'phone' ] : '' ;
global $et_pb_slider , $et_pb_slider_has_video , $et_pb_slider_parallax , $et_pb_slider_parallax_method , $et_pb_slider_show_mobile , $et_pb_slider_custom_icon , $et_pb_slider_custom_icon_tablet , $et_pb_slider_custom_icon_phone , $et_pb_slider_item_num , $et_pb_slider_button_rel ;
$et_pb_slider_item_num ++ ;
$hide_on_mobile_class = self :: HIDE_ON_MOBILE ;
$is_text_overlay_applied = 'on' === $use_text_overlay ;
$custom_slide_icon = 'on' === $button_custom && '' !== $custom_icon ? $custom_icon : $et_pb_slider_custom_icon ;
$custom_slide_icon_tablet = 'on' === $button_custom && '' !== $custom_icon_tablet ? $custom_icon_tablet : $et_pb_slider_custom_icon_tablet ;
$custom_slide_icon_phone = 'on' === $button_custom && '' !== $custom_icon_phone ? $custom_icon_phone : $et_pb_slider_custom_icon_phone ;
if ( '' !== $heading ) {
if ( '#' !== $button_link ) {
$heading = sprintf (
'<a href="%1$s">%2$s</a>' ,
esc_url ( $button_link ),
et_core_esc_previously ( $heading )
);
}
$heading = sprintf (
'<%1$s class="et_pb_slide_title">%2$s</%1$s>' ,
et_pb_process_header_level ( $header_level , 'h2' ),
et_core_esc_previously ( $heading )
);
}
// Overwrite button rel with pricin tables' button_rel if needed
if ( in_array ( $button_rel , array ( '' , 'off|off|off|off|off' ) ) && '' !== $et_pb_slider_button_rel ) {
$button_rel = $et_pb_slider_button_rel ;
}
// render button
$button_classname = array ( 'et_pb_more_button' );
if ( 'on' !== $et_pb_slider_show_mobile [ 'show_cta_on_mobile' ] ) {
$button_classname [] = $hide_on_mobile_class ;
}
$button = $this -> render_button (
array (
'button_classname' => $button_classname ,
'button_custom' => '' !== $custom_slide_icon || '' !== $custom_slide_icon_tablet || '' !== $custom_slide_icon_phone ? 'on' : 'off' ,
'button_rel' => $button_rel ,
'button_text' => $button_text ,
'button_text_escaped' => true ,
'button_url' => $button_link ,
'url_new_window' => $url_new_window ,
'custom_icon' => $custom_slide_icon ,
'custom_icon_tablet' => $custom_slide_icon_tablet ,
'custom_icon_phone' => $custom_slide_icon_phone ,
'display_button' => true ,
'multi_view_data' => $multi_view -> render_attrs (
array (
'content' => '{{button_text}}' ,
'visibility' => array (
'button_text' => '__not_empty' ,
),
)
),
)
);
if ( 'on' === $use_bg_overlay ) {
// Background Overlay Color.
$this -> generate_styles (
array (
'hover' => false ,
'base_attr_name' => 'bg_overlay_color' ,
'attrs' => $this -> props ,
'selector' => '%%order_class%%.et_pb_slide .et_pb_slide_overlay_container' ,
'css_property' => 'background-color' ,
'render_slug' => $render_slug ,
'type' => 'color' ,
// The selector points to module item, thus current module is definitely not sticky.
'is_sticky_module' => false ,
)
);
}
if ( ! empty ( $background_color ) && 'off' !== $this -> props [ 'background_enable_color' ] ) {
ET_Builder_Element :: set_style (
$render_slug ,
array (
'selector' => '%%order_class%%' ,
'declaration' => sprintf (
'background-color: %1$s;' ,
esc_html ( $background_color )
),
)
);
}
if ( $is_text_overlay_applied ) {
// Text Overlay Color.
$this -> generate_styles (
array (
'hover' => false ,
'base_attr_name' => 'text_overlay_color' ,
'attrs' => $this -> props ,
'selector' => '%%order_class%%.et_pb_slide .et_pb_text_overlay_wrapper' ,
'css_property' => 'background-color' ,
'render_slug' => $render_slug ,
'type' => 'color' ,
// The selector points to module item, thus current module is definitely not sticky.
'is_sticky_module' => false ,
)
);
}
// Text Border Radius.
$this -> generate_styles (
array (
'hover' => false ,
'base_attr_name' => 'text_border_radius' ,
'attrs' => $this -> props ,
'selector' => '%%order_class%%.et_pb_slide .et_pb_text_overlay_wrapper' ,
'css_property' => 'border-radius' ,
'render_slug' => $render_slug ,
'type' => 'range' ,
// The selector points to module item, thus current module is definitely not sticky.
'is_sticky_module' => false ,
)
);
$image = '' ;
if ( $multi_view -> has_value ( 'image' ) ) {
$image_attrs = array (
'src' => '{{image}}' ,
'alt' => esc_attr ( $image_alt ),
);
$image_attachment_class = et_pb_media_options () -> get_image_attachment_class ( $this -> props , 'image' );
if ( ! empty ( $image_attachment_class ) ) {
$image_attrs [ 'class' ] = esc_attr ( $image_attachment_class );
}
$image_html = $multi_view -> render_element (
array (
'tag' => 'img' ,
'attrs' => $image_attrs ,
'required' => 'image' ,
)
);
$image = $multi_view -> render_element (
array (
'tag' => 'div' ,
'content' => $image_html ,
'attrs' => array (
'class' => 'et_pb_slide_image' ,
),
'required' => 'image' ,
)
);
}
if ( $multi_view -> has_value ( 'video_url' ) ) {
$image = $multi_view -> render_element (
array (
'tag' => 'div' ,
'content' => '{{video_url}}' ,
'attrs' => array (
'class' => 'et_pb_slide_video' ,
),
)
);
}
// Images: Add CSS Filters and Mix Blend Mode rules (if set)
if ( array_key_exists ( 'image' , $this -> advanced_fields ) && array_key_exists ( 'css' , $this -> advanced_fields [ 'image' ] ) ) {
$this -> add_classname (
$this -> generate_css_filters (
$render_slug ,
'child_' ,
self :: $data_utils -> array_get ( $this -> advanced_fields [ 'image' ][ 'css' ], 'main' , '%%order_class%%' )
)
);
}
// Background layout class names.
$background_layout_class_names = et_pb_background_layout_options () -> get_background_layout_class ( $this -> props );
$this -> add_classname ( $background_layout_class_names );
// Module classnames
if ( $multi_view -> has_value ( 'image' ) || $multi_view -> has_value ( 'video_url' ) ) {
$this -> add_classname ( 'et_pb_slide_with_image' );
}
if ( $multi_view -> has_value ( 'video_url' ) ) {
$this -> add_classname ( 'et_pb_slide_with_video' );
}
if ( 'bottom' !== $alignment ) {
$this -> add_classname ( " et_pb_media_alignment_ { $alignment } " );
}
if ( 'on' === $use_bg_overlay ) {
$this -> add_classname ( 'et_pb_slider_with_overlay' );
}
if ( 'on' === $use_text_overlay ) {
$this -> add_classname ( 'et_pb_slider_with_text_overlay' );
}
if ( 1 === $et_pb_slider_item_num ) {
$this -> add_classname ( 'et-pb-active-slide' );
}
$parent_class = self :: $_ -> array_get ( $et_pb_slider , 'order_class' , 'et_pb_slider' );
$order_class = self :: get_module_order_class ( $render_slug );
$prefix = sprintf ( '.%1$s[data-active-slide="%2$s"]' , $parent_class , $order_class );
$is_slider_sticky = et_ () -> array_get ( $et_pb_slider , 'is_sticky_module' , false );
$this -> generate_styles (
array (
'base_attr_name' => 'arrows_custom_color' ,
'attrs' => $this -> props ,
'selector' => et_pb_slider_options () -> get_arrows_selector ( $prefix ),
'hover_pseudo_selector_location' => 'suffix' ,
'sticky_pseudo_selector_location' => 'prefix' ,
'css_property' => 'color' ,
'render_slug' => $render_slug ,
'type' => 'color' ,
// Selector is started by slider parent's DOM, hence sticky classname prefix depends
// to whether the slider parent is sticky or not.
'is_sticky_module' => $is_slider_sticky ,
)
);
$this -> generate_styles (
array (
'base_attr_name' => 'dot_nav_custom_color' ,
'attrs' => $this -> props ,
'selector' => et_pb_slider_options () -> get_dots_selector ( $prefix ),
'hover_pseudo_selector_location' => 'suffix' ,
'sticky_pseudo_selector_location' => 'prefix' ,
'css_property' => 'background-color' ,
'render_slug' => $render_slug ,
'type' => 'color' ,
// Selector is started by slider parent's DOM, hence sticky classname prefix depends
// to whether the slider parent is sticky or not.
'is_sticky_module' => $is_slider_sticky ,
)
);
// Remove automatically added classnames
$this -> remove_classname (
array (
'et_pb_module' ,
)
);
$heading = $multi_view -> has_value ( 'heading' ) ? '{{heading}}' : '' ;
if ( $heading ) {
if ( $button_link && '#' !== $button_link ) {
$heading = $multi_view -> render_element (
array (
'tag' => 'a' ,
'content' => $heading ,
'attrs' => array (
'href' => esc_url ( $button_link ),
),
)
);
}
$heading = $multi_view -> render_element (
array (
'tag' => et_pb_process_header_level ( $header_level , 'h2' ),
'content' => $heading ,
'attrs' => array (
'class' => 'et_pb_slide_title' ,
),
)
);
}
$slide_content_class = array ( 'et_pb_slide_content' );
if ( 'on' !== $et_pb_slider_show_mobile [ 'show_content_on_mobile' ] ) {
$slide_content_class [] = $hide_on_mobile_class ;
}
$content = $multi_view -> render_element (
array (
'tag' => 'div' ,
'content' => '{{content}}' ,
'attrs' => array (
'class' => implode ( ' ' , $slide_content_class ),
),
)
);
$slide_content = sprintf (
'%1$s%2$s' ,
et_core_esc_previously ( $heading ),
et_core_esc_previously ( $content )
);
// apply text overlay wrapper
if ( $is_text_overlay_applied ) {
$slide_content = sprintf (
' < div class = " et_pb_text_overlay_wrapper " >
% 1 $s
</ div > ' ,
$slide_content
);
}
// Background layout data attributes.
$data_background_layout = et_pb_background_layout_options () -> get_background_layout_attrs ( $this -> props );
$multi_view_classes = $multi_view -> render_attrs (
array (
'classes' => array (
'et_pb_slide_with_image' => array (
'image' => '__not_empty' ,
),
'et_pb_slide_with_video' => array (
'video_url' => '__not_empty' ,
),
),
)
);
$output = sprintf (
' < div class = " %4 $s " % 7 $s % 8 $s % 10 $s data - slide - id = " %11 $s " % 12 $s >
% 6 $s
% 9 $s
< div class = " et_pb_container clearfix " >
< div class = " et_pb_slider_container_inner " >
% 3 $s
< div class = " et_pb_slide_description " >
% 1 $s
% 2 $s
</ div >
</ div >
</ div >
% 5 $s
2022-06-23 12:17:18 +00:00
% 13 $s
% 14 $s
2021-12-07 11:08:05 +00:00
</ div >
' ,
$slide_content ,
$button ,
$image ,
$this -> module_classname ( $render_slug ),
$video_background , // #5
$parallax_image_background ,
'' ,
'' ,
'on' === $use_bg_overlay ? '<div class="et_pb_slide_overlay_container"></div>' : '' ,
et_core_esc_previously ( $data_background_layout ), // #10
self :: get_module_order_class ( $render_slug ),
2022-06-23 12:17:18 +00:00
$multi_view_classes ,
et_core_esc_previously ( $pattern_background ), // #13
et_core_esc_previously ( $mask_background ) // #14
2021-12-07 11:08:05 +00:00
);
return $output ;
}
/**
* Filter multi view value .
*
* @ since 3.27 . 1
*
* @ see ET_Builder_Module_Helper_MultiViewOptions :: filter_value
*
* @ param mixed $raw_value Props raw value .
* @ param array $args {
* Context data .
*
* @ type string $context Context param : content , attrs , visibility , classes .
* @ type string $name Module options props name .
* @ type string $mode Current data mode : desktop , hover , tablet , phone .
* @ type string $attr_key Attribute key for attrs context data . Example : src , class , etc .
* @ type string $attr_sub_key Attribute sub key that availabe when passing attrs value as array such as styes . Example : padding - top , margin - botton , etc .
* }
* @ param ET_Builder_Module_Helper_MultiViewOptions $multi_view Multiview object instance .
*
* @ return mixed
*/
public function multi_view_filter_value ( $raw_value , $args , $multi_view ) {
$name = isset ( $args [ 'name' ] ) ? $args [ 'name' ] : '' ;
$mode = isset ( $args [ 'mode' ] ) ? $args [ 'mode' ] : '' ;
$context = isset ( $args [ 'context' ] ) ? $args [ 'context' ] : '' ;
if ( 'heading' === $name ) {
$raw_value = $this -> _esc_attr ( $multi_view -> get_name_by_mode ( $name , $mode ), 'full' );
} elseif ( 'button_text' === $name && 'content' === $context ) {
$raw_value = $this -> _esc_attr ( $multi_view -> get_name_by_mode ( $name , $mode ), 'limited' );
} elseif ( 'image' === $name && 'classes' === $context ) {
$raw_value = $raw_value ? $raw_value : $multi_view -> get_inherit_value ( 'video_url' , $mode );
} elseif ( 'video_url' === $name ) {
$raw_value = self :: get_video_embed (
array (
'video_url' => esc_url ( $raw_value ),
)
);
}
return $raw_value ;
}
}
if ( et_builder_should_load_all_module_data () ) {
new ET_Builder_Module_Slider_Item ();
}