/* 2017 Julian Garnier Released under the MIT license */ var $jscomp={scope:{}};$jscomp.defineProperty="function"==typeof Object.defineProperties?Object.defineProperty:function(e,r,p){if(p.get||p.set)throw new TypeError("ES3 does not support getters and setters.");e!=Array.prototype&&e!=Object.prototype&&(e[r]=p.value)};$jscomp.getGlobal=function(e){return"undefined"!=typeof window&&window===e?e:"undefined"!=typeof global&&null!=global?global:e};$jscomp.global=$jscomp.getGlobal(this);$jscomp.SYMBOL_PREFIX="jscomp_symbol_"; $jscomp.initSymbol=function(){$jscomp.initSymbol=function(){};$jscomp.global.Symbol||($jscomp.global.Symbol=$jscomp.Symbol)};$jscomp.symbolCounter_=0;$jscomp.Symbol=function(e){return $jscomp.SYMBOL_PREFIX+(e||"")+$jscomp.symbolCounter_++}; $jscomp.initSymbolIterator=function(){$jscomp.initSymbol();var e=$jscomp.global.Symbol.iterator;e||(e=$jscomp.global.Symbol.iterator=$jscomp.global.Symbol("iterator"));"function"!=typeof Array.prototype[e]&&$jscomp.defineProperty(Array.prototype,e,{configurable:!0,writable:!0,value:function(){return $jscomp.arrayIterator(this)}});$jscomp.initSymbolIterator=function(){}};$jscomp.arrayIterator=function(e){var r=0;return $jscomp.iteratorPrototype(function(){return rb&&(b+=1);1b?c:b<2/3?a+(c-a)*(2/3-b)*6:a}var d=/hsl\((\d+),\s*([\d.]+)%,\s*([\d.]+)%\)/g.exec(a)||/hsla\((\d+),\s*([\d.]+)%,\s*([\d.]+)%,\s*([\d.]+)\)/g.exec(a);a=parseInt(d[1])/360;var b=parseInt(d[2])/100,f=parseInt(d[3])/100,d=d[4]||1;if(0==b)f=b=a=f;else{var n=.5>f?f*(1+b):f+b-f*b,k=2*f-n,f=c(k,n,a+1/3),b=c(k,n,a);a=c(k,n,a-1/3)}return"rgba("+ 255*f+","+255*b+","+255*a+","+d+")"}function y(a){if(a=/([\+\-]?[0-9#\.]+)(%|px|pt|em|rem|in|cm|mm|ex|ch|pc|vw|vh|vmin|vmax|deg|rad|turn)?$/.exec(a))return a[2]}function V(a){if(-1=g.currentTime)for(var G=0;G=w||!k)g.began||(g.began=!0,f("begin")),f("run");if(q>n&&q=k&&r!==k||!k)b(k),x||e();f("update");a>=k&&(g.remaining?(t=h,"alternate"===g.direction&&(g.reversed=!g.reversed)):(g.pause(),g.completed||(g.completed=!0,f("complete"),"Promise"in window&&(p(),m=c()))),l=0)}a=void 0===a?{}:a;var h,t,l=0,p=null,m=c(),g=fa(a);g.reset=function(){var a=g.direction,c=g.loop;g.currentTime= 0;g.progress=0;g.paused=!0;g.began=!1;g.completed=!1;g.reversed="reverse"===a;g.remaining="alternate"===a&&1===c?2:c;b(0);for(a=g.children.length;a--;)g.children[a].reset()};g.tick=function(a){h=a;t||(t=h);k((l+h-t)*q.speed)};g.seek=function(a){k(d(a))};g.pause=function(){var a=v.indexOf(g);-1=c&&0<=b&&1>=b){var e=new Float32Array(11);if(c!==d||b!==f)for(var k=0;11>k;++k)e[k]=a(.1*k,c,b);return function(k){if(c===d&&b===f)return k;if(0===k)return 0;if(1===k)return 1;for(var h=0,l=1;10!==l&&e[l]<=k;++l)h+=.1;--l;var l=h+(k-e[l])/(e[l+1]-e[l])*.1,n=3*(1-3*b+3*c)*l*l+2*(3*b-6*c)*l+3*c;if(.001<=n){for(h=0;4>h;++h){n=3*(1-3*b+3*c)*l*l+2*(3*b-6*c)*l+3*c;if(0===n)break;var m=a(l,c,b)-k,l=l-m/n}k=l}else if(0=== n)k=l;else{var l=h,h=h+.1,g=0;do m=l+(h-l)/2,n=a(m,c,b)-k,0++g);k=m}return a(k,d,f)}}}}(),Q=function(){function a(a,b){return 0===a||1===a?a:-Math.pow(2,10*(a-1))*Math.sin(2*(a-1-b/(2*Math.PI)*Math.asin(1))*Math.PI/b)}var c="Quad Cubic Quart Quint Sine Expo Circ Back Elastic".split(" "),d={In:[[.55,.085,.68,.53],[.55,.055,.675,.19],[.895,.03,.685,.22],[.755,.05,.855,.06],[.47,0,.745,.715],[.95,.05,.795,.035],[.6,.04,.98,.335],[.6,-.28,.735,.045],a],Out:[[.25, .46,.45,.94],[.215,.61,.355,1],[.165,.84,.44,1],[.23,1,.32,1],[.39,.575,.565,1],[.19,1,.22,1],[.075,.82,.165,1],[.175,.885,.32,1.275],function(b,c){return 1-a(1-b,c)}],InOut:[[.455,.03,.515,.955],[.645,.045,.355,1],[.77,0,.175,1],[.86,0,.07,1],[.445,.05,.55,.95],[1,0,0,1],[.785,.135,.15,.86],[.68,-.55,.265,1.55],function(b,c){return.5>b?a(2*b,c)/2:1-a(-2*b+2,c)/2}]},b={linear:A(.25,.25,.75,.75)},f={},e;for(e in d)f.type=e,d[f.type].forEach(function(a){return function(d,f){b["ease"+a.type+c[f]]=h.fnc(d)? d:A.apply($jscomp$this,d)}}(f)),f={type:f.type};return b}(),ha={css:function(a,c,d){return a.style[c]=d},attribute:function(a,c,d){return a.setAttribute(c,d)},object:function(a,c,d){return a[c]=d},transform:function(a,c,d,b,f){b[f]||(b[f]=[]);b[f].push(c+"("+d+")")}},v=[],B=0,ia=function(){function a(){B=requestAnimationFrame(c)}function c(c){var b=v.length;if(b){for(var d=0;db&&(c.duration=d.duration);c.children.push(d)});c.seek(0);c.reset();c.autoplay&&c.restart();return c};return c};q.random=function(a,c){return Math.floor(Math.random()*(c-a+1))+a};return q});; /*! Waypoints - 4.0.1 Copyright © 2011-2016 Caleb Troughton Licensed under the MIT license. https://github.com/imakewebthings/waypoints/blob/master/licenses.txt */ !function(){"use strict";function t(o){if(!o)throw new Error("No options passed to Waypoint constructor");if(!o.element)throw new Error("No element option passed to Waypoint constructor");if(!o.handler)throw new Error("No handler option passed to Waypoint constructor");this.key="waypoint-"+e,this.options=t.Adapter.extend({},t.defaults,o),this.element=this.options.element,this.adapter=new t.Adapter(this.element),this.callback=o.handler,this.axis=this.options.horizontal?"horizontal":"vertical",this.enabled=this.options.enabled,this.triggerPoint=null,this.group=t.Group.findOrCreate({name:this.options.group,axis:this.axis}),this.context=t.Context.findOrCreateByElement(this.options.context),t.offsetAliases[this.options.offset]&&(this.options.offset=t.offsetAliases[this.options.offset]),this.group.add(this),this.context.add(this),i[this.key]=this,e+=1}var e=0,i={};t.prototype.queueTrigger=function(t){this.group.queueTrigger(this,t)},t.prototype.trigger=function(t){this.enabled&&this.callback&&this.callback.apply(this,t)},t.prototype.destroy=function(){this.context.remove(this),this.group.remove(this),delete i[this.key]},t.prototype.disable=function(){return this.enabled=!1,this},t.prototype.enable=function(){return this.context.refresh(),this.enabled=!0,this},t.prototype.next=function(){return this.group.next(this)},t.prototype.previous=function(){return this.group.previous(this)},t.invokeAll=function(t){var e=[];for(var o in i)e.push(i[o]);for(var n=0,r=e.length;r>n;n++)e[n][t]()},t.destroyAll=function(){t.invokeAll("destroy")},t.disableAll=function(){t.invokeAll("disable")},t.enableAll=function(){t.Context.refreshAll();for(var e in i)i[e].enabled=!0;return this},t.refreshAll=function(){t.Context.refreshAll()},t.viewportHeight=function(){return window.innerHeight||document.documentElement.clientHeight},t.viewportWidth=function(){return document.documentElement.clientWidth},t.adapters=[],t.defaults={context:window,continuous:!0,enabled:!0,group:"default",horizontal:!1,offset:0},t.offsetAliases={"bottom-in-view":function(){return this.context.innerHeight()-this.adapter.outerHeight()},"right-in-view":function(){return this.context.innerWidth()-this.adapter.outerWidth()}},window.Waypoint=t}(),function(){"use strict";function t(t){window.setTimeout(t,1e3/60)}function e(t){this.element=t,this.Adapter=n.Adapter,this.adapter=new this.Adapter(t),this.key="waypoint-context-"+i,this.didScroll=!1,this.didResize=!1,this.oldScroll={x:this.adapter.scrollLeft(),y:this.adapter.scrollTop()},this.waypoints={vertical:{},horizontal:{}},t.waypointContextKey=this.key,o[t.waypointContextKey]=this,i+=1,n.windowContext||(n.windowContext=!0,n.windowContext=new e(window)),this.createThrottledScrollHandler(),this.createThrottledResizeHandler()}var i=0,o={},n=window.Waypoint,r=window.onload;e.prototype.add=function(t){var e=t.options.horizontal?"horizontal":"vertical";this.waypoints[e][t.key]=t,this.refresh()},e.prototype.checkEmpty=function(){var t=this.Adapter.isEmptyObject(this.waypoints.horizontal),e=this.Adapter.isEmptyObject(this.waypoints.vertical),i=this.element==this.element.window;t&&e&&!i&&(this.adapter.off(".waypoints"),delete o[this.key])},e.prototype.createThrottledResizeHandler=function(){function t(){e.handleResize(),e.didResize=!1}var e=this;this.adapter.on("resize.waypoints",function(){e.didResize||(e.didResize=!0,n.requestAnimationFrame(t))})},e.prototype.createThrottledScrollHandler=function(){function t(){e.handleScroll(),e.didScroll=!1}var e=this;this.adapter.on("scroll.waypoints",function(){(!e.didScroll||n.isTouch)&&(e.didScroll=!0,n.requestAnimationFrame(t))})},e.prototype.handleResize=function(){n.Context.refreshAll()},e.prototype.handleScroll=function(){var t={},e={horizontal:{newScroll:this.adapter.scrollLeft(),oldScroll:this.oldScroll.x,forward:"right",backward:"left"},vertical:{newScroll:this.adapter.scrollTop(),oldScroll:this.oldScroll.y,forward:"down",backward:"up"}};for(var i in e){var o=e[i],n=o.newScroll>o.oldScroll,r=n?o.forward:o.backward;for(var s in this.waypoints[i]){var a=this.waypoints[i][s];if(null!==a.triggerPoint){var l=o.oldScroll=a.triggerPoint,p=l&&h,u=!l&&!h;(p||u)&&(a.queueTrigger(r),t[a.group.id]=a.group)}}}for(var c in t)t[c].flushTriggers();this.oldScroll={x:e.horizontal.newScroll,y:e.vertical.newScroll}},e.prototype.innerHeight=function(){return this.element==this.element.window?n.viewportHeight():this.adapter.innerHeight()},e.prototype.remove=function(t){delete this.waypoints[t.axis][t.key],this.checkEmpty()},e.prototype.innerWidth=function(){return this.element==this.element.window?n.viewportWidth():this.adapter.innerWidth()},e.prototype.destroy=function(){var t=[];for(var e in this.waypoints)for(var i in this.waypoints[e])t.push(this.waypoints[e][i]);for(var o=0,n=t.length;n>o;o++)t[o].destroy()},e.prototype.refresh=function(){var t,e=this.element==this.element.window,i=e?void 0:this.adapter.offset(),o={};this.handleScroll(),t={horizontal:{contextOffset:e?0:i.left,contextScroll:e?0:this.oldScroll.x,contextDimension:this.innerWidth(),oldScroll:this.oldScroll.x,forward:"right",backward:"left",offsetProp:"left"},vertical:{contextOffset:e?0:i.top,contextScroll:e?0:this.oldScroll.y,contextDimension:this.innerHeight(),oldScroll:this.oldScroll.y,forward:"down",backward:"up",offsetProp:"top"}};for(var r in t){var s=t[r];for(var a in this.waypoints[r]){var l,h,p,u,c,d=this.waypoints[r][a],f=d.options.offset,w=d.triggerPoint,y=0,g=null==w;d.element!==d.element.window&&(y=d.adapter.offset()[s.offsetProp]),"function"==typeof f?f=f.apply(d):"string"==typeof f&&(f=parseFloat(f),d.options.offset.indexOf("%")>-1&&(f=Math.ceil(s.contextDimension*f/100))),l=s.contextScroll-s.contextOffset,d.triggerPoint=Math.floor(y+l-f),h=w=s.oldScroll,u=h&&p,c=!h&&!p,!g&&u?(d.queueTrigger(s.backward),o[d.group.id]=d.group):!g&&c?(d.queueTrigger(s.forward),o[d.group.id]=d.group):g&&s.oldScroll>=d.triggerPoint&&(d.queueTrigger(s.forward),o[d.group.id]=d.group)}}return n.requestAnimationFrame(function(){for(var t in o)o[t].flushTriggers()}),this},e.findOrCreateByElement=function(t){return e.findByElement(t)||new e(t)},e.refreshAll=function(){for(var t in o)o[t].refresh()},e.findByElement=function(t){return o[t.waypointContextKey]},window.onload=function(){r&&r(),e.refreshAll()},n.requestAnimationFrame=function(e){var i=window.requestAnimationFrame||window.mozRequestAnimationFrame||window.webkitRequestAnimationFrame||t;i.call(window,e)},n.Context=e}(),function(){"use strict";function t(t,e){return t.triggerPoint-e.triggerPoint}function e(t,e){return e.triggerPoint-t.triggerPoint}function i(t){this.name=t.name,this.axis=t.axis,this.id=this.name+"-"+this.axis,this.waypoints=[],this.clearTriggerQueues(),o[this.axis][this.name]=this}var o={vertical:{},horizontal:{}},n=window.Waypoint;i.prototype.add=function(t){this.waypoints.push(t)},i.prototype.clearTriggerQueues=function(){this.triggerQueues={up:[],down:[],left:[],right:[]}},i.prototype.flushTriggers=function(){for(var i in this.triggerQueues){var o=this.triggerQueues[i],n="up"===i||"left"===i;o.sort(n?e:t);for(var r=0,s=o.length;s>r;r+=1){var a=o[r];(a.options.continuous||r===o.length-1)&&a.trigger([i])}}this.clearTriggerQueues()},i.prototype.next=function(e){this.waypoints.sort(t);var i=n.Adapter.inArray(e,this.waypoints),o=i===this.waypoints.length-1;return o?null:this.waypoints[i+1]},i.prototype.previous=function(e){this.waypoints.sort(t);var i=n.Adapter.inArray(e,this.waypoints);return i?this.waypoints[i-1]:null},i.prototype.queueTrigger=function(t,e){this.triggerQueues[e].push(t)},i.prototype.remove=function(t){var e=n.Adapter.inArray(t,this.waypoints);e>-1&&this.waypoints.splice(e,1)},i.prototype.first=function(){return this.waypoints[0]},i.prototype.last=function(){return this.waypoints[this.waypoints.length-1]},i.findOrCreate=function(t){return o[t.axis][t.name]||new i(t)},n.Group=i}(),function(){"use strict";function t(t){this.$element=e(t)}var e=window.jQuery,i=window.Waypoint;e.each(["innerHeight","innerWidth","off","offset","on","outerHeight","outerWidth","scrollLeft","scrollTop"],function(e,i){t.prototype[i]=function(){var t=Array.prototype.slice.call(arguments);return this.$element[i].apply(this.$element,t)}}),e.each(["extend","inArray","isEmptyObject"],function(i,o){t[o]=e[o]}),i.adapters.push({name:"jquery",Adapter:t}),i.Adapter=t}(),function(){"use strict";function t(t){return function(){var i=[],o=arguments[0];return t.isFunction(arguments[0])&&(o=t.extend({},arguments[1]),o.handler=arguments[0]),this.each(function(){var n=t.extend({},o,{element:this});"string"==typeof n.context&&(n.context=t(this).closest(n.context)[0]),i.push(new e(n))}),i}}var e=window.Waypoint;window.jQuery&&(window.jQuery.fn.waypoint=t(window.jQuery)),window.Zepto&&(window.Zepto.fn.waypoint=t(window.Zepto))}();; ( function( $ ) { 'use strict'; window.JetPopupFrontend = { addedScripts: {}, addedStyles: {}, addedAssetsPromises: [], init: function() { let $popup_list = $( '.jet-popup.jet-popup--front-mode' ); $popup_list.each( function( index ) { let $target = $( this ), instance = null, settings = $target.data( 'settings' ); instance = new window.jetPopup( $target, settings ); instance.init(); } ); JetPopupFrontend.initAttachedPopups(); JetPopupFrontend.initBlocks(); $( window ).on( 'jet-popup/ajax/frontend-init', ( event, payload ) => { switch ( payload.contentType ) { case 'elementor': JetPopupFrontend.maybeElementorFrontendInit( payload.$container ); break; case 'default': JetPopupFrontend.maybeDefaultFrontendInit( payload ); break } } ); }, initAttachedPopups: function ( $scope ) { $scope = $scope || $( 'body' ); $scope.find( '[data-popup-instance]' ).each( ( index, el ) => { let $this = $( el ), popupId = $this.data( 'popup-instance' ) || 'none', triggerType = $this.data( 'popup-trigger-type' ) || 'none', clickedCustomClass = $this.data( 'popup-custom-selector' ) || '', popupData = { popupId: `jet-popup-${ popupId }`, }; if ( $this.hasClass( 'jet-popup-attach-event-inited' ) ) { return; } $this.addClass( 'jet-popup-attach-event-inited' ); switch( triggerType ) { case 'click-self': $this.addClass( 'jet-popup-cursor-pointer' ); $this.on( 'click.JetPopup', function( event ) { event.preventDefault(); $( window ).trigger( { type: 'jet-popup-open-trigger', popupData: popupData, triggeredBy: $this, } ); return false; } ); break; case 'click-selector': if ( '' !== clickedCustomClass ) { $this.find( clickedCustomClass ).addClass( 'jet-popup-cursor-pointer' ); $this.on( 'click.JetPopup', clickedCustomClass, function( event ) { event.preventDefault(); $( window ).trigger( { type: 'jet-popup-open-trigger', popupData: popupData, triggeredBy: $this, } ); return false; } ); } break; case 'hover': $this.on( 'mouseenter.JetPopup', function( event ) { $( window ).trigger( { type: 'jet-popup-open-trigger', popupData: popupData, triggeredBy: $this, } ); } ); break; case 'scroll-to': new Waypoint( { element: el, handler: function( direction ) { $( window ).trigger( { type: 'jet-popup-open-trigger', popupData: popupData, triggeredBy: $this, } ); }, offset: 'bottom-in-view' } ); break; } } ); }, initBlocks: function( $scope ) { $scope = $scope || $( 'body' ); window.JetPlugins.init( $scope, [ { block: 'jet-popup/action-button', callback: ( $scope ) => { let $button = $( '.jet-popup-action-button__instance', $scope ), actionType = $scope.data( 'action-type' ); JetPopupFrontend.actionButtonHandle( $button, actionType ); } } ] ); }, actionButtonBlock: function( $scope ) { var $button = $( '.jet-popup-action-button__instance', $scope ), actionType = $scope.data( 'action-type' ); JetPopupFrontend.actionButtonHandle( $button, actionType ); }, actionButtonHandle: function ( $button, actionType = 'link' ) { switch ( actionType ) { case 'link': $button.on( 'click.JetPopup', function( event ) { event.preventDefault(); var $currentPopup = $button.closest( '.jet-popup' ), link = $( this ).attr( 'href' ), target = $( this ).attr( 'target' ), popupId = $currentPopup.attr( 'id' ); $( window ).trigger( { type: 'jet-popup-close-trigger', popupData: { popupId: popupId, constantly: false } } ); if ( '_blank' === target ) { window.open( link, '_blank' ); } else { window.open( link ); } return false; } ); break; case 'leave': $button.on( 'click.JetPopup', function( event ) { event.preventDefault(); window.history.back(); } ); break; case 'close-popup': $button.on( 'click.JetPopup', function( event ) { event.preventDefault(); var $currentPopup = $button.closest( '.jet-popup' ), popupId = $currentPopup.attr( 'id' ); $( window ).trigger( { type: 'jet-popup-close-trigger', popupData: { popupId: popupId, constantly: false } } ); } ); break; case 'close-all-popups': $button.on( 'click.JetPopup', function( event ) { event.preventDefault(); var $popups = $( '.jet-popup' ); if ( $popups[0] ) { $popups.each( function( index ) { var $popup = $( this ), popupId = $popup.attr( 'id' ); $( window ).trigger( { type: 'jet-popup-close-trigger', popupData: { popupId: popupId, constantly: false } } ); } ); } } ); break; case 'close-constantly': $button.on( 'click.JetPopup', function( event ) { event.preventDefault(); var $currentPopup = $button.closest( '.jet-popup' ), popupId = $currentPopup.attr( 'id' ); $( window ).trigger( { type: 'jet-popup-close-trigger', popupData: { popupId: popupId, constantly: true } } ); } ); break; case 'close-all-constantly': $button.on( 'click.JetPopup', function( event ) { event.preventDefault(); var $popups = $( '.jet-popup' ); if ( $popups[0] ) { $popups.each( function( index ) { var $popup = $( this ), popupId = $popup.attr( 'id' ); $( window ).trigger( { type: 'jet-popup-close-trigger', popupData: { popupId: popupId, constantly: true } } ); } ); } } ); break; } }, loadScriptAsync: function( script, uri ) { if ( JetPopupFrontend.addedScripts.hasOwnProperty( script ) ) { return script; } JetPopupFrontend.addedScripts[ script ] = uri; const asset = document.getElementById( script + '-js' ); if ( asset ) { return script; } return new Promise( function( resolve, reject ) { var tag = document.createElement( 'script' ); tag.src = uri; tag.async = false; tag.onload = function() { resolve( script ); }; document.head.appendChild( tag ); } ); }, loadStyle: function( style, uri ) { if ( JetPopupFrontend.addedStyles.hasOwnProperty( style ) && JetPopupFrontend.addedStyles[ style ] === uri) { return style; } JetPopupFrontend.addedStyles[ style ] = uri; return new Promise( function( resolve, reject ) { var tag = document.createElement( 'link' ); tag.id = style; tag.rel = 'stylesheet'; tag.href = uri; tag.type = 'text/css'; tag.media = 'all'; tag.onload = function() { resolve( style ); }; document.head.appendChild( tag ); }); }, assetsLoaderPromise: function() { return Promise.all( JetPopupFrontend.addedAssetsPromises ); }, maybeElementorFrontendInit: function( $popupContainer ) { $popupContainer.find( 'div[data-element_type]' ).each( function() { var $this = $( this ), elementType = $this.data( 'element_type' ); if ( ! elementType ) { return; } try { if ( 'widget' === elementType ) { elementType = $this.data( 'widget_type' ); if ( window.elementorFrontend && window.elementorFrontend.hooks ) { window.elementorFrontend.hooks.doAction( 'frontend/element_ready/widget', $this, $ ); } } if ( window.elementorFrontend && window.elementorFrontend.hooks ) { window.elementorFrontend.hooks.doAction( 'frontend/element_ready/global', $this, $ ); window.elementorFrontend.hooks.doAction( 'frontend/element_ready/' + elementType, $this, $ ); } } catch ( err ) { console.log(err); $this.remove(); return false; } } ); }, maybeDefaultFrontendInit: function ( payload ) { const contentElements = payload.contentElements || [], $container = payload.$container; $container.find( '[data-is-block*="/"]' ).each( ( index, el ) => { window.JetPlugins.hooks.doAction( window.JetPlugins.hookNameFromBlock( el.dataset.isBlock ), jQuery( el ) ); } ); } }; /** * [jetPopup description] * @param {[type]} $popup [description] * @param {[type]} settings [description] * @return {[type]} [description] */ window.jetPopup = function( $popup, settings ) { var self = this, $window = $( window ), $document = $( document ), popupSettings = settings, id = popupSettings['id'], popupId = popupSettings['jet-popup-id'], popupsLocalStorageData = {}, //editMode = Boolean( window.elementorFrontend.isEditMode() ), isAnimation = false, isOpen = false, ajaxGetContentHanler = null, ajaxContentLoaded = false; self.init = function() { var popupAvailable = self.popupAvailableCheck(); if ( ! popupAvailable ) { return false; } self.setLocalStorageData( popupId, 'enable' ); self.initCompatibilityHandler(); self.initOpenEvent(); self.initCloseEvent(); $window.trigger( 'jet-popup/init/after', { self: self, settings: popupSettings } ); }; /** * [popupAvailableCheck description] * @return {[type]} [description] */ self.popupAvailableCheck = function() { var storageData = self.getLocalStorageData() || {}; if ( ! storageData.hasOwnProperty( popupId ) ) { return true; } var popupData = storageData[ popupId ], status = 'enable', showAgainDate = 'none'; if ( 'disable' === popupData ) { return false; } if ( 'enable' === popupData ) { return true; } if ( popupData.hasOwnProperty( 'status' ) ) { status = popupData['status']; } if ( 'enable' === status ) { return true; } if ( popupData.hasOwnProperty( 'show-again-date' ) ) { showAgainDate = popupData['show-again-date']; } if ( 'none' === showAgainDate && 'disable' === status ) { return false; } if ( showAgainDate < Date.now() ) { return true; } else { return false; } }; /** * [initOpenEvent description] * @return {[type]} [description] */ self.initOpenEvent = function() { $window.trigger( 'jet-popup/init-events/before', { self: self, settings: popupSettings } ); switch ( popupSettings['open-trigger'] ) { case 'page-load': self.pageLoadEvent( popupSettings['page-load-delay'] ); break; case 'user-inactive': self.userInactiveEvent( popupSettings['user-inactivity-time'] ); break; case 'scroll-trigger': self.scrollPageEvent( popupSettings['scrolled-to'] ); break; case 'try-exit-trigger': self.tryExitEvent(); break; case 'on-date': self.onDateEvent( popupSettings['on-date'] ); break; case 'on-time': self.onTimeEvent( popupSettings['on-time-start'], popupSettings['on-time-end'] ); break; case 'custom-selector': self.onCustomSelector( popupSettings['custom-selector'] ); break;$scope } $window.on( 'jet-popup-open-trigger', function( event ) { var popupData = event.popupData || {}, triggeredBy = event.triggeredBy || false, popupUniqId = popupData.popupId || false; if ( popupUniqId == popupId ) { self.showPopup( popupData, triggeredBy ); } }); $window.on( 'jet-popup-close-trigger', function( event ) { var popupData = event.popupData || {}, popupUniqId = popupData.popupId, constantly = popupData.constantly; if ( popupUniqId == popupId ) { self.hidePopup( { popupId: popupUniqId, constantly: constantly, } ); } }); $window.trigger( 'jet-popup/init-events/after', { self: self, settings: popupSettings } ); }; /** * [initCloseEvent description] * @return {[type]} [description] */ self.initCloseEvent = function() { $popup.on( 'click', '.jet-popup__close-button', function( event ) { var target = event.currentTarget; self.hidePopup( { constantly: popupSettings['show-once'], popupId: popupSettings['jet-popup-id'] } ); } ); if ( popupSettings['close-on-overlay-click'] ) { $popup.on( 'click', '.jet-popup__overlay', function( event ) { var target = event.currentTarget; self.hidePopup( { constantly: popupSettings['show-once'], popupId: popupSettings['jet-popup-id'] } ); } ); } $document.on( 'keyup.jetPopup', function( event ) { var key = event.keyCode; if ( 27 === key && isOpen ) { self.hidePopup( { constantly: popupSettings['show-once'], popupId: popupSettings['jet-popup-id'] } ); } } ); }; /** * [initCompatibilityHandler description] * @return {[type]} [description] */ self.initCompatibilityHandler = function() { var $elementorProFormWidget = $( '.elementor-widget-form', $popup ); if ( $elementorProFormWidget[0] ) { $elementorProFormWidget.each( function() { var $this = $( this ), $form = $( '.elementor-form', $this ); $form.on( 'submit_success', function( data ) { setTimeout( function() { $window.trigger( { type: 'jet-popup-close-trigger', popupData: { popupId: popupId, constantly: false } } ); }, 3000 ); } ); } ); } }; /** * Page on load event * * @param {int} openDelay Open delay time. * @return {void} */ self.pageLoadEvent = function( openDelay ) { var delay = +openDelay || 0; delay = delay * 1000; $( function() { setTimeout( function() { self.showPopup(); }, delay ); } ); }; /** * User Inactivity event * * @param {int} inactiveDelay [description] * @return {void} */ self.userInactiveEvent = function( inactiveDelay ) { var delay = +inactiveDelay || 0, isInactive = true; delay = delay * 1000; setTimeout( function() { if ( isInactive ) { self.showPopup(); } }, delay ); $( document ).on( 'click focus resize keyup scroll', function() { isInactive = false; } ); }; /** * Scrolling Page Event * * @param {int} scrollingValue Scrolling porgress value * @return {void} */ self.scrollPageEvent = function( scrollingValue ) { var scrolledValue = +scrollingValue || 0; $window.on( 'scroll.cherryJetScrollEvent resize.cherryJetResizeEvent', function() { var $window = $( window ), windowHeight = $window.height(), documentHeight = $( document ).height(), scrolledHeight = documentHeight - windowHeight, scrolledProgress = Math.max( 0, Math.min( 1, $window.scrollTop() / scrolledHeight ) ) * 100; if ( scrolledProgress >= scrolledValue ) { $window.off( 'scroll.cherryJetScrollEvent resize.cherryJetResizeEvent' ); self.showPopup(); } } ).trigger( 'scroll.cherryJetResizeEvent' ); }; /** * Viewport leave event * * @return {void} */ self.tryExitEvent = function() { var pageY = 0; $( document ).on( 'mouseleave', 'body', function( event ) { pageY = event.pageY - $window.scrollTop(); if ( 0 > pageY && $popup.hasClass( 'jet-popup--hide-state' ) ) { self.showPopup(); } } ); }; /** * onDateEvent Event * * @return {void} */ self.onDateEvent = function( date ) { var nowDate = Date.now(), startDate = Date.parse( date ); if ( startDate < nowDate ) { setTimeout( function() { self.showPopup(); }, 500 ); } } self.onTimeEvent = function( startTime = '00:00', endTime = '23:59' ) { var startTime = '' !== startTime ? startTime : '00:00', endTime = '' !== endTime ? endTime : '23:59', nowTimeStamp = Date.now(), dateTimeFormat = new Intl.DateTimeFormat( 'en', { year: 'numeric', month: 'short', day: '2-digit' } ), [ { value: month },,{ value: day },,{ value: year } ] = dateTimeFormat.formatToParts( nowTimeStamp ), startTime = `${ month }. ${ day }, ${ year } ${ startTime }`, endTime = `${ month }. ${ day }, ${ year } ${ endTime }`, startTimeStamp = Date.parse( startTime ), endTimeStamp = Date.parse( endTime ); if ( ( startTimeStamp < nowTimeStamp ) && ( nowTimeStamp < endTimeStamp ) ) { setTimeout( function() { self.showPopup(); }, 500 ); } } /** * [onCustomSelector description] * @param {[type]} selector [description] * @return {[type]} [description] */ self.onCustomSelector = function( selector ) { let $selector = $( selector ); if ( $selector[0] ) { $( 'body' ).on( 'click', selector, function( event ) { event.preventDefault(); self.showPopup( $( this ).data( 'popup' ), $( this ) ); } ); } } /** * Show Popup * * @return {void} */ self.showPopup = function( data, $trigger ) { var popupData = data || {}, animeOverlay = null, animeContainer = null, animeOverlaySettings = jQuery.extend( { targets: $( '.jet-popup__overlay', $popup )[0] }, self.avaliableEffects[ 'fade' ][ 'show' ] ); $trigger = $trigger || false; if ( ! self.popupAvailableCheck() ) { return false; } animeOverlay = anime( animeOverlaySettings ); $popup.toggleClass( 'jet-popup--hide-state jet-popup--show-state' ); if ( popupSettings['prevent-scrolling'] ) { $( 'body' ).addClass( 'jet-popup-prevent-scroll' ); } popupData = window.JetPlugins.hooks.applyFilters( 'jet-popup.show-popup.data', popupData, $popup, $trigger ); self.showContainer( popupData ); }; /** * [showContainer description] * @return {[type]} [description] */ self.showContainer = function( data ) { var popupData = data || {}, popupDefaultData = { forceLoad: popupSettings['force-ajax'] || false, // Trigger Ajax Every Time customContent: '' // Show Popup with Custom Content }, animeContainerInstance = null, $popupContainer = $( '.jet-popup__container', $popup ), $content = $( '.jet-popup__container-content', $popup ), animeContainer = jQuery.extend( { targets: $( '.jet-popup__container', $popup )[0], begin: function( anime ) { isAnimation = true; $window.trigger( 'jet-popup/show-event/before-show', { self: self, data: popupData, anime: anime } ); }, complete: function( anime ) { isAnimation = false; isOpen = true; $window.trigger( 'jet-popup/show-event/after-show', { self: self, data: popupData, anime: anime } ); } }, self.avaliableEffects[ popupSettings['animation'] ][ 'show' ] ); popupData = jQuery.extend( popupDefaultData, popupData ); // init Custom popup content if ( '' !== popupData.customContent ) { $content.html( popupData.customContent ); self.elementorFrontendInit(); // Show Popup Container animeContainerInstance = anime( animeContainer ); $window.trigger( 'jet-popup/render-content/render-custom-content', { self: self, popup_id: id, data: popupData, } ); return false; } if ( ! popupSettings['use-ajax'] ) { // Show Popup Container animeContainerInstance = anime( animeContainer ); $window.trigger( 'jet-popup/render-content/render-custom-content', { self: self, popup_id: id, data: popupData, } ); return false; } if ( popupData.forceLoad ) { ajaxContentLoaded = false; } if ( ajaxContentLoaded ) { // Show Popup Container animeContainerInstance = anime( animeContainer ); $window.trigger( 'jet-popup/render-content/show-content', { self: self, popup_id: id, data: popupData, } ); return false; } popupData = jQuery.extend( popupData, { 'popup_id': id, 'page_url': window.location.href } ); ajaxGetContentHanler = jQuery.ajax( { type: 'POST', url: window.jetPopupData.ajax_url, data: { 'action': 'jet_popup_get_content', 'data': popupData }, beforeSend: function( jqXHR, ajaxSettings ) { if ( null !== ajaxGetContentHanler ) { ajaxGetContentHanler.abort(); } // Before ajax send Trigger $window.trigger( 'jet-popup/render-content/ajax/before-send', { self: self, popup_id: id, data: popupData } ); $popup.addClass( 'jet-popup--loading-state' ); }, error: function( jqXHR, ajaxSettings ) {}, success: function( data, textStatus, jqXHR ) { var successType = data.type, contentData = data.content || false, $popupContainer = $( '.jet-popup__container-content', $popup ); $popup.removeClass( 'jet-popup--loading-state' ); if ( 'error' === successType ) { var message = data.message; $content.html( '

' + message + '

' ); // Show Popup Container animeContainerInstance = anime( animeContainer ); } if ( 'success' === successType ) { let popupContent = contentData['content'], popupContentElements = contentData['contentElements'], popupScripts = contentData['scripts'], popupStyles = contentData['styles'], popupAfterScripts = contentData['afterScripts']; for ( let { handle: scriptHandler, src: scriptSrc } of popupScripts ) { JetPopupFrontend.addedAssetsPromises.push( JetPopupFrontend.loadScriptAsync( scriptHandler, scriptSrc ) ); } for ( let styleHandler in popupStyles ) { JetPopupFrontend.addedAssetsPromises.push( JetPopupFrontend.loadStyle( styleHandler, popupStyles[ styleHandler ] ) ); } JetPopupFrontend.assetsLoaderPromise().then( async function( value ) { ajaxContentLoaded = true; // Ajax Success Trigger $window.trigger( 'jet-popup/render-content/ajax/success', { self: self, popup_id: id, data: popupData, request: data } ); // Render content if ( popupContent ) { $popupContainer.html( popupContent ); } if ( popupAfterScripts.length ) { await Promise.all( popupAfterScripts.map( ( { handle, src } ) => JetPopupFrontend.loadScriptAsync( handle, src ) ) ); } // Before ajax frontend init $( window ).trigger( 'jet-popup/ajax/frontend-init/before', { $container: $popupContainer, content: popupContent, contentElements: popupContentElements, contentType: popupSettings['content-type'], } ); // Frontend init $( window ).trigger( 'jet-popup/ajax/frontend-init', { $container: $popupContainer, content: popupContent, contentElements: popupContentElements, contentType: popupSettings['content-type'], } ); // after ajax frontend init $( window ).trigger( 'jet-popup/ajax/frontend-init/after', { $container: $popupContainer, content: popupContent, contentElements: popupContentElements, contentType: popupSettings['content-type'], } ); // Show Popup Container animeContainerInstance = anime( animeContainer ); }, function( reason ) { console.log( 'Assets Loaded Error' ); } ); } } } ); }; /** * Hide Popup * * @return {void} */ self.hidePopup = function ( data ) { var popupData = data || {}, $content = $( '.jet-popup__container-content', $popup ), constantly = popupData.constantly || false, animeOverlay = null, animeContainer = null, animeOverlaySettings = jQuery.extend( { targets: $( '.jet-popup__overlay', $popup )[0] }, self.avaliableEffects[ 'fade' ][ 'hide' ] ), animeContainerSettings = jQuery.extend( { targets: $( '.jet-popup__container', $popup )[0], begin: function( anime ) { isAnimation = true; $window.trigger( 'jet-popup/hide-event/before-hide', { self: self, data: popupData, anime: anime } ); }, complete: function( anime ) { isAnimation = false; isOpen = false; $popup.toggleClass( 'jet-popup--show-state jet-popup--hide-state' ); if ( popupSettings['use-ajax'] && popupSettings['force-ajax'] ) { $content.html( '' ); } if ( popupSettings['prevent-scrolling'] && !$( '.jet-popup--show-state' )[0] ) { $( 'body' ).removeClass( 'jet-popup-prevent-scroll' ); } console.log(popupData) // After Popup Hide Action $window.trigger( 'jet-popup/hide-event/after-hide', { self: self, data: popupData, anime: anime } ); } }, self.avaliableEffects[ popupSettings['animation'] ][ 'hide' ] ); if ( constantly ) { self.setLocalStorageData( popupId, 'disable' ); } if ( isAnimation ){ return false; } if ( $popup.hasClass('jet-popup--show-state') ) { animeOverlay = anime( animeOverlaySettings ); animeContainer = anime( animeContainerSettings ); } // On Hide Handler self.onHidePopupAction(); // Before Popup Hide Action $window.trigger( 'jet-popup/close-hide-event/before-hide', { self: self, data: popupData } ); }; /** * [elementorFrontendInit description] * @return {[type]} [description] */ self.elementorFrontendInit = function() { var $content = $( '.jet-popup__container-content', $popup ); $content.find( 'div[data-element_type]' ).each( function() { var $this = $( this ), elementType = $this.data( 'element_type' ); if (!elementType) { return; } try { if( 'widget' === elementType ){ elementType = $this.data( 'widget_type' ); window.elementorFrontend.hooks.doAction( 'frontend/element_ready/widget', $this, $ ); } window.elementorFrontend.hooks.doAction( 'frontend/element_ready/' + elementType, $this, $ ); } catch( err ) { console.log(err); $this.remove(); return false; } }); // On Show Handler self.onShowPopupAction(); } /** * [onShowPopupAction description] * @return {[type]} [description] */ self.onShowPopupAction = function() {}; /** * [onHidePopupAction description] * @return {[type]} [description] */ self.onHidePopupAction = function() {}; /** * Avaliable Effects */ self.avaliableEffects = { 'fade' : { 'show': { opacity: { value: [ 0, 1 ], duration: 600, easing: 'easeOutQuart', }, }, 'hide': { easing: 'easeOutQuart', opacity: { value: [ 1, 0 ], easing: 'easeOutQuart', duration: 400, }, } }, 'zoom-in' : { 'show': { duration: 500, easing: 'easeOutQuart', opacity: { value: [ 0, 1 ], }, scale: { value: [ 0.75, 1 ], } }, 'hide': { duration: 400, easing: 'easeOutQuart', opacity: { value: [ 1, 0 ], }, scale: { value: [ 1, 0.75 ], } } }, 'zoom-out' : { 'show': { duration: 500, easing: 'easeOutQuart', opacity: { value: [ 0, 1 ], }, scale: { value: [ 1.25, 1 ], } }, 'hide': { duration: 400, easing: 'easeOutQuart', opacity: { value: [ 1, 0 ], }, scale: { value: [ 1, 1.25 ], } } }, 'rotate' : { 'show': { duration: 500, easing: 'easeOutQuart', opacity: { value: [ 0, 1 ], }, scale: { value: [ 0.75, 1 ], }, rotate: { value: [ -65, 0 ], } }, 'hide': { duration: 400, easing: 'easeOutQuart', opacity: { value: [ 1, 0 ], }, scale: { value: [ 1, 0.9 ], }, } }, 'move-up' : { 'show': { duration: 500, easing: 'easeOutExpo', opacity: { value: [ 0, 1 ], }, translateY: { value: [ 50, 1 ], } }, 'hide': { duration: 400, easing: 'easeOutQuart', opacity: { value: [ 1, 0 ], }, translateY: { value: [ 1, 50 ], } } }, 'flip-x' : { 'show': { duration: 500, easing: 'easeOutExpo', opacity: { value: [ 0, 1 ], }, rotateX: { value: [ 65, 0 ], } }, 'hide': { duration: 400, easing: 'easeOutQuart', opacity: { value: [ 1, 0 ], } } }, 'flip-y' : { 'show': { duration: 500, easing: 'easeOutExpo', opacity: { value: [ 0, 1 ], }, rotateY: { value: [ 65, 0 ], } }, 'hide': { duration: 400, easing: 'easeOutQuart', opacity: { value: [ 1, 0 ], } } }, 'bounce-in' : { 'show': { opacity: { value: [ 0, 1 ], duration: 500, easing: 'easeOutQuart', }, scale: { value: [ 0.2, 1 ], duration: 800, elasticity: function(el, i, l) { return (400 + i * 200); }, } }, 'hide': { duration: 400, easing: 'easeOutQuart', opacity: { value: [ 1, 0 ], }, scale: { value: [ 1, 0.8 ], } } }, 'bounce-out' : { 'show': { opacity: { value: [ 0, 1 ], duration: 500, easing: 'easeOutQuart', }, scale: { value: [ 1.8, 1 ], duration: 800, elasticity: function(el, i, l) { return (400 + i * 200); }, } }, 'hide': { duration: 400, easing: 'easeOutQuart', opacity: { value: [ 1, 0 ], }, scale: { value: [ 1, 1.5 ], } } }, 'slide-in-up' : { 'show': { opacity: { value: [ 0, 1 ], duration: 400, easing: 'easeOutQuart', }, translateY: { value: ['100vh', 0], duration: 750, easing: 'easeOutQuart', } }, 'hide': { duration: 400, easing: 'easeInQuart', opacity: { value: [ 1, 0 ], }, translateY: { value: [0,'100vh'], } } }, 'slide-in-right' : { 'show': { opacity: { value: [ 0, 1 ], duration: 400, easing: 'easeOutQuart', }, translateX: { value: ['100vw', 0], duration: 750, easing: 'easeOutQuart', } }, 'hide': { duration: 400, easing: 'easeInQuart', opacity: { value: [ 1, 0 ], }, translateX: { value: [0,'100vw'], } } }, 'slide-in-down' : { 'show': { opacity: { value: [ 0, 1 ], duration: 400, easing: 'easeOutQuart', }, translateY: { value: ['-100vh', 0], duration: 750, easing: 'easeOutQuart', } }, 'hide': { duration: 400, easing: 'easeInQuart', opacity: { value: [ 1, 0 ], }, translateY: { value: [0,'-100vh'], } } }, 'slide-in-left' : { 'show': { opacity: { value: [ 0, 1 ], duration: 400, easing: 'easeOutQuart', }, translateX: { value: ['-100vw', 0], duration: 750, easing: 'easeOutQuart', } }, 'hide': { duration: 400, easing: 'easeInQuart', opacity: { value: [ 1, 0 ], }, translateX: { value: [0,'-100vw'], } } } }; /** * Get localStorage data. * * @return {object|boolean} */ self.getLocalStorageData = function() { try { return JSON.parse( localStorage.getItem( 'jetPopupData' ) ); } catch ( e ) { return false; } }; /** * Set localStorage data. * * @return {object|boolean} */ self.setLocalStorageData = function( id, status ) { var jetPopupData = self.getLocalStorageData() || {}, newData = {}; newData['status'] = status; if ( 'disable' === status ) { var nowDate = Date.now(), showAgainDelay = popupSettings['show-again-delay'], showAgainDate = 'none' !== showAgainDelay ? ( nowDate + showAgainDelay ) : 'none'; newData['show-again-date'] = showAgainDate; } jetPopupData[ id ] = newData; localStorage.setItem( 'jetPopupData', JSON.stringify( jetPopupData ) ); } } window.JetPopupFrontend.init(); }( jQuery ) ); ;