/*!
* Dialogs Manager v4.9.3
* https://github.com/kobizz/dialogs-manager
*
* Copyright Kobi Zaltzberg
* Released under the MIT license
* https://github.com/kobizz/dialogs-manager/blob/master/LICENSE.txt
*/
(function($, global) {
'use strict';
/*
* Dialog Manager
*/
var DialogsManager = {
widgetsTypes: {},
createWidgetType: function(typeName, properties, Parent) {
if (!Parent) {
Parent = this.Widget;
}
var WidgetType = function() {
Parent.apply(this, arguments);
};
var prototype = WidgetType.prototype = new Parent(typeName);
prototype.types = prototype.types.concat([typeName]);
$.extend(prototype, properties);
prototype.constructor = WidgetType;
WidgetType.extend = function(typeName, properties) {
return DialogsManager.createWidgetType(typeName, properties, WidgetType);
};
return WidgetType;
},
addWidgetType: function(typeName, properties, Parent) {
if (properties && properties.prototype instanceof this.Widget) {
return this.widgetsTypes[typeName] = properties;
}
return this.widgetsTypes[typeName] = this.createWidgetType(typeName, properties, Parent);
},
getWidgetType: function(widgetType) {
return this.widgetsTypes[widgetType];
}
};
/*
* Dialog Manager instances constructor
*/
DialogsManager.Instance = function() {
var self = this,
elements = {},
settings = {};
var initElements = function() {
elements.body = $('body');
};
var initSettings = function(options) {
var defaultSettings = {
classPrefix: 'dialog',
effects: {
show: 'fadeIn',
hide: 'fadeOut'
}
};
$.extend(settings, defaultSettings, options);
};
this.createWidget = function(widgetType, properties) {
var WidgetTypeConstructor = DialogsManager.getWidgetType(widgetType),
widget = new WidgetTypeConstructor(widgetType);
properties = properties || {};
widget.init(self, properties);
return widget;
};
this.getSettings = function(property) {
if (property) {
return settings[property];
}
return Object.create(settings);
};
this.maybeLoadAssets = async function () {
const isFrontend = !! window.elementorFrontend?.utils?.assetsLoader;
if ( ! isFrontend ) {
return;
}
try {
await elementorFrontend.utils.assetsLoader.load( 'style', 'dialog' );
} catch ( error ) {
console.error( 'Failed to load assets:', error );
}
};
this.init = function (settings) {
this.maybeLoadAssets();
initSettings(settings);
initElements();
return self;
};
self.init();
};
/*
* Widget types constructor
*/
DialogsManager.Widget = function(widgetName) {
var self = this,
settings = {},
events = {},
elements = {},
hideTimeOut = 0,
baseClosureMethods = ['refreshPosition'];
var bindEvents = function() {
var windows = [elements.window];
if (elements.iframe) {
windows.push(jQuery(elements.iframe[0].contentWindow));
}
windows.forEach(function(window) {
if (settings.hide.onEscKeyPress) {
window.on('keyup', onWindowKeyUp);
}
if (settings.hide.onOutsideClick) {
window[0].addEventListener('click', hideOnOutsideClick, true);
}
if (settings.hide.onOutsideContextMenu) {
window[0].addEventListener('contextmenu', hideOnOutsideClick, true);
}
if (settings.position.autoRefresh) {
window.on('resize', self.refreshPosition);
}
});
if (settings.hide.onClick || settings.hide.onBackgroundClick) {
elements.widget.on('click', hideOnClick);
}
};
var callEffect = function(intent, params) {
var effect = settings.effects[intent],
$widget = elements.widget;
if ('function' === typeof effect) {
effect.apply($widget, params);
} else {
if ($widget[effect]) {
$widget[effect].apply($widget, params);
} else {
throw 'Reference Error: The effect ' + effect + ' not found';
}
}
};
var ensureClosureMethods = function() {
var closureMethodsNames = baseClosureMethods.concat(self.getClosureMethods());
$.each(closureMethodsNames, function() {
var methodName = this,
oldMethod = self[methodName];
self[methodName] = function() {
oldMethod.apply(self, arguments);
};
});
};
var fixIframePosition = function(position) {
if (! position.my) {
return;
}
var horizontalOffsetRegex = /left|right/,
extraOffsetRegex = /([+-]\d+)?$/,
iframeOffset = elements.iframe.offset(),
iframeWindow = elements.iframe[0].contentWindow,
myParts = position.my.split(' '),
fixedParts = [];
if (myParts.length === 1) {
if (horizontalOffsetRegex.test(myParts[0])) {
myParts.push('center');
} else {
myParts.unshift('center');
}
}
myParts.forEach(function(part, index) {
var fixedPart = part.replace(extraOffsetRegex, function(partOffset) {
partOffset = +partOffset || 0;
if (! index) {
partOffset += iframeOffset.left - iframeWindow.scrollX;
} else {
partOffset += iframeOffset.top - iframeWindow.scrollY;
}
if (partOffset >= 0) {
partOffset = '+' + partOffset;
}
return partOffset;
});
fixedParts.push(fixedPart);
});
position.my = fixedParts.join(' ');
};
var hideOnClick = function(event) {
if (isContextMenuClickEvent(event)) {
return;
}
if (settings.hide.onClick) {
if ($(event.target).closest(settings.selectors.preventClose).length) {
return;
}
} else if (event.target !== this) {
return;
}
self.hide();
};
var isIgnoredTarget = function(event) {
if (! settings.hide.ignore) {
return false;
}
return !! $(event.target).closest(settings.hide.ignore).length;
};
var hideOnOutsideClick = function(event) {
if (isContextMenuClickEvent(event) || $(event.target).closest(elements.widget).length || isIgnoredTarget(event)) {
return;
}
self.hide();
};
var initElements = function() {
self.addElement('widget');
self.addElement('header');
self.addElement('message');
self.addElement('window', window);
self.addElement('body', document.body);
self.addElement('container', settings.container);
if (settings.iframe) {
self.addElement('iframe', settings.iframe);
}
if (settings.closeButton) {
if ( settings.closeButtonClass ) {
// Backwards compatibility
settings.closeButtonOptions.iconClass = settings.closeButtonClass;
}
const $button = $('', settings.closeButtonOptions.attributes),
$buttonIcon = $(settings.closeButtonOptions.iconElement).addClass(settings.closeButtonOptions.iconClass);
$button.append($buttonIcon);
self.addElement('closeButton', $button);
}
var id = self.getSettings('id');
if (id) {
self.setID(id);
}
var classes = [];
$.each(self.types, function() {
classes.push(settings.classes.globalPrefix + '-type-' + this);
});
classes.push(self.getSettings('className'));
elements.widget
.addClass(classes.join(' '))
.attr({
'aria-modal': true,
'role': 'document',
'tabindex': 0,
});
};
var initSettings = function(parent, userSettings) {
var parentSettings = $.extend(true, {}, parent.getSettings());
settings = {
headerMessage: '',
message: '',
effects: parentSettings.effects,
classes: {
globalPrefix: parentSettings.classPrefix,
prefix: parentSettings.classPrefix + '-' + widgetName,
preventScroll: parentSettings.classPrefix + '-prevent-scroll',
},
selectors: {
preventClose: '.' + parentSettings.classPrefix + '-prevent-close',
},
container: 'body',
preventScroll: false,
iframe: null,
closeButton: false,
closeButtonOptions: {
iconClass: parentSettings.classPrefix + '-close-button-icon',
attributes: {
role: 'button',
'tabindex': 0,
'aria-label': 'Close',
href: '#',
},
iconElement: '',
},
position: {
element: 'widget',
my: 'center',
at: 'center',
enable: true,
autoRefresh: false,
},
hide: {
auto: false,
autoDelay: 5000,
onClick: false,
onOutsideClick: true,
onOutsideContextMenu: false,
onBackgroundClick: true,
onEscKeyPress: true,
ignore: '',
},
};
$.extend(true, settings, self.getDefaultSettings(), userSettings);
initSettingsEvents();
};
var initSettingsEvents = function() {
$.each(settings, function(settingKey) {
var eventName = settingKey.match(/^on([A-Z].*)/);
if (!eventName) {
return;
}
eventName = eventName[1].charAt(0).toLowerCase() + eventName[1].slice(1);
self.on(eventName, this);
});
};
var isContextMenuClickEvent = function(event) {
// Firefox fires `click` event on every `contextmenu` event.
return event.type === 'click' && event.button === 2;
};
var normalizeClassName = function(name) {
return name.replace(/([a-z])([A-Z])/g, function() {
return arguments[1] + '-' + arguments[2].toLowerCase();
});
};
var onWindowKeyUp = function(event) {
var ESC_KEY = 27,
keyCode = event.which;
if (ESC_KEY === keyCode) {
self.hide();
}
};
var unbindEvents = function() {
var windows = [elements.window];
if (elements.iframe) {
windows.push(jQuery(elements.iframe[0].contentWindow));
}
windows.forEach(function(window) {
if (settings.hide.onEscKeyPress) {
window.off('keyup', onWindowKeyUp);
}
if (settings.hide.onOutsideClick) {
window[0].removeEventListener('click', hideOnOutsideClick, true);
}
if (settings.hide.onOutsideContextMenu) {
window[0].removeEventListener('contextmenu', hideOnOutsideClick, true);
}
if (settings.position.autoRefresh) {
window.off('resize', self.refreshPosition);
}
});
if (settings.hide.onClick || settings.hide.onBackgroundClick) {
elements.widget.off('click', hideOnClick);
}
};
this.addElement = function(name, element, classes) {
var $newElement = elements[name] = $(element || '