', 'template_id' => 'element_template_selection_tab', 'args' => array( 'sc' => $this ) ), array( 'type' => 'tab_container_close', 'nodescription' => true ), array( 'id' => 'av_element_hidden_in_editor', 'type' => 'hidden', 'std' => '0' ), ); } /** * Create and register templates for easier maintainance * * @since 4.6.4 */ protected function register_dynamic_templates() { global $avia_config; /** * Layout Tab * =========== */ $c = array( array( 'name' => __( 'Section Minimum Height','avia_framework' ), 'id' => 'min_height', 'desc' => __( 'Define a minimum height for the section. Content within the section will be centered vertically within the section', 'avia_framework' ), 'type' => 'select', 'std' => '', 'lockable' => true, 'subtype' => array( __( 'No minimum height, use content within section to define Section height', 'avia_framework' ) => '', __( 'At least 100% of Browser Window height', 'avia_framework' ) => '100', __( 'At least 75% of Browser Window height', 'avia_framework' ) => '75', __( 'At least 50% of Browser Window height', 'avia_framework' ) => '50', __( 'At least 25% of Browser Window height', 'avia_framework' ) => '25', __( 'Custom height in % based on browser windows height', 'avia_framework' ) => 'percent', __( 'Custom height in pixel', 'avia_framework' ) => 'custom', ) ), array( 'name' => __( 'Section minimum custom height in %', 'avia_framework' ), 'desc' => __( 'Define a minimum height for the section in % based on the browser windows height', 'avia_framework' ), 'id' => 'min_height_pc', 'type' => 'select', 'std' => '25', 'lockable' => true, 'required' => array( 'min_height', 'equals', 'percent' ), 'subtype' => AviaHtmlHelper::number_array( 1, 99, 1 ) ), array( 'name' => __( 'Section custom height', 'avia_framework' ), 'desc' => __( 'Define a minimum height for the section. Use a pixel value. eg: 500px', 'avia_framework' ) , 'id' => 'min_height_px', 'type' => 'input', 'std' => '500px', 'lockable' => true, 'required' => array( 'min_height', 'equals', 'custom' ), ) ); $template = array( array( 'type' => 'template', 'template_id' => 'toggle', 'title' => __( 'Section Height', 'avia_framework' ), 'content' => $c ), ); AviaPopupTemplates()->register_dynamic_template( $this->popup_key( 'layout_section_height' ), $template ); $c = array( array( 'name' => __( 'Section Padding', 'avia_framework' ), 'id' => 'padding', 'desc' => __( 'Define the sections top and bottom padding', 'avia_framework' ), 'type' => 'select', 'std' => 'default', 'lockable' => true, 'subtype' => array( __( 'No Padding', 'avia_framework' ) => 'no-padding', __( 'Small Padding', 'avia_framework' ) => 'small', __( 'Default Padding', 'avia_framework' ) => 'default', __( 'Large Padding', 'avia_framework' ) => 'large', __( 'Huge Padding', 'avia_framework' ) => 'huge', ) ), array( 'name' => __( 'Custom top and bottom margin', 'avia_framework' ), 'desc' => __( 'If checked allows you to set a custom top and bottom margin. Otherwise the margin is calculated by the theme based on surrounding elements', 'avia_framework' ), 'id' => 'margin', 'type' => 'checkbox', 'std' => '', 'lockable' => true, ), array( 'name' => __( 'Custom top and bottom margin', 'avia_framework' ), 'desc' => __( 'Set a custom top or bottom margin. Both pixel and % based values are accepted. eg: 30px, 5%', 'avia_framework' ), 'id' => 'custom_margin', 'type' => 'multi_input', 'sync' => true, 'std' => '0px', 'lockable' => true, 'required' => array( 'margin', 'not','' ), 'multi' => array( 'top' => __( 'Margin-Top', 'avia_framework' ), 'bottom' => __( 'Margin-Bottom', 'avia_framework' ), ) ) ); $template = array( array( 'type' => 'template', 'template_id' => 'toggle', 'title' => __( 'Margin and Padding', 'avia_framework' ), 'content' => $c ), ); AviaPopupTemplates()->register_dynamic_template( $this->popup_key( 'layout_margin_padding' ), $template ); $template = array( array( 'type' => 'template', 'template_id' => 'svg_divider_toggle', 'lockable' => true ), ); AviaPopupTemplates()->register_dynamic_template( $this->popup_key( 'layout_svg_dividers' ), $template ); /** * Styling Tab * =========== */ $c = array( array( 'name' => __( 'Section Colors', 'avia_framework' ), 'desc' => __( 'The section will use the color scheme you select. Color schemes are defined on your styling page', 'avia_framework' ) . '
' . __( '(Show Styling Page)', 'avia_framework' ) . '', 'id' => 'color', 'type' => 'select', 'std' => 'main_color', 'lockable' => true, 'subtype' => array_flip( $avia_config['color_sets'] ) ), array( 'name' => __( 'Background', 'avia_framework' ), 'desc' => __( 'Select the type of background for the column.', 'avia_framework' ), 'id' => 'background', 'type' => 'select', 'std' => 'bg_color', 'lockable' => true, 'subtype' => array( __( 'Background Color', 'avia_framework' ) => 'bg_color', __( 'Background Gradient', 'avia_framework' ) => 'bg_gradient', ) ), array( 'name' => __( 'Custom Background Color', 'avia_framework' ), 'desc' => __( 'Select a custom background color for this cell here. Leave empty for default color', 'avia_framework' ), 'id' => 'custom_bg', 'type' => 'colorpicker', 'rgba' => true, 'std' => '', 'lockable' => true, 'required' => array( 'background', 'equals', 'bg_color' ) ), array( 'type' => 'template', 'template_id' => 'gradient_colors', 'id' => array( 'background_gradient_direction', 'background_gradient_color1', 'background_gradient_color2', 'background_gradient_color3' ), 'lockable' => true, 'required' => array( 'background', 'equals', 'bg_gradient' ), 'container_class' => array( '', 'av_third av_third_first', 'av_third', 'av_third' ), ) ); $template = array( array( 'type' => 'template', 'template_id' => 'toggle', 'title' => __( 'Background Colors', 'avia_framework' ), 'content' => $c ), ); AviaPopupTemplates()->register_dynamic_template( $this->popup_key( 'styling_background_colors' ), $template ); $c = array( array( 'name' => __( 'Custom Background Image', 'avia_framework' ), 'desc' => __( 'Either upload a new, or choose an existing image from your media library. Leave empty if you want to use the background image of the color scheme defined above', 'avia_framework' ), 'id' => 'src', 'type' => 'image', 'title' => __( 'Insert Image', 'avia_framework' ), 'button' => __( 'Insert', 'avia_framework' ), 'std' => '', 'lockable' => true, 'locked' => array( 'src', 'attachment', 'attachment_size' ) ), array( 'name' => __( 'Background Attachment', 'avia_framework' ), 'desc' => __( 'Background can either scroll with the page, be fixed or scroll with a parallax motion', 'avia_framework' ), 'id' => 'attach', 'type' => 'select', 'std' => 'scroll', 'lockable' => true, 'required' => array( 'src', 'not', '' ), 'subtype' => array( __( 'Scroll', 'avia_framework' ) => 'scroll', __( 'Fixed', 'avia_framework' ) => 'fixed', __( 'Parallax', 'avia_framework' ) => 'parallax' ) ), array( 'type' => 'template', 'template_id' => 'background_image_position', 'args' => array( 'id_pos' => 'position', 'id_repeat' => 'repeat' ), 'lockable' => true ) ); $template = array( array( 'type' => 'template', 'template_id' => 'toggle', 'title' => __( 'Background Image', 'avia_framework' ), 'content' => $c ), ); AviaPopupTemplates()->register_dynamic_template( $this->popup_key( 'styling_background_image' ), $template ); $c = array( array( 'name' => __( 'Background Video', 'avia_framework' ), 'desc' => __( 'You can also place a video as background for your section. Enter the URL to the Video. Currently supported are Youtube, Vimeo and direct linking of web-video files (mp4, webm, ogv)', 'avia_framework' ) . '

' . __( 'Working examples Youtube & Vimeo:', 'avia_framework' ) . '
http://vimeo.com/1084537
http://www.youtube.com/watch?v=5guMumPFBag

', 'id' => 'video', 'type' => 'input', 'std' => '', 'lockable' => true ), array( 'name' => __( 'Video Aspect Ratio', 'avia_framework' ), 'desc' => __( 'In order to calculate the correct height and width for the video slide you need to enter a aspect ratio (width:height). usually: 16:9 or 4:3.', 'avia_framework' ) . '
' . __( 'If left empty 16:9 will be used', 'avia_framework' ) , 'id' => 'video_ratio', 'type' => 'input', 'std' => '16:9', 'lockable' => true, 'required' => array( 'video', 'not', '' ), ), array( 'name' => __( 'Hide video on Mobile Devices?', 'avia_framework' ), 'desc' => __( 'You can choose to hide the video entirely on Mobile devices and instead display the Section Background image', 'avia_framework' ) . '
' . __( "Most mobile devices can't autoplay videos to prevent bandwidth problems for the user", 'avia_framework' ) . '' , 'id' => 'video_mobile_disabled', 'type' => 'checkbox', 'std' => '', 'lockable' => true, 'required' => array( 'video', 'not', '' ), ) ); $template = array( array( 'type' => 'template', 'template_id' => 'toggle', 'title' => __( 'Background Video', 'avia_framework' ), 'content' => $c ), ); AviaPopupTemplates()->register_dynamic_template( $this->popup_key( 'styling_background_video' ), $template ); $c = array( array( 'name' => __( 'Enable Overlay?', 'avia_framework' ), 'desc' => __( 'Check if you want to display a transparent color and/or pattern overlay above your section background image/video', 'avia_framework' ), 'id' => 'overlay_enable', 'type' => 'checkbox', 'std' => '', 'lockable' => true, ), array( 'name' => __( 'Overlay Opacity', 'avia_framework' ), 'desc' => __( 'Set the opacity of your overlay: 0.1 is barely visible, 1.0 is opaque ', 'avia_framework' ), 'id' => 'overlay_opacity', 'type' => 'select', 'std' => '0.5', 'lockable' => true, 'required' => array( 'overlay_enable', 'not', '' ), 'subtype' => array( __( '0.1', 'avia_framework' ) => '0.1', __( '0.2', 'avia_framework' ) => '0.2', __( '0.3', 'avia_framework' ) => '0.3', __( '0.4', 'avia_framework' ) => '0.4', __( '0.5', 'avia_framework' ) => '0.5', __( '0.6', 'avia_framework' ) => '0.6', __( '0.7', 'avia_framework' ) => '0.7', __( '0.8', 'avia_framework' ) => '0.8', __( '0.9', 'avia_framework' ) => '0.9', __( '1.0', 'avia_framework' ) => '1', ) ), array( 'name' => __( 'Overlay Color', 'avia_framework' ), 'desc' => __( 'Select a custom color for your overlay here. Leave empty if you want no color overlay', 'avia_framework' ), 'id' => 'overlay_color', 'type' => 'colorpicker', 'std' => '', 'lockable' => true, 'required' => array( 'overlay_enable', 'not', '' ) ), array( 'name' => __( 'Background Image', 'avia_framework' ), 'desc' => __( 'Select an existing or upload a new background image', 'avia_framework' ), 'id' => 'overlay_pattern', 'type' => 'select', 'std' => '', 'folder' => 'images/background-images/', 'folderlabel' => '', 'group' => __( 'Select predefined pattern', 'avia_framework' ), 'exclude' => array( 'fullsize-', 'gradient' ), 'lockable' => true, 'required' => array( 'overlay_enable', 'not', '' ), 'subtype' => array( __( 'No Background Image', 'avia_framework' ) => '', __( 'Upload custom image', 'avia_framework' ) => 'custom' ) ), array( 'name' => __( 'Custom Pattern', 'avia_framework' ), 'desc' => __( 'Upload your own seamless pattern', 'avia_framework' ), 'id' => 'overlay_custom_pattern', 'type' => 'image', 'fetch' => 'url', 'secondary_img' => true, 'title' => __( 'Insert Pattern', 'avia_framework' ), 'button' => __( 'Insert', 'avia_framework' ), 'std' => '', 'lockable' => true, 'required' => array( 'overlay_pattern', 'equals', 'custom' ) ), ); $template = array( array( 'type' => 'template', 'template_id' => 'toggle', 'title' => __( 'Background Overlay', 'avia_framework' ), 'content' => $c ), ); AviaPopupTemplates()->register_dynamic_template( $this->popup_key( 'styling_background_overlay' ), $template ); $c = array( array( 'name' => __( 'Section Top Border Styling', 'avia_framework' ), 'desc' => __( 'Choose a border styling for the top of your section', 'avia_framework' ), 'id' => 'shadow', 'type' => 'select', 'std' => 'no-border-styling', 'lockable' => true, 'subtype' => array( __( 'Display a simple 1px top border', 'avia_framework' ) => 'no-shadow', __( 'Display a small styling shadow at the top of the section', 'avia_framework' ) => 'shadow', __( 'No border styling', 'avia_framework' ) => 'no-border-styling', ) ), array( 'name' => __( 'Section Bottom Border Styling', 'avia_framework' ), 'desc' => __( 'Choose a border styling for the bottom of your section', 'avia_framework' ), 'id' => 'bottom_border', 'type' => 'select', 'std' => 'no-border-styling', 'lockable' => true, 'subtype' => array( __( 'No border styling', 'avia_framework' ) => 'no-border-styling', __( 'Display a small arrow that points down to the next section', 'avia_framework' ) => 'border-extra-arrow-down', __( 'Diagonal section border', 'avia_framework' ) => 'border-extra-diagonal', ) ), array( 'name' => __( 'Diagonal Border: Color', 'avia_framework' ), 'desc' => __( 'Select a custom background color for your Section border here.', 'avia_framework' ), 'id' => 'bottom_border_diagonal_color', 'type' => 'colorpicker', 'std' => '#333333', 'container_class' => 'av_third av_third_first', 'lockable' => true, 'required' => array( 'bottom_border', 'contains', 'diagonal' ) ), array( 'name' => __( 'Diagonal Border: Direction','avia_framework' ), 'desc' => __( 'Set the direction of the diagonal border', 'avia_framework' ), 'id' => 'bottom_border_diagonal_direction', 'type' => 'select', 'std' => '', 'container_class' => 'av_third', 'lockable' => true, 'required' => array( 'bottom_border', 'contains', 'diagonal' ), 'subtype' => array( __( 'Slanting from left to right', 'avia_framework' ) => '', __( 'Slanting from right to left', 'avia_framework' ) => 'border-extra-diagonal-inverse' ) ), array( 'name' => __( 'Diagonal Border Box Style', 'avia_framework' ), 'desc' => __( 'Set the style shadow of the border', 'avia_framework' ), 'id' => 'bottom_border_style', 'type' => 'select', 'std' => '', 'container_class' => 'av_third', 'lockable' => true, 'required' => array( 'bottom_border', 'contains', 'diagonal' ), 'subtype' => array( __( 'Minimal', 'avia_framework' ) => '', __( 'Box shadow', 'avia_framework' ) => 'diagonal-box-shadow' ) ) ); $template = array( array( 'type' => 'template', 'template_id' => 'toggle', 'title' => __( 'Borders', 'avia_framework' ), 'content' => $c ), ); AviaPopupTemplates()->register_dynamic_template( $this->popup_key( 'styling_borders' ), $template ); $c = array( array( 'name' => __( 'Display a scroll down arrow', 'avia_framework' ), 'desc' => __( 'Check if you want to show a button at the bottom of the section that takes the user to the next section by scrolling down', 'avia_framework' ) , 'id' => 'scroll_down', 'type' => 'checkbox', 'std' => '', 'lockable' => true ), array( 'name' => __( 'Custom Arrow Color', 'avia_framework' ), 'desc' => __( 'Select a custom arrow color. Leave empty if you want to use the default arrow color and style', 'avia_framework' ), 'id' => 'custom_arrow_bg', 'type' => 'colorpicker', 'std' => '', 'lockable' => true, 'required' => array( 'scroll_down', 'not', '' ), ) ); $template = array( array( 'type' => 'template', 'template_id' => 'toggle', 'title' => __( 'Scroll Down Arrow', 'avia_framework' ), 'content' => $c ), ); AviaPopupTemplates()->register_dynamic_template( $this->popup_key( 'styling_arrow' ), $template ); } /** * Editor Element - this function defines the visual appearance of an element on the AviaBuilder Canvas * Most common usage is to define some markup in the $params['innerHtml'] which is then inserted into the drag and drop container * Less often used: $params['data'] to add data attributes, $params['class'] to modify the className * * * @param array $params this array holds the default values for $content and $args. * @return $params the return array usually holds an innerHtml key that holds item specific markup. */ function editor_element( $params ) { $default = array(); $locked = array(); $attr = $params['args']; $content = $params['content']; Avia_Element_Templates()->set_locked_attributes( $attr, $this, $this->config['shortcode'], $default, $locked, $content ); $args = $attr; // => extract( $params ); $data = isset( $params['data'] ) && is_array( $params['data'] ) ? $params['data'] : array(); $data_locked = array(); $extraClass = isset( $args['element_template'] ) && $args['element_template'] > 0 ? ' element_template_selected' : ' no_element_template'; $name = $this->config['shortcode']; $data['shortcodehandler'] = $this->config['shortcode']; $data['modal_title'] = $this->config['name']; $data['modal_ajax_hook'] = $this->config['shortcode']; $data['dragdrop-level'] = $this->config['drag-level']; $data['allowed-shortcodes'] = $this->config['shortcode']; $data['base_shortcode'] = $this->config['shortcode']; $data['element_title'] = $this->config['name']; $data['element_tooltip'] = $this->config['tooltip']; $data['preview'] = ! empty( $this->config['preview'] ) ? $this->config['preview'] : 0; $title_id = ! empty( $args['id'] ) ? ': ' . ucfirst( $args['id'] ) : ''; foreach( $locked as $key => $value ) { $data_locked[ 'locked_' . $key ] = $value; } // add background color or gradient to indicator $el_bg = ''; if( empty( $args['background'] ) || ( $args['background'] == 'bg_color' ) ) { $el_bg = ! empty( $args['custom_bg'] ) ? " background:{$args['custom_bg']};" : ''; } else { if( $args['background_gradient_color1'] && $args['background_gradient_color2'] ) { $el_bg = "background:linear-gradient({$args['background_gradient_color1']},{$args['background_gradient_color2']});"; } } $hidden_el_active = ! empty( $args['av_element_hidden_in_editor'] ) ? 'av-layout-element-closed' : ''; if( ! empty( $this->config['modal_on_load'] ) ) { $data['modal_on_load'] = $this->config['modal_on_load']; } $data_locked['initial_el_bg'] = $el_bg; $data_locked['initial_layout_element_bg'] = $this->get_bg_string( $args ); $dataString = AviaHelper::create_data_string( $data ); $dataStringLocked = AviaHelper::create_data_string( $data_locked ); $output = "
"; $output .= '
'; $output .= "'; $output .= "
"; $output .= "'; if( $content ) { $content = $this->builder->do_shortcode_backend( $content ); } $output .= $content; $output .= '
'; $output .= "
"; $output .= "" . __( 'Section content hidden. Click here to show it', 'avia_framework' ) . ''; $output .= '
'; return $output; } /** * Create custom stylings * * @since 4.8.4 * @param array $args * @return array */ protected function get_element_styles( array $args ) { global $avia_config; $result = parent::get_element_styles( $args ); extract( $result ); $default = array( 'src' => '', 'position' => 'top left', 'repeat' => 'no-repeat', 'attach' => 'scroll', 'color' => 'main_color', 'background' => 'bg_color', 'custom_bg' => '', 'background_gradient_color1' => '', 'background_gradient_color2' => '', 'background_gradient_direction' => '', 'padding' => 'default' , 'margin' => '', 'custom_margin' => '', 'shadow' => 'shadow', 'id' => '', 'min_height' => '', 'min_height_pc' => 25, 'min_height_px' => '', 'video' => '', 'video_ratio' =>' 16:9', 'video_mobile_disabled' =>'', 'custom_markup' => '', 'attachment' => '', 'attachment_size' => '', 'bottom_border' => '', 'overlay_enable' => '', 'overlay_opacity' => '', 'overlay_color' => '', 'overlay_pattern' => '', 'overlay_custom_pattern' => '', 'scroll_down' => '', 'bottom_border_diagonal_color' => '', 'bottom_border_diagonal_direction' => '', 'bottom_border_style' => '', 'custom_arrow_bg' => '' ); $default = $this->sync_sc_defaults_array( $default, 'no_modal_item', 'no_content' ); // we skip $content override as we only allow styling of section to be locked $locked = array(); Avia_Element_Templates()->set_locked_attributes( $atts, $this, $shortcodename, $default, $locked ); Avia_Element_Templates()->add_template_class( $meta, $atts, $default ); $atts = shortcode_atts( $default, $atts, $this->config['shortcode'] ); if( 'percent' == $atts['min_height'] ) { $atts['min_height'] = $atts['min_height_pc']; } $element_styling->create_callback_styles( $atts ); $classes = array( 'avia-section', $element_id, $atts['color'], 'avia-section-' . $atts['padding'], 'avia-' . $atts['shadow'] ); $element_styling->add_classes( 'section-outer', $classes ); $element_styling->add_classes_from_array( 'section-outer', $meta, 'el_class' ); // Style background if( empty( $atts['attachment'] ) ) { // manual added shortcodes may contain an url only $atts['src'] = trim( $atts['src'] ); } else if( ! empty( $atts['attachment'] ) && ! empty( $atts['attachment_size'] ) ) { $atts['src'] = ''; /** * Allows e.g. WPML to reroute to translated image */ $posts = get_posts( array( 'include' => $atts['attachment'], 'post_status' => 'inherit', 'post_type' => 'attachment', 'post_mime_type' => 'image', 'order' => 'ASC', 'orderby' => 'post__in' ) ); if( is_array( $posts ) && ! empty( $posts ) ) { $attachment_entry = $posts[0]; $src = wp_get_attachment_image_src( $attachment_entry->ID, $atts['attachment_size'] ); $atts['src'] = ! empty( $src[0] ) ? $src[0] : ''; } else { $atts['attachment'] = false; } } else { $atts['src'] = ''; $atts['attachment'] = false; } $selector_background = 'section-outer'; if( ! empty( $atts['src'] ) && 'parallax' == $atts['attach'] ) { $selector_background = 'section-parallax-inner'; } // background gradient $gradient_val = ''; $attach_class_outer = $atts['attach']; if( $atts['background'] == 'bg_gradient' ) { $fallback_color = ''; if( ! empty( $atts['background_gradient_color1'] ) && ! empty( $atts['background_gradient_color2'] ) ) { $gradient_val_array = $element_styling->get_callback_settings( 'background_gradient_direction', 'styles' ); $gradient_val = isset( $gradient_val_array['background'] ) ? $gradient_val_array['background'] : ''; $fallback_color = $atts['background_gradient_color1']; } else { // Fallback background color for IE9 if( ! empty( $atts['background_gradient_color1'] ) ) { $fallback_color = $atts['background_gradient_color1']; } else if( ! empty( $atts['custom_bg'] ) ) { $fallback_color = $atts['custom_bg']; } } if( ! empty( $fallback_color ) ) { $element_styling->add_styles( $selector_background, array( 'background-color' => $fallback_color ) ); } } else if( ! empty( $atts['custom_bg'] ) ) { $element_styling->add_styles( $selector_background, array( 'background-color' => $atts['custom_bg'] ) ); } /*set background image*/ if( $atts['src'] != '' ) { if( $atts['repeat'] == 'stretch' ) { $element_styling->add_styles( $selector_background, array( 'background-repeat' => 'no-repeat' ) ); $element_styling->add_classes( 'section-outer', 'avia-full-stretch' ); } else if( $atts['repeat'] == 'contain' ) { $element_styling->add_styles( $selector_background, array( 'background-repeat' => 'no-repeat' ) ); $element_styling->add_classes( 'section-outer', 'avia-full-contain' ); } else { $element_styling->add_styles( $selector_background, array( 'background-repeat' => $atts['repeat'] ) ); } // ',' is needed !!! $bg_img_grad = $gradient_val != '' ? "url({$atts['src']}), {$gradient_val}" : "url({$atts['src']})"; $styles = array( 'background-image' => $bg_img_grad, 'background-position' => $element_styling->background_position_string( $atts['position'] ), 'background-attachment' => $atts['attach'] == 'parallax' ? 'scroll' : $atts['attach'] ); $element_styling->add_styles( $selector_background, $styles ); if( $atts['attach'] == 'parallax' ) { $element_styling->add_classes( 'section-outer', 'av-parallax-section' ); if( $atts['repeat'] == 'stretch' || $atts['repeat'] == 'no-repeat' ) { $element_styling->add_classes( 'section-parallax-inner', 'avia-full-stretch' ); } if( $atts['repeat'] == 'contain' ) { $element_styling->add_classes( 'section-parallax-inner', 'avia-full-contain' ); } } } else if( ! empty( $gradient_val ) ) { $attach_class_outer = 'scroll'; $element_styling->add_styles( $selector_background, array( 'background' => $gradient_val ) ); } $element_styling->add_classes( 'section-outer', 'avia-bg-style-' . $attach_class_outer ); /* custom margin */ if( ! empty( $atts['margin'] ) ) { $explode_custom_margin = explode( ',', $atts['custom_margin'] ); if( count( $explode_custom_margin ) > 1 ) { $top = $explode_custom_margin['0']; $bottom = $explode_custom_margin['1']; } else { $top = $explode_custom_margin['0']; $bottom = $explode_custom_margin['0']; } $styles = array( 'margin-top' => $top, 'margin-bottom' => $bottom ); $element_styling->add_styles( 'section-outer', $styles ); } // Create Styles for overlay if( ! empty( $atts['overlay_enable'] ) ) { $element_styling->add_styles( 'overlay', array( 'opacity' => $atts['overlay_opacity'] ) ); if( ! empty( $atts['overlay_color'] ) ) { $element_styling->add_styles( 'overlay', array( 'background-color' => $atts['overlay_color'] ) ); // $overlay .= "background-color: {$overlay_color}; "; } $overlay_src = ''; if( ! empty( $atts['overlay_pattern'] ) ) { if( $atts['overlay_pattern'] == 'custom' ) { $overlay_src = $atts['overlay_custom_pattern']; } else { $overlay_src = str_replace( '{{AVIA_BASE_URL}}', AVIA_BASE_URL, $atts['overlay_pattern'] ); } } if( ! empty( $overlay_src ) ) { $element_styling->add_styles( 'overlay', array( 'background-image' => "url({$overlay_src})" , 'background-repeat' => 'repeat' ) ); } $element_styling->add_classes( 'section-outer', 'av-section-color-overlay-active' ); } // Scroll Down Arrow if( ! empty( $atts['scroll_down'] ) ) { if( ! empty( $atts['custom_arrow_bg'] ) ) { $element_styling->add_styles( 'scroll-down', array( 'color' => $atts['custom_arrow_bg'] ) ); $element_styling->add_classes( 'scroll-down', 'av-custom-scroll-down-color' ); } } // Extra border element: Diagonal or small arrow if( strpos( $atts['bottom_border'], 'border-extra' ) !== false ) { $backgroundElColor = ! empty( $atts['custom_bg'] ) ? $atts['custom_bg'] : $avia_config['backend_colors']['color_set'][ $atts['color'] ]['bg']; if( strpos( $atts['bottom_border'], 'diagonal' ) !== false ) { $backgroundElColor = '#333333'; if( isset( $atts['bottom_border_diagonal_color'] ) ) { $backgroundElColor = $atts['bottom_border_diagonal_color']; } } if( ! empty( $backgroundElColor ) ) { $element_styling->add_styles( 'extra-border-inner', array( 'background-color' => $backgroundElColor ) ); } } // SVG Dividers $element_styling->add_classes( 'divider-top', array( 'avia-divider-svg', 'avia-divider-svg-' . $atts['svg_div_top'] ) ); $element_styling->add_classes( 'divider-bottom', array( 'avia-divider-svg', 'avia-divider-svg-' . $atts['svg_div_bottom'] ) ); $element_styling->add_callback_styles( 'divider-top-svg', array( 'svg_div_top_svg', 'svg_div_top_color' ) ); $element_styling->add_callback_styles( 'divider-bottom-svg', array( 'svg_div_bottom_svg', 'svg_div_bottom_color' ) ); $element_styling->add_callback_classes( 'divider-top', array( 'svg_div_top' ) ); $element_styling->add_callback_classes( 'divider-bottom', array( 'svg_div_bottom' ) ); if( ! empty( $atts['svg_div_top'] ) || ! empty( $atts['svg_div_bottom'] ) ) { // This is a fix that svg shapes can be placed top or bottom. By default avia-section is position: static; $element_styling->add_styles( 'section-outer', array( 'position' => 'relative' ) ); } $selectors = array( 'section-outer' => ".avia-section.{$element_id}", 'section-container' => ".avia-section.{$element_id} .container.av-section-cont-open", 'section-parallax-inner' => ".avia-section.{$element_id} .av-parallax .av-parallax-inner", 'overlay' => ".avia-section.{$element_id} .av-section-color-overlay", 'scroll-down' => "#top .avia-section.{$element_id} .scroll-down-link", 'extra-border-inner' => ".avia-section.{$element_id} .av-extra-border-element .av-extra-border-inner", 'divider-top-div' => ".avia-section.{$element_id} .avia-divider-svg-top", 'divider-bottom-div' => ".avia-section.{$element_id} .avia-divider-svg-bottom", 'divider-top-svg' => ".avia-section.{$element_id} .avia-divider-svg-top svg", 'divider-bottom-svg' => ".avia-section.{$element_id} .avia-divider-svg-bottom svg" ); $element_styling->add_selectors( $selectors ); $result['default'] = $default; $result['atts'] = $atts; $result['content'] = $content; $result['element_styling'] = $element_styling; return $result; } /** * Returns the modal popups svg divider preview windows in $svg_list * * @since 4.8.4 * @param array $args * @param array $svg_list * @return array */ public function build_svg_divider_preview( array $args, array $svg_list ) { // clear content and not needed settings - we only need minimal stylings $args['content'] = ''; unset( $args['atts']['content'] ); // $args['atts']['padding'] = ''; $args['atts']['custom_margin'] = ''; $result = $this->get_element_styles( $args ); extract( $result ); $dummy_text = __( 'Dummy Content to demonstrate "Bring To Front" option', 'avia_framework' ); foreach( $svg_list as $id => $info ) { $svg_height = $atts[ $id . '_height' ]; $svg_max_height = $atts[ $id . '_max_height' ]; if( ! is_numeric( $svg_height ) ) { $svg_height = is_numeric( $svg_max_height ) ? $svg_max_height : 100; } $dummy_dist = $svg_height > 30 ? 20 : 5; $dummy_height = $svg_height + 20; $style_col = array( 'height' => max( $svg_height + 120, 150 ) . 'px' ); $style_dummy = array( 'height' => $dummy_height . 'px', 'line-height' => $dummy_height . 'px' ); if( 'top' == $info['location'] ) { $class = 'av-top-divider'; $element_styling->add_styles( 'preview-column-top', $style_col ); $element_styling->add_styles( 'preview-dummy-top', array( 'top' => $dummy_dist . 'px' ) ); $element_styling->add_styles( 'preview-dummy-top', $style_dummy ); } else { $class = 'av-bottom-divider'; $element_styling->add_styles( 'preview-column-bottom', $style_col ); $element_styling->add_styles( 'preview-dummy-bottom', array( 'bottom' => $dummy_dist . 'px' ) ); $element_styling->add_styles( 'preview-dummy-bottom', $style_dummy ); } $selectors = array( 'preview-column-top' => ".avia-section.{$element_id}.av-top-divider", 'preview-column-bottom' => ".avia-section.{$element_id}.av-bottom-divider", 'preview-dummy-top' => ".avia-section.{$element_id}.av-top-divider .av-dummy-text", 'preview-dummy-bottom' => ".avia-section.{$element_id}.av-bottom-divider .av-dummy-text" ); $element_styling->add_selectors( $selectors ); $style_tag = $element_styling->get_style_tag( $element_id ); $html = ''; $html .= $style_tag; $html .= "
"; if( ! empty( $atts[ $id ] ) ) { $html .= AviaSvgShapes()->get_svg_dividers( $atts, $element_styling, $info['location'] ); } $html .= '
'; $html .= '

' . esc_html( $dummy_text ) . '

'; $html .= '
'; $html .= '
'; $svg_list[ $id ]['html'] = $html; } return $svg_list; } /** * Frontend Shortcode Handler * * @param array $atts array of attributes * @param string $content text within enclosing form of shortcode element * @param string $shortcodename the shortcode found, when == callback name * @return string $output returns the modified html string */ function shortcode_handler( $atts, $content = '', $shortcodename = '', $meta = '' ) { global $avia_config; $result = $this->get_element_styles( compact( array( 'atts', 'content', 'shortcodename', 'meta' ) ) ); extract( $result ); extract( AviaHelper::av_mobile_sizes( $atts ) ); //return $av_font_classes, $av_title_font_classes and $av_display_classes extract( $atts ); avia_sc_section::$section_count ++; $params = array(); $params['id'] = AviaHelper::save_string( $id, '-', 'av_section_' . avia_sc_section::$section_count ); $params['custom_markup'] = $meta['custom_markup']; $params['aria_label'] = $meta['aria_label']; $params['attach'] = ''; /*set background image*/ if( $src != '' ) { if( $attach == 'parallax' ) { $attachment_class = $element_styling->get_class_string( 'section-parallax-inner' ); $speed = apply_filters( 'avf_parallax_speed', '0.3', $params['id'] ); $params['attach'] .= "
"; $params['attach'] .= "
"; $params['attach'] .= '
'; $params['attach'] .= '
'; } $params['data'] = "data-section-bg-repeat='{$repeat}'"; } $pre_wrap = "
" ; /*check/create overlay*/ $overlay = ''; if( ! empty( $overlay_enable ) ) { $overlay = '
'; $params['attach'] .= $pre_wrap . $overlay; } if( ! empty( $scroll_down ) ) { $arrow_class = $element_styling->get_class_string( 'scroll-down' ); if( empty( $overlay ) ) { $params['attach'] .= $pre_wrap; } $params['attach'] .= "'; } $params['class'] = $element_styling->get_class_string( 'section-outer' ) . ' ' . $av_display_classes; $params['min_height'] = $min_height; $params['min_height_px'] = $min_height_px; $params['video'] = $video; $params['video_ratio'] = $video_ratio; $params['video_mobile_disabled'] = $video_mobile_disabled; if( isset( $meta['index'] ) && $meta['index'] >= 0 ) { if( $meta['index'] == 0 ) { $params['main_container'] = true; } if( $meta['index'] == 0 || ( isset( $meta['siblings']['prev']['tag'] ) && in_array( $meta['siblings']['prev']['tag'], AviaBuilder::$full_el_no_section ) ) ) { $params['close'] = false; } } if( $bottom_border == 'border-extra-arrow-down' ) { $params['class'] .= ' av-arrow-down-section'; } $params['container_style_tag'] = $element_styling->get_style_tag( $element_id ); $params['svg_dividers'] = AviaSvgShapes()->get_svg_dividers( $atts, $element_styling ); $avia_config['layout_container'] = 'section'; $output = ''; $output .= avia_new_section( $params ); $output .= ShortcodeHelper::avia_remove_autop( $content, true ) ; /*set extra arrow element*/ if( strpos( $bottom_border, 'border-extra' ) !== false ) { if( strpos( $bottom_border, 'diagonal') !== false ) { // bottom_border_diagonal_direction // bottom_border_diagonal_color $bottom_border .= ' ' . $bottom_border_diagonal_direction . ' ' . $bottom_border_style; } avia_sc_section::$add_to_closing = "
"; } else { avia_sc_section::$add_to_closing = ''; } //next section needs an extra closing tag if overlay with wrapper was added: if( $overlay || ! empty( $scroll_down ) ) { avia_sc_section::$close_overlay = '
'; } else { avia_sc_section::$close_overlay = ''; } //if the next tag is a section dont create a new section from this shortcode if( ! empty( $meta['siblings']['next']['tag'] ) && in_array( $meta['siblings']['next']['tag'], AviaBuilder::$full_el ) ) { $skipSecond = true; } //if there is no next element dont create a new section. if we got a sidebar always create a next section at the bottom if( empty( $meta['siblings']['next']['tag'] ) && ! avia_has_sidebar() ) { $skipSecond = true; } if( empty( $skipSecond ) ) { $new_params['id'] = 'after_section_' . avia_sc_section::$section_count; $output .= avia_new_section( $new_params ); } unset( $avia_config['layout_container'] ); return $output; } /** * Get background image for ALB editor canvas only * * @param array $args * @return string */ protected function get_bg_string( array $args ) { $style = ''; if( ! empty( $args['attachment'] ) || ! empty( $args['src'] ) ) { $image = false; if( empty( $args['attachment'] ) ) { // manually added image link $image = $args['src']; } else { $src = wp_get_attachment_image_src( $args['attachment'], $args['attachment_size'] ); if( ! empty( $src[0] ) ) { $image = $src[0]; } } if( $image ) { $element_styling = new aviaElementStyling( $this, 'xxx' ); // $bg = ! empty( $args['custom_bg'] ) ? $args['custom_bg'] : 'transparent'; $bg = 'transparent'; $pos = $element_styling->background_position_string( $args['position'], 'center center' ); $repeat = ! empty( $args['repeat'] ) ? $args['repeat'] : 'no-repeat'; $extra = ''; if( $repeat == 'stretch' ) { $repeat = 'no-repeat'; $extra = 'background-size: cover;'; } if( $repeat == 'contain' ) { $repeat = 'no-repeat'; $extra = 'background-size: contain;'; } $style = "background: {$bg} url({$image}) {$repeat} {$pos}; {$extra}"; } } return $style; } } } if( ! function_exists( 'avia_new_section' ) ) { function avia_new_section( $params = array() ) { global $avia_section_markup, $avia_config; $defaults = array( 'class' => 'main_color', 'bg' => '', 'custom_margin' => '', 'close' => true, 'open' => true, 'open_structure' => true, 'open_color_wrap' => true, 'data' => '', 'style' => '', 'id' => '', 'main_container' => false, 'min_height' => '', 'min_height_px' => '', 'video' => '', 'video_ratio' => '16:9', 'video_mobile_disabled' => '', 'attach' => '', 'before_new' => '', 'custom_markup' => '', 'aria_label' => '', // set to true to force id as label 'container_style_tag' => '', // added with 4.8.4 - styles from post CSS management 'svg_dividers' => '' // added with 4.8.4 ); $defaults = array_merge( $defaults, $params ); extract( $defaults ); $post_class = ''; $output = ''; $bg_slider = ''; $container_style = ''; $id_val = $id; $id = ! empty( $id_val ) ? "id='{$id_val}'" : ''; if( ! empty( $aria_label ) || ! empty( $id_val ) ) { if( true === $aria_label ) { $label = $id_val; } else if ( ! empty( $aria_label ) ) { $label = $aria_label; } else { $label = ''; } $aria_label = ! empty( $label ) ? "aria-label='{$label}'" : ''; } else { $aria_label = ''; } //close old content structure. only necessary when previous element was a section. other fullwidth elements dont need this if( $close ) { $cm = avia_section_close_markup(); $output .= "{$cm}" . avia_sc_section::$add_to_closing . avia_sc_section::$close_overlay . ''; avia_sc_section::$add_to_closing = ''; avia_sc_section::$close_overlay = ''; } //start new if( $open ) { if( function_exists( 'avia_get_the_id' ) ) { $post_class = 'post-entry-' . avia_get_the_id(); } if( $open_color_wrap ) { if( ! empty( $min_height ) ) { $class .= " av-minimum-height av-minimum-height-{$min_height} "; if( is_numeric( $min_height ) ) { $data .= " data-av_minimum_height_pc='{$min_height}'"; } if( $min_height == 'custom' && $min_height_px != '' ) { $min_height_px = (int) $min_height_px; $container_style = "style='height:{$min_height_px}px'"; } } if( ! empty( $video ) ) { $slide = array( 'shortcode' => 'av_slideshow', 'content' => '', 'attr' => array( 'id' => '', 'video' => $video , 'slide_type' => 'video', 'video_mute' => true, 'video_loop' => true, 'video_ratio' => $video_ratio, 'video_controls' => 'disabled', 'video_section_bg' => true, 'video_format' => '', 'video_mobile' => '', 'video_mobile_disabled' => $video_mobile_disabled ) ); $bg_slider = new avia_slideshow( array( 'content' => array( $slide ) ) ); $bg_slider->set_extra_class( 'av-section-video-bg' ); $class .= ' av-section-with-video-bg'; $class .= ! empty( $video_mobile_disabled ) ? ' av-section-mobile-video-disabled' : ''; $data .= " data-section-video-ratio='{$video_ratio}'"; } $output .= $before_new; /** * We cant just overwrite style since it might be passed by a function. eg the menu element passes z-index. need to merge the style strings * * @since 4.5.1 by Kriesi */ $extra_style = trim( "{$bg} {$custom_margin}" ); if( ! empty( $extra_style ) ) { $style = trim( $style ); if( empty( $style ) ) { $style = "style='{$extra_style}' "; } else { $style = str_replace( "style='", "style='{$extra_style} ", $style ); $style = str_replace( 'style="', 'style="' . $extra_style . ' ', $style ); } } if( $class == 'main_color' ) { $class .= ' av_default_container_wrap'; } $output .= $container_style_tag; $output .= "
"; $output .= $svg_dividers; $output .= ! empty( $bg_slider ) ? $bg_slider->html() : ''; $output .= $attach; $output .= apply_filters( 'avf_section_container_add', '', $defaults ); } //this applies only for sections. other fullwidth elements dont need the container for centering if( $open_structure ) { if( ! empty( $main_container ) ) { $markup = 'main ' . avia_markup_helper( array( 'context' => 'content', 'echo' => false, 'custom_markup' => $custom_markup ) ); $avia_section_markup = 'main'; } else { $markup = 'div'; } $output .= "
"; $output .= "<{$markup} class='template-page content " . avia_layout_class( 'content', false ) . " units'>"; $output .= "
"; $output .= "
"; } } return $output; } } if( ! function_exists( 'avia_section_close_markup' ) ) { function avia_section_close_markup() { global $avia_section_markup, $avia_config; if( ! empty( $avia_section_markup ) ) { $avia_section_markup = false; $close_markup = ''; } else { $close_markup = '
'; } return $close_markup; } } if( ! function_exists( 'avia_section_after_element_content' ) ) { function avia_section_after_element_content( $meta, $second_id = '', $skipSecond = false, $extra = '' ) { $output = '
'; //close section $output .= $extra; //if the next tag is a section dont create a new section from this shortcode if( ! empty( $meta['siblings']['next']['tag'] ) && in_array( $meta['siblings']['next']['tag'], AviaBuilder::$full_el ) ) { $skipSecond = true; } //if there is no next element dont create a new section. if( empty( $meta['siblings']['next']['tag'] ) ) { $skipSecond = true; } if( empty( $skipSecond ) ) { $output .= avia_new_section( array( 'close' => false, 'id' => $second_id ) ); } return $output; } }