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

310 lines
8.9 KiB
JavaScript

/* global FusionEvents, fusionBuilderText */
var FusionPageBuilder = FusionPageBuilder || {};
( function() {
jQuery( document ).ready( function() {
FusionPageBuilder.fusion_widget = FusionPageBuilder.ElementView.extend( {
onInit: function() {
this.contentView = false;
this.listenTo( FusionEvents, 'fusion-widget-rendered', this.removeLoadingOverlay );
this.deprecatedParams();
},
sanitizeValue: function( param, value ) {
// HTML and Text widget especial escape.
if ( 'wp_widget_custom_html__content' === param || 'wp_widget_text__text' === param ) {
return _.escape( value );
}
return value;
},
onRender: function() {
this.renderWidgetContent();
},
/**
* Removes loading overlay
*
* @since 2.0.0
* @return {void}
*/
removeLoadingOverlay: function() {
var contentType = 'element',
$elementContent;
if ( _.isObject( this.model.attributes ) ) {
if ( 'fusion_builder_container' === this.model.attributes.element_type ) {
contentType = 'container';
} else if ( 'fusion_builder_column' === this.model.attributes.element_type ) {
contentType = 'columns';
}
}
$elementContent = this.$el.find( '.fusion-builder-' + contentType + '-content' );
$elementContent.removeClass( 'fusion-loader' );
$elementContent.find( '.fusion-builder-loader' ).remove();
},
beforeRemove: function() {
if ( this.contentView ) {
this.contentView.removeElement();
}
},
renderWidgetContent: function() {
var view,
viewSettings = {
model: this.model
},
widgetType = this.model.attributes.params.type;
if ( ! this.model.get( 'params' ).type ) {
return;
}
if ( this.contentView ) {
this.$el.find( '.fusion-widget-content' ).html( this.contentView.render().el );
} else {
if ( 'undefined' !== typeof FusionPageBuilder[ widgetType ] ) {
view = new FusionPageBuilder[ widgetType ]( viewSettings );
} else {
view = new FusionPageBuilder.fusion_widget_content( viewSettings );
}
this.contentView = view;
this.$el.find( '.fusion-widget-content' ).html( view.render().el );
}
},
/**
* Modify template attributes.
*
* @since 2.0
* @param {Object} atts - The attributes object.
* @return {Object}
*/
filterTemplateAtts: function( atts ) {
var attributes = {};
// Validate values.
this.validateValues( atts.values );
this.values = atts.values;
// Create attribute objects
attributes.attr = this.buildAttr( atts.values );
// Any extras that need passed on.
attributes.cid = this.model.get( 'cid' );
attributes.values = atts.values;
attributes.placeholder = this.getWidgetPlaceholder();
return attributes;
},
/**
* Modify the values.
*
* @since 2.0
* @param {Object} values - The values object.
* @return {void}
*/
validateValues: function( values ) {
values.margin_bottom = _.fusionValidateAttrValue( values.margin_bottom, 'px' );
values.margin_left = _.fusionValidateAttrValue( values.margin_left, 'px' );
values.margin_right = _.fusionValidateAttrValue( values.margin_right, 'px' );
values.margin_top = _.fusionValidateAttrValue( values.margin_top, 'px' );
},
/**
* Get widget placeholder.
*
* @since 2.0.0
* @return {string}
*/
getWidgetPlaceholder: function() {
var placeholder = jQuery( this.getPlaceholder() ).append( '<span class="fusion-tb-source-separator"> - </span><br/><span>' + fusionBuilderText.select_widget + '</span>' );
return placeholder[ 0 ].outerHTML;
},
/**
* Builds attributes.
*
* @since 2.0
* @param {Object} values - The values object.
* @return {Object}
*/
buildAttr: function( values ) {
var attr = _.fusionVisibilityAtts( values.hide_on_mobile, {
class: 'fusion-widget fusion-widget-element fusion-widget-area fusion-content-widget-area widget fusion-live-widget fusion-widget-cid' + this.model.get( 'cid' ),
style: ''
} );
if ( '' !== values[ 'class' ] ) {
attr[ 'class' ] += ' ' + values[ 'class' ];
}
if ( '' !== values.id ) {
attr.id = values.id;
}
if ( values.fusion_align ) {
attr[ 'class' ] += ' fusion-widget-align-' + values.fusion_align;
}
if ( values.fusion_align_mobile ) {
attr[ 'class' ] += ' fusion-widget-mobile-align-' + values.fusion_align_mobile;
}
if ( '' !== values.type ) {
attr[ 'class' ] += ' ' + values.type.toLowerCase();
}
if ( 'no' === values.fusion_display_title ) {
attr[ 'class' ] += ' hide-title';
}
if ( 'Fusion_Widget_Vertical_Menu' === values.type ) {
if ( '' !== values.border_color && '' === values.fusion_divider_color ) {
values.fusion_divider_color = values.border_color;
}
if ( '' === values.fusion_divider_color ) {
attr[ 'class' ] += ' no-divider-color';
}
}
attr.style += this.getStyleVariables( values );
return attr;
},
/**
* Filter out DOM before patching.
*
* @since 2.0.0
* @return {void}
*/
patcherFilter: function( diff ) {
var filteredDiff = [];
_.each( diff, function( info ) {
if ( 'replaceElement' === info.action ) {
if ( 'undefined' !== typeof info.oldValue.attributes && -1 !== info.oldValue.attributes[ 'class' ].indexOf( 'fusion-widget-content-view' ) ) {
// Ignore.
} else {
filteredDiff.push( info );
}
} else if ( 'addElement' === info.action ) {
if ( -1 !== info.element.attributes[ 'class' ].indexOf( 'fusion-widget-content-view' ) || -1 !== info.element.attributes[ 'class' ].indexOf( 'fusion-widget' ) ) {
// Ignore.
} else {
filteredDiff.push( info );
}
} else if ( 'removeElement' === info.action ) {
if ( -1 !== info.element.attributes[ 'class' ].indexOf( 'fusion-widget-content' ) || -1 !== info.element.attributes[ 'class' ].indexOf( 'fusion-widget' ) ) {
// Ignore.
} else {
filteredDiff.push( info );
}
} else {
filteredDiff.push( info );
}
} );
return filteredDiff;
},
deprecatedParams: function() {
var params = this.model.get( 'params' );
// Ensures backwards compatibility for the border_color option of the vertical menu.
if ( 'Fusion_Widget_Vertical_Menu' === params.type && 'undefined' === typeof params.fusion_divider_color ) {
params.fusion_divider_color = params.fusion_widget_vertical_menu__border_color;
delete params.fusion_widget_vertical_menu__border_color;
}
this.model.set( 'params', params );
},
/**
* Gets style variables.
*
* @since 3.9
* @param {Object} values - The values object.
* @return {String}
*/
getStyleVariables: function( values ) {
var customVars = [],
cssVarsOptions;
if ( 'Fusion_Widget_Vertical_Menu' === values.type ) {
if ( 'undefined' !== typeof values.border_color && 'undefined' === typeof values.fusion_divider_color ) {
values.fusion_divider_color = values.border_color;
}
}
if ( 'undefined' !== typeof values.fusion_divider_color ) {
customVars.fusion_divider_color = values.fusion_divider_color;
}
if ( '' === values.margin_top && '' === values.margin_right && '' === values.margin_bottom && '' === values.margin_left && '' !== values.fusion_margin ) {
values.margin_top = values.fusion_margin;
values.margin_right = values.fusion_margin;
values.margin_bottom = values.fusion_margin;
values.margin_left = values.fusion_margin;
}
customVars.margin_top = _.fusionGetValueWithUnit( values.margin_top );
customVars.margin_right = _.fusionGetValueWithUnit( values.margin_right );
customVars.margin_bottom = _.fusionGetValueWithUnit( values.margin_bottom );
customVars.margin_left = _.fusionGetValueWithUnit( values.margin_left );
cssVarsOptions = [
'fusion_bg_color',
'fusion_border_color',
'fusion_border_style'
];
cssVarsOptions.fusion_padding_color = { 'callback': _.fusionGetValueWithUnit };
cssVarsOptions.fusion_border_size = { 'callback': _.fusionGetValueWithUnit };
cssVarsOptions.fusion_bg_radius_size = { 'callback': _.fusionGetValueWithUnit };
return this.getCssVarsForOptions( cssVarsOptions ) + this.getCustomCssVars( customVars );
}
} );
_.extend( FusionPageBuilder.Callback.prototype, {
fusion_get_widget_markup: function( name, value, modelData, args, cid, action, model, view ) {
view.changeParam( name, value );
view.contentView.getHTML( view );
},
fusion_widget_changed: function( name, value, args, view ) {
view.changeParam( name, value );
view.model.attributes.markup = '';
FusionEvents.trigger( 'fusion-widget-changed' );
view.render();
view.addLoadingOverlay();
// prevent another re-render
return {
render: false
};
}
} );
} );
}() );