Willkommen bei WordPress. Dies ist dein erster Beitrag. Bearbeite oder lösche ihn und beginne mit dem Schreiben!
Hallo Welt!
von raredesign | Dez 3, 2019 | Allgemein | 0 Kommentare
Cokiee Shell
Current Path : /var/www/web28/html/wp-content/plugins/fusion-builder/shortcodes/ |
Current File : //var/www/web28/html/wp-content/plugins/fusion-builder/shortcodes/fusion-content-boxes.php |
<?php /** * Add an element to fusion-builder. * * @package fusion-builder * @since 1.0 */ if ( fusion_is_element_enabled( 'fusion_content_boxes' ) ) { if ( ! class_exists( 'FusionSC_ContentBoxes' ) ) { /** * Shortcode class. * * @since 1.0 */ class FusionSC_ContentBoxes extends Fusion_Element { /** * Content box counter. * * @access private * @since 1.0 * @var int */ private $content_box_counter = 1; /** * Columns counter. * * @access private * @since 1.0 * @var int */ private $column_counter = 1; /** * Number of columns. * * @access private * @since 1.0 * @var int */ private $num_of_columns = 1; /** * Total number of columns. * * @access private * @since 1.0 * @var int */ private $total_num_of_columns = 1; /** * Rows counter. * * @access private * @since 1.0 * @var int */ private $row_counter = 1; /** * Parent SC arguments. * * @access protected * @since 1.0 * @var array */ protected $parent_args; /** * Child SC arguments. * * @access protected * @since 1.0 * @var array */ protected $child_args; /** * Constructor. * * @access public * @since 1.0 * @since 1.0 */ public function __construct() { parent::__construct(); add_filter( 'fusion_attr_content-box-shortcode', [ $this, 'child_attr' ] ); add_filter( 'fusion_attr_content-box-shortcode-content-wrapper', [ $this, 'content_wrapper_attr' ] ); add_filter( 'fusion_attr_content-box-shortcode-heading-wrapper', [ $this, 'heading_wrapper_attr' ] ); add_filter( 'fusion_attr_content-box-shortcode-content-container', [ $this, 'content_container_attr' ] ); add_filter( 'fusion_attr_content-box-shortcode-link', [ $this, 'link_attr' ] ); add_filter( 'fusion_attr_content-box-shortcode-icon-parent', [ $this, 'icon_parent_attr' ] ); add_filter( 'fusion_attr_content-box-shortcode-icon-wrapper', [ $this, 'icon_wrapper_attr' ] ); add_filter( 'fusion_attr_content-box-shortcode-icon', [ $this, 'icon_attr' ] ); add_filter( 'fusion_attr_content-box-shortcode-timeline', [ $this, 'timeline_attr' ] ); add_filter( 'fusion_attr_content-box-heading', [ $this, 'content_box_heading_attr' ] ); add_shortcode( 'fusion_content_box', [ $this, 'render_child' ] ); add_filter( 'fusion_attr_content-boxes-shortcode', [ $this, 'parent_attr' ] ); add_shortcode( 'fusion_content_boxes', [ $this, 'render_parent' ] ); add_action( 'wp_ajax_get_fusion_content_box_image_data', [ $this, 'ajax_query_single_child' ] ); add_action( 'wp_ajax_get_fusion_content_boxes_children_data', [ $this, 'query_children' ] ); } /** * Gets the query data. * * @static * @access public * @since 2.0.0 * @return void */ public function ajax_query_single_child() { check_ajax_referer( 'fusion_load_nonce', 'fusion_load_nonce' ); $this->query_single_child(); } /** * Gets the query data for single children. * * @access public * @since 2.0.0 */ public function query_single_child() { $return_data = []; if ( isset( $_POST['model'] ) ) { // phpcs:ignore WordPress.Security.NonceVerification if ( isset( $_POST['model']['params'] ) ) { // phpcs:ignore WordPress.Security.NonceVerification $defaults = $_POST['model']['params']; // phpcs:ignore WordPress.Security } if ( isset( $defaults['image_id'] ) ) { $image_index = '' !== $defaults['image_id'] ? $defaults['image_id'] : $defaults['image']; $return_data[ $image_index ] = fusion_library()->images->get_attachment_data_by_helper( $defaults['image_id'], $defaults['image'] ); } echo wp_json_encode( $return_data ); } wp_die(); } /** * Gets the query data for all children. * * @access public * @since 2.0.0 */ public function query_children() { check_ajax_referer( 'fusion_load_nonce', 'fusion_load_nonce' ); $return_data = []; // From Ajax Request. if ( isset( $_POST['children'] ) ) { $children = $_POST['children']; // phpcs:ignore WordPress.Security foreach ( $children as $cid => $params ) { if ( isset( $params['image_id'] ) ) { $image_index = isset( $params['image_id'] ) && '' !== $params['image_id'] ? $params['image_id'] : $params['image']; $return_data[ $image_index ] = fusion_library()->images->get_attachment_data_by_helper( $params['image_id'], $params['image'] ); } } echo wp_json_encode( $return_data ); } wp_die(); } /** * Gets the default values. * * @static * @access public * @since 2.0.0 * @param string $context Whether we want parent or child. * Returns array( parent, child ) if empty. * @return array */ public static function get_element_defaults( $context = '' ) { $fusion_settings = awb_get_fusion_settings(); $parent = [ 'hide_on_mobile' => fusion_builder_default_visibility( 'string' ), 'class' => '', 'id' => '', 'alignment' => '', 'backgroundcolor' => $fusion_settings->get( 'content_box_bg_color' ), 'border_radius_top_left' => '', 'border_radius_top_right' => '', 'border_radius_bottom_right' => '', 'border_radius_bottom_left' => '', 'columns' => '', 'circle' => '', 'heading_size' => '2', 'icon' => '', 'iconflip' => '', 'iconrotate' => '', 'iconspin' => '', 'iconcolor' => '', 'iconcolor_hover' => '', 'circlecolor' => fusion_library()->sanitize->color( $fusion_settings->get( 'content_box_icon_bg_color' ) ), 'circlecolor_hover' => '', 'circlebordercolor' => fusion_library()->sanitize->color( $fusion_settings->get( 'content_box_icon_bg_inner_border_color' ) ), 'circlebordersize' => intval( $fusion_settings->get( 'content_box_icon_bg_inner_border_size' ) ) . 'px', 'outercirclebordercolor' => fusion_library()->sanitize->color( $fusion_settings->get( 'content_box_icon_bg_outer_border_color' ) ), 'outercirclebordersize' => intval( $fusion_settings->get( 'content_box_icon_bg_outer_border_size' ) ) . 'px', 'icon_circle' => $fusion_settings->get( 'content_box_icon_circle' ), 'icon_circle_radius' => $fusion_settings->get( 'content_box_icon_circle_radius' ), 'icon_size' => fusion_library()->sanitize->size( $fusion_settings->get( 'content_box_icon_size' ) ), 'icon_align' => '', 'icon_hover_type' => $fusion_settings->get( 'content_box_icon_hover_type' ), 'hover_accent_color' => ( '' !== $fusion_settings->get( 'content_box_hover_animation_accent_color' ) ) ? fusion_library()->sanitize->color( $fusion_settings->get( 'content_box_hover_animation_accent_color' ) ) : fusion_library()->sanitize->color( $fusion_settings->get( 'link_hover_color' ) ), 'image' => '', 'image_id' => '', 'image_max_width' => '', 'layout' => 'icon-with-title', 'margin_top' => '', 'margin_bottom' => '', 'title_size' => fusion_library()->sanitize->size( $fusion_settings->get( 'content_box_title_size' ) ), 'title_color' => '', 'body_color' => fusion_library()->sanitize->color( $fusion_settings->get( 'content_box_body_color' ) ), 'link_type' => $fusion_settings->get( 'content_box_link_type' ), 'button_span' => $fusion_settings->get( 'content_box_button_span' ), 'link_area' => $fusion_settings->get( 'content_box_link_area' ), 'link_target' => $fusion_settings->get( 'content_box_link_target' ), 'animation_type' => '', 'animation_delay' => '0', 'animation_direction' => 'left', 'animation_speed' => '0.1', 'animation_offset' => $fusion_settings->get( 'animation_offset' ), 'animation_color' => '', 'settings_lvl' => 'child', 'linktarget' => '', // Deprecated. 'responsive_typography' => 0.0 < $fusion_settings->get( 'typography_sensitivity' ), 'item_margin_top' => '', 'item_margin_bottom' => '', 'box_shadow' => '', 'box_shadow_blur' => '', 'box_shadow_color' => '', 'box_shadow_horizontal' => '', 'box_shadow_spread' => '', 'box_shadow_style' => '', 'box_shadow_vertical' => '', 'dynamic_params' => '', ]; $child = [ 'class' => '', 'id' => '', 'backgroundcolor' => '', 'circle' => '', 'circlecolor' => '', 'circlecolor_hover' => '', 'circlebordercolor' => '', 'circlebordersize' => '', 'outercirclebordercolor' => '', 'outercirclebordersize' => '', 'icon' => $parent['icon'], 'iconcolor' => '', 'iconcolor_hover' => '', 'iconflip' => '', 'iconrotate' => '', 'iconspin' => '', 'image' => '', 'image_max_width' => '', 'link' => '', 'link_target' => '', 'linktext' => '', 'textcolor' => '', 'title' => '', 'animation_type' => '', 'animation_direction' => '', 'animation_speed' => '', 'animation_offset' => '', 'animation_color' => '', 'linktarget' => '', // Deprecated. ]; if ( 'parent' === $context ) { return $parent; } elseif ( 'child' === $context ) { return $child; } else { return [ 'parent' => $parent, 'child' => $child, ]; } } /** * Maps settings to param variables. * * @static * @access public * @param string $context Whether we want parent or child. * @since 2.0.0 * @return array */ public static function settings_to_params( $context = '' ) { $parent = [ 'content_box_icon_color' => 'iconcolor', 'content_box_bg_color' => 'backgroundcolor', 'content_box_icon_bg_color' => 'circlecolor', 'content_box_icon_bg_inner_border_color' => 'circlebordercolor', 'content_box_icon_bg_inner_border_size' => 'circlebordersize', 'content_box_icon_bg_outer_border_color' => 'outercirclebordercolor', 'content_box_icon_bg_outer_border_size' => 'outercirclebordersize', 'content_box_icon_circle' => 'icon_circle', 'content_box_icon_circle_radius' => 'icon_circle_radius', 'content_box_icon_size' => 'icon_size', 'content_box_icon_hover_type' => 'icon_hover_type', 'content_box_hover_animation_accent_color' => 'hover_accent_color', 'content_box_margin[top]' => 'margin_top', 'content_box_margin[bottom]' => 'margin_bottom', 'content_box_title_size' => 'title_size', 'content_box_title_color' => 'title_color', 'content_box_body_color' => 'body_color', 'content_box_link_type' => 'link_type', 'content_box_link_area' => 'link_area', 'content_box_link_target' => 'link_target', 'animation_offset' => 'animation_offset', 'content_box_button_span' => 'button_span', ]; $child = []; if ( 'parent' === $context ) { return $parent; } elseif ( 'child' === $context ) { return $child; } else { return [ 'parent' => $parent, 'child' => $child, ]; } } /** * Used to set any other variables for use on front-end editor template. * * @static * @access public * @param string $context Whether we want parent or child. * @since 2.0.0 * @return array */ public static function get_element_extras( $context = '' ) { $fusion_settings = awb_get_fusion_settings(); $parent = []; $child = [ 'button_shape' => strtolower( $fusion_settings->get( 'button_shape' ) ), 'button_type' => strtolower( $fusion_settings->get( 'button_type' ) ), ]; if ( 'parent' === $context ) { return $parent; } if ( 'child' === $context ) { return $child; } return [ 'parent' => $parent, 'child' => $child, ]; } /** * Maps settings to extra variables. * * @static * @access public * @param string $context Whether we want parent or child. * @since 2.0.0 * @return array */ public static function settings_to_extras( $context = '' ) { $parent = []; $child = [ 'button_shape' => 'button_shape', 'button_type' => 'button_type', ]; if ( 'parent' === $context ) { return $parent; } elseif ( 'child' === $context ) { return $child; } else { return [ 'parent' => $parent, 'child' => $child, ]; } } /** * Change args to valid values based on other options. * * @access public * @param string $context The parent or child context. Defaults to ''. * @since 3.9 * @return void */ public function validate_args( $context = '' ) { if ( 'parent' === $context ) { if ( 5 >= $this->parent_args['animation_delay'] ) { $this->parent_args['animation_delay'] = $this->parent_args['animation_delay'] * 1000; } } } /** * Render the shortcode. * * @access public * @since 1.0 * @param array $args Shortcode parameters. * @param string $content Content between shortcode. * @return string HTML output. */ public function render_parent( $args, $content = '' ) { $fusion_settings = awb_get_fusion_settings(); $defaults = FusionBuilder::set_shortcode_defaults( self::get_element_defaults( 'parent' ), $args, 'fusion_content_boxes' ); // Backwards compatibility for when we had image width and height params. if ( isset( $args['image_width'] ) ) { $defaults['image_width'] = ( $args['image_width'] ) ? $args['image_width'] : '35'; } else { $defaults['image_width'] = $defaults['image_max_width']; } $defaults['title_size'] = ( $defaults['title_size'] ) ? (float) fusion_library()->sanitize->number( $defaults['title_size'] ) : (float) fusion_library()->sanitize->number( $fusion_settings->get( 'content_box_title_size' ) ); $defaults['icon_circle_radius'] = FusionBuilder::validate_shortcode_attr_value( $defaults['icon_circle_radius'], 'px' ); $defaults['icon_size'] = FusionBuilder::validate_shortcode_attr_value( $defaults['icon_size'], 'px' ); $defaults['margin_top'] = FusionBuilder::validate_shortcode_attr_value( $defaults['margin_top'], 'px' ); $defaults['margin_bottom'] = FusionBuilder::validate_shortcode_attr_value( $defaults['margin_bottom'], 'px' ); $defaults['circlebordersize'] = FusionBuilder::validate_shortcode_attr_value( $defaults['circlebordersize'], 'px' ); $defaults['outercirclebordersize'] = FusionBuilder::validate_shortcode_attr_value( $defaults['outercirclebordersize'], 'px' ); if ( $defaults['linktarget'] ) { $defaults['link_target'] = $defaults['linktarget']; } if ( 'timeline-vertical' === $defaults['layout'] ) { $defaults['columns'] = 1; } if ( 'timeline-vertical' === $defaults['layout'] || 'timeline-horizontal' === $defaults['layout'] ) { // See #1362. $defaults['animation_delay'] = 350; $defaults['animation_speed'] = 0.25; $defaults['animation_type'] = 'fade'; $defaults['animation_direction'] = ''; } extract( $defaults ); $this->parent_args = $defaults; $this->validate_args( 'parent' ); $this->column_counter = 1; $this->row_counter = 1; preg_match_all( '/\[fusion_content_box (.*?)\]/s', $content, $matches ); if ( is_array( $matches ) && ! empty( $matches ) ) { $this->total_num_of_columns = count( $matches[0] ); } $this->num_of_columns = $columns; if ( ! $columns || empty( $columns ) ) { $this->num_of_columns = $this->total_num_of_columns; $this->num_of_columns = max( 6, $this->num_of_columns ); } elseif ( $columns > 6 ) { $this->num_of_columns = 6; } $html = '<div ' . FusionBuilder::attributes( 'content-boxes-shortcode' ) . '>'; if ( $this->parent_args['dynamic_params'] ) { $dynamic_data = json_decode( fusion_decode_if_needed( $this->parent_args['dynamic_params'] ), true ); if ( isset( $dynamic_data['parent_dynamic_content'] ) ) { $html .= self::get_acf_repeater( $dynamic_data['parent_dynamic_content'], $this->parent_args, $content ); } } else { $html .= do_shortcode( $content ); } $html .= '<div class="fusion-clearfix"></div></div>'; $this->content_box_counter++; $this->on_render(); return apply_filters( 'fusion_element_content_boxes_parent_content', $html, $args ); } /** * Builds the attributes array. * * @access public * @since 1.0 * @return array */ public function parent_attr() { $attr = [ 'class' => '', 'style' => $this->get_parent_css_vars(), ]; $attr['class'] = 'fusion-content-boxes content-boxes columns row'; $attr['class'] .= ' fusion-columns-' . $this->num_of_columns; $attr['class'] .= ' fusion-columns-total-' . $this->total_num_of_columns; $attr['class'] .= ' fusion-content-boxes-' . $this->content_box_counter; $attr['class'] .= ' content-boxes-' . $this->parent_args['layout']; $attr['class'] .= ' content-' . $this->parent_args['icon_align']; $attr = fusion_builder_visibility_atts( $this->parent_args['hide_on_mobile'], $attr ); if ( 'timeline-horizontal' === $this->parent_args['layout'] || 'clean-vertical' === $this->parent_args['layout'] ) { $attr['class'] .= ' content-boxes-icon-on-top'; } if ( 'timeline-vertical' === $this->parent_args['layout'] || 'timeline-horizontal' === $this->parent_args['layout'] ) { $attr['class'] .= ' content-boxes-timeline-layout'; } if ( 'timeline-vertical' === $this->parent_args['layout'] ) { $attr['class'] .= ' content-boxes-icon-with-title'; } if ( 'clean-horizontal' === $this->parent_args['layout'] ) { $attr['class'] .= ' content-boxes-icon-on-side'; } if ( $this->parent_args['alignment'] ) { $attr['class'] .= ' has-flex-alignment'; } if ( $this->parent_args['class'] ) { $attr['class'] .= ' ' . $this->parent_args['class']; } if ( $this->parent_args['id'] ) { $attr['id'] = $this->parent_args['id']; } if ( $this->parent_args['animation_delay'] ) { $attr['data-animation-delay'] = $this->parent_args['animation_delay']; $attr['class'] .= ' fusion-delayed-animation'; } if ( $this->parent_args['animation_offset'] ) { $animations = FusionBuilder::animations( [ 'offset' => $this->parent_args['animation_offset'], ] ); $attr = array_merge( $attr, $animations ); } return $attr; } /** * Render the child shortcode. * * @access public * @since 1.0 * @param array $args Shortcode parameters. * @param string $content Content between shortcode. * @return string HTML output. */ public function render_child( $args, $content = '' ) { $fusion_settings = awb_get_fusion_settings(); $defaults = FusionBuilder::set_shortcode_defaults( [ 'class' => '', 'id' => '', 'backgroundcolor' => $this->parent_args['backgroundcolor'], 'circle' => '', 'circlecolor' => $this->parent_args['circlecolor'], 'circlecolor_hover' => $this->parent_args['circlecolor_hover'], 'circlebordercolor' => $this->parent_args['circlebordercolor'], 'circlebordersize' => $this->parent_args['circlebordersize'], 'heading_size' => $this->parent_args['heading_size'], 'outercirclebordercolor' => $this->parent_args['outercirclebordercolor'], 'outercirclebordersize' => $this->parent_args['outercirclebordersize'], 'icon' => $this->parent_args['icon'], 'iconcolor' => $this->parent_args['iconcolor'], 'iconcolor_hover' => $this->parent_args['iconcolor_hover'], 'iconflip' => $this->parent_args['iconflip'], 'iconrotate' => $this->parent_args['iconrotate'], 'iconspin' => $this->parent_args['iconspin'], 'image' => $this->parent_args['image'], 'image_id' => $this->parent_args['image_id'], 'image_max_width' => $this->parent_args['image_max_width'], 'link' => '', 'link_target' => $this->parent_args['link_target'], 'linktext' => '', 'textcolor' => '', 'title' => '', 'animation_type' => $this->parent_args['animation_type'], 'animation_direction' => $this->parent_args['animation_direction'], 'animation_speed' => $this->parent_args['animation_speed'], 'animation_offset' => $this->parent_args['animation_offset'], 'animation_color' => $this->parent_args['animation_color'], 'linktarget' => '', // Deprecated. 'responsive_typography' => 0.0 < $fusion_settings->get( 'typography_sensitivity' ), ], $args, 'fusion_content_box' ); $content = apply_filters( 'fusion_shortcode_content', $content, 'fusion_content_box', $args ); // Case when image is set on parent element and icon on child element. if ( empty( $args['image'] ) && ! empty( $args['icon'] ) ) { $defaults['image'] = ''; } // Backwards compatibility for when we had image width and height params. if ( isset( $args['image_width'] ) && $args['image_width'] ) { $defaults['image_width'] = $args['image_width']; } else { $defaults['image_width'] = $defaults['image_max_width']; } $defaults['image_width'] = FusionBuilder::validate_shortcode_attr_value( $defaults['image_width'], '' ); if ( $defaults['image'] ) { $image_data = fusion_library()->images->get_attachment_data_by_helper( $defaults['image_id'], $defaults['image'] ); $image_width = $image_data['width']; $image_height = $image_data['height']; if ( '-1' === $defaults['image_width'] || '' === $defaults['image_width'] ) { $defaults['image_width'] = ( $image_width ) ? $image_width : '35'; } $defaults['image_height'] = ( $image_width ) ? round( $defaults['image_width'] / $image_width * $image_height, 2 ) : $defaults['image_width']; } else { $defaults['image_width'] = '' === $defaults['image_width'] ? '35' : $defaults['image_width']; $defaults['image_height'] = '35'; } if ( $defaults['linktarget'] ) { $defaults['link_target'] = $defaults['linktarget']; } if ( 'timeline-vertical' === $this->parent_args['layout'] || 'timeline-horizontal' === $this->parent_args['layout'] ) { $defaults['animation_speed'] = 0.25; $defaults['animation_type'] = 'fade'; $defaults['animation_direction'] = ''; } // This block is needed for legacy setups, #494. if ( 'parent' === $this->parent_args['settings_lvl'] ) { $defaults['backgroundcolor'] = $this->parent_args['backgroundcolor']; $defaults['circlecolor'] = $this->parent_args['circlecolor']; $defaults['circlebordercolor'] = $this->parent_args['circlebordercolor']; $defaults['circlebordersize'] = $this->parent_args['circlebordersize']; $defaults['outercirclebordercolor'] = $this->parent_args['outercirclebordercolor']; $defaults['outercirclebordersize'] = $this->parent_args['outercirclebordersize']; $defaults['iconcolor'] = $this->parent_args['iconcolor']; $defaults['animation_type'] = $this->parent_args['animation_type']; $defaults['animation_direction'] = $this->parent_args['animation_direction']; $defaults['animation_speed'] = $this->parent_args['animation_speed']; $defaults['link_target'] = $this->parent_args['link_target']; } // Make sure original child animation type is accessible, for later check on column-wrapper attributes. $defaults['animation_type_original'] = ( isset( $args['animation_type'] ) ) ? $args['animation_type'] : ''; $defaults['circlebordersize'] = FusionBuilder::validate_shortcode_attr_value( $defaults['circlebordersize'], 'px' ); $defaults['outercirclebordersize'] = FusionBuilder::validate_shortcode_attr_value( $defaults['outercirclebordersize'], 'px' ); extract( $defaults ); $this->child_args = $defaults; $output = ''; $icon_output = ''; $title_output = ''; $content_output = ''; $link_output = ''; $alt = ''; $heading = ''; if ( $image && $image_width && $image_height ) { $image_data = fusion_library()->images->get_attachment_data_by_helper( $this->child_args['image_id'], $image ); $alt = $image_data['alt']; if ( $image_data['url'] ) { $image = $image_data['url']; } $image = '<img src="' . $image . '" width="' . $image_width . '" height="' . $image_height . '" alt="' . $alt . '" />'; $image = fusion_library()->images->apply_lazy_loading( $image, null, $this->child_args['image_id'], 'full' ); $icon_output = '<div ' . FusionBuilder::attributes( 'content-box-shortcode-icon' ) . '>'; $icon_output .= $image; $icon_output .= '</div>'; } elseif ( $icon ) { $icon_output = '<div ' . FusionBuilder::attributes( 'content-box-shortcode-icon-parent' ) . '>'; $icon_output .= '<i ' . FusionBuilder::attributes( 'content-box-shortcode-icon' ) . '></i>'; $icon_output .= '</div>'; if ( $outercirclebordercolor && $outercirclebordersize && intval( $outercirclebordersize ) ) { $icon_output = '<div ' . FusionBuilder::attributes( 'content-box-shortcode-icon-parent' ) . '>'; $icon_output .= '<span ' . FusionBuilder::attributes( 'content-box-shortcode-icon-wrapper' ) . '>'; $icon_output .= '<i ' . FusionBuilder::attributes( 'content-box-shortcode-icon' ) . '></i>'; $icon_output .= '</span></div>'; } } if ( $title ) { $heading_size = $this->get_heading_tag(); $title_output = '<' . $heading_size . ' ' . FusionBuilder::attributes( 'content-box-heading' ) . '>' . $title . '</' . $heading_size . '>'; } if ( 'right' === $this->parent_args['icon_align'] && ! is_rtl() && in_array( $this->parent_args['layout'], [ 'icon-on-side', 'icon-with-title', 'timeline-vertical', 'clean-horizontal' ], true ) ) { $heading_content = $title_output . $icon_output; } else { $heading_content = $icon_output . $title_output; } if ( $link ) { $heading_content = '<a ' . FusionBuilder::attributes( 'content-box-shortcode-link', [ 'heading_link' => true ] ) . '>' . $heading_content . '</a>'; } if ( $heading_content ) { $heading = '<div ' . FusionBuilder::attributes( 'content-box-shortcode-heading-wrapper' ) . '>' . $heading_content . '</div>'; } if ( $link && $linktext ) { if ( 'text' === $this->parent_args['link_type'] || 'button-bar' === $this->parent_args['link_type'] ) { $link_output = '<div class="fusion-clearfix"></div>'; $link_output .= '<a ' . FusionBuilder::attributes( 'content-box-shortcode-link', [ 'readmore' => true ] ) . '>' . $linktext . '</a>'; $link_output .= '<div class="fusion-clearfix"></div>'; } elseif ( 'button' === $this->parent_args['link_type'] ) { $link_output = '<div class="fusion-clearfix"></div>'; $link_output .= '<a ' . FusionBuilder::attributes( 'content-box-shortcode-link', [ 'readmore' => true ] ) . '><span class="fusion-button-text">' . $linktext . '</span></a>'; $link_output .= '<div class="fusion-clearfix"></div>'; } } if ( $content ) { $content_output .= '<div class="fusion-clearfix"></div>'; $content_output .= '<div ' . FusionBuilder::attributes( 'content-box-shortcode-content-container' ) . '>' . do_shortcode( $content ) . '</div>'; } $output = $heading . $content_output . $link_output; $timeline = ''; if ( $icon && 'yes' === $this->parent_args['icon_circle'] && 'timeline-horizontal' === $this->parent_args['layout'] && '1' != $this->parent_args['columns'] ) { // phpcs:ignore Universal.Operators.StrictComparisons $timeline = '<div ' . FusionBuilder::attributes( 'content-box-shortcode-timeline' ) . '></div>'; } if ( $icon && 'yes' === $this->parent_args['icon_circle'] && 'timeline-vertical' === $this->parent_args['layout'] ) { $timeline = '<div ' . FusionBuilder::attributes( 'content-box-shortcode-timeline' ) . '></div>'; } $html = '<div ' . FusionBuilder::attributes( 'content-box-shortcode' ) . '>'; $html .= '<div ' . FusionBuilder::attributes( 'content-box-shortcode-content-wrapper' ) . '>' . $output . $timeline . '</div>'; $html .= '</div>'; $this->column_counter++; return apply_filters( 'fusion_element_content_boxes_child_content', $html, $args ); } /** * Get the parent css variables. * * @since 3.9 * @return string */ private function get_parent_css_vars() { $this->args = $this->parent_args; $this->defaults = $this->get_element_defaults( 'parent' ); $sanitize = fusion_library()->sanitize; $custom_css_vars = []; $css_vars = [ 'backgroundcolor', 'border_radius_top_left' => [ 'callback' => [ $sanitize, 'get_value_with_unit' ] ], 'border_radius_top_right' => [ 'callback' => [ $sanitize, 'get_value_with_unit' ] ], 'border_radius_bottom_right' => [ 'callback' => [ $sanitize, 'get_value_with_unit' ] ], 'border_radius_bottom_left' => [ 'callback' => [ $sanitize, 'get_value_with_unit' ] ], 'alignment', 'body_color', 'title_color', 'iconcolor', 'iconcolor_hover', 'circlecolor_hover', 'item_margin_top' => [ 'callback' => [ $sanitize, 'get_value_with_unit' ] ], 'item_margin_bottom' => [ 'callback' => [ $sanitize, 'get_value_with_unit' ] ], 'margin_top', 'margin_bottom', ]; $custom_css_vars['hover_accent_color'] = $this->args['hover_accent_color']; $circle_hover_accent_color = $this->args['hover_accent_color']; if ( Fusion_Color::new_color( $this->args['circlecolor'] )->is_color_transparent() || 'no' === $this->args['icon_circle'] ) { $circle_hover_accent_color = 'transparent'; } $custom_css_vars['circle_hover_accent_color'] = $circle_hover_accent_color; // if 1 column and not margin bottom is set, then set margin-bottom to 40px. if ( 1 === (int) $this->num_of_columns && empty( $this->args['item_margin_bottom'] ) ) { $custom_css_vars['item_margin_bottom'] = '40px'; } if ( 'yes' === $this->args['box_shadow'] ) { $custom_css_vars['box_shadow'] = Fusion_Builder_Box_Shadow_Helper::get_box_shadow_styles( $this->args ); } return $this->get_css_vars_for_options( $css_vars ) . $this->get_custom_css_vars( $custom_css_vars ); } /** * Get the child css variables. * * @since 3.9 * @return string */ private function get_child_css_vars() { $this->args = $this->child_args; $this->defaults = $this->get_element_defaults( 'child' ); $custom_css_vars = []; $css_vars = [ 'backgroundcolor', 'iconcolor', 'iconcolor_hover', 'circlecolor_hover', ]; $var_already_on_parent = ( Fusion_Color::new_color( $this->parent_args['circlecolor'] )->is_color_transparent() || 'no' === $this->parent_args['icon_circle'] ); if ( Fusion_Color::new_color( $this->args['circlecolor'] )->is_color_transparent() && ! $var_already_on_parent ) { $custom_css_vars['circle_hover_accent_color'] = 'transparent'; } if ( in_array( $this->parent_args['layout'], [ 'icon-on-side', 'timeline-vertical', 'clean-horizontal' ], true ) && $this->child_args['image'] && $this->child_args['image_width'] && $this->child_args['image_height'] ) { if ( 'right' === $this->parent_args['icon_align'] ) { $custom_css_vars['content-padding-right'] = ( $this->child_args['image_width'] + 20 ) . 'px'; } else { $custom_css_vars['content-padding-left'] = ( $this->child_args['image_width'] + 20 ) . 'px'; } } elseif ( in_array( $this->parent_args['layout'], [ 'icon-on-side', 'timeline-vertical', 'clean-horizontal' ], true ) && $this->child_args['icon'] ) { if ( 'yes' === $this->parent_args['icon_circle'] ) { $full_icon_size = ( intval( $this->parent_args['icon_size'] ) + intval( $this->child_args['circlebordersize'] ) + intval( $this->child_args['outercirclebordersize'] ) ) * 2; } else { $full_icon_size = intval( $this->parent_args['icon_size'] ); } if ( 'right' === $this->parent_args['icon_align'] ) { $custom_css_vars['content-padding-right'] = ( intval( $full_icon_size ) + 20 ) . 'px'; } else { $custom_css_vars['content-padding-left'] = ( intval( $full_icon_size ) + 20 ) . 'px'; } } if ( ( in_array( $this->parent_args['layout'], [ 'icon-on-side', 'icon-with-title', 'timeline-vertical', 'clean-horizontal' ], true ) ) ) { if ( 'right' === $this->parent_args['icon_align'] || ( 'left' === $this->parent_args['icon_align'] ) && is_rtl() ) { $custom_css_vars['content-text-align'] = $this->parent_args['icon_align']; } } return $this->get_css_vars_for_options( $css_vars ) . $this->get_custom_css_vars( $custom_css_vars ); } /** * Get the heading css variables. * * @since 3.9 * @return string */ private function get_heading_css_vars() { $this->args = $this->parent_args; $heading_size = ''; if ( $this->args['title_size'] ) { $heading_size = $this->get_heading_font_vars( $this->get_heading_tag(), [ 'font-size' => $this->args['title_size'] . 'px' ] ); } else { $heading_size = $this->get_heading_font_vars( $this->get_heading_tag(), [ 'font-size' => 'var(--content_box_title_size)' ] ); } return $heading_size; } /** * Get the heading tag. * * @return string */ private function get_heading_tag() { $heading_tag = $this->parent_args['heading_size']; $heading_tag = 'div' === $heading_tag || 'p' === $heading_tag ? $heading_tag : 'h' . $heading_tag; return $heading_tag; } /** * Builds the attributes array. * * @access public * @since 1.0 * @return array */ public function child_attr() { $columns = 12 / $this->num_of_columns; if ( $this->row_counter > intval( $this->num_of_columns ) ) { $this->row_counter = 1; } $attr = [ 'style' => $this->get_child_css_vars(), 'class' => 'fusion-column content-box-column', ]; $attr['class'] .= ' content-box-column content-box-column-' . $this->column_counter . ' col-lg-' . $columns . ' col-md-' . $columns . ' col-sm-' . $columns; if ( '5' == $this->num_of_columns ) { // phpcs:ignore Universal.Operators.StrictComparisons $attr['class'] = 'fusion-column content-box-column content-box-column-' . $this->column_counter . ' col-lg-2 col-md-2 col-sm-2'; } $attr['class'] .= ' fusion-content-box-hover '; $border_color = ''; if ( $this->child_args['circlebordercolor'] ) { $border_color = $this->child_args['circlebordercolor']; } if ( $this->child_args['outercirclebordercolor'] ) { $border_color = $this->child_args['outercirclebordercolor']; } if ( ! $this->child_args['circlebordercolor'] && ! $this->child_args['outercirclebordercolor'] ) { $border_color = '#f6f6f6'; } if ( 1 === $this->column_counter % (int) $this->num_of_columns ) { $attr['class'] .= ' content-box-column-first-in-row'; } if ( $this->column_counter === $this->total_num_of_columns ) { $attr['class'] .= ' content-box-column-last'; } if ( (int) $this->num_of_columns === $this->row_counter ) { $attr['class'] .= ' content-box-column-last-in-row'; } if ( $border_color && in_array( $this->parent_args['layout'], [ 'clean-vertical', 'clean-horizontal' ], true ) ) { $attr['style'] .= 'border-color:' . $border_color . ';'; } if ( $this->child_args['class'] ) { $attr['class'] .= ' ' . $this->child_args['class']; } if ( $this->child_args['id'] ) { $attr['id'] = $this->child_args['id']; } $this->row_counter++; return $attr; } /** * Builds the attributes array. * * @access public * @since 1.0 * @return array */ public function content_wrapper_attr() { $attr = [ 'class' => 'col content-box-wrapper content-wrapper', ]; // Set parent values if child values are unset to get downwards compatibility. if ( ! $this->child_args['backgroundcolor'] ) { $this->child_args['backgroundcolor'] = $this->parent_args['backgroundcolor']; } if ( $this->child_args['backgroundcolor'] ) { if ( ! Fusion_Color::new_color( $this->child_args['backgroundcolor'] )->is_color_transparent() ) { $attr['class'] .= '-background'; } } if ( 'icon-boxed' === $this->parent_args['layout'] ) { $attr['class'] .= ' content-wrapper-boxed'; } if ( $this->child_args['link'] && 'box' === $this->parent_args['link_area'] ) { $attr['data-link'] = $this->child_args['link']; $attr['data-link-target'] = $this->child_args['link_target']; } $attr['class'] .= ' link-area-' . $this->parent_args['link_area']; if ( $this->child_args['link'] && $this->parent_args['link_type'] ) { $attr['class'] .= ' link-type-' . $this->parent_args['link_type']; } if ( $this->child_args['outercirclebordercolor'] && $this->child_args['outercirclebordersize'] && intval( $this->child_args['outercirclebordersize'] ) ) { $attr['class'] .= ' content-icon-wrapper-yes'; } if ( $this->child_args['outercirclebordercolor'] && $this->child_args['outercirclebordersize'] && intval( $this->child_args['outercirclebordersize'] ) && 'pulsate' === $this->parent_args['icon_hover_type'] ) { $attr['class'] .= ' icon-wrapper-hover-animation-' . $this->parent_args['icon_hover_type']; } else { $attr['class'] .= ' icon-hover-animation-' . $this->parent_args['icon_hover_type']; } if ( $this->child_args['textcolor'] ) { $attr['style'] .= 'color:' . $this->child_args['textcolor'] . ';'; } if ( isset( $this->child_args['animation_type_original'] ) ) { if ( '' === $this->child_args['animation_type_original'] ) { $animations = FusionBuilder::animations( [ 'type' => $this->parent_args['animation_type'], 'direction' => $this->parent_args['animation_direction'], 'speed' => $this->parent_args['animation_speed'], 'offset' => $this->parent_args['animation_offset'], ] ); } else { $animations = FusionBuilder::animations( [ 'type' => $this->child_args['animation_type'], 'direction' => $this->child_args['animation_direction'], 'speed' => $this->child_args['animation_speed'], 'offset' => $this->child_args['animation_offset'], ] ); } if ( 'none' !== $this->child_args['animation_type'] ) { $attr = array_merge( $attr, $animations ); if ( isset( $attr['animation_class'] ) ) { $attr['class'] .= ' ' . $attr['animation_class']; unset( $attr['animation_class'] ); } if ( isset( $this->child_args['animation_color'] ) && $this->child_args['animation_color'] ) { $attr['style'] .= '--awb-animation-color:' . $this->child_args['animation_color'] . ';'; } } } return $attr; } /** * Builds the attributes array. * * @access public * @since 1.0 * @param array $args The arguments array. * @return array */ public function link_attr( $args ) { $fusion_settings = awb_get_fusion_settings(); $attr = [ 'class' => '', 'style' => '', ]; if ( isset( $args['heading_link'] ) ) { $attr['class'] .= 'heading-link'; } if ( $this->child_args['link'] ) { $attr['href'] = $this->child_args['link']; } if ( $this->child_args['link_target'] ) { $attr['target'] = $this->child_args['link_target']; } if ( '_blank' === $this->child_args['link_target'] ) { $attr['rel'] = 'noopener noreferrer'; } if ( ! isset( $args['heading_link'] ) ) { if ( 'text' === $this->parent_args['link_type'] || 'button-bar' === $this->parent_args['link_type'] ) { $attr['class'] .= ' fusion-read-more'; if ( 'button-bar' === $this->parent_args['link_type'] ) { $attr['class'] .= ' fusion-button-bar'; } } elseif ( 'button' === $this->parent_args['link_type'] ) { $attr['class'] .= 'fusion-read-more-button fusion-content-box-button fusion-button button-default fusion-button-default-size button-' . strtolower( $fusion_settings->get( 'button_shape' ) ) . ' button-' . strtolower( $fusion_settings->get( 'button_type' ) ); } } if ( 'button-bar' === $this->parent_args['link_type'] && 'timeline-vertical' === $this->parent_args['layout'] && isset( $args['readmore'] ) ) { $addition_margin = 20 + 15; $full_icon_size = 0; if ( $this->child_args['backgroundcolor'] && ! Fusion_Color::new_color( $this->child_args['backgroundcolor'] )->is_color_transparent() ) { $addition_margin += 35; } if ( $this->child_args['image'] && $this->child_args['image_width'] && $this->child_args['image_height'] ) { $full_icon_size = $this->child_args['image_width']; } elseif ( $this->child_args['icon'] ) { if ( 'yes' === $this->parent_args['icon_circle'] ) { $full_icon_size = ( intval( $this->parent_args['icon_size'] ) + intval( $this->child_args['circlebordersize'] ) + intval( $this->child_args['outercirclebordersize'] ) ) * 2; } else { $full_icon_size = intval( $this->parent_args['icon_size'] ); } } if ( 'right' === $this->parent_args['icon_align'] ) { $attr['style'] .= 'margin-right:' . ( $full_icon_size + $addition_margin ) . 'px;'; } else { $attr['style'] .= 'margin-left:' . ( $full_icon_size + $addition_margin ) . 'px;'; } $attr['style'] .= 'width:calc(100% - ' . ( $full_icon_size + $addition_margin + 15 ) . 'px);'; } elseif ( in_array( $this->parent_args['layout'], [ 'icon-on-side', 'clean-horizontal', 'timeline-vertical' ], true ) && in_array( $this->parent_args['link_type'], [ 'text', 'button' ], true ) && isset( $args['readmore'] ) ) { $addition_margin = 20; $full_icon_size = 0; if ( $this->child_args['image'] && $this->child_args['image_width'] && $this->child_args['image_height'] ) { $full_icon_size = $this->child_args['image_width']; } elseif ( $this->child_args['icon'] ) { if ( 'yes' === $this->parent_args['icon_circle'] ) { $full_icon_size = ( intval( $this->parent_args['icon_size'] ) + intval( $this->child_args['circlebordersize'] ) + intval( $this->child_args['outercirclebordersize'] ) ) * 2; } else { $full_icon_size = intval( $this->parent_args['icon_size'] ); } } if ( 'right' === $this->parent_args['icon_align'] ) { $attr['style'] .= 'margin-right:' . ( $full_icon_size + $addition_margin ) . 'px;'; } else { $attr['style'] .= 'margin-left:' . ( $full_icon_size + $addition_margin ) . 'px;'; } if ( 'button' === $this->parent_args['link_type'] && 'yes' === $this->parent_args['button_span'] ) { $attr['style'] .= 'width: calc(100% - ' . ( $full_icon_size + $addition_margin ) . 'px);'; } } elseif ( 'icon-with-title' === $this->parent_args['layout'] ) { $attr['style'] .= 'float:' . $this->parent_args['icon_align'] . ';'; } if ( ! in_array( $this->parent_args['layout'], [ 'icon-on-side', 'clean-horizontal', 'timeline-vertical' ], true ) && 'button' === $this->parent_args['link_type'] && 'yes' === $this->parent_args['button_span'] ) { $attr['style'] .= 'width: 100%;'; } return $attr; } /** * Builds the attributes array. * * @access public * @since 1.0 * @return array */ public function heading_wrapper_attr() { $attr = [ 'class' => 'heading', 'style' => '', ]; if ( $this->child_args['icon'] || $this->child_args['image'] ) { $attr['class'] .= ' heading-with-icon'; if ( 'timeline-vertical' === $this->parent_args['layout'] ) { // Image is used. if ( $this->child_args['image'] && $this->child_args['image_width'] && $this->child_args['image_height'] ) { $image_height = $this->child_args['image_height']; if ( $image_height > $this->parent_args['title_size'] && $image_height - $this->parent_args['title_size'] - 15 > 0 ) { $attr['style'] .= 'margin-top:' . ( $image_height - $this->parent_args['title_size'] ) . 'px;'; } } elseif ( $this->child_args['icon'] ) { // Icon is used. if ( 'yes' === $this->parent_args['icon_circle'] ) { $full_icon_size = ( intval( $this->parent_args['icon_size'] ) + intval( $this->child_args['circlebordersize'] ) + intval( $this->child_args['outercirclebordersize'] ) ) * 2; } else { $full_icon_size = intval( $this->parent_args['icon_size'] ); } if ( $full_icon_size > $this->parent_args['title_size'] && $full_icon_size - $this->parent_args['title_size'] - 15 > 0 ) { $attr['style'] .= 'margin-top:' . ( ( intval( $full_icon_size ) - $this->parent_args['title_size'] ) / 2 ) . 'px;'; } } } } if ( $this->parent_args['icon_align'] ) { $attr['class'] .= ' icon-' . $this->parent_args['icon_align']; } return $attr; } /** * Builds the attributes array. * * @access public * @since 1.0 * @return array */ public function icon_parent_attr() { $attr = [ 'class' => 'icon', 'style' => '', ]; if ( 'yes' !== $this->parent_args['icon_circle'] && 'icon-boxed' === $this->parent_args['layout'] ) { $attr['style'] .= 'position:absolute;width: 100%;top:-' . ( 50 + ( intval( $this->parent_args['icon_size'] ) / 2 ) ) . 'px;'; } if ( 'timeline-vertical' === $this->parent_args['layout'] && 'right' === $this->parent_args['icon_align'] && ( ! $this->child_args['outercirclebordercolor'] || ! $this->child_args['circlebordersize'] ) ) { $attr['style'] .= 'padding-left:20px;'; } if ( 'timeline-vertical' === $this->parent_args['layout'] ) { // Image is used. if ( $this->child_args['image'] && $this->child_args['image_width'] && $this->child_args['image_height'] ) { $image_height = $this->child_args['image_height']; if ( $image_height > $this->parent_args['title_size'] && $image_height - $this->parent_args['title_size'] - 15 > 0 ) { $attr['style'] .= 'margin-top:-' . ( $image_height - $this->parent_args['title_size'] ) . 'px;'; $attr['style'] .= 'margin-bottom:-' . ( $image_height - $this->parent_args['title_size'] ) . 'px;'; } } elseif ( $this->child_args['icon'] ) { // Icon is used. if ( 'yes' === $this->parent_args['icon_circle'] ) { $full_icon_size = ( intval( $this->parent_args['icon_size'] ) + intval( $this->child_args['circlebordersize'] ) + intval( $this->child_args['outercirclebordersize'] ) ) * 2; } else { $full_icon_size = intval( $this->parent_args['icon_size'] ); } if ( $full_icon_size > $this->parent_args['title_size'] && $full_icon_size - $this->parent_args['title_size'] - 15 > 0 ) { $attr['style'] .= 'margin-top:-' . ( ( intval( $full_icon_size ) - $this->parent_args['title_size'] ) / 2 ) . 'px;'; $attr['style'] .= 'margin-bottom:-' . ( ( intval( $full_icon_size ) - $this->parent_args['title_size'] ) / 2 ) . 'px;'; } } } if ( $this->parent_args['animation_delay'] ) { $animation_delay = $this->parent_args['animation_delay']; $attr['style'] .= '-webkit-animation-duration: ' . $animation_delay . 'ms;'; $attr['style'] .= 'animation-duration: ' . $animation_delay . 'ms;'; } return $attr; } /** * Builds the attributes array. * * @access public * @since 1.0 * @return array */ public function icon_wrapper_attr() { $attr = [ 'style' => '', ]; if ( $this->child_args['icon'] ) { $attr['class'] = ''; if ( 'yes' === $this->parent_args['icon_circle'] ) { $attr['style'] .= 'height:' . ( ( intval( $this->parent_args['icon_size'] ) + intval( $this->child_args['circlebordersize'] ) ) * 2 ) . 'px;width:' . ( ( intval( $this->parent_args['icon_size'] ) + intval( $this->child_args['circlebordersize'] ) ) * 2 ) . 'px;line-height:' . ( intval( $this->parent_args['icon_size'] ) + intval( $this->child_args['circlebordersize'] ) * 2 ) . 'px;'; if ( $this->child_args['outercirclebordercolor'] ) { $attr['style'] .= 'border-color:' . $this->child_args['outercirclebordercolor'] . ';'; } if ( $this->child_args['outercirclebordersize'] && intval( $this->child_args['outercirclebordersize'] ) ) { $attr['style'] .= 'border-width:' . $this->child_args['outercirclebordersize'] . ';'; } $attr['style'] .= 'border-style:solid;'; if ( $this->child_args['circlebordercolor'] && intval( $this->child_args['circlebordersize'] ) ) { $attr['style'] .= 'background-color:' . $this->child_args['circlebordercolor'] . ';'; } elseif ( $this->child_args['outercirclebordersize'] && intval( $this->child_args['outercirclebordersize'] ) && ! Fusion_Color::new_color( $this->child_args['circlecolor'] )->is_color_transparent() ) { $attr['style'] .= 'background-color:' . $this->child_args['outercirclebordercolor'] . ';'; } if ( 'icon-boxed' === $this->parent_args['layout'] ) { $attr['style'] .= 'position:absolute;top:-' . ( 50 + intval( $this->parent_args['icon_size'] ) + intval( $this->child_args['circlebordersize'] ) ) . 'px;margin-left:-' . ( intval( $this->parent_args['icon_size'] ) + intval( $this->child_args['circlebordersize'] ) ) . 'px;'; } if ( 'round' === $this->parent_args['icon_circle_radius'] ) { $this->parent_args['icon_circle_radius'] = '100%'; } if ( in_array( $this->parent_args['layout'], [ 'icon-on-side', 'timeline-vertical', 'clean-horizontal' ], true ) ) { $margin_direction = 'margin-right'; if ( 'right' === $this->parent_args['icon_align'] ) { $margin_direction = 'margin-left'; } $margin = '20px'; if ( 'timeline-vertical' === $this->parent_args['layout'] && 'right' === $this->parent_args['icon_align'] ) { $margin = '10px'; } $attr['style'] .= $margin_direction . ':' . $margin . ';'; } $attr['style'] .= 'box-sizing:content-box;'; $attr['style'] .= 'border-radius:' . $this->parent_args['icon_circle_radius'] . ';'; } } return $attr; } /** * Builds the attributes array. * * @access public * @since 1.0 * @return array */ public function icon_attr() { $attr = [ 'style' => '', 'aria-hidden' => 'true', ]; if ( $this->child_args['image'] ) { $attr['class'] = 'image'; if ( 'icon-boxed' === $this->parent_args['layout'] && $this->child_args['image_width'] && $this->child_args['image_height'] ) { $attr['style'] = 'margin-left:-' . ( $this->child_args['image_width'] / 2 ) . 'px;'; $attr['style'] .= 'top:-' . ( $this->child_args['image_height'] / 2 + 50 ) . 'px;'; } } elseif ( $this->child_args['icon'] ) { $attr['class'] = 'fontawesome-icon ' . fusion_font_awesome_name_handler( $this->child_args['icon'] ); // Set parent values if child values are unset to get downwards compatibility. if ( ! $this->child_args['circle'] ) { $this->child_args['circle'] = $this->parent_args['circle']; } if ( 'yes' === $this->parent_args['icon_circle'] ) { $attr['class'] .= ' circle-yes'; if ( $this->child_args['circlebordercolor'] ) { $attr['style'] .= 'border-color:' . $this->child_args['circlebordercolor'] . ';'; } $icon_circle_dimension = intval( $this->parent_args['icon_size'] ) * 2; $this->child_args['circlebordersize'] = FusionBuilder::validate_shortcode_attr_value( $this->child_args['circlebordersize'], 'px' ); if ( $this->child_args['circlebordersize'] ) { $attr['style'] .= 'border-width:' . $this->child_args['circlebordersize'] . ';'; } if ( $this->child_args['circlecolor'] ) { $attr['style'] .= 'background-color:' . $this->child_args['circlecolor'] . ';'; } $attr['style'] .= 'box-sizing:content-box;height:' . $icon_circle_dimension . 'px;width:' . $icon_circle_dimension . 'px;line-height:' . $icon_circle_dimension . 'px;'; if ( 'icon-boxed' === $this->parent_args['layout'] && ( ! $this->child_args['outercirclebordercolor'] || ! $this->child_args['outercirclebordersize'] || ! intval( $this->child_args['outercirclebordersize'] ) ) ) { $attr['style'] .= 'top:-' . ( 50 + intval( $this->parent_args['icon_size'] ) ) . 'px;margin-left:-' . intval( $this->parent_args['icon_size'] ) . 'px;'; } if ( 'round' === $this->parent_args['icon_circle_radius'] ) { $this->parent_args['icon_circle_radius'] = '100%'; } $attr['style'] .= 'border-radius:' . $this->parent_args['icon_circle_radius'] . ';'; if ( $this->child_args['outercirclebordercolor'] && $this->child_args['outercirclebordersize'] && intval( $this->child_args['outercirclebordersize'] ) ) { // If there is a thick border, kill border width and make it center aligned positioned. $attr['style'] .= 'position:relative;'; $attr['style'] .= 'top:auto;'; $attr['style'] .= 'left:auto;'; $attr['style'] .= 'margin:0;'; $attr['style'] .= 'border-radius:' . $this->parent_args['icon_circle_radius'] . ';'; } } else { $attr['class'] .= ' circle-no'; $attr['style'] .= 'background-color:transparent;border-color:transparent;height:auto;width: ' . fusion_library()->sanitize->get_value_with_unit( $this->parent_args['icon_size'] ) . ';line-height:normal;'; if ( 'icon-boxed' === $this->parent_args['layout'] ) { $attr['style'] .= 'position:relative;left:auto;right:auto;top:auto;margin-left:auto;margin-right:auto;'; } } if ( $this->child_args['iconflip'] && 'none' !== $this->child_args['iconflip'] ) { $attr['class'] .= ' fa-flip-' . $this->child_args['iconflip']; } if ( $this->child_args['iconrotate'] && 'none' !== $this->child_args['iconrotate'] ) { $attr['class'] .= ' fa-rotate-' . $this->child_args['iconrotate']; } if ( 'yes' === $this->child_args['iconspin'] ) { $attr['class'] .= ' fa-spin'; } $attr['style'] .= 'font-size:' . $this->parent_args['icon_size'] . ';'; } return $attr; } /** * Builds the attributes array. * * @access public * @since 1.0 * @return array */ public function content_container_attr() { $attr = [ 'class' => 'content-container', 'style' => '', ]; return $attr; } /** * Builds the attributes array. * * @access public * @since 1.0 * @return array */ public function timeline_attr() { $attr = []; if ( 'timeline-horizontal' === $this->parent_args['layout'] ) { $attr['class'] = 'content-box-shortcode-timeline'; $attr['style'] = ''; $border_color = ''; if ( $this->child_args['image'] && $this->child_args['image_width'] && $this->child_args['image_height'] ) { $full_icon_size = $this->child_args['image_height']; } elseif ( 'yes' === $this->parent_args['icon_circle'] ) { if ( intval( $this->child_args['outercirclebordersize'] ) ) { $full_icon_size = ( intval( $this->parent_args['icon_size'] ) + intval( $this->child_args['circlebordersize'] ) + intval( $this->child_args['outercirclebordersize'] ) ) * 2; } else { $full_icon_size = intval( $this->parent_args['icon_size'] ) * 2; } } else { $full_icon_size = intval( $this->parent_args['icon_size'] ); } $position_top = $full_icon_size / 2; if ( $this->child_args['backgroundcolor'] && ! Fusion_Color::new_color( $this->child_args['backgroundcolor'] )->is_color_transparent() ) { $position_top += 35; } if ( $this->child_args['circlebordercolor'] ) { $border_color = $this->child_args['circlebordercolor']; } if ( $this->child_args['outercirclebordercolor'] && $this->child_args['outercirclebordersize'] ) { $border_color = $this->child_args['outercirclebordercolor']; } if ( ! $this->child_args['circlebordercolor'] && ! $this->child_args['outercirclebordercolor'] ) { $border_color = '#f6f6f6'; } if ( $border_color ) { $attr['style'] .= 'border-color:' . $border_color . ';'; } if ( $position_top ) { $attr['style'] .= 'top:' . intval( $position_top ) . 'px;'; } } elseif ( 'timeline-vertical' === $this->parent_args['layout'] ) { $attr['class'] = 'content-box-shortcode-timeline-vertical'; $attr['style'] = ''; $border_color = ''; if ( $this->child_args['image'] && $this->child_args['image_width'] && $this->child_args['image_height'] ) { $full_icon_size = $this->child_args['image_height']; } elseif ( 'yes' === $this->parent_args['icon_circle'] ) { if ( intval( $this->child_args['outercirclebordersize'] ) ) { $full_icon_size = ( intval( $this->parent_args['icon_size'] ) + intval( $this->child_args['circlebordersize'] ) + intval( $this->child_args['outercirclebordersize'] ) ) * 2; } else { $full_icon_size = intval( $this->parent_args['icon_size'] ) * 2; } } else { $full_icon_size = intval( $this->parent_args['icon_size'] ); } $position_top = $full_icon_size / 2; if ( $this->parent_args['title_size'] > $full_icon_size ) { $position_top = $this->parent_args['title_size'] / 2; } $position_horizontal = $full_icon_size / 2 + 15; if ( $this->child_args['backgroundcolor'] && ! Fusion_Color::new_color( $this->child_args['backgroundcolor'] )->is_color_transparent() ) { $position_top += 35; $position_horizontal += 35; } if ( $this->child_args['circlebordercolor'] ) { $border_color = $this->child_args['circlebordercolor']; } if ( $this->child_args['outercirclebordercolor'] && intval( $this->child_args['outercirclebordersize'] ) ) { $border_color = $this->child_args['outercirclebordercolor']; } if ( ! $this->child_args['circlebordercolor'] && ! $this->child_args['outercirclebordercolor'] ) { $border_color = '#f6f6f6'; } if ( $border_color ) { $attr['style'] .= 'border-color:' . $border_color . ';'; } if ( $position_horizontal ) { if ( 'right' === $this->parent_args['icon_align'] ) { $attr['style'] .= 'right:' . intval( $position_horizontal ) . 'px;'; } else { $attr['style'] .= 'left:' . intval( $position_horizontal ) . 'px;'; } } if ( $position_top ) { $attr['style'] .= 'top:' . $position_top . 'px;'; } } if ( $this->parent_args['animation_delay'] ) { $animation_delay = $this->parent_args['animation_delay']; $attr['style'] .= '-webkit-transition-duration: ' . $animation_delay . 'ms;'; $attr['style'] .= 'animation-duration: ' . $animation_delay . 'ms;'; } return $attr; } /** * Builds the attributes array. * * @access public * @since 1.0 * @return array */ public function content_box_heading_attr() { $attr = [ 'class' => 'content-box-heading', 'style' => $this->get_heading_css_vars(), ]; $font_size = $this->parent_args['title_size']; if ( $this->parent_args['responsive_typography'] ) { $data = awb_get_responsive_type_data( $this->child_args['heading_size'], $font_size, '' ); $attr['class'] .= ' ' . $data['class']; $attr['style'] .= $data['font_size']; $attr['style'] .= $data['line_height']; } else { $attr['style'] .= 'line-height:' . ( $font_size + 5 ) . 'px;'; } if ( 'icon-on-side' === $this->parent_args['layout'] || 'clean-horizontal' === $this->parent_args['layout'] ) { if ( $this->child_args['image'] && $this->child_args['image_width'] && $this->child_args['image_height'] ) { if ( 'right' === $this->parent_args['icon_align'] ) { $attr['style'] .= 'padding-right:' . ( $this->child_args['image_width'] + 20 ) . 'px;'; } else { $attr['style'] .= 'padding-left:' . ( $this->child_args['image_width'] + 20 ) . 'px;'; } } elseif ( $this->child_args['icon'] ) { if ( 'yes' === $this->parent_args['icon_circle'] ) { $full_icon_size = ( intval( $this->parent_args['icon_size'] ) + intval( $this->child_args['circlebordersize'] ) + intval( $this->child_args['outercirclebordersize'] ) ) * 2; } else { $full_icon_size = intval( $this->parent_args['icon_size'] ); } if ( 'right' === $this->parent_args['icon_align'] ) { $attr['style'] .= 'padding-right:' . ( intval( $full_icon_size ) + 20 ) . 'px;'; } else { $attr['style'] .= 'padding-left:' . ( intval( $full_icon_size ) + 20 ) . 'px;'; } } } return $attr; } /** * Builds the dynamic styling. * * @access public * @since 1.1 * @return array */ public function add_styling() { global $wp_version, $content_media_query, $six_fourty_media_query, $three_twenty_six_fourty_media_query, $ipad_portrait_media_query, $fusion_settings, $dynamic_css_helpers; $main_elements = apply_filters( 'fusion_builder_element_classes', [ '.fusion-content-boxes' ], '.fusion-content-boxes' ); $elements = array_merge( $dynamic_css_helpers->map_selector( $main_elements, '.content-boxes-clean-vertical .content-box-column' ), $dynamic_css_helpers->map_selector( $main_elements, '.content-boxes-clean-horizontal .content-box-column' ) ); $css[ $content_media_query ][ $dynamic_css_helpers->implode( $elements ) ]['border-right-width'] = '1px'; $elements = $dynamic_css_helpers->map_selector( $main_elements, ' .content-box-shortcode-timeline' ); $css[ $content_media_query ][ $dynamic_css_helpers->implode( $elements ) ]['display'] = 'none'; $elements = $dynamic_css_helpers->map_selector( $main_elements, '.content-boxes-icon-boxed .content-wrapper-boxed' ); $css[ $content_media_query ][ $dynamic_css_helpers->implode( $elements ) ]['padding-bottom'] = '20px'; $css[ $content_media_query ][ $dynamic_css_helpers->implode( $elements ) ]['padding-left'] = '3%'; $css[ $content_media_query ][ $dynamic_css_helpers->implode( $elements ) ]['padding-right'] = '3%'; $css[ $six_fourty_media_query ][ $dynamic_css_helpers->implode( $elements ) ]['min-height'] = 'inherit !important'; $css[ $six_fourty_media_query ][ $dynamic_css_helpers->implode( $elements ) ]['padding-bottom'] = '20px'; $css[ $six_fourty_media_query ][ $dynamic_css_helpers->implode( $elements ) ]['padding-left'] = '3% !important'; $css[ $six_fourty_media_query ][ $dynamic_css_helpers->implode( $elements ) ]['padding-right'] = '3% !important'; $css[ $three_twenty_six_fourty_media_query ][ $dynamic_css_helpers->implode( $elements ) ]['min-height'] = 'inherit !important'; $css[ $three_twenty_six_fourty_media_query ][ $dynamic_css_helpers->implode( $elements ) ]['padding-bottom'] = '20px'; $css[ $three_twenty_six_fourty_media_query ][ $dynamic_css_helpers->implode( $elements ) ]['padding-left'] = '3% !important'; $css[ $three_twenty_six_fourty_media_query ][ $dynamic_css_helpers->implode( $elements ) ]['padding-right'] = '3% !important'; $css[ $ipad_portrait_media_query ][ $dynamic_css_helpers->implode( $elements ) ]['padding-bottom'] = '20px'; $css[ $ipad_portrait_media_query ][ $dynamic_css_helpers->implode( $elements ) ]['padding-left'] = '3%'; $css[ $ipad_portrait_media_query ][ $dynamic_css_helpers->implode( $elements ) ]['padding-right'] = '3%'; $elements = array_merge( $dynamic_css_helpers->map_selector( $main_elements, '.content-boxes-icon-on-top .content-box-column' ), $dynamic_css_helpers->map_selector( $main_elements, '.content-boxes-icon-boxed .content-box-column' ) ); $css[ $content_media_query ][ $dynamic_css_helpers->implode( $elements ) ]['margin-bottom'] = '55px'; $css[ $six_fourty_media_query ][ $dynamic_css_helpers->implode( $elements ) ]['margin-bottom'] = '55px'; $css[ $three_twenty_six_fourty_media_query ][ $dynamic_css_helpers->implode( $elements ) ]['margin-bottom'] = '55px'; $css[ $ipad_portrait_media_query ][ $dynamic_css_helpers->implode( $elements ) ]['margin-bottom'] = '55px'; for ( $i = 1; $i <= 6; $i++ ) { $elements = $dynamic_css_helpers->map_selector( $main_elements, '.content-boxes-icon-boxed .content-box-column .heading h' . $i ); $css[ $six_fourty_media_query ][ $dynamic_css_helpers->implode( $elements ) ]['margin-top'] = '-5px'; } $elements = $dynamic_css_helpers->map_selector( $main_elements, '.content-boxes-icon-boxed .content-box-column .more' ); $css[ $six_fourty_media_query ][ $dynamic_css_helpers->implode( $elements ) ]['margin-top'] = '12px'; $elements = $dynamic_css_helpers->map_selector( $main_elements, '.content-boxes-icon-boxed .col' ); $css[ $six_fourty_media_query ][ $dynamic_css_helpers->implode( $elements ) ]['box-sizing'] = 'border-box'; // Content box buttons. $elements = array_merge( $dynamic_css_helpers->map_selector( $main_elements, ' .link-type-button-bar .fusion-read-more' ) ); $css['global'][ $dynamic_css_helpers->implode( $elements ) ]['background'] = fusion_library()->sanitize->color( $fusion_settings->get( 'button_gradient_top_color' ) ); $css['global'][ $dynamic_css_helpers->implode( $elements ) ]['color'] = fusion_library()->sanitize->color( $fusion_settings->get( 'button_accent_color' ) ); if ( $fusion_settings->get( 'button_gradient_top_color' ) != $fusion_settings->get( 'button_gradient_bottom_color' ) ) { // phpcs:ignore Universal.Operators.StrictComparisons $css['global'][ $dynamic_css_helpers->implode( $elements ) ]['background-image'][] = '-webkit-gradient( linear, left bottom, left top, from( ' . fusion_library()->sanitize->color( $fusion_settings->get( 'button_gradient_bottom_color' ) ) . ' ), to( ' . fusion_library()->sanitize->color( $fusion_settings->get( 'button_gradient_top_color' ) ) . ' ) )'; $css['global'][ $dynamic_css_helpers->implode( $elements ) ]['background-image'][] = 'linear-gradient( to top, ' . fusion_library()->sanitize->color( $fusion_settings->get( 'button_gradient_bottom_color' ) ) . ', ' . fusion_library()->sanitize->color( $fusion_settings->get( 'button_gradient_top_color' ) ) . ' )'; } $elements = array_merge( $dynamic_css_helpers->map_selector( $main_elements, ' .link-type-button-bar .fusion-read-more:after' ), $dynamic_css_helpers->map_selector( $main_elements, ' .link-type-button-bar .fusion-read-more:before' ) ); $css['global'][ $dynamic_css_helpers->implode( $elements ) ]['color'] = fusion_library()->sanitize->color( $fusion_settings->get( 'button_accent_color' ) ); $elements = array_merge( $dynamic_css_helpers->map_selector( $main_elements, ' .link-type-button-bar .fusion-read-more:hover' ), $dynamic_css_helpers->map_selector( $main_elements, ' .link-type-button-bar.link-area-box:hover .fusion-read-more' ) ); $css['global'][ $dynamic_css_helpers->implode( $elements ) ]['background'] = fusion_library()->sanitize->color( $fusion_settings->get( 'button_gradient_top_color_hover' ) ); $css['global'][ $dynamic_css_helpers->implode( $elements ) ]['color'] = fusion_library()->sanitize->color( $fusion_settings->get( 'button_accent_hover_color' ) ) . '!important'; if ( $fusion_settings->get( 'button_gradient_top_color_hover' ) != $fusion_settings->get( 'button_gradient_bottom_color_hover' ) ) { // phpcs:ignore Universal.Operators.StrictComparisons $css['global'][ $dynamic_css_helpers->implode( $elements ) ]['background-image'][] = '-webkit-gradient( linear, left bottom, left top, from( ' . fusion_library()->sanitize->color( $fusion_settings->get( 'button_gradient_bottom_color_hover' ) ) . ' ), to( ' . fusion_library()->sanitize->color( $fusion_settings->get( 'button_gradient_top_color_hover' ) ) . ' ) )'; $css['global'][ $dynamic_css_helpers->implode( $elements ) ]['background-image'][] = 'linear-gradient( to top, ' . fusion_library()->sanitize->color( $fusion_settings->get( 'button_gradient_bottom_color_hover' ) ) . ', ' . fusion_library()->sanitize->color( $fusion_settings->get( 'button_gradient_top_color_hover' ) ) . ' )'; } $elements = array_merge( $dynamic_css_helpers->map_selector( $main_elements, ' .link-type-button-bar .fusion-read-more:hover:after' ), $dynamic_css_helpers->map_selector( $main_elements, ' .link-type-button-bar .fusion-read-more:hover:before' ), $dynamic_css_helpers->map_selector( $main_elements, ' .link-type-button-bar.link-area-box:hover .fusion-read-more:after' ), $dynamic_css_helpers->map_selector( $main_elements, ' .link-type-button-bar.link-area-box:hover .fusion-read-more:before' ) ); $css['global'][ $dynamic_css_helpers->implode( $elements ) ]['color'] = fusion_library()->sanitize->color( $fusion_settings->get( 'button_accent_hover_color' ) ) . '!important'; return $css; } /** * Sets the necessary scripts. * * @access public * @since 3.2 * @return void */ public function on_first_render() { Fusion_Dynamic_JS::enqueue_script( 'fusion-content-boxes', FusionBuilder::$js_folder_url . '/general/fusion-content-boxes.js', FusionBuilder::$js_folder_path . '/general/fusion-content-boxes.js', [ 'jquery', 'fusion-animations', 'fusion-equal-heights' ], FUSION_BUILDER_VERSION, true ); } /** * Load base CSS. * * @access public * @since 3.0 * @return void */ public function add_css_files() { FusionBuilder()->add_element_css( FUSION_BUILDER_PLUGIN_DIR . 'assets/css/shortcodes/content-boxes.min.css' ); } /** * Adds settings to element options panel. * * @access public * @since 1.1 * @return array $sections Content Box settings. */ public function add_options() { return [ 'content_boxes_shortcode_section' => [ 'label' => esc_html__( 'Content Boxes', 'fusion-builder' ), 'id' => 'content_boxes_shortcode_section', 'icon' => 'fusiona-newspaper', 'type' => 'accordion', 'fields' => [ 'content_box_bg_color' => [ 'label' => esc_html__( 'Content Box Background Color', 'fusion-builder' ), 'description' => esc_html__( 'Controls the background color for content boxes.', 'fusion-builder' ), 'id' => 'content_box_bg_color', 'default' => 'rgba(255,255,255,0)', 'type' => 'color-alpha', 'transport' => 'postMessage', 'css_vars' => [ [ 'name' => '--content_box_bg_color', 'callback' => [ 'sanitize_color' ], ], ], ], 'content_box_title_size' => [ 'label' => esc_html__( 'Content Box Title Font Size', 'fusion-builder' ), 'description' => esc_html__( 'Controls the size of the title text.', 'fusion-builder' ), 'id' => 'content_box_title_size', 'default' => '24', 'type' => 'slider', 'transport' => 'postMessage', 'choices' => [ 'min' => '0', 'max' => '250', 'step' => '1', ], 'css_vars' => [ [ 'name' => '--content_box_title_size', 'value_pattern' => '$px', ], ], ], 'content_box_title_color' => [ 'label' => esc_html__( 'Content Box Title Font Color', 'fusion-builder' ), 'description' => esc_html__( 'Controls the color of the title font.', 'fusion-builder' ), 'id' => 'content_box_title_color', 'default' => 'var(--awb-color8)', 'type' => 'color-alpha', 'transport' => 'postMessage', 'css_vars' => [ [ 'name' => '--content_box_title_color', 'callback' => [ 'sanitize_color' ], ], ], ], 'content_box_body_color' => [ 'label' => esc_html__( 'Content Box Body Font Color', 'fusion-builder' ), 'description' => esc_html__( 'Controls the color of the body font.', 'fusion-builder' ), 'id' => 'content_box_body_color', 'default' => 'var(--awb-color8)', 'type' => 'color-alpha', 'transport' => 'postMessage', 'css_vars' => [ [ 'name' => '--content_box_body_color', 'callback' => [ 'sanitize_color' ], ], ], ], 'content_box_icon_size' => [ 'label' => esc_html__( 'Content Box Icon Font Size', 'fusion-builder' ), 'description' => esc_html__( 'Controls the size of the icon.', 'fusion-builder' ), 'id' => 'content_box_icon_size', 'default' => '20', 'type' => 'slider', 'transport' => 'postMessage', 'choices' => [ 'min' => '0', 'max' => '250', 'step' => '1', ], ], 'content_box_icon_color' => [ 'label' => esc_html__( 'Content Box Icon Color', 'fusion-builder' ), 'description' => esc_html__( 'Controls the color of the content box icon.', 'fusion-builder' ), 'id' => 'content_box_icon_color', 'default' => 'var(--awb-color1)', 'type' => 'color-alpha', 'transport' => 'postMessage', 'css_vars' => [ [ 'name' => '--content_box_icon_color', 'callback' => [ 'sanitize_color' ], ], ], ], 'content_box_icon_circle' => [ 'label' => esc_html__( 'Content Box Icon Background', 'fusion-builder' ), 'description' => esc_html__( 'Turn on to display a background behind the icon.', 'fusion-builder' ), 'id' => 'content_box_icon_circle', 'default' => 'yes', 'type' => 'radio-buttonset', 'transport' => 'postMessage', 'choices' => [ 'yes' => esc_html__( 'On', 'fusion-builder' ), 'no' => esc_html__( 'Off', 'fusion-builder' ), ], ], 'content_box_icon_circle_radius' => [ 'label' => esc_html__( 'Content Box Icon Background Radius', 'fusion-builder' ), 'description' => esc_html__( 'Controls the border radius of the icon background.', 'fusion-builder' ), 'id' => 'content_box_icon_circle_radius', 'default' => '50%', 'type' => 'dimension', 'transport' => 'postMessage', 'soft_dependency' => true, ], 'content_box_icon_bg_color' => [ 'label' => esc_html__( 'Content Box Icon Background Color', 'fusion-builder' ), 'description' => esc_html__( 'Controls the color of the icon background.', 'fusion-builder' ), 'id' => 'content_box_icon_bg_color', 'default' => 'var(--awb-color7)', 'type' => 'color-alpha', 'transport' => 'postMessage', 'soft_dependency' => true, ], 'content_box_icon_bg_inner_border_color' => [ 'label' => esc_html__( 'Content Box Icon Background Inner Border Color', 'fusion-builder' ), 'description' => esc_html__( 'Controls the inner border color of the icon background.', 'fusion-builder' ), 'id' => 'content_box_icon_bg_inner_border_color', 'default' => 'var(--awb-color8)', 'type' => 'color-alpha', 'transport' => 'postMessage', 'soft_dependency' => true, ], 'content_box_icon_bg_inner_border_size' => [ 'label' => esc_html__( 'Content Box Icon Background Inner Border Size', 'fusion-builder' ), 'description' => esc_html__( 'Controls the inner border size of the icon background.', 'fusion-builder' ), 'id' => 'content_box_icon_bg_inner_border_size', 'default' => '1', 'type' => 'slider', 'transport' => 'postMessage', 'choices' => [ 'min' => '0', 'max' => '20', 'step' => '1', ], 'soft_dependency' => true, ], 'content_box_icon_bg_outer_border_color' => [ 'label' => esc_html__( 'Content Box Icon Background Outer Border Color', 'fusion-builder' ), 'description' => esc_html__( 'Controls the outer border color of the icon background.', 'fusion-builder' ), 'id' => 'content_box_icon_bg_outer_border_color', 'default' => 'rgba(255,255,255,0)', 'type' => 'color-alpha', 'transport' => 'postMessage', 'soft_dependency' => true, ], 'content_box_icon_bg_outer_border_size' => [ 'label' => esc_html__( 'Content Box Icon Background Outer Border Size', 'fusion-builder' ), 'description' => esc_html__( 'Controls the outer border size of the icon background.', 'fusion-builder' ), 'id' => 'content_box_icon_bg_outer_border_size', 'default' => '1', 'type' => 'slider', 'transport' => 'postMessage', 'choices' => [ 'min' => '0', 'max' => '20', 'step' => '1', ], 'soft_dependency' => true, ], 'content_box_icon_hover_type' => [ 'label' => esc_html__( 'Content Box Hover Animation Type', 'fusion-builder' ), 'description' => esc_html__( 'Controls the hover effect of the icon.', 'fusion-builder' ), 'id' => 'content_box_icon_hover_type', 'default' => 'fade', 'type' => 'radio-buttonset', 'transport' => 'postMessage', 'choices' => [ 'none' => esc_html__( 'None', 'fusion-builder' ), 'fade' => esc_html__( 'Fade', 'fusion-builder' ), 'slide' => esc_html__( 'Slide', 'fusion-builder' ), 'pulsate' => esc_html__( 'Pulsate', 'fusion-builder' ), ], ], 'content_box_hover_animation_accent_color' => [ 'label' => esc_html__( 'Content Box Hover Accent Color', 'fusion-builder' ), 'description' => esc_html__( 'Controls the accent color on hover.', 'fusion-builder' ), 'id' => 'content_box_hover_animation_accent_color', 'default' => 'var(--awb-color4)', 'type' => 'color-alpha', 'transport' => 'postMessage', 'css_vars' => [ [ 'name' => '--content_box_hover_animation_accent_color', 'callback' => [ 'sanitize_color' ], ], ], ], 'content_box_link_type' => [ 'label' => esc_html__( 'Content Box Link Type', 'fusion-builder' ), 'description' => esc_html__( 'Controls the type of link that displays in the content box.', 'fusion-builder' ), 'id' => 'content_box_link_type', 'default' => 'text', 'type' => 'radio-buttonset', 'transport' => 'postMessage', 'choices' => [ 'text' => esc_html__( 'Text', 'fusion-builder' ), 'button-bar' => esc_html__( 'Button Bar', 'fusion-builder' ), 'button' => esc_html__( 'Button', 'fusion-builder' ), ], ], 'content_box_button_span' => [ 'label' => esc_html__( 'Button Span', 'fusion-builder' ), 'description' => esc_html__( 'Choose to have the button span the full width.', 'fusion-builder' ), 'id' => 'content_box_button_span', 'default' => 'no', 'type' => 'radio-buttonset', 'transport' => 'postMessage', 'choices' => [ 'yes' => esc_html__( 'Yes', 'fusion-builder' ), 'no' => esc_html__( 'No', 'fusion-builder' ), ], 'soft_dependency' => true, ], 'content_box_link_area' => [ 'label' => esc_html__( 'Content Box Link Area', 'fusion-builder' ), 'description' => esc_html__( 'Controls which area the link will be assigned to.', 'fusion-builder' ), 'id' => 'content_box_link_area', 'default' => 'link-icon', 'type' => 'radio-buttonset', 'transport' => 'postMessage', 'choices' => [ 'link-icon' => esc_html__( 'Link + Icon', 'fusion-builder' ), 'box' => esc_html__( 'Entire Content Box', 'fusion-builder' ), ], ], 'content_box_link_target' => [ 'label' => esc_html__( 'Content Box Link Target', 'fusion-builder' ), 'description' => esc_html__( 'Controls how the link will open.', 'fusion-builder' ), 'id' => 'content_box_link_target', 'default' => '_self', 'type' => 'radio-buttonset', 'transport' => 'postMessage', 'choices' => [ '_self' => esc_html__( 'Same Window/Tab', 'fusion-builder' ), '_blank' => esc_html__( 'New Window/Tab', 'fusion-builder' ), ], ], 'content_box_margin' => [ 'label' => esc_html__( 'Content Box Top/Bottom Margins', 'fusion-builder' ), 'description' => esc_html__( 'Controls the top/bottom margin for content boxes.', 'fusion-builder' ), 'id' => 'content_box_margin', 'type' => 'spacing', 'transport' => 'postMessage', 'choices' => [ 'top' => true, 'bottom' => true, ], 'default' => [ 'top' => '', 'bottom' => '', ], 'css_vars' => [ [ 'name' => '--content_box_margin_top', 'choice' => 'top', ], [ 'name' => '--content_box_margin_bottom', 'choice' => 'bottom', ], ], ], ], ], ]; } } } new FusionSC_ContentBoxes(); } /** * Map shortcode to Avada Builder. * * @since 1.0 */ function fusion_element_content_boxes() { $fusion_settings = awb_get_fusion_settings(); fusion_builder_map( fusion_builder_frontend_data( 'FusionSC_ContentBoxes', [ 'name' => esc_attr__( 'Content Boxes', 'fusion-builder' ), 'shortcode' => 'fusion_content_boxes', 'multi' => 'multi_element_parent', 'element_child' => 'fusion_content_box', 'icon' => 'fusiona-newspaper', 'child_ui' => true, 'preview' => FUSION_BUILDER_PLUGIN_DIR . 'inc/templates/previews/fusion-content-boxes-preview.php', 'preview_id' => 'fusion-builder-block-module-content-boxes-preview-template', 'help_url' => 'https://avada.com/documentation/content-boxes-element/', 'params' => [ [ 'type' => 'textfield', 'heading' => esc_attr__( 'Dynamic Content', 'fusion-builder' ), 'param_name' => 'parent_dynamic_content', 'dynamic_data' => true, 'dynamic_options' => [ 'acf_repeater_parent' ], 'group' => esc_attr__( 'children', 'fusion-builder' ), ], [ 'type' => 'tinymce', 'heading' => esc_attr__( 'Content', 'fusion-builder' ), 'description' => esc_attr__( 'Enter some content for this content box.', 'fusion-builder' ), 'param_name' => 'element_content', 'value' => '[fusion_content_box title="' . esc_attr__( 'Your Content Goes Here', 'fusion-builder' ) . '" backgroundcolor="" icon="" iconflip="" iconrotate="" iconspin="" iconcolor="" circlecolor="" circlebordercolor="" image="" image_id="" image_max_width="" link="" linktext="Read More" animation_type="" animation_direction="left" animation_speed="0.3" ]' . esc_attr__( 'Your Content Goes Here', 'fusion-builder' ) . '[/fusion_content_box]', ], [ 'type' => 'select', 'heading' => esc_attr__( 'Box Layout', 'fusion-builder' ), 'description' => esc_attr__( 'Select the layout for the content box.', 'fusion-builder' ), 'param_name' => 'layout', 'default' => 'icon-with-title', 'value' => [ 'icon-with-title' => esc_attr__( 'Classic Icon With Title', 'fusion-builder' ), 'icon-on-top' => esc_attr__( 'Classic Icon On Top', 'fusion-builder' ), 'icon-on-side' => esc_attr__( 'Classic Icon On Side', 'fusion-builder' ), 'icon-boxed' => esc_attr__( 'Classic Icon Boxed', 'fusion-builder' ), 'clean-vertical' => esc_attr__( 'Clean Layout Vertical', 'fusion-builder' ), 'clean-horizontal' => esc_attr__( 'Clean Layout Horizontal', 'fusion-builder' ), 'timeline-vertical' => esc_attr__( 'Timeline Vertical', 'fusion-builder' ), 'timeline-horizontal' => esc_attr__( 'Timeline Horizontal', 'fusion-builder' ), ], ], [ 'type' => 'range', 'heading' => esc_attr__( 'Number of Columns', 'fusion-builder' ), 'description' => esc_attr__( 'Set the number of columns per row.', 'fusion-builder' ), 'param_name' => 'columns', 'value' => '1', 'min' => '1', 'max' => '6', 'step' => '1', 'dependency' => [ [ 'element' => 'layout', 'value' => 'timeline-vertical', 'operator' => '!=', ], ], ], [ 'type' => 'radio_button_set', 'heading' => esc_attr__( 'Alignment', 'fusion-builder' ), 'description' => esc_attr__( 'Defines how the content boxes should align within the container.', 'fusion-builder' ), 'param_name' => 'alignment', 'default' => '', 'group' => esc_attr__( 'General', 'fusion-builder' ), 'value' => [ '' => esc_attr__( 'Default', 'fusion-builder' ), 'flex-start' => esc_attr__( 'Flex Start', 'fusion-builder' ), 'center' => esc_attr__( 'Center', 'fusion-builder' ), 'flex-end' => esc_attr__( 'Flex End', 'fusion-builder' ), 'stretch' => esc_attr__( 'Stretch', 'fusion-builder' ), ], 'icons' => [ '' => '<span class="fusiona-cog"></span>', 'flex-start' => '<span class="fusiona-align-top-columns"></span>', 'center' => '<span class="fusiona-align-center-columns"></span>', 'flex-end' => '<span class="fusiona-align-bottom-columns"></span>', 'stretch' => '<span class="fusiona-full-height"></span>', ], 'grid_layout' => true, 'back_icons' => true, ], [ 'type' => 'textfield', 'heading' => esc_attr__( 'Title Size', 'fusion-builder' ), 'description' => esc_attr__( 'Controls the size of the title. In pixels ex: 18px.', 'fusion-builder' ), 'param_name' => 'title_size', 'value' => '', 'group' => esc_attr__( 'Design', 'fusion-builder' ), ], [ 'type' => 'radio_button_set', 'heading' => esc_attr__( 'HTML Heading Tag', 'fusion-builder' ), 'description' => esc_attr__( 'Choose HTML tag of the heading, either div, p or the heading tag, h1-h6.', 'fusion-builder' ), 'param_name' => 'heading_size', 'group' => esc_attr__( 'Design', 'fusion-builder' ), 'value' => [ '1' => 'H1', '2' => 'H2', '3' => 'H3', '4' => 'H4', '5' => 'H5', '6' => 'H6', 'div' => 'DIV', 'p' => 'P', ], 'default' => '2', ], [ 'type' => 'colorpickeralpha', 'heading' => esc_attr__( 'Title Font Color', 'fusion-builder' ), 'description' => esc_attr__( 'Controls the color of the title font. ex: #000.', 'fusion-builder' ), 'param_name' => 'title_color', 'value' => '', 'default' => $fusion_settings->get( 'content_box_title_color' ), 'group' => esc_attr__( 'Design', 'fusion-builder' ), ], [ 'type' => 'colorpickeralpha', 'heading' => esc_attr__( 'Body Font Color', 'fusion-builder' ), 'description' => esc_attr__( 'Controls the color of the body font. ex: #000.', 'fusion-builder' ), 'param_name' => 'body_color', 'value' => '', 'default' => $fusion_settings->get( 'content_box_body_color' ), 'group' => esc_attr__( 'Design', 'fusion-builder' ), ], [ 'type' => 'colorpickeralpha', 'heading' => esc_attr__( 'Content Box Background Color', 'fusion-builder' ), 'description' => '', 'param_name' => 'backgroundcolor', 'value' => '', 'default' => $fusion_settings->get( 'content_box_bg_color' ), 'group' => esc_attr__( 'Design', 'fusion-builder' ), ], [ 'type' => 'dimension', 'remove_from_atts' => true, 'heading' => esc_attr__( 'Border Radius', 'fusion-builder' ), 'description' => __( 'Enter values including any valid CSS unit, ex: 10px.', 'fusion-builder' ), 'param_name' => 'border_radius', 'group' => esc_attr__( 'Design', 'fusion-builder' ), 'value' => [ 'border_radius_top_left' => '', 'border_radius_top_right' => '', 'border_radius_bottom_right' => '', 'border_radius_bottom_left' => '', ], ], 'fusion_box_shadow_placeholder' => [ 'dependency' => [ [ 'element' => 'box_shadow', 'value' => 'yes', 'operator' => '==', ], ], ], [ 'type' => 'iconpicker', 'heading' => esc_attr__( 'Icon', 'fusion-builder' ), 'param_name' => 'icon', 'value' => '', 'description' => esc_attr__( 'Global setting for all content boxes, this can be overridden individually. Click an icon to select, click again to deselect.', 'fusion-builder' ), 'group' => esc_attr__( 'Design', 'fusion-builder' ), ], [ 'type' => 'radio_button_set', 'heading' => esc_attr__( 'Flip Icon', 'fusion-builder' ), 'description' => esc_attr__( 'Choose to flip the icon.', 'fusion-builder' ), 'param_name' => 'iconflip', 'value' => [ '' => esc_attr__( 'None', 'fusion-builder' ), 'horizontal' => esc_attr__( 'Horizontal', 'fusion-builder' ), 'vertical' => esc_attr__( 'Vertical', 'fusion-builder' ), ], 'default' => '', 'group' => esc_attr__( 'Design', 'fusion-builder' ), ], [ 'type' => 'radio_button_set', 'heading' => esc_attr__( 'Rotate Icon', 'fusion-builder' ), 'description' => esc_attr__( 'Choose to rotate the icon.', 'fusion-builder' ), 'param_name' => 'iconrotate', 'value' => [ '' => esc_attr__( 'None', 'fusion-builder' ), '90' => '90', '180' => '180', '270' => '270', ], 'default' => '', 'group' => esc_attr__( 'Design', 'fusion-builder' ), ], [ 'type' => 'radio_button_set', 'heading' => esc_attr__( 'Spinning Icon', 'fusion-builder' ), 'description' => esc_attr__( 'Choose to let the icon spin.', 'fusion-builder' ), 'param_name' => 'iconspin', 'value' => [ 'yes' => esc_attr__( 'Yes', 'fusion-builder' ), 'no' => esc_attr__( 'No', 'fusion-builder' ), ], 'default' => 'no', 'group' => esc_attr__( 'Design', 'fusion-builder' ), ], [ 'type' => 'colorpickeralpha', 'heading' => esc_attr__( 'Icon Color', 'fusion-builder' ), 'description' => '', 'param_name' => 'iconcolor', 'value' => '', 'default' => $fusion_settings->get( 'content_box_icon_color' ), 'group' => esc_attr__( 'Design', 'fusion-builder' ), 'states' => [ 'hover' => [ 'label' => __( 'Hover', 'fusion-builder' ), 'default' => '', 'preview' => [ 'selector' => '.icon', 'type' => 'class', 'toggle' => 'hover', ], ], ], 'connect-state' => [ 'circlecolor' ], ], [ 'type' => 'radio_button_set', 'heading' => esc_attr__( 'Icon Background', 'fusion-builder' ), 'description' => esc_attr__( 'Choose to show a background behind the icon. Select default for Global Options selection.', 'fusion-builder' ), 'param_name' => 'icon_circle', 'value' => [ '' => esc_attr__( 'Default', 'fusion-builder' ), 'yes' => esc_attr__( 'Yes', 'fusion-builder' ), 'no' => esc_attr__( 'No', 'fusion-builder' ), ], 'child_dependency' => true, 'default' => '', 'group' => esc_attr__( 'Design', 'fusion-builder' ), ], [ 'type' => 'textfield', 'heading' => esc_attr__( 'Icon Background Radius', 'fusion-builder' ), 'description' => esc_attr__( 'Choose the border radius of the icon background. In pixels (px), ex: 1px, or "round".', 'fusion-builder' ), 'param_name' => 'icon_circle_radius', 'value' => '', 'group' => esc_attr__( 'Design', 'fusion-builder' ), 'dependency' => [ [ 'element' => 'icon_circle', 'value' => 'no', 'operator' => '!=', ], ], ], [ 'type' => 'colorpickeralpha', 'heading' => esc_attr__( 'Icon Background Color', 'fusion-builder' ), 'description' => '', 'param_name' => 'circlecolor', 'value' => '', 'default' => $fusion_settings->get( 'content_box_icon_bg_color' ), 'group' => esc_attr__( 'Design', 'fusion-builder' ), 'dependency' => [ [ 'element' => 'icon_circle', 'value' => 'no', 'operator' => '!=', ], ], 'states' => [ 'hover' => [ 'label' => __( 'Hover', 'fusion-builder' ), 'default' => '', 'preview' => [ 'selector' => '.icon', 'type' => 'class', 'toggle' => 'hover', ], ], ], 'connect-state' => [ 'circlecolor' ], ], [ 'type' => 'range', 'heading' => esc_attr__( 'Icon Background Inner Border Size', 'fusion-builder' ), 'description' => '', 'param_name' => 'circlebordersize', 'value' => '', 'min' => '0', 'max' => '20', 'step' => '1', 'default' => $fusion_settings->get( 'content_box_icon_bg_inner_border_size' ), 'group' => esc_attr__( 'Design', 'fusion-builder' ), 'dependency' => [ [ 'element' => 'icon_circle', 'value' => 'no', 'operator' => '!=', ], ], ], [ 'type' => 'colorpickeralpha', 'heading' => esc_attr__( 'Icon Background Inner Border Color', 'fusion-builder' ), 'description' => '', 'param_name' => 'circlebordercolor', 'value' => '', 'default' => $fusion_settings->get( 'content_box_icon_bg_inner_border_color' ), 'group' => esc_attr__( 'Design', 'fusion-builder' ), 'dependency' => [ [ 'element' => 'icon_circle', 'value' => 'no', 'operator' => '!=', ], [ 'element' => 'circlebordersize', 'value' => '0', 'operator' => '!=', ], ], ], [ 'type' => 'range', 'heading' => esc_attr__( 'Icon Background Outer Border Size', 'fusion-builder' ), 'description' => '', 'param_name' => 'outercirclebordersize', 'value' => '', 'min' => '0', 'max' => '20', 'step' => '1', 'default' => $fusion_settings->get( 'content_box_icon_bg_outer_border_size' ), 'group' => esc_attr__( 'Design', 'fusion-builder' ), 'dependency' => [ [ 'element' => 'icon_circle', 'value' => 'no', 'operator' => '!=', ], ], ], [ 'type' => 'colorpickeralpha', 'heading' => esc_attr__( 'Icon Background Outer Border Color', 'fusion-builder' ), 'description' => '', 'param_name' => 'outercirclebordercolor', 'value' => '', 'default' => $fusion_settings->get( 'content_box_icon_bg_outer_border_color' ), 'group' => esc_attr__( 'Design', 'fusion-builder' ), 'dependency' => [ [ 'element' => 'icon_circle', 'value' => 'no', 'operator' => '!=', ], [ 'element' => 'outercirclebordersize', 'value' => '0', 'operator' => '!=', ], ], ], [ 'type' => 'range', 'heading' => esc_attr__( 'Icon Size', 'fusion-builder' ), 'description' => esc_attr__( 'Controls the size of the icon. In pixels.', 'fusion-builder' ), 'param_name' => 'icon_size', 'value' => '', 'min' => '0', 'max' => '250', 'step' => '1', 'default' => $fusion_settings->get( 'content_box_icon_size' ), 'group' => esc_attr__( 'Design', 'fusion-builder' ), ], [ 'type' => 'select', 'heading' => esc_attr__( 'Icon Hover Animation Type', 'fusion-builder' ), 'description' => esc_attr__( 'Select the animation type for icon on hover. Select default for Global Options selection.', 'fusion-builder' ), 'param_name' => 'icon_hover_type', 'group' => esc_attr__( 'Design', 'fusion-builder' ), 'value' => [ '' => esc_attr__( 'Default', 'fusion-builder' ), 'none' => esc_attr__( 'None', 'fusion-builder' ), 'fade' => esc_attr__( 'Fade', 'fusion-builder' ), 'slide' => esc_attr__( 'Slide', 'fusion-builder' ), 'pulsate' => esc_attr__( 'Pulsate', 'fusion-builder' ), ], 'default' => '', 'preview' => [ 'selector' => '.link-area-box,.link-area-link-icon,.link-area-link-icon', 'type' => 'class', 'toggle' => '-hover', 'append' => true, ], ], [ 'type' => 'colorpickeralpha', 'heading' => esc_attr__( 'Hover Accent Color', 'fusion-builder' ), 'description' => esc_attr__( 'Controls the accent color on hover.', 'fusion-builder' ), 'param_name' => 'hover_accent_color', 'value' => '', 'default' => $fusion_settings->get( 'content_box_hover_animation_accent_color' ), 'group' => esc_attr__( 'Design', 'fusion-builder' ), 'preview' => [ 'selector' => '.link-area-box,.link-area-link-icon,.link-area-link-icon', 'type' => 'class', 'toggle' => '-hover', 'append' => true, ], ], [ 'type' => 'upload', 'heading' => esc_attr__( 'Icon Image', 'fusion-builder' ), 'description' => esc_attr__( 'To upload your own icon image, deselect the icon above and then upload your icon image.', 'fusion-builder' ), 'param_name' => 'image', 'value' => '', 'group' => esc_attr__( 'Design', 'fusion-builder' ), ], [ 'type' => 'textfield', 'heading' => esc_attr__( 'Icon Image ID', 'fusion-builder' ), 'description' => esc_attr__( 'Icon Image ID from Media Library.', 'fusion-builder' ), 'param_name' => 'image_id', 'value' => '', 'hidden' => true, 'group' => esc_attr__( 'Design', 'fusion-builder' ), ], [ 'type' => 'textfield', 'heading' => esc_attr__( 'Icon Image Max Width', 'fusion-builder' ), 'description' => esc_attr__( 'Set the icon image max width. Leave empty to use image\'s native width. In pixels, ex: 35.', 'fusion-builder' ), 'param_name' => 'image_max_width', 'default' => '35', 'group' => esc_attr__( 'Design', 'fusion-builder' ), ], [ 'type' => 'radio_button_set', 'heading' => esc_attr__( 'Link Type', 'fusion-builder' ), 'description' => esc_attr__( 'Select the type of link that should show in the content box. Select default for Global Options selection.', 'fusion-builder' ), 'param_name' => 'link_type', 'value' => [ '' => esc_attr__( 'Default', 'fusion-builder' ), 'text' => esc_attr__( 'Text', 'fusion-builder' ), 'button-bar' => esc_attr__( 'Button Bar', 'fusion-builder' ), 'button' => esc_attr__( 'Button', 'fusion-builder' ), ], 'default' => '', ], [ 'type' => 'radio_button_set', 'heading' => esc_attr__( 'Button Span', 'fusion-builder' ), 'description' => esc_attr__( 'Choose to have the button span the full width.', 'fusion-builder' ), 'param_name' => 'button_span', 'value' => [ '' => esc_attr__( 'Default', 'fusion-builder' ), 'yes' => esc_attr__( 'Yes', 'fusion-builder' ), 'no' => esc_attr__( 'No', 'fusion-builder' ), ], 'default' => '', 'dependency' => [ [ 'element' => 'link_type', 'value' => 'text', 'operator' => '!=', ], [ 'element' => 'link_type', 'value' => 'button-bar', 'operator' => '!=', ], ], ], [ 'type' => 'select', 'heading' => esc_attr__( 'Link Area', 'fusion-builder' ), 'description' => esc_attr__( 'Select which area the link will be assigned to. Select default for Global Options selection.', 'fusion-builder' ), 'param_name' => 'link_area', 'value' => [ '' => esc_attr__( 'Default', 'fusion-builder' ), 'link-icon' => esc_attr__( 'Link+Icon', 'fusion-builder' ), 'box' => esc_attr__( 'Entire Content Box', 'fusion-builder' ), ], 'default' => '', ], [ 'type' => 'radio_button_set', 'heading' => esc_attr__( 'Link Target', 'fusion-builder' ), 'description' => __( '_self = open in same window <br />_blank = open in new window', 'fusion-builder' ), 'param_name' => 'link_target', 'value' => [ '' => esc_attr__( 'Default', 'fusion-builder' ), '_self' => esc_attr__( 'Same Window', 'fusion-builder' ), '_blank' => esc_attr__( 'New Window/Tab', 'fusion-builder' ), ], 'default' => '', ], [ 'type' => 'radio_button_set', 'heading' => esc_attr__( 'Content Alignment', 'fusion-builder' ), 'description' => esc_attr__( 'Works with "Classic Icon With Title" and "Classic Icon On Side" layout options.', 'fusion-builder' ), 'param_name' => 'icon_align', 'value' => [ 'left' => esc_attr__( 'Left', 'fusion-builder' ), 'right' => esc_attr__( 'Right', 'fusion-builder' ), ], 'default' => 'left', ], [ 'type' => 'select', 'heading' => esc_attr__( 'Animation Type', 'fusion-builder' ), 'description' => esc_attr__( 'Select the type of animation to use on the element.', 'fusion-builder' ), 'param_name' => 'animation_type', 'value' => fusion_builder_available_animations(), 'default' => '', 'dependency' => [ [ 'element' => 'layout', 'value' => 'timeline-vertical', 'operator' => '!=', ], [ 'element' => 'layout', 'value' => 'timeline-horizontal', 'operator' => '!=', ], ], 'preview' => [ 'selector' => '.content-box-column', 'type' => 'animation', ], ], [ 'type' => 'radio_button_set', 'heading' => esc_attr__( 'Direction of Animation', 'fusion-builder' ), 'description' => esc_attr__( 'Select the incoming direction for the animation.', 'fusion-builder' ), 'param_name' => 'animation_direction', 'value' => [ 'down' => esc_attr__( 'Top', 'fusion-builder' ), 'right' => esc_attr__( 'Right', 'fusion-builder' ), 'up' => esc_attr__( 'Bottom', 'fusion-builder' ), 'left' => esc_attr__( 'Left', 'fusion-builder' ), 'static' => esc_attr__( 'Static', 'fusion-builder' ), ], 'default' => 'left', 'dependency' => [ [ 'element' => 'animation_type', 'value' => '', 'operator' => '!=', ], [ 'element' => 'layout', 'value' => 'timeline-vertical', 'operator' => '!=', ], [ 'element' => 'layout', 'value' => 'timeline-horizontal', 'operator' => '!=', ], ], 'preview' => [ 'selector' => '.content-box-column', 'type' => 'animation', ], ], [ 'type' => 'colorpickeralpha', 'heading' => esc_attr__( 'Animation Color', 'fusion-builder' ), 'description' => esc_attr__( 'Select the color of the animation', 'fusion-builder' ), 'param_name' => 'animation_color', 'default' => 'var(--primary_color)', 'dependency' => [ [ 'element' => 'animation_type', 'value' => 'reveal', 'operator' => '==', ], ], 'preview' => [ 'selector' => '.link-area-box,.link-area-link-icon,.link-area-link-icon', 'type' => 'animation', ], ], [ 'type' => 'range', 'heading' => esc_attr__( 'Speed of Animation', 'fusion-builder' ), 'description' => esc_attr__( 'Type in speed of animation in seconds (0.1 - 5).', 'fusion-builder' ), 'param_name' => 'animation_speed', 'min' => '0.1', 'max' => '5', 'step' => '0.1', 'value' => '0.3', 'dependency' => [ [ 'element' => 'animation_type', 'value' => '', 'operator' => '!=', ], [ 'element' => 'layout', 'value' => 'timeline-vertical', 'operator' => '!=', ], [ 'element' => 'layout', 'value' => 'timeline-horizontal', 'operator' => '!=', ], ], 'preview' => [ 'selector' => '.content-box-column', 'type' => 'animation', ], ], [ 'type' => 'range', 'heading' => esc_attr__( 'Animation Delay', 'fusion-builder' ), 'description' => esc_attr__( 'Controls the delay of animation between each element in a set. In seconds (0.0 - 5.0).', 'fusion-builder' ), 'param_name' => 'animation_delay', 'min' => '0', 'max' => '5', 'step' => '0.1', 'value' => '0', 'dependency' => [ [ 'element' => 'animation_type', 'value' => '', 'operator' => '!=', ], [ 'element' => 'layout', 'value' => 'timeline-vertical', 'operator' => '!=', ], [ 'element' => 'layout', 'value' => 'timeline-horizontal', 'operator' => '!=', ], ], 'preview' => [ 'selector' => '.content-box-column', 'type' => 'animation', ], ], [ 'type' => 'select', 'heading' => esc_attr__( 'Offset of Animation', 'fusion-builder' ), 'description' => esc_attr__( 'Controls when the animation should start.', 'fusion-builder' ), 'param_name' => 'animation_offset', 'value' => [ '' => esc_attr__( 'Default', 'fusion-builder' ), 'top-into-view' => esc_attr__( 'Top of element hits bottom of viewport', 'fusion-builder' ), 'top-mid-of-view' => esc_attr__( 'Top of element hits middle of viewport', 'fusion-builder' ), 'bottom-in-view' => esc_attr__( 'Bottom of element enters viewport', 'fusion-builder' ), ], 'default' => '', 'dependency' => [ [ 'element' => 'animation_type', 'value' => '', 'operator' => '!=', ], [ 'element' => 'layout', 'value' => 'timeline-vertical', 'operator' => '!=', ], [ 'element' => 'layout', 'value' => 'timeline-horizontal', 'operator' => '!=', ], ], ], 'fusion_margin_placeholder' => [ 'param_name' => 'dimensions', 'description' => esc_attr__( 'Spacing above and below the content boxes. In px, em or %, e.g. 10px.', 'fusion-builder' ), ], [ 'type' => 'dimension', 'remove_from_atts' => true, 'heading' => esc_attr__( 'Item Margin', 'fusion-builder' ), 'description' => esc_attr__( 'Spacing above and below each item boxes. In px, em or %, e.g. 10px.', 'fusion-builder' ), 'param_name' => 'item_margin', 'group' => esc_attr__( 'Design', 'fusion-builder' ), 'value' => [ 'item_margin_top' => '', 'item_margin_bottom' => '', ], ], [ 'type' => 'checkbox_button_set', 'heading' => esc_attr__( 'Element Visibility', 'fusion-builder' ), 'param_name' => 'hide_on_mobile', 'value' => fusion_builder_visibility_options( 'full' ), 'default' => fusion_builder_default_visibility( 'array' ), 'description' => esc_attr__( 'Choose to show or hide the element on small, medium or large screens. You can choose more than one at a time.', 'fusion-builder' ), ], [ 'type' => 'textfield', 'heading' => esc_attr__( 'CSS Class', 'fusion-builder' ), 'description' => esc_attr__( 'Add a class to the wrapping HTML element.', 'fusion-builder' ), 'param_name' => 'class', 'value' => '', 'group' => esc_attr__( 'General', 'fusion-builder' ), ], [ 'type' => 'textfield', 'heading' => esc_attr__( 'CSS ID', 'fusion-builder' ), 'description' => esc_attr__( 'Add an ID to the wrapping HTML element.', 'fusion-builder' ), 'param_name' => 'id', 'value' => '', 'group' => esc_attr__( 'General', 'fusion-builder' ), ], ], ], 'parent' ) ); } add_action( 'fusion_builder_before_init', 'fusion_element_content_boxes' ); /** * Map shortcode to Avada Builder. * * @since 1.0 */ function fusion_element_content_box() { $fusion_settings = awb_get_fusion_settings(); fusion_builder_map( fusion_builder_frontend_data( 'FusionSC_ContentBoxes', [ 'name' => esc_attr__( 'Content Box', 'fusion-builder' ), 'description' => esc_attr__( 'Enter some content for this textblock', 'fusion-builder' ), 'shortcode' => 'fusion_content_box', 'hide_from_builder' => true, 'allow_generator' => true, 'inline_editor' => true, 'inline_editor_shortcodes' => true, 'params' => [ [ 'type' => 'textfield', 'heading' => esc_attr__( 'Title', 'fusion-builder' ), 'description' => esc_attr__( 'The box title.', 'fusion-builder' ), 'param_name' => 'title', 'value' => esc_attr__( 'Your Content Goes Here', 'fusion-builder' ), 'placeholder' => true, 'dynamic_data' => true, ], [ 'type' => 'colorpickeralpha', 'heading' => esc_attr__( 'Content Box Background Color', 'fusion-builder' ), 'description' => '', 'param_name' => 'backgroundcolor', 'value' => '', 'default' => $fusion_settings->get( 'content_box_bg_color' ), ], [ 'type' => 'iconpicker', 'heading' => esc_attr__( 'Icon', 'fusion-builder' ), 'param_name' => 'icon', 'value' => '', 'description' => esc_attr__( 'Click an icon to select, click again to deselect.', 'fusion-builder' ), 'dependency' => [ [ 'element' => 'image', 'value' => '', 'operator' => '==', ], ], ], [ 'type' => 'radio_button_set', 'heading' => esc_attr__( 'Flip Icon', 'fusion-builder' ), 'description' => esc_attr__( 'Choose to flip the icon.', 'fusion-builder' ), 'param_name' => 'iconflip', 'value' => [ '' => esc_attr__( 'Default', 'fusion-builder' ), 'none' => esc_attr__( 'None', 'fusion-builder' ), 'horizontal' => esc_attr__( 'Horizontal', 'fusion-builder' ), 'vertical' => esc_attr__( 'Vertical', 'fusion-builder' ), ], 'default' => '', 'dependency' => [ [ 'element' => 'icon', 'value' => '', 'operator' => '!=', ], [ 'element' => 'image', 'value' => '', 'operator' => '==', ], ], ], [ 'type' => 'radio_button_set', 'heading' => esc_attr__( 'Rotate Icon', 'fusion-builder' ), 'description' => esc_attr__( 'Choose to rotate the icon.', 'fusion-builder' ), 'param_name' => 'iconrotate', 'value' => [ '' => esc_attr__( 'Default', 'fusion-builder' ), 'none' => esc_attr__( 'None', 'fusion-builder' ), '90' => '90', '180' => '180', '270' => '270', ], 'default' => '', 'dependency' => [ [ 'element' => 'icon', 'value' => '', 'operator' => '!=', ], [ 'element' => 'image', 'value' => '', 'operator' => '==', ], ], ], [ 'type' => 'radio_button_set', 'heading' => esc_attr__( 'Spinning Icon', 'fusion-builder' ), 'description' => esc_attr__( 'Choose to let the icon spin.', 'fusion-builder' ), 'param_name' => 'iconspin', 'value' => [ '' => esc_attr__( 'Default', 'fusion-builder' ), 'yes' => esc_attr__( 'Yes', 'fusion-builder' ), 'no' => esc_attr__( 'No', 'fusion-builder' ), ], 'default' => '', 'dependency' => [ [ 'element' => 'icon', 'value' => '', 'operator' => '!=', ], [ 'element' => 'image', 'value' => '', 'operator' => '==', ], ], ], [ 'type' => 'colorpickeralpha', 'heading' => esc_attr__( 'Icon Color', 'fusion-builder' ), 'description' => esc_attr__( 'Controls the color of the icon. ', 'fusion-builder' ), 'param_name' => 'iconcolor', 'value' => '', 'default' => $fusion_settings->get( 'content_box_icon_color' ), 'dependency' => [ [ 'element' => 'icon', 'value' => '', 'operator' => '!=', ], [ 'element' => 'image', 'value' => '', 'operator' => '==', ], ], 'states' => [ 'hover' => [ 'label' => __( 'Hover', 'fusion-builder' ), 'default' => '', 'preview' => [ 'selector' => '.icon', 'type' => 'class', 'toggle' => 'hover', ], ], ], 'connect-state' => [ 'circlecolor' ], ], [ 'type' => 'colorpickeralpha', 'heading' => esc_attr__( 'Icon Background Color', 'fusion-builder' ), 'description' => esc_attr__( 'Choose to show a background behind the icon.', 'fusion-builder' ), 'param_name' => 'circlecolor', 'value' => '', 'default' => $fusion_settings->get( 'content_box_icon_bg_color' ), 'dependency' => [ [ 'element' => 'icon', 'value' => '', 'operator' => '!=', ], [ 'element' => 'image', 'value' => '', 'operator' => '==', ], [ 'element' => 'parent_icon_circle', 'value' => 'no', 'operator' => '!=', ], ], 'states' => [ 'hover' => [ 'label' => __( 'Hover', 'fusion-builder' ), 'default' => '', 'preview' => [ 'selector' => '.icon', 'type' => 'class', 'toggle' => 'hover', ], ], ], 'connect-state' => [ 'iconcolor' ], ], [ 'type' => 'range', 'heading' => esc_attr__( 'Icon Background Inner Border Size', 'fusion-builder' ), 'description' => '', 'param_name' => 'circlebordersize', 'value' => '', 'min' => '0', 'max' => '20', 'step' => '1', 'default' => $fusion_settings->get( 'content_box_icon_bg_inner_border_size' ), 'dependency' => [ [ 'element' => 'icon', 'value' => '', 'operator' => '!=', ], [ 'element' => 'image', 'value' => '', 'operator' => '==', ], [ 'element' => 'parent_icon_circle', 'value' => 'no', 'operator' => '!=', ], ], ], [ 'type' => 'colorpickeralpha', 'heading' => esc_attr__( 'Icon Background Inner Border Color', 'fusion-builder' ), 'description' => '', 'param_name' => 'circlebordercolor', 'value' => '', 'default' => $fusion_settings->get( 'content_box_icon_bg_inner_border_color' ), 'dependency' => [ [ 'element' => 'icon', 'value' => '', 'operator' => '!=', ], [ 'element' => 'image', 'value' => '', 'operator' => '==', ], [ 'element' => 'slidercirclebordersize', 'value' => '0', 'operator' => '!=', ], [ 'element' => 'parent_icon_circle', 'value' => 'no', 'operator' => '!=', ], ], ], [ 'type' => 'range', 'heading' => esc_attr__( 'Icon Background Outer Border Size', 'fusion-builder' ), 'description' => '', 'param_name' => 'outercirclebordersize', 'value' => '', 'min' => '0', 'max' => '20', 'step' => '1', 'default' => $fusion_settings->get( 'content_box_icon_bg_outer_border_size' ), 'dependency' => [ [ 'element' => 'icon', 'value' => '', 'operator' => '!=', ], [ 'element' => 'image', 'value' => '', 'operator' => '==', ], [ 'element' => 'parent_icon_circle', 'value' => 'no', 'operator' => '!=', ], ], ], [ 'type' => 'colorpickeralpha', 'heading' => esc_attr__( 'Icon Background Outer Border Color', 'fusion-builder' ), 'description' => '', 'param_name' => 'outercirclebordercolor', 'value' => '', 'default' => $fusion_settings->get( 'content_box_icon_bg_outer_border_color' ), 'dependency' => [ [ 'element' => 'icon', 'value' => '', 'operator' => '!=', ], [ 'element' => 'image', 'value' => '', 'operator' => '==', ], [ 'element' => 'slideroutercirclebordersize', 'value' => '0', 'operator' => '!=', ], [ 'element' => 'parent_icon_circle', 'value' => 'no', 'operator' => '!=', ], ], ], [ 'type' => 'upload', 'heading' => esc_attr__( 'Icon Image', 'fusion-builder' ), 'description' => esc_attr__( 'To upload your own icon image, deselect the icon above and then upload your icon image.', 'fusion-builder' ), 'param_name' => 'image', 'value' => '', ], [ 'type' => 'textfield', 'heading' => esc_attr__( 'Icon Image ID', 'fusion-builder' ), 'description' => esc_attr__( 'Icon Image ID from Media Library.', 'fusion-builder' ), 'param_name' => 'image_id', 'value' => '', 'hidden' => true, 'callback' => [ 'function' => 'fusion_ajax', 'action' => 'get_fusion_content_box_image_data', 'ajax' => true, ], ], [ 'type' => 'textfield', 'heading' => esc_attr__( 'Icon Image Max Width', 'fusion-builder' ), 'description' => esc_attr__( 'Set the icon image max width. Leave empty for value set in parent option. Set to -1 to use image\'s native width. In pixels, ex: 35.', 'fusion-builder' ), 'param_name' => 'image_max_width', 'default' => '', 'dependency' => [ [ 'element' => 'image', 'value' => '', 'operator' => '!=', ], ], ], [ 'type' => 'link_selector', 'heading' => esc_attr__( 'Read More Link Url', 'fusion-builder' ), 'description' => esc_attr__( "Add the link's url ex: http://example.com.", 'fusion-builder' ), 'param_name' => 'link', 'value' => '', ], [ 'type' => 'textfield', 'heading' => esc_attr__( 'Read More Link Text', 'fusion-builder' ), 'description' => esc_attr__( 'Insert the text to display as the link.', 'fusion-builder' ), 'param_name' => 'linktext', 'value' => '', 'dependency' => [ [ 'element' => 'link', 'value' => '', 'operator' => '!=', ], ], ], [ 'type' => 'radio_button_set', 'heading' => esc_attr__( 'Read More Link Target', 'fusion-builder' ), 'description' => esc_html__( 'Controls how the link will open.', 'fusion-builder' ), 'param_name' => 'link_target', 'value' => [ '' => esc_attr__( 'Default', 'fusion-builder' ), '_self' => esc_attr__( 'Same Window', 'fusion-builder' ), '_blank' => esc_attr__( 'New Window/Tab', 'fusion-builder' ), ], 'default' => '', 'dependency' => [ [ 'element' => 'link', 'value' => '', 'operator' => '!=', ], ], ], [ 'type' => 'tinymce', 'heading' => esc_attr__( 'Content Box Content', 'fusion-builder' ), 'description' => esc_attr__( 'Add content for content box.', 'fusion-builder' ), 'param_name' => 'element_content', 'value' => esc_attr__( 'Your Content Goes Here', 'fusion-builder' ), 'placeholder' => true, 'dynamic_data' => true, ], [ 'type' => 'select', 'heading' => esc_attr__( 'Animation Type', 'fusion-builder' ), 'description' => esc_attr__( 'Select the type of animation to use on the element.', 'fusion-builder' ), 'param_name' => 'animation_type', 'value' => fusion_builder_available_animations(), 'default' => '', 'group' => esc_attr__( 'Animation', 'fusion-builder' ), 'preview' => [ 'selector' => '.link-area-box,.link-area-link-icon,.link-area-link-icon', 'type' => 'animation', ], ], [ 'type' => 'radio_button_set', 'heading' => esc_attr__( 'Direction of Animation', 'fusion-builder' ), 'description' => esc_attr__( 'Select the incoming direction for the animation.', 'fusion-builder' ), 'param_name' => 'animation_direction', 'value' => [ 'down' => esc_attr__( 'Top', 'fusion-builder' ), 'right' => esc_attr__( 'Right', 'fusion-builder' ), 'up' => esc_attr__( 'Bottom', 'fusion-builder' ), 'left' => esc_attr__( 'Left', 'fusion-builder' ), 'static' => esc_attr__( 'Static', 'fusion-builder' ), ], 'default' => 'left', 'group' => esc_attr__( 'Animation', 'fusion-builder' ), 'dependency' => [ [ 'element' => 'animation_type', 'value' => '', 'operator' => '!=', ], [ 'element' => 'animation_type', 'value' => 'none', 'operator' => '!=', ], ], 'preview' => [ 'selector' => '.link-area-box,.link-area-link-icon,.link-area-link-icon', 'type' => 'animation', ], ], [ 'type' => 'colorpickeralpha', 'heading' => esc_attr__( 'Animation Color', 'fusion-builder' ), 'description' => esc_attr__( 'Select the color of the animation', 'fusion-builder' ), 'param_name' => 'animation_color', 'default' => 'var(--primary_color)', 'dependency' => [ [ 'element' => 'animation_type', 'value' => 'reveal', 'operator' => '==', ], ], 'preview' => [ 'selector' => '.link-area-box,.link-area-link-icon,.link-area-link-icon', 'type' => 'animation', ], ], [ 'type' => 'range', 'heading' => esc_attr__( 'Speed of Animation', 'fusion-builder' ), 'description' => esc_attr__( 'Type in speed of animation in seconds (0.1 - 5).', 'fusion-builder' ), 'param_name' => 'animation_speed', 'min' => '0.1', 'max' => '5', 'step' => '0.1', 'value' => '0.3', 'group' => esc_attr__( 'Animation', 'fusion-builder' ), 'dependency' => [ [ 'element' => 'animation_type', 'value' => '', 'operator' => '!=', ], [ 'element' => 'animation_type', 'value' => 'none', 'operator' => '!=', ], ], 'preview' => [ 'selector' => '.link-area-box,.link-area-link-icon,.link-area-link-icon', 'type' => 'animation', ], ], [ 'type' => 'select', 'heading' => esc_attr__( 'Offset of Animation', 'fusion-builder' ), 'description' => esc_attr__( 'Controls when the animation should start.', 'fusion-builder' ), 'param_name' => 'animation_offset', 'value' => [ '' => esc_attr__( 'Default', 'fusion-builder' ), 'top-into-view' => esc_attr__( 'Top of element hits bottom of viewport', 'fusion-builder' ), 'top-mid-of-view' => esc_attr__( 'Top of element hits middle of viewport', 'fusion-builder' ), 'bottom-in-view' => esc_attr__( 'Bottom of element enters viewport', 'fusion-builder' ), ], 'default' => '', 'group' => esc_attr__( 'Animation', 'fusion-builder' ), 'dependency' => [ [ 'element' => 'animation_type', 'value' => '', 'operator' => '!=', ], [ 'element' => 'animation_type', 'value' => 'none', 'operator' => '!=', ], ], ], ], ], 'child' ) ); } add_action( 'fusion_builder_before_init', 'fusion_element_content_box' );
Cokiee Shell Web 1.0, Coded By Razor
Neueste Kommentare