2026-02-05 17:08:59 +03:00

346 lines
10 KiB
JavaScript

var FusionPageBuilder = FusionPageBuilder || {};
( function() {
jQuery( document ).ready( function() {
// Content Boxes Parent View.
FusionPageBuilder.fusion_content_boxes = FusionPageBuilder.ParentElementView.extend( {
/**
* Image map of child element images and thumbs.
*
* @since 2.0
*/
imageMap: {},
/**
* Initial data has run.
*
* @since 2.0
*/
initialData: false,
/**
* Runs after view DOM is patched.
*
* @since 2.0
* @return {void}
*/
afterPatch: function() {
this.generateChildElements();
this._refreshJs();
this.initListeners();
},
/**
* Runs after view DOM is loaded for first time.
*
* @since 2.0
* @return {void}
*/
onRender: function() {
this.initListeners();
},
/**
* Add mouse listeners for effects.
*
* @since 3.9
* @return {void}
*/
initListeners: function() {
this.$el.find( '.link-area-link-icon .fusion-read-more-button, .link-area-link-icon .fusion-read-more, .link-area-link-icon .heading' ).off( 'mouseenter.awb' ).on( 'mouseenter.awb', function() {
jQuery( this ).parents( '.link-area-link-icon' ).addClass( 'link-area-link-icon-hover' );
} );
this.$el.find( '.link-area-link-icon .fusion-read-more-button, .link-area-link-icon .fusion-read-more, .link-area-link-icon .heading' ).off( 'mouseleave.awb' ).on( 'mouseleave.awb', function() {
jQuery( this ).parents( '.link-area-link-icon' ).removeClass( 'link-area-link-icon-hover' );
} );
this.$el.find( '.link-area-box' ).off( 'mouseenter.awb' ).on( 'mouseenter.awb', function() {
jQuery( this ).addClass( 'link-area-box-hover' );
} );
this.$el.find( '.link-area-box' ).off( 'mouseleave.awb' ).on( 'mouseleave.awb', function() {
jQuery( this ).removeClass( 'link-area-box-hover' );
} );
},
/**
* Modify template attributes.
*
* @since 2.0
* @param {Object} atts - The attributes.
* @return {Object}
*/
filterTemplateAtts: function( atts ) {
var attributes = {};
// Validate values.
this.validateValues( atts.values );
// Create attribute objects.
attributes.attr = this.buildAttr( atts.values );
return attributes;
},
/**
* Modify values.
*
* @since 2.0
* @param {Object} values - The values.
* @return {void}
*/
validateValues: function( values ) {
// Backwards compatibility for when we had image width and height params.
if ( 'undefined' !== typeof values.image_width ) {
values.image_width = values.image_width ? values.image_width : '35';
} else {
values.image_width = values.image_max_width;
}
values.title_size = _.fusionValidateAttrValue( values.title_size, 'px', false );
values.icon_circle_radius = _.fusionValidateAttrValue( values.icon_circle_radius, 'px' );
values.icon_size = _.fusionValidateAttrValue( values.icon_size, 'px' );
values.margin_top = _.fusionValidateAttrValue( values.margin_top, 'px' );
values.margin_bottom = _.fusionValidateAttrValue( values.margin_bottom, 'px' );
values.margin_bottom = _.fusionValidateAttrValue( values.margin_bottom, 'px' );
values.circlebordersize = _.fusionValidateAttrValue( values.circlebordersize, 'px' );
values.outercirclebordersize = _.fusionValidateAttrValue( values.outercirclebordersize, 'px' );
if ( values.linktarget ) {
values.link_target = values.linktarget;
}
if ( 'timeline-vertical' === values.layout ) {
values.columns = 1;
}
if ( 'timeline-vertical' === values.layout || 'timeline-horizontal' === values.layout ) {
values.animation_delay = 350;
values.animation_speed = 0.25;
values.animation_type = 'fade';
values.animation_direction = '';
}
if ( 5 >= values.animation_delay ) {
values.animation_delay = values.animation_delay * 1000;
}
},
/**
* Builds attributes.
*
* @since 2.0
* @param {Object} values - The values.
* @return {Object}
*/
buildAttr: function( values ) {
var attr = _.fusionVisibilityAtts( values.hide_on_mobile, {
class: 'fusion-content-boxes content-boxes',
style: this.getParentCssVars( values )
} ),
cid = this.model.get( 'cid' ),
totalNumOfColumns = 'undefined' !== typeof values.element_content ? values.element_content.match( /\[fusion_content_box ((.|\n|\r)*?)\]/g ) : 1,
numOfColumns;
totalNumOfColumns = null !== totalNumOfColumns ? totalNumOfColumns.length : 1;
numOfColumns = values.columns;
if ( '' === numOfColumns || '0' === numOfColumns ) {
numOfColumns = totalNumOfColumns;
numOfColumns = Math.max( 6, numOfColumns );
} else if ( 6 < numOfColumns ) {
numOfColumns = 6;
}
values.columns = numOfColumns;
attr[ 'class' ] += ' columns row';
attr[ 'class' ] += ' fusion-columns-' + numOfColumns;
attr[ 'class' ] += ' fusion-columns-total-' + totalNumOfColumns;
attr[ 'class' ] += ' fusion-content-boxes-cid' + cid;
attr[ 'class' ] += ' content-boxes-' + values.layout;
attr[ 'class' ] += ' content-' + values.icon_align;
if ( 'timeline-horizontal' === values.layout || 'clean-vertical' === values.layout ) {
attr[ 'class' ] += ' content-boxes-icon-on-top';
}
if ( 'timeline-vertical' === values.layout ) {
attr[ 'class' ] += ' content-boxes-icon-with-title';
}
if ( 'clean-horizontal' === values.layout ) {
attr[ 'class' ] += ' content-boxes-icon-on-side';
}
if ( '' !== values.animation_delay ) {
attr[ 'data-animation-delay' ] = values.animation_delay;
attr[ 'class' ] += ' fusion-delayed-animation';
}
attr[ 'class' ] += ' fusion-child-element';
if ( values.alignment ) {
attr[ 'class' ] += ' has-flex-alignment';
}
if ( '' !== values[ 'class' ] ) {
attr[ 'class' ] += ' ' + values[ 'class' ];
}
if ( '' !== values.id ) {
attr.id = values.id;
}
attr = _.fusionAnimations( values, attr );
return attr;
},
getParentCssVars: function( values ) {
var cssVars = [
'backgroundcolor',
'body_color',
'title_color',
'iconcolor',
'iconcolor_hover',
'circlecolor_hover',
'margin_top',
'margin_bottom',
'alignment'
];
var customCssVars = [];
this.values = values;
cssVars.item_margin_top = { 'callback': _.fusionGetValueWithUnit };
cssVars.item_margin_bottom = { 'callback': _.fusionGetValueWithUnit };
cssVars.border_radius_top_left = { 'callback': _.fusionGetValueWithUnit };
cssVars.border_radius_top_right = { 'callback': _.fusionGetValueWithUnit };
cssVars.border_radius_bottom_right = { 'callback': _.fusionGetValueWithUnit };
cssVars.border_radius_bottom_left = { 'callback': _.fusionGetValueWithUnit };
customCssVars.hover_accent_color = values.hover_accent_color;
let circleHoverAccentColor = values.hover_accent_color;
if ( 'transparent' === values.circlecolor || 0 === jQuery.AWB_Color( values.circlecolor ).alpha() || 'no' === values.icon_circle ) {
circleHoverAccentColor = 'transparent';
}
customCssVars.circle_hover_accent_color = circleHoverAccentColor;
// if 1 column and not margin bottom is set, then set margin-bottom to 40px.
if ( 1 === parseInt( values.columns ) && ! values.item_margin_bottom ) {
customCssVars.item_margin_bottom = '40px';
}
// Box Shadow.
let boxShadow = '';
if ( 'yes' === values.box_shadow ) {
boxShadow = _.awbGetBoxShadowCssVar( '--awb-box-shadow', this.values );
}
return this.getCssVarsForOptions( cssVars ) + this.getCustomCssVars( customCssVars ) + boxShadow;
},
/**
* Extendable function for when child elements get generated.
*
* @since 2.0.0
* @param {Object} modules An object of modules that are not a view yet.
* @return {void}
*/
onGenerateChildElements: function( modules ) {
this.addImagesToImageMap( modules, false, false );
},
/**
* Add images to the view's image map.
*
* @since 2.0
* @param {Object} childrenData - The children for which images need added to the map.
* @param bool async - Determines if the AJAX call should be async.
* @param bool async - Determines if the view should be re-rendered.
* @return void
*/
addImagesToImageMap: function( childrenData, async, reRender ) {
var view = this,
queryData = {};
async = ( 'undefined' === typeof async ) ? true : async;
reRender = ( 'undefined' === typeof reRender ) ? true : reRender;
view.initialData = true;
_.each( childrenData, function( child ) {
var params = ( 'undefined' !== typeof child.get ) ? child.get( 'params' ) : child.params,
cid = ( 'undefined' !== typeof child.get ) ? child.get( 'cid' ) : child.cid,
imageId = 'undefined' !== typeof params.image_id && '' !== params.image_id ? params.image_id : false,
image = 'undefined' !== typeof params.image && '' !== params.image ? params.image : false;
// Has neither url or ID set.
if ( ! imageId && ! image ) {
return;
}
// if it has image id set and available, no need to progress.
if ( imageId && 'undefined' !== typeof view.imageMap[ imageId ] ) {
return;
}
// if it has image url set and available, no need to progress.
if ( image && 'undefined' !== typeof view.imageMap[ image ] ) {
return;
}
// Made it this far we need to get image data.
queryData[ cid ] = params;
} );
// Send this data with ajax or rest.
if ( ! _.isEmpty( queryData ) ) {
jQuery.ajax( {
async: async,
url: window.fusionAppConfig.ajaxurl,
type: 'post',
dataType: 'json',
data: {
action: 'get_fusion_content_boxes_children_data',
children: queryData,
fusion_load_nonce: window.fusionAppConfig.fusion_load_nonce
}
} )
.done( function( response ) {
view.updateImageMap( response );
if ( reRender ) {
view.reRender();
}
} );
} else if ( reRender ) {
view.reRender();
}
},
/**
* Update the view's image map.
*
* @since 2.0
* @param {Object} images - The images object to inject.
* @return void
*/
updateImageMap: function( images ) {
var self = this;
_.each( images, function( imageData, image ) {
if ( 'undefined' === typeof self.imageMap[ image ] ) {
self.imageMap[ image ] = imageData;
}
} );
}
} );
} );
}( jQuery ) );