File: /home/remoteac/public_html/wp-content/plugins/fusion-builder/shortcodes/fusion-image.php
<?php
/**
* Add an element to fusion-builder.
*
* @package fusion-builder
* @since 1.0
*/
if ( fusion_is_element_enabled( 'fusion_imageframe' ) ) {
if ( ! class_exists( 'FusionSC_Imageframe' ) ) {
/**
* Shortcode class.
*
* @package fusion-builder
* @since 1.0
*/
class FusionSC_Imageframe extends Fusion_Element {
/**
* The image-frame counter.
*
* @access private
* @since 1.0
* @var int
*/
private $imageframe_counter = 1;
/**
* The image data.
*
* @access private
* @since 1.0
* @var false|array
*/
private $image_data = false;
/**
* The lightbox image data.
*
* @access private
* @since 1.7
* @var false|array
*/
private $lightbox_image_data = false;
/**
* An array of the shortcode arguments.
*
* @access protected
* @since 1.0
* @var array
*/
protected $args;
/**
* An array of wrapper attributes.
*
* @access protected
* @since 3.0
* @var array
*/
protected $wrapper_attr = [
'class' => '',
'style' => '',
];
/**
* Constructor.
*
* @access public
* @since 1.0
*/
public function __construct() {
parent::__construct();
add_filter( 'fusion_attr_image-shortcode', [ $this, 'attr' ] );
add_filter( 'fusion_attr_image-shortcode-link', [ $this, 'link_attr' ] );
add_filter( 'fusion_attr_image-shortcode-tag-element', [ $this, 'tag_element_attr' ] );
add_filter( 'fusion_attr_image-shortcode-special-container', [ $this, 'special_container_attr' ] );
add_filter( 'fusion_attr_image-shortcode-responsive-container', [ $this, 'responsive_container_attr' ] );
add_filter( 'fusion_attr_image-shortcode-caption', [ $this, 'caption_attr' ] );
add_shortcode( 'fusion_imageframe', [ $this, 'render' ] );
}
/**
* Gets the default values.
*
* @static
* @access public
* @since 2.0.0
* @return array
*/
public static function get_element_defaults() {
$fusion_settings = awb_get_fusion_settings();
return [
'src' => '',
'align' => '',
'align_medium' => '',
'align_small' => '',
'margin_bottom' => '',
'margin_left' => '',
'margin_right' => '',
'margin_top' => '',
'margin_bottom_medium' => '',
'margin_left_medium' => '',
'margin_right_medium' => '',
'margin_top_medium' => '',
'margin_bottom_small' => '',
'margin_left_small' => '',
'margin_right_small' => '',
'margin_top_small' => '',
'alt' => '',
'animation_direction' => 'left',
'animation_offset' => $fusion_settings->get( 'animation_offset' ),
'animation_speed' => '',
'animation_type' => '',
'blur' => $fusion_settings->get( 'imageframe_blur' ),
'bordercolor' => $fusion_settings->get( 'imgframe_border_color' ),
'borderradius' => intval( $fusion_settings->get( 'imageframe_border_radius' ) ) . 'px',
'bordersize' => $fusion_settings->get( 'imageframe_border_size' ),
'class' => '',
'gallery_id' => '',
'hide_on_mobile' => fusion_builder_default_visibility( 'string' ),
'sticky_display' => '',
'hover_type' => 'none',
'image_id' => '',
'id' => '',
'lightbox' => 'no',
'lightbox_image' => '',
'lightbox_image_id' => '',
'link' => '',
'link_attributes' => '',
'linktarget' => '_self',
'max_width' => '',
'skip_lazy_load' => '',
'sticky_max_width' => '',
'stylecolor' => $fusion_settings->get( 'imgframe_style_color' ),
'style_type' => $fusion_settings->get( 'imageframe_style_type' ),
// Filters.
'filter_hue' => '0',
'filter_saturation' => '100',
'filter_brightness' => '100',
'filter_contrast' => '100',
'filter_invert' => '0',
'filter_sepia' => '0',
'filter_opacity' => '100',
'filter_blur' => '0',
'filter_hue_hover' => '0',
'filter_saturation_hover' => '100',
'filter_brightness_hover' => '100',
'filter_contrast_hover' => '100',
'filter_invert_hover' => '0',
'filter_sepia_hover' => '0',
'filter_opacity_hover' => '100',
'filter_blur_hover' => '0',
// Caption params.
'caption_style' => 'off',
'caption_title' => '',
'caption_text' => '',
'caption_title_color' => '',
'caption_title_size' => '',
'caption_title_line_height' => '',
'caption_title_letter_spacing' => '',
'caption_title_tag' => '2',
'fusion_font_family_caption_title_font' => '',
'fusion_font_variant_caption_title_font' => '',
'caption_text_color' => '',
'caption_text_size' => '',
'caption_text_line_height' => '',
'fusion_font_family_caption_text_font' => '',
'fusion_font_variant_caption_text_font' => '',
'caption_border_color' => '',
'caption_overlay_color' => $fusion_settings->get( 'primary_color' ),
'caption_background_color' => '',
'caption_margin_top' => '',
'caption_margin_right' => '',
'caption_margin_bottom' => '',
'caption_margin_left' => '',
'caption_title_transform' => '',
'caption_text_transform' => '',
'caption_align' => 'none',
'caption_align_medium' => 'none',
'caption_align_small' => 'none',
// Mask.
'mask' => '',
'custom_mask' => '',
'mask_size' => '',
'mask_custom_size' => '',
'mask_position' => '',
'mask_custom_position' => '',
'mask_repeat' => '',
// aspect ratio.
'aspect_ratio' => '',
'custom_aspect_ratio' => '',
'aspect_ratio_position' => '',
// Deprecated params.
'style' => '',
];
}
/**
* Maps settings to param variables.
*
* @static
* @access public
* @since 2.0.0
* @return array
*/
public static function settings_to_params() {
return [
'animation_offset' => 'animation_offset',
'imageframe_blur' => 'blur',
'imgframe_border_color' => 'bordercolor',
'imageframe_border_radius' => 'borderradius',
'imageframe_border_size' => 'bordersize',
'imgframe_style_color' => 'stylecolor',
'imageframe_style_type' => 'style_type',
'lazy_load' => 'lazy_load',
];
}
/**
* Sets the args from the attributes.
*
* @access public
* @since 3.0
* @param array $args Element attributes.
* @return void
*/
public function set_args( $args ) {
$this->defaults = self::get_element_defaults();
$this->args = FusionBuilder::set_shortcode_defaults( $this->defaults, $args, 'fusion_imageframe' );
}
/**
* Validate the arguments into correct format.
*
* @access public
* @since 3.0
* @return void
*/
public function validate_args() {
$this->args['blur'] = FusionBuilder::validate_shortcode_attr_value( $this->args['blur'], 'px' );
$this->args['borderradius'] = FusionBuilder::validate_shortcode_attr_value( $this->args['borderradius'], 'px' );
$this->args['bordersize'] = FusionBuilder::validate_shortcode_attr_value( $this->args['bordersize'], 'px' );
// Validate margin values.
foreach ( [ 'large', 'medium', 'small' ] as $size ) {
foreach ( [ 'top', 'right', 'bottom', 'left' ] as $direction ) {
$margin_key = 'large' === $size ? 'margin_' . $direction : 'margin_' . $direction . '_' . $size;
$this->args[ $margin_key ] = FusionBuilder::validate_shortcode_attr_value( $this->args[ $margin_key ], 'px' );
}
}
// Validate caption color.
foreach ( [ 'caption_title_color', 'caption_text_color', 'caption_border_color', 'caption_overlay_color', 'caption_background_color' ] as $key ) {
if ( ! $this->is_default( $key ) ) {
$this->args[ $key ] = fusion_library()->sanitize->color( $this->args[ $key ] );
}
}
}
/**
* Sets the extra args.
*
* @access public
* @since 3.0
* @param string $content Shortcode content.
* @return void
*/
public function set_extra_args( $content ) {
if ( ! $this->args['style'] ) {
$this->args['style'] = $this->args['style_type'];
// If caption style used then disable style type.
if ( ! in_array( $this->args['caption_style'], [ 'off', 'above', 'below' ], true ) ) {
$this->args['style'] = 'none';
}
// If mask used then disable style type.
if ( '' !== $this->args['mask'] ) {
$this->args['style'] = 'none';
}
}
if ( $this->args['borderradius'] && 'bottomshadow' === $this->args['style'] ) {
$this->args['borderradius'] = '0';
}
if ( 'round' === $this->args['borderradius'] ) {
$this->args['borderradius'] = '50%';
}
$this->args['border_radius'] = '';
if ( '0' !== $this->args['borderradius'] && 0 !== $this->args['borderradius'] && '0px' !== $this->args['borderradius'] ) {
$this->args['border_radius'] .= "border-radius:{$this->args['borderradius']};";
}
// The URL is added as element content, but where image ID was not available.
if ( false === strpos( $content, '<img' ) && $content ) {
$this->args['src'] = $content;
} elseif ( empty( $this->args['src'] ) ) {
// Old version, where the img tag was added in element contant.
preg_match( '/(src=["\'](.*?)["\'])/', $content, $this->args['src'] );
if ( array_key_exists( '2', $this->args['src'] ) ) {
$this->args['src'] = $this->args['src'][2];
}
}
if ( $this->args['src'] ) {
$this->args['src'] = str_replace( '×', 'x', $this->args['src'] );
}
$this->args['pic_link'] = $this->args['lightbox_image'] ? $this->args['lightbox_image'] : $this->args['src'];
}
/**
* Sets the image data.
*
* @access public
* @since 3.0
* @return void
*/
public function set_image_data() {
if ( $this->args['lightbox_image'] ) {
$this->lightbox_image_data = fusion_library()->images->get_attachment_data_by_helper( $this->args['lightbox_image_id'], $this->args['lightbox_image'] );
}
if ( is_array( $this->args['src'] ) && empty( $this->args['src'] ) ) {
$this->args['image_id'] = false;
}
$this->image_data = fusion_library()->images->get_attachment_data_by_helper( $this->args['image_id'], $this->args['src'] );
}
/**
* Builds the image element attributes array.
*
* @access public
* @since 3.0
* @param string $content Shortcode content.
* @return array
*/
public function tag_element_attr( $content ) {
$attr = [
'width' => $this->image_data['width'],
'height' => $this->image_data['height'],
'alt' => $this->image_data['alt'],
'title' => $this->image_data['title_attribute'],
'src' => $this->args['src'] ? $this->args['src'] : $this->image_data['url'],
];
// For pre 5.0 shortcodes extract the alt tag.
preg_match( '/(alt=["\'](.*?)["\'])/', $content, $legacy_alt );
if ( array_key_exists( '2', $legacy_alt ) && '' !== $legacy_alt[2] ) {
$attr['alt'] = $legacy_alt[2];
} elseif ( ! empty( $this->args['alt'] ) ) {
$attr['alt'] = $this->args['alt'];
}
if ( ! ( 'no' === $this->args['lightbox'] && ! $this->args['link'] ) ) {
unset( $attr['title'] );
}
if ( '' !== $this->args['aspect_ratio'] ) {
$attr['class'] = 'img-with-aspect-ratio';
}
return $attr;
}
/**
* Builds the special container attributes array.
*
* @access public
* @since 3.0
* @return array
*/
public function special_container_attr() {
$attr = [
'class' => 'awb-image-frame awb-image-frame-' . $this->element_id,
'style' => '',
];
if ( 'liftup' === $this->args['hover_type'] && in_array( $this->args['caption_style'], [ 'off', 'above', 'below' ], true ) ) {
$attr['class'] .= ' imageframe-liftup';
if ( '' !== $this->args['aspect_ratio'] ) {
$attr['class'] .= ' liftup-with-aspect-ratio';
}
if ( ! fusion_element_rendering_is_flex() ) {
if ( 'left' === $this->args['align'] ) {
$attr['class'] .= ' fusion-imageframe-liftup-left';
} elseif ( 'right' === $this->args['align'] ) {
$attr['class'] .= ' fusion-imageframe-liftup-right';
}
}
if ( $this->args['border_radius'] ) {
$attr['class'] .= ' imageframe-' . $this->element_id;
}
if ( 'bottomshadow' === $this->args['style'] ) {
$attr['class'] .= ' fusion-image-frame-bottomshadow image-frame-shadow-' . $this->element_id;
}
} else {
if ( 'zoomin' === $this->args['hover_type'] || 'zoomout' === $this->args['hover_type'] ) {
$attr['class'] .= ' fusion-image-frame-bottomshadow element-bottomshadow image-frame-shadow-' . $this->element_id;
} else {
$attr['class'] .= ' fusion-image-frame-bottomshadow image-frame-shadow-' . $this->element_id;
}
}
if ( '' !== $this->args['hover_type'] && '' !== $this->args['mask'] ) {
$attr['class'] .= ' hover-with-mask';
}
$attr['class'] = fusion_builder_visibility_atts( $this->args['hide_on_mobile'], $attr['class'] );
$attr['class'] .= Fusion_Builder_Sticky_Visibility_Helper::get_sticky_class( $this->args['sticky_display'] );
$attr['style'] = '';
if ( $this->args['max_width'] && '' === $this->args['aspect_ratio'] ) {
$attr['style'] = 'max-width:' . fusion_library()->sanitize->get_value_with_unit( $this->args['max_width'] ) . ';';
if ( 'bottomshadow' === $this->args['style'] ) {
$attr['style'] .= 'display:inline-block;';
}
}
return $attr;
}
/**
* Builds the responsive container attributes array.
*
* @access public
* @since 3.0
* @return array
*/
public function responsive_container_attr() {
$attr = [
'class' => '',
'style' => '',
];
$align_large = ! empty( $this->args['align'] ) && 'none' !== $this->args['align'] ? $this->args['align'] : false;
if ( $align_large ) {
$attr['style'] .= 'text-align:' . $this->args['align'] . ';';
}
$align_medium = ! empty( $this->args['align_medium'] ) && 'none' !== $this->args['align_medium'] ? $this->args['align_medium'] : false;
if ( $align_medium && $align_large !== $align_medium ) {
$attr['class'] .= ' md-text-align-' . $align_medium;
}
$align_small = ! empty( $this->args['align_small'] ) && 'none' !== $this->args['align_small'] ? $this->args['align_small'] : false;
if ( $align_small && $align_large !== $align_small ) {
$attr['class'] .= ' sm-text-align-' . $align_small;
}
if ( in_array( $this->args['caption_style'], [ 'above', 'below' ], true ) ) {
$attr['class'] .= ' awb-imageframe-style awb-imageframe-style-' . $this->args['caption_style'] . ' awb-imageframe-style-' . $this->element_id;
}
return $attr;
}
/**
* Render the shortcode
*
* @access public
* @since 1.0
* @param array $args Shortcode paramters.
* @param string $content Content between shortcode.
* @return string HTML output.
*/
public function render( $args, $content = '' ) {
$this->set_element_id( $this->imageframe_counter );
$this->set_args( $args );
$content = apply_filters( 'fusion_shortcode_content', $content, 'fusion_imageframe', $args );
$this->validate_args();
$this->set_extra_args( $content );
$this->set_image_data();
if ( is_array( $this->image_data ) ) {
if ( is_array( json_decode( $this->image_data['url'], true ) ) ) {
$content = $this->get_logo_images( $this->image_data['url'] );
} else {
$atts = FusionBuilder::attributes( 'image-shortcode-tag-element', $content );
$atts = false === strpos( $atts, 'alt=' ) ? $atts . ' alt' : $atts;
$content = '<img ' . $atts . ' />';
}
}
$img_classes = 'img-responsive';
if ( ! empty( $this->image_data['id'] ) ) {
$img_classes .= ' wp-image-' . $this->image_data['id'];
}
// Get custom classes from the img tag.
preg_match( '/(class=["\'](.*?)["\'])/', $content, $classes );
if ( ! empty( $classes ) ) {
$img_classes .= ' ' . $classes[2];
}
if ( 'skip' === $this->args['skip_lazy_load'] ) {
$img_classes .= ' disable-lazyload';
}
$img_classes = 'class="' . $img_classes . '"';
// Add custom and responsive class to the img tag.
if ( ! empty( $classes ) ) {
$content = str_replace( $classes[0], $img_classes, $content );
} else {
$content = str_replace( '/>', $img_classes . '/>', $content );
}
fusion_library()->images->set_grid_image_meta(
[
'layout' => 'large',
'columns' => '1',
]
);
$content = fusion_add_responsive_image_markup( $content );
$image_id = false;
if ( isset( $this->image_data['id'] ) ) {
$image_id = $this->image_data['id'];
}
if ( 'skip' !== $this->args['skip_lazy_load'] ) {
$content = fusion_library()->images->apply_lazy_loading( $content, null, $image_id, 'full' );
}
fusion_library()->images->set_grid_image_meta( [] );
$output = do_shortcode( $content );
$html = '';
if ( ! empty( $output ) ) {
if ( ! in_array( $this->args['caption_style'], [ 'off', 'above', 'below' ], true ) ) {
$output .= $this->render_caption();
}
if ( 'yes' === $this->args['lightbox'] || $this->args['link'] ) {
$output = '<a ' . FusionBuilder::attributes( 'image-shortcode-link' ) . '>' . $output . '</a>';
}
$html = '<span ' . FusionBuilder::attributes( 'image-shortcode' ) . '>' . $output . '</span>';
$element_styles = '';
if ( 'liftup' === $this->args['hover_type'] || ( 'bottomshadow' === $this->args['style'] && ( 'none' === $this->args['hover_type'] || 'zoomin' === $this->args['hover_type'] || 'zoomout' === $this->args['hover_type'] ) ) ) {
$stylecolor = ( '#' === $this->args['stylecolor'][0] ) ? Fusion_Color::new_color( $this->args['stylecolor'] )->get_new( 'alpha', '0.4' )->to_css_var_or_rgba() : Fusion_Color::new_color( $this->args['stylecolor'] )->to_css_var_or_rgba();
if ( 'liftup' === $this->args['hover_type'] ) {
if ( $this->args['border_radius'] ) {
$element_styles = '.imageframe-liftup.imageframe-' . $this->element_id . ':before{' . $this->args['border_radius'] . '}';
}
if ( 'bottomshadow' === $this->args['style'] ) {
$element_styles .= '.element-bottomshadow.imageframe-' . $this->element_id . ':before, .element-bottomshadow.imageframe-' . $this->element_id . ':after{';
$element_styles .= '-webkit-box-shadow: 0 17px 10px ' . $stylecolor . ';box-shadow: 0 17px 10px ' . $stylecolor . ';}';
}
} else {
if ( ! fusion_element_rendering_is_flex() ) {
$element_styles .= '.fusion-image-frame-bottomshadow.image-frame-shadow-' . $this->element_id . '{';
if ( 'left' === $this->args['align'] ) {
$element_styles .= 'margin-right:25px;float:left;';
} elseif ( 'right' === $this->args['align'] ) {
$element_styles .= 'margin-left:25px;float:right;';
}
$element_styles .= 'display:inline-block}';
}
$element_styles .= '.element-bottomshadow.imageframe-' . $this->element_id . ':before, .element-bottomshadow.imageframe-' . $this->element_id . ':after{';
$element_styles .= '-webkit-box-shadow: 0 17px 10px ' . $stylecolor . ';box-shadow: 0 17px 10px ' . $stylecolor . ';}';
}
$html = '<div ' . FusionBuilder::attributes( 'image-shortcode-special-container' ) . '>' . $html . '</div>';
}
if ( in_array( $this->args['caption_style'], [ 'off', 'above', 'below' ], true ) ) {
$html = 'above' === $this->args['caption_style'] ? $this->render_caption() . $html : $html . $this->render_caption();
}
$fusion_settings = awb_get_fusion_settings();
$element_style_selector = '.awb-image-frame.awb-image-frame-' . $this->element_id;
if ( 'liftup' !== $this->args['hover_type'] && 'bottomshadow' !== $this->args['style'] ) {
$element_style_selector = '.fusion-imageframe.imageframe-' . $this->element_id;
}
// Responsive Margin.
foreach ( [ 'large', 'medium', 'small' ] as $size ) {
$margin_styles = '';
foreach ( [ 'top', 'right', 'bottom', 'left' ] as $direction ) {
$margin_key = 'large' === $size ? 'margin_' . $direction : 'margin_' . $direction . '_' . $size;
if ( '' !== $this->args[ $margin_key ] ) {
$margin_styles .= 'margin-' . $direction . ' : ' . $this->args[ $margin_key ] . ';';
}
}
if ( '' === $margin_styles ) {
continue;
}
$margin_styles = $element_style_selector . '{ ' . $margin_styles . '}';
// Large styles, no wrapping needed.
if ( 'large' === $size ) {
$element_styles .= $margin_styles;
} else {
// Medium and Small size screen styles.
$element_styles .= '@media only screen and (max-width:' . $fusion_settings->get( 'visibility_' . $size ) . 'px) {' . $margin_styles . '}';
}
}
// caption style.
$element_styles .= $this->generate_caption_styles();
// Mask style.
$element_styles .= $this->generate_mask_styles();
// Aspect ratio.
$element_styles .= $this->generate_aspect_ratio_styles();
// Output styles.
if ( '' !== $element_styles ) {
$element_styles = '<style>' . $element_styles . '</style>';
}
$html = $element_styles . $html;
if ( '' !== $this->args['max_width'] && '' !== $this->args['aspect_ratio'] ) {
$aspect_ratio_wrapper_style = 'display:inline-block; max-width:100%;';
$aspect_ratio_wrapper_style .= 'width:' . fusion_library()->sanitize->get_value_with_unit( $this->args['max_width'] ) . ';';
if ( ! fusion_element_rendering_is_flex() ) {
if ( 'left' === $this->args['align'] ) {
$aspect_ratio_wrapper_style .= 'float:left;';
} elseif ( 'right' === $this->args['align'] ) {
$aspect_ratio_wrapper_style .= 'float:right;';
}
}
$html = '<div style="' . esc_attr( $aspect_ratio_wrapper_style ) . '">' . $html . '</div>';
}
if ( 'center' === $this->args['align'] && ! fusion_element_rendering_is_flex() ) {
$html = '<div ' . FusionBuilder::attributes( 'imageframe-align-center' ) . '>' . $html . '</div>';
}
// Add filter styles.
$filter_style = Fusion_Builder_Filter_Helper::get_filter_style_element( $this->args, '.imageframe-' . $this->element_id );
if ( '' !== $filter_style ) {
$html .= $filter_style;
}
// Add min height sticky.
if ( '' !== $this->args['sticky_max_width'] ) {
$html .= '<style>.fusion-sticky-container.fusion-sticky-transition .imageframe-' . $this->element_id . '{ max-width:' . fusion_library()->sanitize->get_value_with_unit( $this->args['sticky_max_width'] ) . ' !important; }</style>';
}
// Mobile logo.
if ( false !== strpos( $this->wrapper_attr['class'], 'has-fusion-mobile-logo' ) ) {
$html .= $this->mobile_logo_styles();
}
if ( fusion_element_rendering_is_flex() ) {
$html = '<div ' . FusionBuilder::attributes( 'image-shortcode-responsive-container' ) . '>' . $html . '</div>';
}
}
$this->imageframe_counter++;
$this->lightbox_image_data = false;
$this->wrapper_attr = [
'class' => '',
'style' => '',
];
$this->on_render();
return apply_filters( 'fusion_element_image_content', $html, $args );
}
/**
* Render the caption.
*
* @access public
* @since 3.5
* @return string HTML output.
*/
public function render_caption() {
if ( 'off' === $this->args['caption_style'] ) {
return '';
}
$output = '<div ' . FusionBuilder::attributes( 'image-shortcode-caption' ) . '><div class="awb-imageframe-caption">';
$title = '';
$caption = '';
if ( $this->image_data ) {
if ( '' !== $this->image_data['title'] ) {
$title = $this->image_data['title'];
}
if ( '' !== $this->image_data['caption'] ) {
$caption = $this->image_data['caption'];
}
}
if ( ! $this->is_default( 'caption_title' ) ) {
$title = $this->args['caption_title'];
}
if ( ! $this->is_default( 'caption_text' ) ) {
$caption = $this->args['caption_text'];
}
if ( '' !== $title ) {
$title_tag = 'div' === $this->args['caption_title_tag'] ? 'div' : 'h' . $this->args['caption_title_tag'];
$output .= sprintf( '<%1$s class="awb-imageframe-caption-title">%2$s</%1$s>', $title_tag, $title );
}
if ( '' !== $caption ) {
$output .= sprintf( '<p class="awb-imageframe-caption-text">%1$s</p>', $caption );
}
$output .= '</div></div>';
return $output;
}
/**
* Generate caption styles.
*
* @access public
* @since 3.5
* @return string CSS output.
*/
public function generate_caption_styles() {
if ( 'off' === $this->args['caption_style'] ) {
return '';
}
global $fusion_settings;
$this->dynamic_css = [];
$this->base_selector = '.fusion-imageframe.imageframe-' . $this->element_id;
if ( in_array( $this->args['caption_style'], [ 'above', 'below' ], true ) ) {
$this->base_selector = '.awb-imageframe-style.awb-imageframe-style-' . $this->element_id;
}
$selectors = [
$this->base_selector . ' .awb-imageframe-caption-container .awb-imageframe-caption-title',
];
// title color.
if ( ! $this->is_default( 'caption_title_color' ) ) {
$this->add_css_property( $selectors, 'color', $this->args['caption_title_color'], true );
}
// title size.
if ( ! $this->is_default( 'caption_title_size' ) ) {
$this->add_css_property( $selectors, 'font-size', fusion_library()->sanitize->get_value_with_unit( $this->args['caption_title_size'] ), true );
}
// title font.
$font_styles = Fusion_Builder_Element_Helper::get_font_styling( $this->args, 'caption_title_font', 'array' );
foreach ( $font_styles as $rule => $value ) {
$this->add_css_property( $selectors, $rule, $value, true );
}
// title transform.
if ( ! $this->is_default( 'caption_title_transform' ) ) {
$this->add_css_property( $selectors, 'text-transform', $this->args['caption_title_transform'], true );
}
// Line height.
if ( ! $this->is_default( 'caption_title_line_height' ) ) {
$this->add_css_property( $selectors, 'line-height', $this->args['caption_title_line_height'], true );
}
// Letter spacing.
if ( ! $this->is_default( 'caption_title_letter_spacing' ) ) {
$this->add_css_property( $selectors, 'letter-spacing', fusion_library()->sanitize->get_value_with_unit( $this->args['caption_title_letter_spacing'] ) );
}
$selectors = [
$this->base_selector . ' .awb-imageframe-caption-container .awb-imageframe-caption-text',
];
// text color.
if ( ! $this->is_default( 'caption_text_color' ) ) {
$this->add_css_property( $selectors, 'color', $this->args['caption_text_color'] );
}
// text size.
if ( ! $this->is_default( 'caption_text_size' ) ) {
$this->add_css_property( $selectors, 'font-size', fusion_library()->sanitize->get_value_with_unit( $this->args['caption_text_size'] ) );
}
// text font.
$font_styles = Fusion_Builder_Element_Helper::get_font_styling( $this->args, 'caption_text_font', 'array' );
foreach ( $font_styles as $rule => $value ) {
$this->add_css_property( $selectors, $rule, $value );
}
// text transform.
if ( ! $this->is_default( 'caption_text_transform' ) ) {
$this->add_css_property( $selectors, 'text-transform', $this->args['caption_text_transform'] );
}
// Line height.
if ( ! $this->is_default( 'caption_text_line_height' ) ) {
$this->add_css_property( $selectors, 'line-height', $this->args['caption_text_line_height'] );
}
// Letter spacing.
if ( ! $this->is_default( 'caption_text_letter_spacing' ) ) {
$this->add_css_property( $selectors, 'letter-spacing', fusion_library()->sanitize->get_value_with_unit( $this->args['caption_text_letter_spacing'] ) );
}
// Border color.
if ( 'resa' === $this->args['caption_style'] && ! $this->is_default( 'caption_border_color' ) ) {
$selectors = [
$this->base_selector . ' .awb-imageframe-caption-container:before',
];
$this->add_css_property( $selectors, 'border-top-color', $this->args['caption_border_color'] );
$this->add_css_property( $selectors, 'border-bottom-color', $this->args['caption_border_color'] );
$selectors = [
$this->base_selector . ' .awb-imageframe-caption-container:after',
];
$this->add_css_property( $selectors, 'border-right-color', $this->args['caption_border_color'] );
$this->add_css_property( $selectors, 'border-left-color', $this->args['caption_border_color'] );
}
if ( 'dario' === $this->args['caption_style'] && ! $this->is_default( 'caption_border_color' ) ) {
$selectors = [
$this->base_selector . ' .awb-imageframe-caption .awb-imageframe-caption-title:after',
];
$this->add_css_property( $selectors, 'background', $this->args['caption_border_color'] );
}
// Overlay color.
if ( in_array( $this->args['caption_style'], [ 'dario', 'resa', 'schantel', 'dany', 'navin' ], true ) ) {
$selectors = [
$this->base_selector,
];
$this->add_css_property( $selectors, 'background', $this->args['caption_overlay_color'] );
}
// Background color.
if ( in_array( $this->args['caption_style'], [ 'schantel', 'dany' ], true ) && ! $this->is_default( 'caption_background_color' ) ) {
$selectors = [
$this->base_selector . ' .awb-imageframe-caption-container .awb-imageframe-caption-text',
];
$this->add_css_property( $selectors, 'background', $this->args['caption_background_color'] );
}
// If no caption bg color then set bg same as overlay color.
if ( 'dany' === $this->args['caption_style'] && $this->is_default( 'caption_background_color' ) ) {
$selectors = [
$this->base_selector . ' .awb-imageframe-caption-container .awb-imageframe-caption-text',
];
$this->add_css_property( $selectors, 'background', $this->args['caption_overlay_color'] );
}
// Caption area margin.
if ( in_array( $this->args['caption_style'], [ 'above', 'below' ], true ) ) {
$sides = [ 'top', 'right', 'bottom', 'left' ];
$selectors = [
$this->base_selector . ' .awb-imageframe-caption-container',
];
foreach ( $sides as $side ) {
// Element margin.
$margin_name = 'caption_margin_' . $side;
if ( ! $this->is_default( $margin_name ) ) {
$this->add_css_property( $selectors, 'margin-' . $side, fusion_library()->sanitize->get_value_with_unit( $this->args[ $margin_name ] ) );
}
}
if ( ! $this->is_default( 'caption_title' ) ) {
$selectors = [
$this->base_selector . ' .awb-imageframe-caption-container .awb-imageframe-caption-text',
];
$this->add_css_property( $selectors, 'margin-top', '0.5em' );
}
}
$css = $this->parse_css();
if ( in_array( $this->args['caption_style'], [ 'above', 'below' ], true ) && $this->args['max_width'] ) {
// Responsive Alignment.
foreach ( [ 'large', 'medium', 'small' ] as $size ) {
$key = 'align' . ( 'large' === $size ? '' : '_' . $size );
$align = ! empty( $this->args[ $key ] ) && 'none' !== $this->args[ $key ] ? $this->args[ $key ] : false;
if ( $align ) {
if ( 'left' === $align ) {
$align = 'right';
} elseif ( 'right' === $align ) {
$align = 'left';
}
if ( 'center' === $align ) {
$props = 'margin: 0 auto;';
} else {
$props = 'margin-' . $align . ': auto;';
}
if ( 'small' === $size ) {
$props = 'margin: 0;';
}
$styles = $this->base_selector . ' .awb-imageframe-caption-container {' . $props . '}';
if ( 'large' === $size ) {
$css .= $styles;
} else {
$css .= '@media only screen and (max-width:' . $fusion_settings->get( 'visibility_' . $size ) . 'px) {' . $styles . '}';
}
}
}
}
return $css;
}
/**
* Generate mask styles.
*
* @access public
* @since 7.6
* @return string CSS output.
*/
public function generate_mask_styles() {
if ( '' === $this->args['mask'] ) {
return '';
}
$this->dynamic_css = [];
$this->base_selector = '.fusion-imageframe.imageframe-' . $this->element_id;
$selectors = [
$this->base_selector . ' img',
];
// Mask image.
$mask_url = 'custom' === $this->args['mask'] ? $this->args['custom_mask'] : FUSION_BUILDER_PLUGIN_URL . '/assets/images/masks/' . $this->args['mask'] . '.svg';
if ( '' !== $mask_url ) {
$this->add_css_property( $selectors, '-webkit-mask-image', 'url(' . $mask_url . ')' );
$this->add_css_property( $selectors, '-mask-image', 'url(' . $mask_url . ')' );
if ( 'liftup' === $this->args['hover_type'] ) {
$this->add_css_property( '.imageframe-liftup.awb-image-frame-' . $this->element_id . ':before', 'background-image', 'url(' . $mask_url . ')' );
}
}
// Mask size.
if ( ! $this->is_default( 'mask_size' ) ) {
$mask_size = $this->args['mask_size'];
if ( 'fit' === $mask_size ) {
$this->add_css_property( $selectors, '-webkit-mask-size', 'contain' );
$this->add_css_property( $selectors, '-mask-size', 'contain' );
if ( 'liftup' === $this->args['hover_type'] ) {
$this->add_css_property( '.imageframe-liftup.awb-image-frame-' . $this->element_id . ':before', 'background-size', 'contain' );
}
}
if ( 'fill' === $mask_size ) {
$this->add_css_property( $selectors, '-webkit-mask-size', 'cover' );
$this->add_css_property( $selectors, '-mask-size', 'cover' );
if ( 'liftup' === $this->args['hover_type'] ) {
$this->add_css_property( '.imageframe-liftup.awb-image-frame-' . $this->element_id . ':before', 'background-size', 'cover' );
}
}
if ( 'custom' === $mask_size ) {
$this->add_css_property( $selectors, '-webkit-mask-size', $this->args['mask_custom_size'] );
$this->add_css_property( $selectors, '-mask-size', $this->args['mask_custom_size'] );
if ( 'liftup' === $this->args['hover_type'] ) {
$this->add_css_property( '.imageframe-liftup.awb-image-frame-' . $this->element_id . ':before', 'background-size', $this->args['mask_custom_size'] );
}
}
}
// Mask position.
if ( ! $this->is_default( 'mask_position' ) ) {
$mask_position = 'custom' !== $this->args['mask_position'] ? str_replace( '-', ' ', $this->args['mask_position'] ) : $this->args['mask_custom_position'];
$this->add_css_property( $selectors, '-webkit-mask-position', $mask_position );
$this->add_css_property( $selectors, '-mask-position', $mask_position );
if ( 'liftup' === $this->args['hover_type'] ) {
$this->add_css_property( '.imageframe-liftup.awb-image-frame-' . $this->element_id . ':before', 'background-position', $mask_position );
}
}
// Mask Repeat.
if ( ! $this->is_default( 'mask_repeat' ) ) {
$this->add_css_property( $selectors, '-webkit-mask-repeat', $this->args['mask_repeat'] );
$this->add_css_property( $selectors, '-mask-repeat', $this->args['mask_repeat'] );
if ( 'liftup' === $this->args['hover_type'] ) {
$this->add_css_property( '.imageframe-liftup.awb-image-frame-' . $this->element_id . ':before', 'background-repeat', $this->args['mask_repeat'] );
}
}
return $this->parse_css();
}
/**
* Generate aspect ratio styles.
*
* @access public
* @since 3.6
* @return string CSS output.
*/
public function generate_aspect_ratio_styles() {
if ( '' === $this->args['aspect_ratio'] ) {
return '';
}
$this->dynamic_css = [];
$this->base_selector = '.fusion-imageframe.imageframe-' . $this->element_id . ' img';
$selectors = [ $this->base_selector ];
// Calc Ratio.
if ( 'custom' === $this->args['aspect_ratio'] && '' !== $this->args['custom_aspect_ratio'] ) {
$this->add_css_property( $selectors, 'aspect-ratio', '100 / ' . $this->args['custom_aspect_ratio'] );
} else {
$aspect_ratio = explode( '-', $this->args['aspect_ratio'] );
$width = isset( $aspect_ratio[0] ) ? $aspect_ratio[0] : '';
$height = isset( $aspect_ratio[1] ) ? $aspect_ratio[1] : '';
$this->add_css_property( $selectors, 'aspect-ratio', "$width / $height" );
}
// Set Image Position.
if ( '' !== $this->args['aspect_ratio_position'] ) {
$this->add_css_property( $selectors, 'object-position', $this->args['aspect_ratio_position'] );
}
return $this->parse_css();
}
/**
* Builds the attributes array.
*
* @access public
* @since 1.0
* @return array
*/
public function attr() {
$visibility_classes_need_set = false;
$bordercolor = $this->args['bordercolor'];
$stylecolor = ( '#' === $this->args['stylecolor'][0] ) ? Fusion_Color::new_color( $this->args['stylecolor'] )->get_new( 'alpha', '0.3' )->to_css_var_or_rgba() : Fusion_Color::new_color( $this->args['stylecolor'] )->to_css_var_or_rgba();
$blur = $this->args['blur'];
$blur_radius = ( (int) $blur + 4 ) . 'px';
$bordersize = $this->args['bordersize'];
$borderradius = $this->args['borderradius'];
$style = $this->args['style'];
$img_styles = '';
$this->wrapper_attr['class'] .= ' fusion-imageframe';
// Border style only if not using mask.
if ( '' === $this->args['mask'] ) {
if ( '0' !== $bordersize && 0 !== $bordersize && '0px' !== $bordersize ) {
$img_styles .= "border:{$bordersize} solid {$bordercolor};";
}
if ( '0' !== $borderradius && 0 !== $borderradius && '0px' !== $borderradius ) {
$img_styles .= "border-radius:{$borderradius};";
}
}
if ( 'glow' === $style ) {
$img_styles .= "-webkit-box-shadow: 0 0 {$blur} {$stylecolor};box-shadow: 0 0 {$blur} {$stylecolor};";
} elseif ( 'dropshadow' === $style ) {
$img_styles .= "-webkit-box-shadow: {$blur} {$blur} {$blur_radius} {$stylecolor};box-shadow: {$blur} {$blur} {$blur_radius} {$stylecolor};";
}
if ( $img_styles ) {
$this->wrapper_attr['style'] .= $img_styles;
}
$this->wrapper_attr['class'] .= ' imageframe-' . $this->args['style'] . ' imageframe-' . $this->element_id;
if ( 'bottomshadow' === $this->args['style'] ) {
$this->wrapper_attr['class'] .= ' element-bottomshadow';
}
if ( 'liftup' !== $this->args['hover_type'] && ( 'bottomshadow' !== $this->args['style'] && ( 'zoomin' !== $this->args['hover_type'] || 'zoomout' !== $this->args['hover_type'] ) ) ) {
$visibility_classes_need_set = true;
if ( ! fusion_element_rendering_is_flex() ) {
if ( 'left' === $this->args['align'] ) {
$this->wrapper_attr['style'] .= 'margin-right:25px;float:left;';
} elseif ( 'right' === $this->args['align'] ) {
$this->wrapper_attr['style'] .= 'margin-left:25px;float:right;';
}
}
}
if ( $this->args['max_width'] && '' === $this->args['aspect_ratio'] && 'liftup' !== $this->args['hover_type'] && 'bottomshadow' !== $this->args['style'] ) {
$this->wrapper_attr['style'] .= 'max-width:' . fusion_library()->sanitize->get_value_with_unit( $this->args['max_width'] ) . ';';
}
if ( 'liftup' !== $this->args['hover_type'] && in_array( $this->args['caption_style'], [ 'off', 'above', 'below' ], true ) ) {
$this->wrapper_attr['class'] .= ' hover-type-' . $this->args['hover_type'];
}
// Caption style.
if ( ! in_array( $this->args['caption_style'], [ 'off', 'above', 'below' ], true ) ) {
$this->wrapper_attr['class'] .= ' awb-imageframe-style awb-imageframe-style-' . $this->args['caption_style'];
}
if ( '' !== $this->args['mask'] ) {
$this->wrapper_attr['class'] .= ' has-mask';
}
if ( '' !== $this->args['aspect_ratio'] ) {
$this->wrapper_attr['class'] .= ' has-aspect-ratio';
}
if ( $this->args['class'] ) {
$this->wrapper_attr['class'] .= ' ' . $this->args['class'];
}
if ( $this->args['id'] ) {
$this->wrapper_attr['id'] = $this->args['id'];
}
if ( $this->args['animation_type'] ) {
$this->wrapper_attr = Fusion_Builder_Animation_Helper::add_animation_attributes( $this->args, $this->wrapper_attr );
}
if ( $visibility_classes_need_set ) {
$this->wrapper_attr['class'] .= Fusion_Builder_Sticky_Visibility_Helper::get_sticky_class( $this->args['sticky_display'] );
return fusion_builder_visibility_atts( $this->args['hide_on_mobile'], $this->wrapper_attr );
}
return $this->wrapper_attr;
}
/**
* Builds the link attributes array.
*
* @access public
* @since 1.0
* @return array
*/
public function link_attr() {
$attr = [];
if ( 'yes' === $this->args['lightbox'] ) {
$this->args['pic_link'] = is_string( $this->args['pic_link'] ) ? $this->args['pic_link'] : '';
$attr['href'] = $this->args['pic_link'];
$attr['class'] = 'fusion-lightbox';
if ( $this->args['gallery_id'] || '0' === $this->args['gallery_id'] ) {
$attr['data-rel'] = 'iLightbox[' . $this->args['gallery_id'] . ']';
} else {
$attr['data-rel'] = 'iLightbox[' . substr( md5( $this->args['pic_link'] ), 13 ) . ']';
}
if ( $this->lightbox_image_data ) {
$attr['data-caption'] = $this->lightbox_image_data['caption'];
$attr['data-title'] = $this->lightbox_image_data['title'];
} elseif ( $this->image_data ) {
$attr['data-caption'] = $this->image_data['caption'];
$attr['data-title'] = $this->image_data['title'];
}
if ( $this->image_data ) {
$attr['title'] = $this->image_data['title'];
}
} elseif ( $this->args['link'] ) {
$attr['class'] = 'fusion-no-lightbox';
$attr['href'] = $this->args['link'];
$attr['target'] = $this->args['linktarget'];
$attr['aria-label'] = ( $this->image_data ) ? $this->image_data['title'] : '';
if ( '_blank' === $this->args['linktarget'] ) {
$attr['rel'] = 'noopener noreferrer';
}
// Add additional, custom link attributes correctly formatted to the anchor.
$attr = fusion_get_link_attributes( $this->args, $attr );
}
return $attr;
}
/**
* Builds the caption attributes array.
*
* @access public
* @since 3.5
* @return array
*/
public function caption_attr() {
$attr = [
'class' => 'awb-imageframe-caption-container',
'style' => '',
];
if ( ! fusion_element_rendering_is_flex() ) {
return $attr;
}
if ( in_array( $this->args['caption_style'], [ 'above', 'below' ], true ) ) {
// Responsive alignment.
foreach ( [ 'large', 'medium', 'small' ] as $size ) {
$key = 'caption_align' . ( 'large' === $size ? '' : '_' . $size );
$align = ! empty( $this->args[ $key ] ) && 'none' !== $this->args[ $key ] ? $this->args[ $key ] : false;
if ( $align ) {
if ( 'large' === $size ) {
$attr['style'] .= 'text-align:' . $this->args[ $key ] . ';';
} else {
$attr['class'] .= ( 'medium' === $size ? ' md-text-align-' : ' sm-text-align-' ) . $this->args[ $key ];
}
}
}
if ( $this->args['max_width'] && '' === $this->args['aspect_ratio'] ) {
$attr['style'] .= 'max-width:' . fusion_library()->sanitize->get_value_with_unit( $this->args['max_width'] ) . ';';
}
}
return $attr;
}
/**
* Generate logos images markup.
*
* @access public
* @since 3.0
* @param string $images JSON string of images.
* @return string HTML output.
*/
public function get_logo_images( $images ) {
$data = json_decode( $images, true );
$content = '';
$normal_url = isset( $data['default']['normal']['url'] ) && '' !== $data['default']['normal']['url'];
$sticky_url = isset( $data['sticky']['normal']['url'] ) && '' !== $data['sticky']['normal']['url'];
$mobile_url = isset( $data['mobile']['normal']['url'] ) && '' !== $data['mobile']['normal']['url'];
if ( $normal_url ) {
$content .= $this->get_logo_image( $data['default'], 'fusion-standard-logo' );
}
if ( $sticky_url ) {
$content .= $this->get_logo_image( $data['sticky'], 'fusion-sticky-logo' );
}
if ( $mobile_url ) {
$content .= $this->get_logo_image( $data['mobile'], 'fusion-mobile-logo' );
}
return $content;
}
/**
* Generate logos image markup.
*
* @access public
* @since 3.0
* @param array $data Array of image data.
* @param string $class CSS class for item.
* @return string HTML output.
*/
public function get_logo_image( $data, $class = '' ) {
$logo_data = [
'src' => '',
'srcset' => '',
'style' => '',
'retina_url' => false,
'width' => '',
'height' => '',
'class' => $class,
'alt' => apply_filters( 'fusion_logo_alt_tag', get_bloginfo( 'name', 'display' ) . ' ' . __( 'Logo', 'fusion-builder' ) ),
];
$retina_url = isset( $data['retina']['url'] ) ? $data['retina']['url'] : '';
$content = '';
$logo_url = set_url_scheme( $data['normal']['url'] );
$logo_data['srcset'] = $logo_url . ' 1x';
// Get retina logo, if default one is not set.
if ( '' === $logo_url ) {
$logo_url = set_url_scheme( $retina_url );
$logo_data['srcset'] = $logo_url . ' 1x';
$logo_data['src'] = $logo_url;
$logo_data['width'] = $data['retina']['width'];
$logo_data['height'] = $data['retina']['height'];
if ( '' !== $logo_data['width'] ) {
$logo_data['style'] = 'max-height:' . $logo_data['height'] . 'px;height:auto;';
}
} else {
$logo_data['src'] = $logo_url;
$logo_data['width'] = isset( $data['normal']['width'] ) ? $data['normal']['width'] : '';
$logo_data['height'] = isset( $data['normal']['height'] ) ? $data['normal']['height'] : '';
}
if ( $data['normal'] && '' !== $data['normal'] && '' !== $logo_data['width'] && '' !== $logo_data['height'] ) {
$retina_logo = set_url_scheme( $retina_url );
$logo_data['srcset'] .= ', ' . $retina_logo . ' 2x';
$logo_data['retina_url'] = $retina_logo;
if ( '' !== $logo_data['width'] ) {
$logo_data['style'] = 'max-height:' . $logo_data['height'] . 'px;height:auto;';
}
}
$content = '<img ' . FusionBuilder::attributes( 'fusion-logo-attributes', $logo_data ) . ' />';
$this->wrapper_attr['class'] .= ' has-' . $class;
return $content;
}
/**
* Generate mobile logo style.
*
* @access public
* @since 3.0
* @return string Media query.
*/
public function mobile_logo_styles() {
global $small_media_query;
return '<style>' . $small_media_query . ' {
.fusion-imageframe.has-fusion-mobile-logo img.fusion-sticky-logo,
.fusion-imageframe.has-fusion-mobile-logo img.fusion-standard-logo {
display: none !important;
}
.fusion-imageframe.has-fusion-mobile-logo img.fusion-mobile-logo {
display: inline-block !important;
}
} </style>';
}
/**
* Adds settings to element options panel.
*
* @access public
* @since 1.1
* @return array $sections Image Frame settings.
*/
public function add_options() {
return [
'imageframe_shortcode_section' => [
'label' => esc_html__( 'Image', 'fusion-builder' ),
'description' => '',
'id' => 'imageframe_shortcode_section',
'type' => 'accordion',
'icon' => 'fusiona-image',
'fields' => [
'imageframe_style_type' => [
'label' => esc_html__( 'Image Style Type', 'fusion-builder' ),
'description' => esc_html__( 'Select the style type.', 'fusion-builder' ),
'id' => 'imageframe_style_type',
'default' => 'none',
'type' => 'radio-buttonset',
'transport' => 'postMessage',
'choices' => [
'none' => esc_attr__( 'None', 'fusion-builder' ),
'glow' => esc_attr__( 'Glow', 'fusion-builder' ),
'dropshadow' => esc_attr__( 'Drop Shadow', 'fusion-builder' ),
'bottomshadow' => esc_attr__( 'Bottom Shadow', 'fusion-builder' ),
],
],
'imageframe_blur' => [
'label' => esc_html__( 'Image Glow / Drop Shadow Blur', 'fusion-builder' ),
'description' => esc_html__( 'Choose the amount of blur added to glow or drop shadow effect.', 'fusion-builder' ),
'id' => 'imageframe_blur',
'default' => '3',
'type' => 'slider',
'transport' => 'postMessage',
'choices' => [
'min' => '0',
'max' => '50',
'step' => '1',
],
'soft_dependency' => true,
],
'imgframe_style_color' => [
'label' => esc_html__( 'Image Style Color', 'fusion-builder' ),
'description' => esc_html__( 'Controls the style color for all style types except border. Hex colors will use a subtle auto added alpha level to produce a nice effect.', 'fusion-builder' ),
'id' => 'imgframe_style_color',
'default' => 'var(--awb-color7)',
'type' => 'color-alpha',
'transport' => 'postMessage',
'soft_dependency' => true,
],
'imageframe_border_size' => [
'label' => esc_html__( 'Image Border Size', 'fusion-builder' ),
'description' => esc_html__( 'Controls the border size of the image.', 'fusion-builder' ),
'id' => 'imageframe_border_size',
'default' => '0',
'type' => 'slider',
'transport' => 'postMessage',
'choices' => [
'min' => '0',
'max' => '50',
'step' => '1',
],
],
'imgframe_border_color' => [
'label' => esc_html__( 'Image Border Color', 'fusion-builder' ),
'description' => esc_html__( 'Controls the border color of the image.', 'fusion-builder' ),
'id' => 'imgframe_border_color',
'default' => 'var(--awb-color3)',
'type' => 'color-alpha',
'transport' => 'postMessage',
'soft_dependency' => true,
],
'imageframe_border_radius' => [
'label' => esc_html__( 'Image Border Radius', 'fusion-builder' ),
'description' => esc_html__( 'Controls the border radius of the image.', 'fusion-builder' ),
'id' => 'imageframe_border_radius',
'default' => '0px',
'type' => 'dimension',
'choices' => [ 'px', '%' ],
'transport' => 'postMessage',
],
],
],
];
}
/**
* Sets the necessary scripts.
*
* @access public
* @since 3.2
* @return void
*/
public function on_first_render() {
Fusion_Dynamic_JS::enqueue_script( 'fusion-animations' );
Fusion_Dynamic_JS::enqueue_script( 'fusion-lightbox' );
}
/**
* Used to set any other variables for use on front-end editor template.
*
* @static
* @access public
* @since 3.5
* @return array
*/
public static function get_element_extras() {
$fusion_settings = awb_get_fusion_settings();
return [
'visibility_large' => $fusion_settings->get( 'visibility_large' ),
'visibility_medium' => $fusion_settings->get( 'visibility_medium' ),
'visibility_small' => $fusion_settings->get( 'visibility_small' ),
];
}
/**
* 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/image.min.css' );
}
}
}
new FusionSC_Imageframe();
}
/**
* Map shortcode to Avada Builder.
*
* @since 1.0
*/
function fusion_element_image() {
$fusion_settings = awb_get_fusion_settings();
fusion_builder_map(
fusion_builder_frontend_data(
'FusionSC_Imageframe',
[
'name' => esc_attr__( 'Image', 'fusion-builder' ),
'shortcode' => 'fusion_imageframe',
'icon' => 'fusiona-image',
'preview' => FUSION_BUILDER_PLUGIN_DIR . 'inc/templates/previews/fusion-image-frame-preview.php',
'preview_id' => 'fusion-builder-block-module-image-frame-preview-template',
'help_url' => 'https://theme-fusion.com/documentation/avada/elements/image-element/',
'subparam_map' => [
/* Caption title */
'fusion_font_family_caption_title_font' => 'caption_title_fonts',
'fusion_font_variant_caption_title_font' => 'caption_title_fonts',
'caption_title_size' => 'caption_title_fonts',
'caption_title_transform' => 'caption_title_fonts',
'caption_title_line_height' => 'caption_title_fonts',
'caption_title_letter_spacing' => 'caption_title_fonts',
'caption_title_color' => 'caption_title_fonts',
/* Caption text */
'fusion_font_family_caption_text_font' => 'caption_text_fonts',
'fusion_font_variant_caption_text_font' => 'caption_text_fonts',
'caption_text_size' => 'caption_text_fonts',
'caption_text_transform' => 'caption_text_fonts',
'caption_text_transform' => 'caption_text_fonts',
'caption_text_line_height' => 'caption_text_fonts',
'caption_text_color' => 'caption_text_fonts',
],
'params' => [
[
'type' => 'upload',
'heading' => esc_attr__( 'Image', 'fusion-builder' ),
'description' => esc_attr__( 'Upload an image to display.', 'fusion-builder' ),
'param_name' => 'element_content',
'value' => '',
'dynamic_data' => true,
],
[
'type' => 'textfield',
'heading' => esc_attr__( 'Image ID', 'fusion-builder' ),
'description' => esc_attr__( 'Image ID from Media Library.', 'fusion-builder' ),
'param_name' => 'image_id',
'value' => '',
'hidden' => true,
],
[
'type' => 'select',
'heading' => esc_attr__( 'Image Aspect Ratio', 'fusion-builder' ),
'description' => esc_attr__( 'Select an aspect ratio for the image.', 'fusion-builder' ),
'param_name' => 'aspect_ratio',
'value' => [
'' => esc_attr__( 'Automatic', 'fusion-builder' ),
'1-1' => esc_attr__( '1:1', 'fusion-builder' ),
'2-1' => esc_attr__( '2:1', 'fusion-builder' ),
'2-3' => esc_attr__( '2:3', 'fusion-builder' ),
'3-1' => esc_attr__( '3:1', 'fusion-builder' ),
'3-2' => esc_attr__( '3:2', 'fusion-builder' ),
'4-1' => esc_attr__( '4:1', 'fusion-builder' ),
'4-3' => esc_attr__( '4:3', 'fusion-builder' ),
'5-4' => esc_attr__( '5:4', 'fusion-builder' ),
'16-9' => esc_attr__( '16:9', 'fusion-builder' ),
'9-16' => esc_attr__( '9:16', 'fusion-builder' ),
'21-9' => esc_attr__( '21:9', 'fusion-builder' ),
'9-21' => esc_attr__( '9:21', 'fusion-builder' ),
'custom' => esc_attr__( 'Custom', 'fusion-builder' ),
],
],
[
'type' => 'range',
'heading' => esc_attr__( 'Custom Aspect Ratio', 'fusion-builder' ),
'description' => esc_attr__( 'Set a custom aspect ratio for the image.', 'fusion-builder' ),
'param_name' => 'custom_aspect_ratio',
'min' => 1,
'max' => 500,
'value' => 100,
'dependency' => [
[
'element' => 'aspect_ratio',
'value' => 'custom',
'operator' => '==',
],
],
],
[
'type' => 'image_focus_point',
'heading' => esc_attr__( 'Image Focus Point', 'fusion-builder' ),
'description' => esc_attr__( 'Set the image focus point by dragging the blue dot.', 'fusion-builder' ),
'param_name' => 'aspect_ratio_position',
'image' => 'element_content',
'image_id' => 'image_id',
'dependency' => [
[
'element' => 'aspect_ratio',
'value' => '',
'operator' => '!=',
],
],
],
[
'type' => 'select',
'heading' => esc_attr__( 'Lazy Load', 'fusion-builder' ),
'description' => esc_attr__( 'Lazy load which is being used.', 'fusion-builder' ),
'param_name' => 'lazy_load',
'value' => [
'avada' => esc_attr__( 'Avada', 'fusion-builder' ),
'wordpress' => esc_attr__( 'WordPress', 'fusion-builder' ),
'none' => esc_attr__( 'None', 'fusion-builder' ),
],
'default' => $fusion_settings->get( 'lazy_load' ),
'hidden' => true,
'remove_from_atts' => true,
],
[
'type' => 'radio_button_set',
'heading' => esc_attr__( 'Skip Lazy Loading', 'fusion-builder' ),
'description' => esc_attr__( 'Select whether you want to skip lazy loading on this image or not.', 'fusion-builder' ),
'param_name' => 'skip_lazy_load',
'default' => '',
'value' => [
'skip' => esc_attr__( 'Yes', 'fusion-builder' ),
'' => esc_attr__( 'No', 'fusion-builder' ),
],
'dependency' => [
[
'element' => 'lazy_load',
'value' => 'avada',
'operator' => '==',
],
],
],
[
'type' => 'radio_button_set',
'heading' => esc_attr__( 'Image Lightbox', 'fusion-builder' ),
'description' => esc_attr__( 'Show image in lightbox. Lightbox must be enabled in Global Options or the image will open up in the same tab by itself.', 'fusion-builder' ),
'param_name' => 'lightbox',
'value' => [
'yes' => esc_attr__( 'Yes', 'fusion-builder' ),
'no' => esc_attr__( 'No', 'fusion-builder' ),
],
'default' => 'no',
],
[
'type' => 'textfield',
'heading' => esc_attr__( 'Gallery ID', 'fusion-builder' ),
'description' => esc_attr__( 'Set a name for the lightbox gallery this image should belong to.', 'fusion-builder' ),
'param_name' => 'gallery_id',
'value' => '',
'dependency' => [
[
'element' => 'lightbox',
'value' => 'no',
'operator' => '!=',
],
],
],
[
'type' => 'upload',
'heading' => esc_attr__( 'Lightbox Image', 'fusion-builder' ),
'description' => esc_attr__( 'Upload an image that will show up in the lightbox.', 'fusion-builder' ),
'param_name' => 'lightbox_image',
'value' => '',
'dependency' => [
[
'element' => 'lightbox',
'value' => 'no',
'operator' => '!=',
],
],
],
[
'type' => 'textfield',
'heading' => esc_attr__( 'Lightbox Image ID', 'fusion-builder' ),
'description' => esc_attr__( 'Lightbox Image ID from Media Library.', 'fusion-builder' ),
'param_name' => 'lightbox_image_id',
'value' => '',
'hidden' => true,
],
[
'type' => 'textfield',
'heading' => esc_attr__( 'Image Alt Text', 'fusion-builder' ),
'description' => esc_attr__( 'The alt attribute provides alternative information if an image cannot be viewed.', 'fusion-builder' ),
'param_name' => 'alt',
'value' => '',
'dynamic_data' => true,
],
[
'type' => 'link_selector',
'heading' => esc_attr__( 'Image Link URL', 'fusion-builder' ),
'description' => esc_attr__( 'Add the URL the image will link to, ex: http://example.com.', 'fusion-builder' ),
'param_name' => 'link',
'value' => '',
'dynamic_data' => true,
'dependency' => [
[
'element' => 'lightbox',
'value' => 'yes',
'operator' => '!=',
],
],
],
[
'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' => 'linktarget',
'value' => [
'_self' => esc_attr__( '_self', 'fusion-builder' ),
'_blank' => esc_attr__( '_blank', 'fusion-builder' ),
],
'default' => '_self',
'dependency' => [
[
'element' => 'lightbox',
'value' => 'yes',
'operator' => '!=',
],
[
'element' => 'link',
'value' => '',
'operator' => '!=',
],
],
],
// design.
[
'type' => 'textfield',
'heading' => esc_attr__( 'Image Max Width', 'fusion-builder' ),
'description' => esc_attr__( 'Set the maximum width the image should take up. Enter value including any valid CSS unit, ex: 200px. Leave empty to use full image width.', 'fusion-builder' ),
'group' => esc_attr__( 'Design', 'fusion-builder' ),
'param_name' => 'max_width',
'value' => '',
],
[
'type' => 'textfield',
'heading' => esc_attr__( 'Image Sticky Max Width', 'fusion-builder' ),
'description' => esc_attr__( 'Set the maximum width the image should take up when its parent container is sticky. Enter value including any valid CSS unit, ex: 200px. Leave empty to use full image width.', 'fusion-builder' ),
'group' => esc_attr__( 'Design', 'fusion-builder' ),
'param_name' => 'sticky_max_width',
'value' => '',
'dependency' => [
[
'element' => 'fusion_builder_container',
'param' => 'sticky',
'value' => 'on',
'operator' => '==',
],
],
],
[
'type' => 'radio_button_set',
'heading' => esc_attr__( 'Alignment', 'fusion-builder' ),
'description' => esc_attr__( 'Choose how to align the image.', 'fusion-builder' ),
'group' => esc_attr__( 'Design', 'fusion-builder' ),
'param_name' => 'align',
'responsive' => [
'state' => 'large',
],
'value' => [
'none' => esc_attr__( 'Text Flow', 'fusion-builder' ),
'left' => esc_attr__( 'Left', 'fusion-builder' ),
'right' => esc_attr__( 'Right', 'fusion-builder' ),
'center' => esc_attr__( 'Center', 'fusion-builder' ),
],
'default' => 'none',
],
[
'type' => 'radio_button_set',
'heading' => esc_attr__( 'Mask', 'fusion-builder' ),
'description' => esc_attr__( 'Select an image mask.', 'fusion-builder' ),
'group' => esc_attr__( 'Design', 'fusion-builder' ),
'param_name' => 'mask',
'value' => [
'' => esc_attr__( 'None', 'fusion-builder' ),
'mask-1' => esc_attr__( 'Mask 1', 'fusion-builder' ),
'mask-2' => esc_attr__( 'Mask 2', 'fusion-builder' ),
'mask-3' => esc_attr__( 'Mask 3', 'fusion-builder' ),
'mask-4' => esc_attr__( 'Mask 4', 'fusion-builder' ),
'mask-5' => esc_attr__( 'Mask 5', 'fusion-builder' ),
'mask-6' => esc_attr__( 'Mask 6', 'fusion-builder' ),
'mask-7' => esc_attr__( 'Mask 7', 'fusion-builder' ),
'mask-8' => esc_attr__( 'Mask 8', 'fusion-builder' ),
'mask-9' => esc_attr__( 'Mask 9', 'fusion-builder' ),
'mask-10' => esc_attr__( 'Mask 10', 'fusion-builder' ),
'mask-11' => esc_attr__( 'Mask 11', 'fusion-builder' ),
'mask-12' => esc_attr__( 'Mask 12', 'fusion-builder' ),
'mask-13' => esc_attr__( 'Mask 13', 'fusion-builder' ),
'mask-14' => esc_attr__( 'Mask 14', 'fusion-builder' ),
'mask-15' => esc_attr__( 'Mask 15', 'fusion-builder' ),
'mask-16' => esc_attr__( 'Mask 16', 'fusion-builder' ),
'mask-17' => esc_attr__( 'Mask 17', 'fusion-builder' ),
'mask-18' => esc_attr__( 'Mask 18', 'fusion-builder' ),
'custom' => esc_attr__( 'Custom', 'fusion-builder' ),
],
'icons' => [
'' => '<span class="fusiona-minus"></span>',
'mask-1' => '<span class="fusiona-mask-1"></span>',
'mask-2' => '<span class="fusiona-mask-2"></span>',
'mask-3' => '<span class="fusiona-mask-3"></span>',
'mask-4' => '<span class="fusiona-mask-4"></span>',
'mask-5' => '<span class="fusiona-mask-5"></span>',
'mask-6' => '<span class="fusiona-mask-6"></span>',
'mask-7' => '<span class="fusiona-mask-7"></span>',
'mask-8' => '<span class="fusiona-mask-8"></span>',
'mask-9' => '<span class="fusiona-mask-9"></span>',
'mask-10' => '<span class="fusiona-mask-10"></span>',
'mask-11' => '<span class="fusiona-mask-11"></span>',
'mask-12' => '<span class="fusiona-mask-12"></span>',
'mask-13' => '<span class="fusiona-mask-13"></span>',
'mask-14' => '<span class="fusiona-mask-14"></span>',
'mask-15' => '<span class="fusiona-mask-15"></span>',
'mask-16' => '<span class="fusiona-mask-16"></span>',
'mask-17' => '<span class="fusiona-mask-17"></span>',
'mask-18' => '<span class="fusiona-mask-18"></span>',
'custom' => '<span class="fusiona-cog"></span>',
],
'grid_layout' => true,
'back_icons' => true,
],
[
'type' => 'upload',
'heading' => esc_attr__( 'Custom Mask', 'fusion-builder' ),
'description' => esc_attr__( 'Upload a custom mask image. The image should be in SVG or PNG format with transparent background.', 'fusion-builder' ),
'group' => esc_attr__( 'Design', 'fusion-builder' ),
'param_name' => 'custom_mask',
'dependency' => [
[
'element' => 'mask',
'value' => 'custom',
'operator' => '==',
],
],
],
[
'type' => 'radio_button_set',
'heading' => esc_attr__( 'Mask Size', 'fusion-builder' ),
'description' => esc_attr__( 'Select the mask size.', 'fusion-builder' ),
'group' => esc_attr__( 'Design', 'fusion-builder' ),
'param_name' => 'mask_size',
'value' => [
'' => esc_attr__( 'Fit', 'fusion-builder' ),
'fill' => esc_attr__( 'Fill', 'fusion-builder' ),
'custom' => esc_attr__( 'Custom', 'fusion-builder' ),
],
'dependency' => [
[
'element' => 'mask',
'value' => '',
'operator' => '!=',
],
],
],
[
'type' => 'textfield',
'heading' => esc_attr__( 'Custom Size', 'fusion-builder' ),
'description' => esc_attr__( 'Set the size of the image mask. Enter value including any valid CSS unit ex. 60% or 200px.', 'fusion-builder' ),
'group' => esc_attr__( 'Design', 'fusion-builder' ),
'param_name' => 'mask_custom_size',
'dependency' => [
[
'element' => 'mask',
'value' => '',
'operator' => '!=',
],
[
'element' => 'mask_size',
'value' => 'custom',
'operator' => '==',
],
],
],
[
'type' => 'select',
'heading' => esc_attr__( 'Mask Position', 'fusion-builder' ),
'description' => esc_attr__( 'Set image mask position.', 'fusion-builder' ),
'group' => esc_attr__( 'Design', 'fusion-builder' ),
'param_name' => 'mask_position',
'value' => [
'top-center' => esc_attr__( 'Top Center', 'fusion-builder' ),
'top-left' => esc_attr__( 'Top Left', 'fusion-builder' ),
'top-right' => esc_attr__( 'Top Right', 'fusion-builder' ),
'' => esc_attr__( 'Center Center', 'fusion-builder' ),
'center-left' => esc_attr__( 'Center Left', 'fusion-builder' ),
'center-right' => esc_attr__( 'Center Right', 'fusion-builder' ),
'bottom-center' => esc_attr__( 'Bottom Center', 'fusion-builder' ),
'bottom-left' => esc_attr__( 'Bottom Left', 'fusion-builder' ),
'bottom-right' => esc_attr__( 'Bottom Right', 'fusion-builder' ),
'custom' => esc_attr__( 'Custom', 'fusion-builder' ),
],
'dependency' => [
[
'element' => 'mask',
'value' => '',
'operator' => '!=',
],
],
],
[
'type' => 'textfield',
'heading' => esc_attr__( 'Custom Mask Position', 'fusion-builder' ),
'description' => esc_attr__( 'Set a custom image mask position. Enter value including any valid CSS unit in pair first for X axis second for Y axis ex. 60% 50px.', 'fusion-builder' ),
'group' => esc_attr__( 'Design', 'fusion-builder' ),
'param_name' => 'mask_custom_position',
'dependency' => [
[
'element' => 'mask',
'value' => '',
'operator' => '!=',
],
[
'element' => 'mask_position',
'value' => 'custom',
'operator' => '==',
],
],
],
[
'type' => 'select',
'heading' => esc_attr__( 'Mask Repeat', 'fusion-builder' ),
'description' => esc_attr__( 'Select how the image mask repeats.', 'fusion-builder' ),
'group' => esc_attr__( 'Design', 'fusion-builder' ),
'param_name' => 'mask_repeat',
'value' => [
'' => esc_attr__( 'No Repeat', 'fusion-builder' ),
'repeat' => esc_attr__( 'Repeat', 'fusion-builder' ),
'repeat-x' => esc_attr__( 'Repeat X', 'fusion-builder' ),
'repeat-y' => esc_attr__( 'Repeat Y', 'fusion-builder' ),
'space' => esc_attr__( 'Space', 'fusion-builder' ),
'round' => esc_attr__( 'Round', 'fusion-builder' ),
],
'dependency' => [
[
'element' => 'mask',
'value' => '',
'operator' => '!=',
],
],
],
[
'type' => 'radio_button_set',
'heading' => esc_attr__( 'Style Type', 'fusion-builder' ),
'description' => esc_attr__( 'Select the style type. Style type will be disabled when using mask or caption styles other than "Above" or "Below" are chosen.', 'fusion-builder' ),
'group' => esc_attr__( 'Design', 'fusion-builder' ),
'param_name' => 'style_type',
'value' => [
'' => esc_attr__( 'Default', 'fusion-builder' ),
'none' => esc_attr__( 'None', 'fusion-builder' ),
'glow' => esc_attr__( 'Glow', 'fusion-builder' ),
'dropshadow' => esc_attr__( 'Drop Shadow', 'fusion-builder' ),
'bottomshadow' => esc_attr__( 'Bottom Shadow', 'fusion-builder' ),
],
'dependency' => [
[
'element' => 'mask',
'value' => '',
'operator' => '==',
],
[
'element' => 'caption_style',
'value' => 'navin',
'operator' => '!=',
],
[
'element' => 'caption_style',
'value' => 'dario',
'operator' => '!=',
],
[
'element' => 'caption_style',
'value' => 'resa',
'operator' => '!=',
],
[
'element' => 'caption_style',
'value' => 'schantel',
'operator' => '!=',
],
[
'element' => 'caption_style',
'value' => 'dany',
'operator' => '!=',
],
],
],
[
'type' => 'range',
'heading' => esc_attr__( 'Glow / Drop Shadow Blur', 'fusion-builder' ),
'description' => esc_attr__( 'Choose the amount of blur added to glow or drop shadow effect. In pixels.', 'fusion-builder' ),
'group' => esc_attr__( 'Design', 'fusion-builder' ),
'param_name' => 'blur',
'value' => '',
'min' => '0',
'max' => '50',
'step' => '1',
'default' => $fusion_settings->get( 'imageframe_blur' ),
'dependency' => [
[
'element' => 'style_type',
'value' => 'none',
'operator' => '!=',
],
[
'element' => 'style_type',
'value' => 'bottomshadow',
'operator' => '!=',
],
[
'element' => 'mask',
'value' => '',
'operator' => '==',
],
[
'element' => 'caption_style',
'value' => 'navin',
'operator' => '!=',
],
[
'element' => 'caption_style',
'value' => 'dario',
'operator' => '!=',
],
[
'element' => 'caption_style',
'value' => 'resa',
'operator' => '!=',
],
[
'element' => 'caption_style',
'value' => 'schantel',
'operator' => '!=',
],
[
'element' => 'caption_style',
'value' => 'dany',
'operator' => '!=',
],
],
],
[
'type' => 'colorpickeralpha',
'heading' => esc_attr__( 'Style Color', 'fusion-builder' ),
'description' => esc_attr__( 'Controls the style color for all style types except border. Hex colors will use a subtle auto added alpha level to produce a nice effect.', 'fusion-builder' ),
'group' => esc_attr__( 'Design', 'fusion-builder' ),
'param_name' => 'stylecolor',
'value' => '',
'default' => $fusion_settings->get( 'imgframe_style_color' ),
'dependency' => [
[
'element' => 'style_type',
'value' => 'none',
'operator' => '!=',
],
[
'element' => 'mask',
'value' => '',
'operator' => '==',
],
[
'element' => 'caption_style',
'value' => 'navin',
'operator' => '!=',
],
[
'element' => 'caption_style',
'value' => 'dario',
'operator' => '!=',
],
[
'element' => 'caption_style',
'value' => 'resa',
'operator' => '!=',
],
[
'element' => 'caption_style',
'value' => 'schantel',
'operator' => '!=',
],
[
'element' => 'caption_style',
'value' => 'dany',
'operator' => '!=',
],
],
],
[
'type' => 'radio_button_set',
'heading' => esc_attr__( 'Hover Type', 'fusion-builder' ),
'description' => esc_attr__( 'Select the hover effect type. Hover Type will be disabled when caption styles other than Above or Below are chosen.', 'fusion-builder' ),
'group' => esc_attr__( 'Design', 'fusion-builder' ),
'param_name' => 'hover_type',
'value' => [
'none' => esc_attr__( 'None', 'fusion-builder' ),
'zoomin' => esc_attr__( 'Zoom In', 'fusion-builder' ),
'zoomout' => esc_attr__( 'Zoom Out', 'fusion-builder' ),
'liftup' => esc_attr__( 'Lift Up', 'fusion-builder' ),
],
'default' => 'none',
'preview' => [
'selector' => '.fusion-imageframe',
'type' => 'class',
'toggle' => 'hover',
],
'dependency' => [
[
'element' => 'caption_style',
'value' => 'navin',
'operator' => '!=',
],
[
'element' => 'caption_style',
'value' => 'dario',
'operator' => '!=',
],
[
'element' => 'caption_style',
'value' => 'resa',
'operator' => '!=',
],
[
'element' => 'caption_style',
'value' => 'schantel',
'operator' => '!=',
],
[
'element' => 'caption_style',
'value' => 'dany',
'operator' => '!=',
],
],
],
'fusion_margin_placeholder' => [
'param_name' => 'margin',
'value' => [
'margin_top' => '',
'margin_right' => '',
'margin_bottom' => '',
'margin_left' => '',
],
'responsive' => [
'state' => 'large',
],
],
[
'type' => 'range',
'heading' => esc_attr__( 'Border Size', 'fusion-builder' ),
'description' => esc_attr__( 'In pixels.', 'fusion-builder' ),
'group' => esc_attr__( 'Design', 'fusion-builder' ),
'param_name' => 'bordersize',
'value' => '',
'min' => '0',
'max' => '50',
'step' => '1',
'default' => $fusion_settings->get( 'imageframe_border_size' ),
'dependency' => [
[
'element' => 'mask',
'value' => '',
'operator' => '==',
],
],
],
[
'type' => 'colorpickeralpha',
'heading' => esc_attr__( 'Border Color', 'fusion-builder' ),
'description' => esc_attr__( 'Controls the border color. ', 'fusion-builder' ),
'group' => esc_attr__( 'Design', 'fusion-builder' ),
'param_name' => 'bordercolor',
'value' => '',
'default' => $fusion_settings->get( 'imgframe_border_color' ),
'dependency' => [
[
'element' => 'mask',
'value' => '',
'operator' => '==',
],
[
'element' => 'bordersize',
'value' => '0',
'operator' => '!=',
],
],
],
[
'type' => 'textfield',
'heading' => esc_attr__( 'Border Radius', 'fusion-builder' ),
'description' => esc_attr__( 'Controls the image border radius. In pixels (px), ex: 1px, or "round". ', 'fusion-builder' ),
'group' => esc_attr__( 'Design', 'fusion-builder' ),
'param_name' => 'borderradius',
'value' => '',
'dependency' => [
[
'element' => 'mask',
'value' => '',
'operator' => '==',
],
[
'element' => 'style_type',
'value' => 'bottomshadow',
'operator' => '!=',
],
],
],
// design end.
[
'type' => 'select',
'heading' => esc_attr__( 'Caption', 'fusion-builder' ),
'description' => esc_attr__( 'Choose the caption style.', 'fusion-builder' ),
'param_name' => 'caption_style',
'value' => [
'off' => esc_attr__( 'Off', 'fusion-builder' ),
'above' => esc_attr__( 'Above', 'fusion-builder' ),
'below' => esc_attr__( 'Below', 'fusion-builder' ),
'navin' => esc_attr__( 'Navin', 'fusion-builder' ),
'dario' => esc_attr__( 'Dario', 'fusion-builder' ),
'resa' => esc_attr__( 'Resa', 'fusion-builder' ),
'schantel' => esc_attr__( 'Schantel', 'fusion-builder' ),
'dany' => esc_attr__( 'Dany', 'fusion-builder' ),
],
'default' => 'off',
'group' => esc_attr__( 'Caption', 'fusion-builder' ),
],
[
'type' => 'radio_button_set',
'heading' => esc_attr__( 'Title / Caption Align', 'fusion-builder' ),
'description' => esc_attr__( 'Choose how to align the caption.', 'fusion-builder' ),
'param_name' => 'caption_align',
'responsive' => [
'state' => 'large',
],
'value' => [
'none' => esc_attr__( 'Text Flow', 'fusion-builder' ),
'left' => esc_attr__( 'Left', 'fusion-builder' ),
'right' => esc_attr__( 'Right', 'fusion-builder' ),
'center' => esc_attr__( 'Center', 'fusion-builder' ),
],
'default' => 'none',
'group' => esc_attr__( 'Caption', 'fusion-builder' ),
'dependency' => [
[
'element' => 'caption_style',
'value' => 'off',
'operator' => '!=',
],
[
'element' => 'caption_style',
'value' => 'schantel',
'operator' => '!=',
],
[
'element' => 'caption_style',
'value' => 'dany',
'operator' => '!=',
],
[
'element' => 'caption_style',
'value' => 'navin',
'operator' => '!=',
],
[
'element' => 'caption_style',
'value' => 'dario',
'operator' => '!=',
],
[
'element' => 'caption_style',
'value' => 'resa',
'operator' => '!=',
],
],
],
[
'type' => 'textfield',
'heading' => esc_attr__( 'Image Title', 'fusion-builder' ),
'description' => esc_attr__( 'Enter title text to be displayed on image.', 'fusion-builder' ),
'param_name' => 'caption_title',
'value' => '',
'dynamic_data' => true,
'group' => esc_attr__( 'Caption', 'fusion-builder' ),
'dependency' => [
[
'element' => 'caption_style',
'value' => 'off',
'operator' => '!=',
],
],
'responsive' => [
'state' => 'large',
],
],
[
'type' => 'textfield',
'heading' => esc_attr__( 'Image Caption', 'fusion-builder' ),
'description' => esc_attr__( 'Enter caption text to be displayed on image.', 'fusion-builder' ),
'param_name' => 'caption_text',
'value' => '',
'dynamic_data' => true,
'group' => esc_attr__( 'Caption', 'fusion-builder' ),
'dependency' => [
[
'element' => 'caption_style',
'value' => 'off',
'operator' => '!=',
],
],
],
[
'type' => 'radio_button_set',
'heading' => esc_attr__( 'Image Title Heading Tag', 'fusion-builder' ),
'description' => esc_attr__( 'Choose HTML tag of the image title, either div or the heading tag, h1-h6.', 'fusion-builder' ),
'param_name' => 'caption_title_tag',
'value' => [
'1' => 'H1',
'2' => 'H2',
'3' => 'H3',
'4' => 'H4',
'5' => 'H5',
'6' => 'H6',
'div' => 'DIV',
],
'default' => '2',
'group' => esc_attr__( 'Caption', 'fusion-builder' ),
'dependency' => [
[
'element' => 'caption_style',
'value' => 'off',
'operator' => '!=',
],
],
],
[
'type' => 'typography',
'heading' => esc_attr__( 'Image Title Typography', 'fusion-builder' ),
'description' => esc_html__( 'Controls the typography of the image title. Leave empty for the global font family.', 'fusion-builder' ),
'param_name' => 'caption_title_fonts',
'choices' => [
'font-family' => 'caption_title_font',
'font-size' => 'caption_title_size',
'text-transform' => 'caption_title_transform',
'line-height' => 'caption_title_line_height',
'letter-spacing' => 'caption_title_letter_spacing',
'color' => 'caption_title_color',
],
'default' => [
'font-family' => '',
'variant' => '400',
'text-transform' => '',
'line-height' => '',
'letter-spacing' => '',
'color' => '',
],
'remove_from_atts' => true,
'global' => true,
'group' => esc_attr__( 'Caption', 'fusion-builder' ),
'dependency' => [
[
'element' => 'caption_style',
'value' => 'off',
'operator' => '!=',
],
],
],
[
'type' => 'colorpickeralpha',
'heading' => esc_attr__( 'Image Caption Background Color', 'fusion-builder' ),
'description' => esc_attr__( 'Controls the background color of the caption.', 'fusion-builder' ),
'param_name' => 'caption_background_color',
'value' => '',
'group' => esc_attr__( 'Caption', 'fusion-builder' ),
'default' => '',
'dependency' => [
[
'element' => 'caption_style',
'value' => 'off',
'operator' => '!=',
],
[
'element' => 'caption_style',
'value' => 'above',
'operator' => '!=',
],
[
'element' => 'caption_style',
'value' => 'below',
'operator' => '!=',
],
[
'element' => 'caption_style',
'value' => 'navin',
'operator' => '!=',
],
[
'element' => 'caption_style',
'value' => 'dario',
'operator' => '!=',
],
[
'element' => 'caption_style',
'value' => 'resa',
'operator' => '!=',
],
],
],
[
'type' => 'typography',
'heading' => esc_attr__( 'Image Caption Typography', 'fusion-builder' ),
'description' => esc_html__( 'Controls the typography of the image caption. Leave empty for the global font family.', 'fusion-builder' ),
'param_name' => 'caption_text_fonts',
'choices' => [
'font-family' => 'caption_text_font',
'font-size' => 'caption_text_size',
'text-transform' => 'caption_text_transform',
'line-height' => 'caption_text_line_height',
'letter-spacing' => 'caption_text_letter_spacing',
'color' => 'caption_text_color',
],
'default' => [
'font-family' => '',
'variant' => '400',
'text-transform' => '',
'line-height' => '',
'letter-spacing' => '',
'color' => '',
],
'remove_from_atts' => true,
'global' => true,
'group' => esc_attr__( 'Caption', 'fusion-builder' ),
'dependency' => [
[
'element' => 'caption_style',
'value' => 'off',
'operator' => '!=',
],
],
],
[
'type' => 'colorpickeralpha',
'heading' => esc_attr__( 'Caption Border Color', 'fusion-builder' ),
'description' => esc_attr__( 'Controls the color of the caption border.', 'fusion-builder' ),
'param_name' => 'caption_border_color',
'value' => '',
'group' => esc_attr__( 'Caption', 'fusion-builder' ),
'default' => 'var(--awb-color1)',
'dependency' => [
[
'element' => 'caption_style',
'value' => 'off',
'operator' => '!=',
],
[
'element' => 'caption_style',
'value' => 'above',
'operator' => '!=',
],
[
'element' => 'caption_style',
'value' => 'below',
'operator' => '!=',
],
[
'element' => 'caption_style',
'value' => 'navin',
'operator' => '!=',
],
[
'element' => 'caption_style',
'value' => 'schantel',
'operator' => '!=',
],
[
'element' => 'caption_style',
'value' => 'dany',
'operator' => '!=',
],
],
],
[
'type' => 'colorpickeralpha',
'heading' => esc_attr__( 'Image Overlay Color', 'fusion-builder' ),
'description' => esc_attr__( 'Controls the color of the image overlay.', 'fusion-builder' ),
'param_name' => 'caption_overlay_color',
'value' => '',
'group' => esc_attr__( 'Caption', 'fusion-builder' ),
'default' => $fusion_settings->get( 'primary_color' ),
'dependency' => [
[
'element' => 'caption_style',
'value' => 'off',
'operator' => '!=',
],
[
'element' => 'caption_style',
'value' => 'above',
'operator' => '!=',
],
[
'element' => 'caption_style',
'value' => 'below',
'operator' => '!=',
],
],
],
[
'type' => 'dimension',
'remove_from_atts' => true,
'heading' => esc_attr__( 'Caption Area Margin', 'fusion-builder' ),
'description' => esc_attr__( 'In pixels or percentage, ex: 10px or 10%.', 'fusion-builder' ),
'param_name' => 'caption_margin',
'value' => [
'caption_margin_top' => '',
'caption_margin_right' => '',
'caption_margin_bottom' => '',
'caption_margin_left' => '',
],
'callback' => [
'function' => 'fusion_style_block',
],
'group' => esc_attr__( 'Caption', 'fusion-builder' ),
'dependency' => [
[
'element' => 'caption_style',
'value' => 'off',
'operator' => '!=',
],
[
'element' => 'caption_style',
'value' => 'schantel',
'operator' => '!=',
],
[
'element' => 'caption_style',
'value' => 'dany',
'operator' => '!=',
],
[
'element' => 'caption_style',
'value' => 'navin',
'operator' => '!=',
],
[
'element' => 'caption_style',
'value' => 'dario',
'operator' => '!=',
],
[
'element' => 'caption_style',
'value' => 'resa',
'operator' => '!=',
],
],
],
[
'type' => 'select',
'heading' => esc_attr__( 'Caption', 'fusion-builder' ),
'description' => esc_attr__( 'Choose the caption style.', 'fusion-builder' ),
'param_name' => 'caption_style',
'value' => [
'off' => esc_attr__( 'Off', 'fusion-builder' ),
'above' => esc_attr__( 'Above', 'fusion-builder' ),
'below' => esc_attr__( 'Below', 'fusion-builder' ),
'navin' => esc_attr__( 'Navin', 'fusion-builder' ),
'dario' => esc_attr__( 'Dario', 'fusion-builder' ),
'resa' => esc_attr__( 'Resa', 'fusion-builder' ),
'schantel' => esc_attr__( 'Schantel', 'fusion-builder' ),
'dany' => esc_attr__( 'Dany', 'fusion-builder' ),
],
'default' => 'off',
'group' => esc_attr__( 'Caption', 'fusion-builder' ),
],
[
'type' => 'radio_button_set',
'heading' => esc_attr__( 'Title / Caption Align', 'fusion-builder' ),
'description' => esc_attr__( 'Choose how to align the caption.', 'fusion-builder' ),
'param_name' => 'caption_align',
'responsive' => [
'state' => 'large',
],
'value' => [
'none' => esc_attr__( 'Text Flow', 'fusion-builder' ),
'left' => esc_attr__( 'Left', 'fusion-builder' ),
'right' => esc_attr__( 'Right', 'fusion-builder' ),
'center' => esc_attr__( 'Center', 'fusion-builder' ),
],
'default' => 'none',
'group' => esc_attr__( 'Caption', 'fusion-builder' ),
'dependency' => [
[
'element' => 'caption_style',
'value' => 'off',
'operator' => '!=',
],
[
'element' => 'caption_style',
'value' => 'schantel',
'operator' => '!=',
],
[
'element' => 'caption_style',
'value' => 'dany',
'operator' => '!=',
],
[
'element' => 'caption_style',
'value' => 'navin',
'operator' => '!=',
],
[
'element' => 'caption_style',
'value' => 'dario',
'operator' => '!=',
],
[
'element' => 'caption_style',
'value' => 'resa',
'operator' => '!=',
],
],
],
[
'type' => 'textfield',
'heading' => esc_attr__( 'Image Title', 'fusion-builder' ),
'description' => esc_attr__( 'Enter title text to be displayed on image.', 'fusion-builder' ),
'param_name' => 'caption_title',
'value' => '',
'dynamic_data' => true,
'group' => esc_attr__( 'Caption', 'fusion-builder' ),
'dependency' => [
[
'element' => 'caption_style',
'value' => 'off',
'operator' => '!=',
],
],
],
[
'type' => 'textfield',
'heading' => esc_attr__( 'Image Caption', 'fusion-builder' ),
'description' => esc_attr__( 'Enter caption text to be displayed on image.', 'fusion-builder' ),
'param_name' => 'caption_text',
'value' => '',
'dynamic_data' => true,
'group' => esc_attr__( 'Caption', 'fusion-builder' ),
'dependency' => [
[
'element' => 'caption_style',
'value' => 'off',
'operator' => '!=',
],
],
],
[
'type' => 'colorpickeralpha',
'heading' => esc_attr__( 'Image Title Color', 'fusion-builder' ),
'description' => esc_attr__( 'Controls the color of the image title.', 'fusion-builder' ),
'param_name' => 'caption_title_color',
'value' => '',
'group' => esc_attr__( 'Caption', 'fusion-builder' ),
'default' => '',
'dependency' => [
[
'element' => 'caption_style',
'value' => 'off',
'operator' => '!=',
],
],
],
[
'type' => 'textfield',
'heading' => esc_attr__( 'Image Title Size', 'fusion-builder' ),
'description' => esc_html__( 'Controls the font size of the image title. Enter value including any valid CSS unit, ex: 20px.', 'fusion-builder' ),
'param_name' => 'caption_title_size',
'value' => '',
'group' => esc_attr__( 'Caption', 'fusion-builder' ),
'dependency' => [
[
'element' => 'caption_style',
'value' => 'off',
'operator' => '!=',
],
],
],
[
'type' => 'radio_button_set',
'heading' => esc_attr__( 'Image Title Heading Tag', 'fusion-builder' ),
'description' => esc_attr__( 'Choose HTML tag of the image title, either div or the heading tag, h1-h6.', 'fusion-builder' ),
'param_name' => 'caption_title_tag',
'value' => [
'1' => 'H1',
'2' => 'H2',
'3' => 'H3',
'4' => 'H4',
'5' => 'H5',
'6' => 'H6',
'div' => 'DIV',
],
'default' => '2',
'group' => esc_attr__( 'Caption', 'fusion-builder' ),
'dependency' => [
[
'element' => 'caption_style',
'value' => 'off',
'operator' => '!=',
],
],
],
[
'type' => 'font_family',
'remove_from_atts' => true,
'heading' => esc_attr__( 'Image Title Font Family', 'fusion-builder' ),
'description' => esc_html__( 'Controls the font family of the image title.', 'fusion-builder' ),
'param_name' => 'caption_title_font',
'group' => esc_attr__( 'Caption', 'fusion-builder' ),
'default' => [
'font-family' => '',
'font-variant' => '400',
],
'dependency' => [
[
'element' => 'caption_style',
'value' => 'off',
'operator' => '!=',
],
],
],
[
'type' => 'radio_button_set',
'heading' => esc_attr__( 'Image Title Transform', 'fusion-builder' ),
'description' => esc_attr__( 'Choose how the title is displayed.', 'fusion-builder' ),
'param_name' => 'caption_title_transform',
'default' => '',
'value' => [
'' => esc_attr__( 'Default', 'fusion-builder' ),
'none' => esc_attr__( 'Normal', 'fusion-builder' ),
'uppercase' => esc_attr__( 'Uppercase', 'fusion-builder' ),
],
'group' => esc_attr__( 'Caption', 'fusion-builder' ),
'dependency' => [
[
'element' => 'caption_style',
'value' => 'off',
'operator' => '!=',
],
],
],
[
'type' => 'colorpickeralpha',
'heading' => esc_attr__( 'Image Caption Color', 'fusion-builder' ),
'description' => esc_attr__( 'Controls the color of the image caption.', 'fusion-builder' ),
'param_name' => 'caption_text_color',
'value' => '',
'group' => esc_attr__( 'Caption', 'fusion-builder' ),
'default' => '',
'dependency' => [
[
'element' => 'caption_style',
'value' => 'off',
'operator' => '!=',
],
],
],
[
'type' => 'colorpickeralpha',
'heading' => esc_attr__( 'Image Caption Background Color', 'fusion-builder' ),
'description' => esc_attr__( 'Controls the background color of the caption.', 'fusion-builder' ),
'param_name' => 'caption_background_color',
'value' => '',
'group' => esc_attr__( 'Caption', 'fusion-builder' ),
'default' => '',
'dependency' => [
[
'element' => 'caption_style',
'value' => 'off',
'operator' => '!=',
],
[
'element' => 'caption_style',
'value' => 'above',
'operator' => '!=',
],
[
'element' => 'caption_style',
'value' => 'below',
'operator' => '!=',
],
[
'element' => 'caption_style',
'value' => 'navin',
'operator' => '!=',
],
[
'element' => 'caption_style',
'value' => 'dario',
'operator' => '!=',
],
[
'element' => 'caption_style',
'value' => 'resa',
'operator' => '!=',
],
],
],
[
'type' => 'textfield',
'heading' => esc_attr__( 'Image Caption Size', 'fusion-builder' ),
'description' => esc_html__( 'Controls the font size of the image caption. Enter value including any valid CSS unit, ex: 20px.', 'fusion-builder' ),
'param_name' => 'caption_text_size',
'value' => '',
'group' => esc_attr__( 'Caption', 'fusion-builder' ),
'dependency' => [
[
'element' => 'caption_style',
'value' => 'off',
'operator' => '!=',
],
],
],
[
'type' => 'font_family',
'remove_from_atts' => true,
'heading' => esc_attr__( 'Image Caption Font Family', 'fusion-builder' ),
'description' => esc_html__( 'Controls the font family of the image caption.', 'fusion-builder' ),
'param_name' => 'caption_text_font',
'group' => esc_attr__( 'Caption', 'fusion-builder' ),
'default' => [
'font-family' => '',
'font-variant' => '400',
],
'dependency' => [
[
'element' => 'caption_style',
'value' => 'off',
'operator' => '!=',
],
],
],
[
'type' => 'radio_button_set',
'heading' => esc_attr__( 'Image Caption Transform', 'fusion-builder' ),
'description' => esc_attr__( 'Choose how the text is displayed.', 'fusion-builder' ),
'param_name' => 'caption_text_transform',
'default' => '',
'value' => [
'' => esc_attr__( 'Default', 'fusion-builder' ),
'none' => esc_attr__( 'Normal', 'fusion-builder' ),
'uppercase' => esc_attr__( 'Uppercase', 'fusion-builder' ),
],
'group' => esc_attr__( 'Caption', 'fusion-builder' ),
'dependency' => [
[
'element' => 'caption_style',
'value' => 'off',
'operator' => '!=',
],
],
],
[
'type' => 'colorpickeralpha',
'heading' => esc_attr__( 'Caption Border Color', 'fusion-builder' ),
'description' => esc_attr__( 'Controls the color of the caption border.', 'fusion-builder' ),
'param_name' => 'caption_border_color',
'value' => '',
'group' => esc_attr__( 'Caption', 'fusion-builder' ),
'default' => '',
'dependency' => [
[
'element' => 'caption_style',
'value' => 'off',
'operator' => '!=',
],
[
'element' => 'caption_style',
'value' => 'above',
'operator' => '!=',
],
[
'element' => 'caption_style',
'value' => 'below',
'operator' => '!=',
],
[
'element' => 'caption_style',
'value' => 'navin',
'operator' => '!=',
],
[
'element' => 'caption_style',
'value' => 'schantel',
'operator' => '!=',
],
[
'element' => 'caption_style',
'value' => 'dany',
'operator' => '!=',
],
],
],
[
'type' => 'colorpickeralpha',
'heading' => esc_attr__( 'Image Overlay Color', 'fusion-builder' ),
'description' => esc_attr__( 'Controls the color of the image overlay.', 'fusion-builder' ),
'param_name' => 'caption_overlay_color',
'value' => '',
'group' => esc_attr__( 'Caption', 'fusion-builder' ),
'default' => $fusion_settings->get( 'primary_color' ),
'dependency' => [
[
'element' => 'caption_style',
'value' => 'off',
'operator' => '!=',
],
[
'element' => 'caption_style',
'value' => 'above',
'operator' => '!=',
],
[
'element' => 'caption_style',
'value' => 'below',
'operator' => '!=',
],
],
],
[
'type' => 'dimension',
'remove_from_atts' => true,
'heading' => esc_attr__( 'Caption Area Margin', 'fusion-builder' ),
'description' => esc_attr__( 'In pixels or percentage, ex: 10px or 10%.', 'fusion-builder' ),
'param_name' => 'caption_margin',
'value' => [
'caption_margin_top' => '',
'caption_margin_right' => '',
'caption_margin_bottom' => '',
'caption_margin_left' => '',
],
'callback' => [
'function' => 'fusion_style_block',
],
'group' => esc_attr__( 'Caption', 'fusion-builder' ),
'dependency' => [
[
'element' => 'caption_style',
'value' => 'off',
'operator' => '!=',
],
[
'element' => 'caption_style',
'value' => 'schantel',
'operator' => '!=',
],
[
'element' => 'caption_style',
'value' => 'dany',
'operator' => '!=',
],
[
'element' => 'caption_style',
'value' => 'navin',
'operator' => '!=',
],
[
'element' => 'caption_style',
'value' => 'dario',
'operator' => '!=',
],
[
'element' => 'caption_style',
'value' => 'resa',
'operator' => '!=',
],
],
],
'fusion_animation_placeholder' => [
'preview_selector' => '.fusion-imageframe',
],
[
'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' ),
],
'fusion_sticky_visibility_placeholder' => [],
[
'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' ),
],
'fusion_filter_placeholder' => [
'selector_base' => 'imageframe-cid',
],
],
]
)
);
}
add_action( 'fusion_builder_before_init', 'fusion_element_image' );