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

509 lines
18 KiB
JavaScript

/* global cssua */
/* jshint -W107 */
var FusionPageBuilder = FusionPageBuilder || {};
( function() {
jQuery( document ).ready( function() {
// Sharing Box View.
FusionPageBuilder.fusion_sharing = FusionPageBuilder.ElementView.extend( {
/**
* Runs after view DOM is patched.
*
* @since 2.0
* @return {void}
*/
beforePatch: function() {
var tooltips = jQuery( '#fb-preview' )[ 0 ].contentWindow.jQuery( this.$el ).find( '.fusion-social-networks [data-toggle="tooltip"]' );
tooltips.tooltip( 'destroy' );
},
/**
* Runs after view DOM is patched.
*
* @since 2.0
* @return {void}
*/
afterPatch: function() {
var tooltips = jQuery( '#fb-preview' )[ 0 ].contentWindow.jQuery( this.$el ).find( '.fusion-social-networks [data-toggle="tooltip"]' );
setTimeout( function() {
tooltips.tooltip( {
container: 'body'
} );
}, 150 );
},
/**
* Modify template attributes.
*
* @since 2.0
* @param {Object} atts - The attributes.
* @return {Object}
*/
filterTemplateAtts: function( atts ) {
var attributes = {};
// Validate values and extras.
this.validateValuesExtras( atts.values, atts.extras );
this.values = atts.values;
// Create attribute objects.
attributes.cid = this.model.get( 'cid' );
this.counter = this.model.get( 'cid' );
attributes.shortcodeAttr = this.buildShortcodeAttr( atts.values );
attributes.socialNetworksAttr = this.buildSocialNetworksAttr( atts.values );
attributes.taglineAttr = this.buildTaglineAttr( atts.values );
attributes.icons = this.buildIcons( atts.values );
attributes.tagline = atts.values.tagline;
attributes.taglineVisibility = atts.values.tagline_visibility;
attributes.taglineTag = this.getTaglineTag( atts.values );
return attributes;
},
/**
* Modifies the values.
*
* @since 2.0
* @param {Object} values - The values object.
* @param {Object} extras - Extra args.
* @return {void}
*/
validateValuesExtras: function( values, extras ) {
extras.linktarget = extras.linktarget ? '_blank' : '_self';
values.icons_boxed_radius = _.fusionValidateAttrValue( values.icons_boxed_radius, 'px' );
},
/**
* Gets style variables.
*
* @since 3.9
* @param {Object} values - The values.
* @return {String}
*/
getStyleVariables: function( values ) {
const cssVarsOptions = [
'icon_tagline_color',
'icon_tagline_color_hover',
'separator_border_color',
'alignment',
'stacked_align'
];
cssVarsOptions.margin_top = { 'callback': _.fusionGetValueWithUnit };
cssVarsOptions.margin_right = { 'callback': _.fusionGetValueWithUnit };
cssVarsOptions.margin_bottom = { 'callback': _.fusionGetValueWithUnit };
cssVarsOptions.margin_left = { 'callback': _.fusionGetValueWithUnit };
cssVarsOptions.wrapper_padding_top = { 'callback': _.fusionGetValueWithUnit };
cssVarsOptions.wrapper_padding_right = { 'callback': _.fusionGetValueWithUnit };
cssVarsOptions.wrapper_padding_bottom = { 'callback': _.fusionGetValueWithUnit };
cssVarsOptions.wrapper_padding_left = { 'callback': _.fusionGetValueWithUnit };
cssVarsOptions.padding_top = { 'callback': _.fusionGetValueWithUnit };
cssVarsOptions.padding_right = { 'callback': _.fusionGetValueWithUnit };
cssVarsOptions.padding_bottom = { 'callback': _.fusionGetValueWithUnit };
cssVarsOptions.padding_left = { 'callback': _.fusionGetValueWithUnit };
cssVarsOptions.border_top = { 'callback': _.fusionGetValueWithUnit };
cssVarsOptions.border_right = { 'callback': _.fusionGetValueWithUnit };
cssVarsOptions.border_bottom = { 'callback': _.fusionGetValueWithUnit };
cssVarsOptions.border_left = { 'callback': _.fusionGetValueWithUnit };
cssVarsOptions.border_radius_top_left = { 'callback': _.fusionGetValueWithUnit };
cssVarsOptions.border_radius_top_right = { 'callback': _.fusionGetValueWithUnit };
cssVarsOptions.border_radius_bottom_right = { 'callback': _.fusionGetValueWithUnit };
cssVarsOptions.border_radius_bottom_left = { 'callback': _.fusionGetValueWithUnit };
cssVarsOptions.tagline_text_size = { 'callback': _.fusionGetValueWithUnit };
cssVarsOptions.icon_size = { 'callback': _.fusionGetValueWithUnit };
cssVarsOptions.separator_border_sizes = { 'callback': _.fusionGetValueWithUnit };
const customVars = [];
const layout = 'stacked' === values.layout ? 'column' : 'row';
customVars.layout = layout;
if ( values.alignment_medium ) {
customVars.alignment_medium = values.alignment_medium;
}
if ( values.stacked_align_medium ) {
customVars.stacked_align_medium = values.stacked_align_medium;
}
if ( values.alignment_small ) {
customVars.alignment_small = values.alignment_small;
}
if ( values.stacked_align_small ) {
customVars.stacked_align_small = values.stacked_align_small;
}
return this.getCssVarsForOptions( cssVarsOptions ) + this.getCustomCssVars( customVars );
},
/**
* Builds attributes.
*
* @since 2.0
* @param {Object} values - The values.
* @return {Object}
*/
buildShortcodeAttr: function( values ) {
var sharingboxShortcode = _.fusionVisibilityAtts( values.hide_on_mobile, {
class: 'fusion-sharing-box fusion-sharing-box-' + this.model.get( 'cid' ),
style: ''
} );
sharingboxShortcode[ 'class' ] += _.fusionGetStickyClass( values.sticky_display );
if ( 'yes' === values.icons_boxed ) {
sharingboxShortcode[ 'class' ] += ' boxed-icons';
}
if ( '' !== values.backgroundcolor ) {
sharingboxShortcode.style = 'background-color:' + values.backgroundcolor + ';';
if ( 'transparent' === values.backgroundcolor || 0 === jQuery.AWB_Color( values.backgroundcolor ).alpha() ) {
sharingboxShortcode.style += 'padding:0;';
}
}
if ( '' !== values[ 'class' ] ) {
sharingboxShortcode[ 'class' ] += ' ' + values[ 'class' ];
}
if ( '' !== values.id ) {
sharingboxShortcode[ 'class' ] += ' ' + values.id;
}
sharingboxShortcode[ 'data-title' ] = values.title;
sharingboxShortcode[ 'data-description' ] = values.description;
sharingboxShortcode[ 'data-link' ] = values.link;
sharingboxShortcode[ 'data-image' ] = values.pinterest_image;
sharingboxShortcode = _.fusionAnimations( values, sharingboxShortcode );
if ( 'show' === values.tagline_visibility ) {
sharingboxShortcode[ 'class' ] += ' has-taglines';
if ( values.layout ) {
sharingboxShortcode[ 'class' ] += ' layout-' + values.layout;
}
if ( values.layout_medium ) {
sharingboxShortcode[ 'class' ] += ' layout-medium-' + values.layout_medium;
} else {
sharingboxShortcode[ 'class' ] += ' layout-medium-' + values.layout;
}
if ( values.layout_small ) {
sharingboxShortcode[ 'class' ] += ' layout-small-' + values.layout_small;
} else {
sharingboxShortcode[ 'class' ] += ' layout-small-' + values.layout;
}
}
if ( values.icon_taglines ) {
sharingboxShortcode[ 'class' ] += ' has-icon-taglines';
sharingboxShortcode[ 'class' ] += ' icon-taglines-placement-' + values.tagline_placement;
}
if ( ! this.isDefault( 'border_color' ) ) {
sharingboxShortcode.style += 'border-color:' + values.border_color + ';';
}
sharingboxShortcode.style += this.getStyleVariables( values );
return sharingboxShortcode;
},
/**
* Builds attributes.
*
* @since 2.0
* @param {Object} values - The values.
* @return {Object}
*/
buildSocialNetworksAttr: function( values ) {
var sharingboxShortcodeSocialNetworks = {
class: 'fusion-social-networks sharingbox-shortcode-icon-wrapper sharingbox-shortcode-icon-wrapper-' + this.model.get( 'cid' )
};
if ( 'yes' === values.icons_boxed ) {
sharingboxShortcodeSocialNetworks[ 'class' ] += ' boxed-icons';
}
if ( '' !== values.alignment ) {
sharingboxShortcodeSocialNetworks.style = 'text-align: ' + values.alignment + ';';
}
return sharingboxShortcodeSocialNetworks;
},
/**
* Builds attributes.
*
* @since 2.0
* @param {Object} values - The values.
* @return {Object}
*/
buildTaglineAttr: function( values ) {
var sharingboxShortcodeTagline = {
class: 'tagline'
},
that = this;
if ( '' !== values.tagline_color ) {
sharingboxShortcodeTagline.style = 'color:' + values.tagline_color + ';';
}
sharingboxShortcodeTagline.style += _.fusionGetFontStyle( 'tagline_font', values );
if ( 'undefined' !== typeof values.tagline_font_size && '' !== values.tagline_font_size ) {
sharingboxShortcodeTagline.style += 'font-size:' + values.tagline_font_size + ';';
}
if ( 'undefined' !== typeof values.tagline_line_height && '' !== values.tagline_line_height ) {
sharingboxShortcodeTagline.style += 'line-height:' + values.tagline_line_height + ';';
}
if ( 'undefined' !== typeof values.tagline_letter_spacing && '' !== values.tagline_letter_spacing ) {
sharingboxShortcodeTagline.style += 'letter-spacing:' + values.tagline_letter_spacing + ';';
}
if ( 'undefined' !== typeof values.tagline_text_transform && '' !== values.tagline_text_transform ) {
sharingboxShortcodeTagline.style += 'text-transform:' + values.tagline_text_transform + ';';
}
sharingboxShortcodeTagline = _.fusionInlineEditor( {
param: 'tagline',
cid: that.model.get( 'cid' ),
toolbar: false
}, sharingboxShortcodeTagline );
return sharingboxShortcodeTagline;
},
/**
* Builds attributes.
*
* @since 2.0
* @param {Object} values - The values.
* @return {Object}
*/
buildIconAttr: function( values ) {
var sharingboxShortcodeTagline = {
class: 'tagline'
};
if ( '' !== values.tagline_color ) {
sharingboxShortcodeTagline.style = 'color:' + values.tagline_color + ';';
}
return sharingboxShortcodeTagline;
},
/**
* Builds HTML for the icons.
*
* @since 2.0
* @param {Object} values - The values.
* @param {Object} extras - Extra args.
* @return {string}
*/
buildIcons: function( values ) {
var icons = '',
iconColors = values.icon_colors,
boxColors = values.box_colors,
itemTagline = values.icon_taglines,
useBrandColors = false,
numOfIconColors,
numOfBoxColors,
socialNetworks,
socialNetworksCount,
i,
description,
link,
title,
image,
socialLink,
sharingboxShortcodeIcon,
sharingboxShortcodeIconLink,
iconOptions,
socialIconBoxedColors,
network,
tooltip,
numOfTaglines;
if ( 'brand' === values.color_type ) {
useBrandColors = true;
// Get a list of all the available social networks.
socialIconBoxedColors = _.fusionSocialIcons( false, true );
socialIconBoxedColors.mail = {
label: 'Email Address',
color: '#000000'
};
}
iconColors = iconColors.split( '|' );
boxColors = boxColors.split( '|' );
itemTagline = itemTagline.split( '|' );
numOfIconColors = iconColors.length;
numOfBoxColors = boxColors.length;
numOfTaglines = itemTagline.length;
socialNetworks = values.social_share_links;
if ( 'string' === typeof socialNetworks ) {
socialNetworks = socialNetworks.split( ',' );
}
socialNetworksCount = socialNetworks.length;
for ( i = 0; i < socialNetworksCount; i++ ) {
network = socialNetworks[ i ];
if ( true === useBrandColors ) {
iconOptions = {
social_network: network,
icon_color: ( 'yes' === values.icons_boxed ) ? '#ffffff' : socialIconBoxedColors[ network ].color,
box_color: ( 'yes' === values.icons_boxed ) ? socialIconBoxedColors[ network ].color : ''
};
} else {
iconOptions = {
social_network: network,
icon_color: i < iconColors.length ? iconColors[ i ] : '',
box_color: i < boxColors.length ? boxColors[ i ] : ''
};
if ( 1 === numOfIconColors ) {
iconOptions.icon_color = iconColors[ 0 ];
}
if ( 1 === numOfBoxColors ) {
iconOptions.box_color = boxColors[ 0 ];
}
}
if ( 1 === numOfTaglines ) {
iconOptions.icon_tagline = itemTagline[ 0 ];
} else {
iconOptions.icon_tagline = i < itemTagline.length ? itemTagline[ i ] : '';
}
iconOptions.social_network = 'email' === iconOptions.social_network ? 'mail' : iconOptions.social_network;
// sharingboxShortcodeIcon attributes
description = values.description;
link = values.link;
title = values.title;
image = _.fusionRawUrlEncode( values.pinterest_image );
sharingboxShortcodeIcon = {
class: 'fusion-social-network-icon fusion-tooltip fusion-' + iconOptions.social_network + ' awb-icon-' + iconOptions.social_network
};
sharingboxShortcodeIconLink = {};
socialLink = '';
switch ( iconOptions.social_network ) {
case 'facebook':
socialLink = 'https://m.facebook.com/sharer.php?u=' + link;
if ( cssua.ua.mobile ) {
socialLink = 'https://www.facebook.com/sharer.php?m2w&s=100&p&#91;url&#93;=' + link + '&p&#91;images&#93;&#91;title&#93;=' + _.fusionRawUrlEncode( title );
}
break;
case 'twitter':
socialLink = 'https://x.com/intent/post?text=' + _.fusionRawUrlEncode( title ) + '&url=' + _.fusionRawUrlEncode( link );
break;
case 'bluesky':
socialLink = 'https://bsky.app/intent/compose?text=' + _.fusionRawUrlEncode( title ) + '%20' + _.fusionRawUrlEncode( link ) + '%20' + _.fusionRawUrlEncode( description );
break;
case 'linkedin':
socialLink = 'https://www.linkedin.com/shareArticle?mini=true&url=' + _.fusionRawUrlEncode( link ) + '&amp;title=' + _.fusionRawUrlEncode( title ) + '&amp;summary=' + _.fusionRawUrlEncode( description );
break;
case 'mastodon':
socialLink = 'https://mastodonshare.com/?url=' + _.fusionRawUrlEncode( link ) + '&amp;text=' + _.fusionRawUrlEncode( title ) + '%20' + _.fusionRawUrlEncode( description );
break;
case 'reddit':
socialLink = 'https://reddit.com/submit?url=' + link + '&amp;title=' + title;
break;
case 'telegram':
socialLink = 'https://t.me/share/url?url=' + _.fusionRawUrlEncode( link ) + '&text=' + _.fusionRawUrlEncode( title );
break;
case 'threads':
socialLink = 'https://www.threads.net/intent/post?url=' + _.fusionRawUrlEncode( link ) + '&amp;text=' + _.fusionRawUrlEncode( title ) + '%20' + _.fusionRawUrlEncode( description );
break;
case 'tumblr':
socialLink = 'https://www.tumblr.com/share/link?url=' + _.fusionRawUrlEncode( link ) + '&amp;name=' + _.fusionRawUrlEncode( title ) + '&amp;description=' + _.fusionRawUrlEncode( description );
break;
case 'pinterest':
socialLink = 'https://pinterest.com/pin/create/button/?url=' + _.fusionRawUrlEncode( link ) + '&amp;description=' + _.fusionRawUrlEncode( description ) + '&amp;media=' + image;
break;
case 'vk':
socialLink = 'https://vk.com/share.php?url=' + _.fusionRawUrlEncode( link ) + '&amp;title=' + _.fusionRawUrlEncode( title ) + '&amp;description=' + _.fusionRawUrlEncode( description );
break;
case 'mail':
socialLink = 'mailto:?subject=' + _.fusionRawUrlEncode( title ) + '&body=' + _.fusionRawUrlEncode( link );
break;
}
sharingboxShortcodeIconLink.href = socialLink;
sharingboxShortcodeIconLink.target = ( values.linktarget && 'mail' !== iconOptions.social_network ) ? '_blank' : '_self';
if ( '_blank' === sharingboxShortcodeIcon.target ) {
sharingboxShortcodeIconLink.rel = 'noopener noreferrer';
}
sharingboxShortcodeIcon.style = ( iconOptions.icon_color ) ? 'color:' + iconOptions.icon_color + ';' : '';
if ( values.icons_boxed && 'yes' === values.icons_boxed && iconOptions.box_color ) {
sharingboxShortcodeIcon.style += 'background-color:' + iconOptions.box_color + ';border-color:' + iconOptions.box_color + ';';
}
if ( ( 'yes' === values.icons_boxed && values.icons_boxed_radius ) || '0' === values.icons_boxed_radius ) {
if ( 'round' === values.icons_boxed_radius ) {
values.icons_boxed_radius = '50%';
}
sharingboxShortcodeIcon.style += 'border-radius:' + values.icons_boxed_radius + ';';
}
sharingboxShortcodeIconLink[ 'data-placement' ] = values.tooltip_placement;
tooltip = iconOptions.social_network;
sharingboxShortcodeIconLink[ 'data-title' ] = _.fusionUcFirst( tooltip );
sharingboxShortcodeIconLink.title = _.fusionUcFirst( tooltip );
sharingboxShortcodeIconLink[ 'aria-label' ] = _.fusionUcFirst( tooltip );
if ( 'none' !== values.tooltip_placement ) {
sharingboxShortcodeIconLink[ 'data-toggle' ] = 'tooltip';
}
icons += '<span><a ' + _.fusionGetAttributes( sharingboxShortcodeIconLink ) + '>';
icons += 'before' === values.tagline_placement && '' !== iconOptions.icon_tagline ? '<div class="fusion-social-network-icon-tagline">' + iconOptions.icon_tagline + '</div>' : '';
icons += '<i ' + _.fusionGetAttributes( sharingboxShortcodeIcon ) + ' aria-hidden="true"></i>';
icons += 'after' === values.tagline_placement && '' !== iconOptions.icon_tagline ? '<div class="fusion-social-network-icon-tagline">' + iconOptions.icon_tagline + '</div>' : '';
icons += '</a></span>';
if ( 0 < values.separator_border_sizes && i < socialNetworks.length - 1 ) {
icons += '<span class="sharingbox-shortcode-icon-separator"></span>';
}
}
return icons;
},
getTaglineTag: function( values ) {
if ( ! values.tagline_size ) {
return 'h4';
}
if ( !isNaN( values.tagline_size ) && !isNaN( parseFloat( values.tagline_size ) ) ) {
return 'h' + values.tagline_size;
}
return values.tagline_size;
}
} );
} );
}( jQuery ) );