@abtasty/progress-bar 1.1.21 → 1.2.0-0
Sign up to get free protection for your applications and to get access to all the features.
- package/README.md +75 -0
- package/dist/form.js +1 -1
- package/dist/main.js +1 -1
- package/package.json +2 -2
package/dist/main.js
CHANGED
@@ -1 +1 @@
|
|
1
|
-
!function(){"use strict";const e=()=>Object.prototype.hasOwnProperty.call(window,"ABTastyEditor"),t=()=>{let e;return window.ABTasty||window.ABTASTY_S?(window.ABTASTY_S&&window.ABTASTY_S.USER&&window.ABTASTY_S.USER.accountIdentifier&&window.ABTASTY_S.USER.accountIdentifier.length?e=window.ABTASTY_S.USER.accountIdentifier:window.ABTasty&&window.ABTasty.getAccountSettings&&"function"==typeof window.ABTasty.getAccountSettings?e=window.ABTasty.getAccountSettings().identifier:window.ABTasty&&window.ABTasty.accountSettings&&(e=window.ABTasty.accountSettings.identifier),e):e},n=()=>{const e=!!document.getElementById("ABTastyPreviewBar"),t=location.href.includes("ab_project=preview");return e||t},r=()=>!e()&&(n()||!!window.ABTasty.getTestsOnPage()[TEST_ID]),s=()=>window.ABTasty&&!0===window.ABTasty.consentReady,i="remove",o="rebuild",a="https://api-social-proof.abtasty.com/clients/",c=()=>{const{type:e}=DATA;return`${PACKAGE.replace("@abtasty/","")}${e?`_${e}`:""}`},l=()=>{const e=c();return`${e.charAt(0).toUpperCase()}${e.slice(1)}`.split("-").join(" ")},h=()=>`${PLUGIN_ID.split("-")[0]}_${TEST_ID}`,u=t=>{if((()=>{if(e()||n())return!1;const t=ABTasty.getTestsOnPage()[TEST_ID];return!!t&&Object.keys(t.targetings.qaParameters).length>0})()){const e=l();window.console.log(`%c${e} - QA Mode for campaign ${TEST_ID}\n${t}`,"background-color: rgba(0, 127, 145, 1); color: rgba(247, 247, 247, 1)")}},d=e=>{const t={promise:null,resolve:null,reject:null,name:e};return t.promise=new Promise((e,n)=>{t.resolve=e,t.reject=n}),t},g=(e,t)=>{const n=()=>{try{return document.querySelector(e)}catch(e){return null}};let r=n();const s=[document.body||document.documentElement,{childList:!0,subtree:!0,attributes:!0}],i=()=>a.disconnect(),o=()=>a.observe(...s),a=new MutationObserver(()=>(r=n(),r&&!i()&&t(r)));return r?setTimeout(()=>t(r),0):o(),{selector:e,clear:i,observe:o}};function m(e,t){return t(e)||!e.parentElement?e:m(e.parentElement,t)}class p{constructor(){this.targets=[],this.existingTargets=[],this.inViewportTargets=[],this.visibilityObserver=this.startVisibilityObserver(),this.mutationObserver=this.startMutationObserver(),this.mouseOverEvent=this.mouseOverHandler()}intersectionHandler(e){e.forEach(e=>{e.isIntersecting?(this.existingTargets.forEach(t=>{t.element.isSameNode(e.target)&&(this.inViewportTargets.push(t),this.mouseOverEvent.start())}),this.checkElements()):this.inViewportTargets=this.inViewportTargets.filter(t=>!t.element.isSameNode(e.target)||(this.mouseOverEvent.clear(),!1))})}startVisibilityObserver(){return new IntersectionObserver(this.intersectionHandler.bind(this),{root:null,rootMargin:"0px",threshold:0})}startMutationObserver(){const e=this.mutationObserver||new MutationObserver(this.checkElements.bind(this));return document.body&&e.observe(document.body,{attributes:!0,childList:!0,subtree:!0}),e}onMouseOver({target:e,path:t}){const n=this.inViewportTargets.find(({element:n,selector:r})=>{if(n.isSameNode(e))return!0;const s=[...e.querySelectorAll(r)];if(s.length&&s.includes(n))return!0;if(t.includes(n))return!0;const i=[...e.parentElement.children],o=i.findIndex(t=>t.isSameNode(e)),a=i.filter((e,t)=>t>o);if(a.length){if(a.includes(n))return!0;if(a.some(e=>[...e.querySelectorAll(r)].includes(n)))return!0}return!1});if(n&&this.isElementVisible(n.element)){const{selector:e,element:t,uniqueId:r}=n,s=this.targets.find(t=>t.selector===e&&t.uniqueId===r);s&&s.resolve(t),this.clear(e,r)}}mouseOverHandler(){const e=["mouseover",e=>setTimeout(()=>this.onMouseOver(e),50),!0];return{start:()=>document.addEventListener(...e),clear:()=>document.removeEventListener(...e)}}isElementVisible(e){return this.isElementTopmost(e)&&this.isElementOpaque(e)}isElementOpaque(e){return"HTML"===m(e,e=>"0"===window.getComputedStyle(e).opacity).nodeName}isElementTopmost(e){const t=e.getBoundingClientRect(),n=[[t.left,t.top],[t.right,t.top],[t.left,t.bottom],[t.right,t.bottom],[t.left+t.width/2,t.top],[t.left+t.width/2,t.bottom],[t.left,t.height/2],[t.right,t.height/2],[t.left+t.left/2,t.height/2]];let r=!1,s=0;for(;!r&&s<n.length;){const t=document.elementFromPoint(...n[s]);r=e===t||e.contains(t),s+=1}return r}checkElements(){this.targets.forEach(({selector:e,uniqueId:t})=>{const n=document.querySelector(e);n&&!this.existingTargets.find(n=>n.element.matches(e)&&n.uniqueId===t)&&(this.existingTargets.push({element:n,selector:e,uniqueId:t}),this.visibilityObserver.observe(n))}),this.existingTargets=this.existingTargets.filter(({selector:e,element:t})=>!!document.querySelector(e)||(t&&this.visibilityObserver.unobserve(t),!1)),this.inViewportTargets=this.inViewportTargets.filter(({selector:e,element:t,uniqueId:n})=>{if(t.matches(e)&&this.isElementVisible(t)){const r=this.targets.find(t=>t.selector===e&&t.uniqueId===n);return r&&r.resolve(t),this.clear(e,n),!1}return!0})}watch(e,t,n){this.targets.push({selector:e,resolve:t,uniqueId:n});const r=()=>{this.startMutationObserver(),this.checkElements()};document.body?r():g("body",r)}clear(e,t){[this.targets,this.existingTargets,this.inViewportTargets]=[this.targets,this.existingTargets,this.inViewportTargets].map(n=>n.filter(({selector:n,uniqueId:r})=>n!==e&&r!==t));const n=document.querySelector(e);n&&this.visibilityObserver.unobserve(n),0===this.targets.length&&this.mutationObserver.disconnect(),0===this.inViewportTargets.length&&this.mouseOverEvent.clear()}}class v{constructor({triggerEvent:e,triggerSelector:t,triggerDelay:n}){this.event=e,this.selector=t&&t.length?t:"body",this.delay=1e3*n,this.elementsSelectors=[],this.eventsListeners=[],this.timeouts=[],this.intervals=[],this.observers=[],this.promises=[],this.visibilityObservers=[],this.elementsWaiters=[]}async onElementVisible({promise:e,resolve:t}){const n=d(`${this.event}DomReady`);this.promises.push(n);const r=await this.onPageLoad(n),s=await async function(){let e;return e=await("IntersectionObserver"in window&&"IntersectionObserverEntry"in window&&"intersectionRatio"in window.IntersectionObserverEntry.prototype||new Promise((e,t)=>{const n=window.document.getElementsByTagName("script")[0],r=window.document.createElement("script");r.src="",n.parentNode.insertBefore(r,n),r.onload=e,r.onerror=t})),e}(),i=new p;if(this.visibilityObservers.push(i),s&&r){const e=h();i.watch(this.selector,t,e)}return e}onPageLoad({promise:e,resolve:t}){const n=()=>"complete"===document.readyState;if(!n()){const r=["readystatechange",({isTrusted:e})=>e&&n()&&t(!0),{passive:!0}];return this.eventsListeners.push(r),document.addEventListener(...r),e}return t(!0),e}onClick({promise:e,resolve:t}){const n=document.createElement("style");n.type="text/css",n.id=`Click_${h()}`,n.innerHTML=`${this.selector} {\n\t\t\tcursor: pointer !important;\n\t\t\tpointer-events: all !important;\n\t\t}`,document.head.appendChild(n),this.elementsSelectors.push(`#${n.id}`);const r=e=>[...document.querySelectorAll(this.selector)].some(t=>t.isSameNode(e)||!!e.closest(this.selector)),s=["click",({isTrusted:e,target:n})=>e&&r(n)&&t(!0),{passive:!0,capture:!0}];return this.eventsListeners.push(s),document.addEventListener(...s),e}onExitIntent({promise:e,resolve:t}){const n=["mouseleave",({isTrusted:e,clientY:n})=>{e&&n<=0&&t(!0)},{passive:!0}],r=g("body",e=>{e.addEventListener(...n),this.eventsListeners.push([e,...n]),this.elementsWaiters=this.elementsWaiters.filter(e=>e!==r)});return this.elementsWaiters.push(r),e}onReengage({promise:e,resolve:t}){const n=this.delay;let r=n;const s=[({isTrusted:e})=>{e&&(r=n)},{passive:!0}];["click","mousemove","scroll","keypress"].forEach(e=>{document.addEventListener(e,...s),this.eventsListeners.push([e,...s])});const i=setInterval(()=>{r<=0?t(!0):r-=100},100);return this.intervals.push(i),e}onCustomTrigger({promise:e,resolve:t}){const{triggerEventCustomScript:n}=DATA;return new Function(`return new Promise(async resolve => {${n}})`)().then(e=>e&&t(!0)),e}getSocialProofPurchases({promise:e,resolve:n}){const r=window.ABTastyProductKey,s=t(),{viewInterval:i,triggerSocialProofMinPurchases:o,spNoTrim:c}=DATA;return r||(u("Not able to find ABTastyProductKey, impossible to call the API."),n(!1)),r&&s?fetch(`${a}${s}/metrics/i?key=${r}${c?"&noTrim=true":""}`).then(e=>e.ok&&e.json()).then(e=>(e=>{if(void 0===i||void 0===o)return!1;const t=void 0!==e[i]&&e[i]>=o;return t||u(`Widget will not be shown, product has been purchased ${e[i]} times while ${o} are required`),t})(e)&&n(`${e[i]}`)).catch(()=>u("Failed to fetch datas from server.")):n(!1),e}getSocialProofPageViews({promise:e,resolve:n}){const{viewInterval:r,triggerSocialProofMinPageViews:s,spNoTrim:i}=DATA,o=encodeURIComponent(i?window.location.href.replace(window.location.origin,""):`${window.location.pathname}`),c=t();return o&&c?fetch(`${a}${c}/metrics/pv?key=${o}${i?"&noTrim=true":""}`).then(e=>e.ok&&e.json()).then(e=>(e=>{if(void 0===r||void 0===s)return!1;const t=void 0!==e[r]&&e[r]>=s;return t||u(`Widget will not be shown, page has been seen ${e[r]} times while ${s} are required`),t})(e)&&n(`${e[r]}`)).catch(()=>u("Failed to fetch datas from server.")):n(!1),e}onConsent({promise:e,resolve:t}){if(!s()){const n=["abtasty_consentValid",()=>t(!0)];return this.eventsListeners.push(n),window.addEventListener(...n),e}return t(!0),e}clear(){if(this.elementsSelectors.length&&(this.elementsSelectors.forEach(e=>{document.querySelector(e)&&document.querySelector(e).remove()}),this.elementsSelectors=[]),this.eventsListeners.length&&(this.eventsListeners.forEach(e=>{const[t,...n]="string"==typeof e[0]?[document,...e]:e;t&&n.length>1&&t.removeEventListener(...n)}),this.eventsListeners=[]),this.timeouts.length&&(this.timeouts.forEach(e=>clearTimeout(e)),this.timeouts=[]),this.intervals.length&&(this.intervals.forEach(e=>clearInterval(e)),this.intervals=[]),this.observers.length&&(this.observers.forEach(e=>e.disconnect()),this.observers=[]),this.visibilityObservers.length){const e=h();this.visibilityObservers.forEach(t=>t.clear(this.selector,e)),this.visibilityObservers=[]}return this.promises.length&&(this.promises.forEach(e=>e.resolve(!1)),this.promises=[]),this.elementsWaiters.length&&(this.elementsWaiters.forEach(e=>e.clear()),this.elementsWaiters=[]),this}async isTriggered(){this.clear();const e=d(this.event);this.promises.push(e);const t={consent:()=>this.onConsent(e),direct:()=>!0,pageLoad:()=>this.onPageLoad(e),click:()=>this.onClick(e),exitIntent:()=>this.onExitIntent(e),reengage:()=>this.onReengage(e),elementVisible:()=>this.onElementVisible(e),script:()=>this.onCustomTrigger(e),socialProofPurchases:()=>this.getSocialProofPurchases(e),socialProofPageViews:()=>this.getSocialProofPageViews(e)},n=!Object.prototype.hasOwnProperty.call(t,this.event)||await t[this.event]();return this.clear(),"reengage"!==this.event&&this.delay?n&&await(async()=>{const e=d(`${this.event}Delay`);return this.promises.push(e),setTimeout(()=>{e.resolve(!0),this.clear()},this.delay),e.promise})():n}}const b="closing",f="validation",y="ABTastyWidgets",w="ABTastyWidgetsTemporary";class ${constructor({displayRecurrence:e,closingRecurrence:t,validationRecurrence:n},r){this.displayRecurrence=parseFloat(e),this.closingRecurrence=parseFloat(t),this.validationRecurrence=parseFloat(n),this.onSetCallback=r,this.widgetName=c(),this.uniqueId=h(),this.recurrenceKey=`${this.widgetName}_${this.uniqueId}`,this.isListeningStorageEvent=this.listenStorageEvent(),this.pendingRecurrence=!1,this.pendingRecurrenceValue={}}onStorage({key:e}){const t=localStorage.getItem(w),n=sessionStorage.getItem(y);"ABTastyData"===e&&!t&&n&&localStorage.setItem(w,n)}listenStorageEvent(){return this.isListeningStorageEvent||window.addEventListener("storage",this.onStorage.bind(this)),!0}getGivenRecurrenceStorageParsed(e){try{const t=e.getItem(y);return JSON.parse(t)}catch(t){return e.removeItem(y),!1}}getSessionRecurrenceStorageParsed(){return this.getGivenRecurrenceStorageParsed(window.sessionStorage)}getLocalRecurrenceStorageParsed(){return this.getGivenRecurrenceStorageParsed(window.localStorage)}removeGivenStorage(e,t){const{[this.recurrenceKey]:n,...r}=t;return Object.entries(r).length?(e.setItem(y,JSON.stringify(r)),r):(e.removeItem(y),!1)}removeSessionRecurrenceStorage(){const e=this.getSessionRecurrenceStorageParsed();return!!e&&this.removeGivenStorage(window.sessionStorage,e)}removeLocalRecurrenceStorage(){const e=this.getLocalRecurrenceStorageParsed();return!!e&&this.removeGivenStorage(window.localStorage,e)}getSessionRecurrence(){const e=this.getSessionRecurrenceStorageParsed();return!!e&&e[this.recurrenceKey]}getLocalRecurrence(){const e=this.getLocalRecurrenceStorageParsed();return!!e&&e[this.recurrenceKey]}getCurrentRecurrence(){if(this.pendingRecurrence)return this.pendingRecurrenceValue;const e=this.getSessionRecurrence(),t=this.getLocalRecurrence();return e||t||{type:!1}}isOver(){const e=localStorage.getItem(w),t=!(!e||!e.includes(this.recurrenceKey))||this.getSessionRecurrence();e&&(sessionStorage.setItem(y,e),localStorage.removeItem(w));const n=this.getLocalRecurrence(),r=(n?parseFloat(n.stamp):0)<(new Date).getTime();return r&&this.removeLocalRecurrenceStorage(),!this.pendingRecurrence&&r&&!this.getLocalRecurrence()&&!t}setRecurrence(e,t){0!==e&&(window.removeEventListener("storage",this.onStorage.bind(this)),this.isListeningStorageEvent=!1);const r=this.getTypeOfStorage(e);if(n()||!r&&"object"!=typeof r)return!1;const{storageString:i,storageMethod:o}=r,a=this.getStamp(e),c={type:t,stamp:a},{type:l}=this.getCurrentRecurrence(),h=async()=>{if(!s()){this.pendingRecurrence=!0,this.pendingRecurrenceValue=c;const e=new v({triggerEvent:"consent"});await e.isTriggered(),this.pendingRecurrence=!1,this.pendingRecurrenceValue={}}const e=this.getSessionRecurrence(),t=this.getLocalRecurrence();let n;"session"===i?e?n=this.removeSessionRecurrenceStorage():(this.removeLocalRecurrenceStorage(),n=this.getSessionRecurrenceStorageParsed()):"local"===i&&(t?n=this.removeLocalRecurrenceStorage():(this.removeSessionRecurrenceStorage(),n=this.getLocalRecurrenceStorageParsed()));const r=n?{[this.recurrenceKey]:c,...n}:{[this.recurrenceKey]:c};o.setItem(y,JSON.stringify(r)),this.onSetCallback&&"function"==typeof this.onSetCallback&&this.onSetCallback()};if(!o)return!1;if(l&&t!==f)if(t===b&&l!==f)h();else{if("display"!==t||l===f||l===b)return!1;h()}else h();return a}setDisplayRecurrence(){this.setRecurrence(this.displayRecurrence,"display")}setClosingRecurrence(){this.setRecurrence(this.closingRecurrence,"closing")}setValidationRecurrence(){this.setRecurrence(this.validationRecurrence,"validation")}getStamp(e){return(new Date).getTime()+864e5*e}getTypeOfStorage(e){return!(isNaN(e)||e<0||0!==e&&!e)&&(e>0?{storageString:"local",storageMethod:window.localStorage}:0===e&&{storageString:"session",storageMethod:window.sessionStorage})}}class C{constructor(e,t,n){this.recurrence=e,this.isWidgetApplied=t,this.callback=n,this.observer=new MutationObserver(this.observerHandler.bind(this)),this.eventListenerParams=["abtasty_resetActionTracking",this.eventHandler.bind(this),{passive:!0}],this.elementsWaiters=[]}recurrenceIsDone(){return!this.recurrence||this.recurrence.isOver()}decisionHandler(e){const t=r(),{type:n}=this.recurrence?this.recurrence.getCurrentRecurrence():{type:!1};let s;const a=this.isWidgetApplied(),c=(()=>{const t=this.recurrenceIsDone();return e&&"display"===n||t})();return!a&&t&&c?s=o:(a&&(!t||!c)||!a&&!t)&&(s=i),"string"==typeof s&&(this.clearWatcher(),this.callback(s,e),this.watch()),this}eventHandler(){let e=r();return[250,500].forEach(t=>{setTimeout(()=>{const n=r();return 500===t&&n===e?this:(e=n,this.decisionHandler(!1))},t)}),this}observerHandler(e){return e.some(e=>["removedNodes","addedNodes"].some(t=>e[t]&&e[t].length))?this.decisionHandler(!0):this}watch(){if(e())return this;this.clearWatcher(),document.addEventListener(...this.eventListenerParams);const t=()=>{const e=[document.body,{childList:!0,subtree:!0}];this.observer.observe(...e)};return document.body?t():(()=>{const e=g("body",()=>{t(),this.elementsWaiters=this.elementsWaiters.filter(t=>t!==e)});this.elementsWaiters.push(e)})(),this}clearWatcher(){return document.removeEventListener(...this.eventListenerParams),this.elementsWaiters.length&&(this.elementsWaiters.forEach(e=>e.clear()),this.elementsWaiters=[]),this.observer.disconnect(),this}}const S=/.+\/([^.]+)\.(otf|ttf)$/;class T{constructor(){this.children=void 0,this.uniqueId=h(),this.widgetName=c(),this.prettyName=l(),this.recurrenceParams=(()=>{const{displayRecurrence:t,closingRecurrence:n,validationRecurrence:r}=DATA;if(e()||!t&&!n&&!r)return!1;const s={everytime:()=>-1,session:()=>0,once:()=>395,day:e=>DATA[`${e}_day`],week:e=>7*DATA[`${e}_week`],month:e=>30.5*DATA[`${e}_month`]},i={};return t&&(i.displayRecurrence=s[t]("displayRecurrence")),n&&(i.closingRecurrence=s[n]("closingRecurrence")),r&&(i.validationRecurrence=s[r]("validationRecurrence")),i})(),this.triggerParams=(()=>{let{triggerEvent:t}=DATA;const{triggerEventClick:n,triggerEventReengageDelay:r,socialProofContentType:s,triggerEventElementVisible:i,triggerEventDelay:o}=DATA;if(e()||!t&&!s)return!1;const a={click:()=>n,elementVisible:()=>i},c=Object.prototype.hasOwnProperty.call(a,t)?a[t]():"body",l="reengage"===t?r:o;return s&&(t=1===s?"socialProofPurchases":"socialProofPageViews"),{triggerEvent:t,triggerSelector:c,triggerDelay:l}})(),this.recurrence=!!this.recurrenceParams&&new $(this.recurrenceParams,this.clearGivenClearables.bind(this)),this.trigger=!!this.triggerParams&&new v(this.triggerParams),this.pageWatcher=new C(this.recurrence,this.isWidgetApplied.bind(this),this.onPageChange.bind(this)),this.hasOncePerPageTrigger=(()=>{const{isOncePerPageTrigger:e,triggerEvent:t}=DATA;return!t||!(!e||!["click","script"].includes(t))||["pageLoad","direct","reengage","socialProofPurchases","socialProofPageViews","elementVisible"].some(e=>e===t)})(),this.basicClassName=`ab_widget_container_${this.widgetName}`,this.widgetContainerId=`${this.basicClassName}_${this.uniqueId}`,this.contentClassName=`${this.basicClassName}_content`,this.overlayClassName=`${this.basicClassName}_overlay`,this.closeButtonClassName=`${this.basicClassName}_close_button`,this.hideClassName=`ab_hide_${this.uniqueId}`,this.domElement=this.getDom(),this.hasBeenShown=!1,this.closedByUser=!1,this.eventsListeners=[],this.timeouts=[],this.intervals=[],this.observers=[],this.promises=[],this.elementsWaiters=[]}clearGivenClearables(){this.eventsListeners.length&&(this.eventsListeners.forEach(e=>document.removeEventListener(...e)),this.eventsListeners=[]),this.timeouts.length&&(this.timeouts.forEach(e=>clearTimeout(e)),this.timeouts=[]),this.intervals.length&&(this.intervals.forEach(e=>clearInterval(e)),this.intervals=[]),this.observers.length&&(this.observers.forEach(e=>e.disconnect()),this.observers=[]),this.promises.length&&(this.promises.forEach(e=>e.resolve(!1)),this.promises=[]),this.elementsWaiters.length&&(this.elementsWaiters.forEach(e=>e.clear()),this.elementsWaiters=[])}isWidgetApplied(){return this.domElement&&this.domElement.isConnected}removeOldDomElement(){const e=document.getElementById(this.widgetContainerId);return e&&e.remove(),this}async insert(){if(this.isWidgetApplied())return!1;const e=new Promise(e=>{const t=g("head",t=>{this.elementsWaiters=this.elementsWaiters.filter(({selector:e})=>"head"!==e),e(t.appendChild(this.styleElement))});this.elementsWaiters.push(t)}),t=new Promise(e=>{const{elementReferrer:t="body",referrerInsertType:n="beforeend"}="free"===DATA.layout?DATA:{},r=g(t,r=>{this.elementsWaiters=this.elementsWaiters.filter(e=>e.selector!==t),this.removeOldDomElement(),e(r.insertAdjacentElement(n,this.domElement))});this.elementsWaiters.push(r)});return Promise.all([t,e]).then(()=>this)}remove(){return this.pageWatcher.clearWatcher(),[this.domElement,this.styleElement].forEach(e=>e&&e.isConnected&&e.remove()),this.hasOncePerPageTrigger?this.pageWatcher.watch():e()||this.init().then(({response:e})=>e?this.show():this),this}show(){return e()||this.hasBeenShown&&this.hasOncePerPageTrigger||window.ABTastyEvent(`${this.prettyName} displayed`,null,TEST_ID),this.closedByUser=!1,this.domElement.classList.remove(this.hideClassName),this.recurrence&&this.recurrence.setDisplayRecurrence(),this.hasBeenShown=!0,this.pageWatcher.watch(),this}hide(){return!e()&&this.hasBeenShown&&window.ABTastyEvent(`${this.prettyName} closed`,null,TEST_ID),this.closedByUser=!0,this.domElement.classList.add(this.hideClassName),this}async init(t){const n=e(),s=r(),i=this.trigger&&this.trigger.promises.length,o=!this.recurrence||this.recurrence.isOver();if(!n&&!s||i||!o)return!1;this.pageWatcher.watch();const a=n||!this.trigger||this.trigger&&await this.trigger.isTriggered();return!!a&&(await this.insert(),this.addCloseEvent(),n||t||this.hasBeenShown||void 0===this.children||"function"!=typeof this.children.refreshContent||this.children.refreshContent(a),{container:this,response:a})}onPageChange(e,t){const n=()=>this.init().then(({response:e})=>e&&this.show());t||(this.hasBeenShown=!1);const r=this.isWidgetApplied(),s={[i]:()=>{r?this.remove():(this.trigger&&this.trigger.clear(),this.pageWatcher.watch())},[o]:()=>{this.hasBeenShown?this.closedByUser?this.pageWatcher.watch():r||this.insert().then(e=>e.show()).catch(this.pageWatcher.watch):n()}};"function"==typeof s[e]&&s[e]()}addCloseEvent(...t){const{closeButton:n,overlay:r,overlayClickable:s,layout:i}=DATA,o=[];if(void 0!==r&&!0!==r||!0!==s||"popin"!==i||o.push(`.${this.overlayClassName}`),void 0!==n&&n&&o.push(`.${this.closeButtonClassName}`),!o.length)return this;const a=this.domElement.querySelectorAll(o.join(", "));return a.length?(t.push(...a),t.forEach(t=>{e()&&(t.dataset.abtastyActionnable="true"),t.addEventListener("click",t=>{(t=>{e()||(t.preventDefault(),t.stopPropagation(),t.stopImmediatePropagation())})(t),this.recurrence&&this.recurrence.setClosingRecurrence(),this.hide(),setTimeout(()=>this.remove(),1e3)},{once:!0,capture:!0})}),this):this}getDom(){const{closeButton:e,layout:t,overlay:n=!0}=DATA,r=document.createElement("div");return r.className=`${this.basicClassName} ${this.hideClassName}`,r.id=this.widgetContainerId,r.innerHTML=`\n\t\t\t${"popin"===t&&!0===n?`<div class="${this.overlayClassName}"></div>`:""}\n\t\t\t<div class="${this.contentClassName}">\n\t\t\t${e?`<button class="${this.closeButtonClassName}"><svg viewBox="0 0 16 16">\n\t<defs><path id="prefix__a" d="M12 4.991L11.009 4 8 7.009 4.991 4 4 4.991 7.009 8 4 11.009 4.991 12 8 8.991 11.009 12 12 11.009 8.991 8z"></path></defs>\n\t<g><use xlink:href="#prefix__a"></use></g>\n</svg></button>`:""}\n\t\t\t</div>`,r}loadFont(e,t){if(!e||"inherit"===e)return;const n=document.createElement("style"),r=t.match(S)?t.match(S)[1]:"";n.innerHTML=`@font-face { font-family: '${e}_${r}'; src: url('${t}');}`,document.head.appendChild(n)}getStyleTag(t="",n=DATA){const{noStyles:r,layout:s}=n,{backgroundColor:i,isBackgroundImage:o,backgroundImage:a,backgroundSize:c,backgroundPosition:l,backgroundRepeat:h,borderColor:u,borderRadius:d,borderWidth:g,textColor:m,textAlign:p,fontName:v,fontStyle:b,fontSize:f,isTitle:y,titleTextAlign:w,titleTextColor:$,titleFontName:C,titleFontStyle:T,titleFontSize:E,overlay:A,overlayColor:x,dropShadow:R,dropShadowColor:B,dropShadowBlur:I,containerMargin:P,containerPadding:N,closeButton:k,closeButtonPosition:_,closeButtonSize:O,closeButtonBorderRadius:V,closeButtonBorderWidth:L,closeButtonBorderColor:D,closeButtonColor:W,closeButtonBackgroundColor:j,buttonsBorderWidth:H,buttonsBorderColor:q,buttonsBorderRadius:M,buttonsBackgroundColor:U,buttonsTextColor:z,buttonsFontName:F,buttonsFontStyle:G,buttonsFontSize:K}=r?{}:n,Q=document.createElement("style");Q.type="text/css",e()&&Q.setAttribute("abtasty-script-added","true"),this.loadFont(v,b),this.loadFont(C,T),this.loadFont(F,G);const Y=`background: ${["string"==typeof i?i:"rgba(255, 255, 255, 1)",o&&"string"==typeof a&&a.length?`url(${a})`:"",o&&"string"==typeof l&&"100% 100%"!==c?l:"0 0",o&&"string"==typeof c?`/ ${c}`:"/ auto",o&&h&&!["cover","100% 100%"].includes(c)?"repeat":"no-repeat"].join(" ").trim()};`,J="number"==typeof g&&g>0,X=`border: ${[J?`${g}px`:"unset",J?"solid":"",J&&"string"==typeof u&&u.length?u:""].join(" ").trim()};`,Z=void 0!==d?`border-radius: ${d}px;`:"",ee=void 0!==m?`color: ${m}; fill: ${m}; -webkit-text-fill-color: ${m};`:"",te=void 0!==p?`text-align: ${p};`:"",ne=v&&"inherit"!==v?`font-family:${v}_${b.match(S)?b.match(S)[1]:""};`:b||"",re=f?`font-size: ${f}px;`:"",se=void 0!==R&&R?`box-shadow: 0 5px ${I}px 0 ${B};`:"",ie=P instanceof Array&&1===P.length&&P[0],oe=ie?`margin: ${ie.top}px ${ie.right}px ${ie.bottom}px ${ie.left}px;`:"",ae=ie?`margin: calc(${ie.top}px * 0.5) calc(${ie.right}px * 0.5) calc(${ie.bottom}px * 0.5) calc(${ie.left}px * 0.5);`:"",ce=N instanceof Array&&1===N.length&&N[0],le=ce?`padding: ${ce.top}px ${ce.right}px ${ce.bottom}px ${ce.left}px;`:"",he=ce?`padding: calc(${ce.top}px * 0.5) calc(${ce.right}px * 0.5) calc(${ce.bottom}px * 0.5) calc(${ce.left}px * 0.5);`:"",ue=void 0!==H&&H?`border-width: ${H}px; border-style: solid;`:"",de=[q,H].every(e=>void 0!==e)&&H?`border-color: ${q};`:"",ge=void 0!==M?`border-radius: ${M}px;`:"",me=void 0!==U?`background-color: ${U};`:"",pe=void 0!==z?`color: ${z}; fill: ${z}; -webkit-text-fill-color: ${z};`:"",ve=F&&"inherit"!==F?`font-family:${F}_${G.match(S)?G.match(S)[1]:""};`:G||"",be=K?`font-size: ${K}px;`:"",fe="popin"!==s||void 0!==A&&!0!==A?"":[`#${this.widgetContainerId} .${this.overlayClassName} {`,`background-color: ${void 0!==x?x:"rgba(0, 0, 0, 0.6)"};`,"}"].join(""),ye="number"==typeof O?O:16,we=ye/2,$e=r||void 0!==k&&k?[`#${this.widgetContainerId} .${this.contentClassName} .${this.closeButtonClassName} {`,"position: absolute;",("out"===_?`bottom: calc(100% + ${we}px)`:`top: ${we}px`)+";",`right: ${we}px;`,"width: auto;","height: auto;","background: none;","border: none;","cursor: pointer;","outline: none;","padding: 0;","margin: 0;","line-height: 0;","z-index: 9;","number"==typeof V?`border-radius: ${V}px;`:"","number"==typeof L&&L>0?`border: ${L}px solid ${void 0!==D?D:"rgba(57, 57, 57, 1)"};`:"","string"==typeof j?`background-color: ${j};`:"","}",`#${this.widgetContainerId} .${this.contentClassName} .${this.closeButtonClassName} svg {`,"pointer-events: none;",`width: ${ye}px;`,`height: ${ye}px;`,"string"==typeof W?`fill: ${W};`:"","}"].join(""):"",Ce=y&&"string"==typeof $?[`#${this.widgetContainerId} .${this.contentClassName} > * h1, `,`#${this.widgetContainerId} .${this.contentClassName} > * h2, `,`#${this.widgetContainerId} .${this.contentClassName} > * h3, `,`#${this.widgetContainerId} .${this.contentClassName} > * h4, `,`#${this.widgetContainerId} .${this.contentClassName} > * h5, `,`#${this.widgetContainerId} .${this.contentClassName} > * h6 {`,`color: ${$}; fill: ${$}; -webkit-text-fill-color: ${$};`,void 0!==w?`text-align: ${w};`:"",C&&"inherit"!==C?`font-family:${C}_${T.match(S)?T.match(S)[1]:""};`:T||"",E?`font-size: ${E}px;`:"","}"].join(""):"";return Q.textContent=[`.${this.hideClassName} {`,"opacity: 0 !important;","pointer-events: none;","}",`#${this.widgetContainerId} .${this.contentClassName} {`,Y,Z,X,ee,te,se,oe,ne,re,"}",`#${this.widgetContainerId} .${this.contentClassName} p {`,ee,te,ne,re,"}",`#${this.widgetContainerId} .${this.contentClassName} > * {`,"display: block;","line-height: 1;","text-indent: unset;",le,ne,re,"}",`#${this.widgetContainerId} .${this.contentClassName} > * a, `,`#${this.widgetContainerId} .${this.contentClassName} > * button {`,"box-sizing: border-box;","display: inline-block;",ue,de,ge,me,pe,ve,be,"}",`#${this.widgetContainerId} .${this.contentClassName} > * a *, `,`#${this.widgetContainerId} .${this.contentClassName} > * button * {`,pe,ve,be,"}","@media screen and (max-width: 579px) {",`#${this.widgetContainerId} .${this.contentClassName} {`,ae,"}",`#${this.widgetContainerId} .${this.contentClassName} > * {`,he,"}","}",fe,$e,Ce,`${t}`].join(""),Q}}const E=["top: 0;","top: 50%;","bottom: 0;"],A=["left: 0;","left: 50%;","right: 0;"],x=e=>1===e?"-50%":0,R=()=>{if(Array.isArray(DATA.popinPosition)){const{popinPosition:[{x:e,y:t}]}=DATA,n=`translate(${x(t)}, ${x(e)});`;return`${E[e]}${A[t]}transform: ${n}`}return"left: 50%;top: 50%;transform: translate(-50%, -50%);"},B=()=>"autoWidth"in DATA&&!0===DATA.autoWidth,I=()=>{if(B())return"width: auto;height: auto;";const{popinPercentWidth:e,popinPixelsWidth:t,widthUnit:n,autoHeight:r,popinPercentHeight:s,popinPixelsHeight:i,heightUnit:o}=DATA;return`width: ${"px"===n?t:e}${n};height: ${r?"auto":`${"px"===o?i:s}${o}`};`};class P extends T{constructor(){super(),this.stringStyles=this.getStyles(),this.styleElement=this.getStyleTag(this.stringStyles)}getStyles(){const{zindex:e,zindexCustom:t,overlay:n}=DATA;return[`#${this.widgetContainerId} {`,"position: fixed;","top: 0;","left: 0;","width: 100%;","height: 100%;",`z-index: ${"custom"===e?t:e};`,"opacity: 1;","transition: opacity 0.25s ease;","background: none;","pointer-events: "+(!1===n?"none":"all"),"}",`#${this.widgetContainerId} .${this.overlayClassName} {`,"position: absolute;","z-index: -1;","top: 0;","left: 0;","width: 100%;","height: 100%;","}",`#${this.widgetContainerId} .${this.contentClassName} {`,"position: absolute;",R(),I(),"pointer-events: all","}",`${B()?"":[`#${this.widgetContainerId} .${this.contentClassName} > div {`,"height: 100%;","overflow: auto;","box-sizing: border-box;","}"].join("")}`,"@media screen and (max-width: 579px) {",`#${this.widgetContainerId} .${this.contentClassName} {`,"max-width: 94vw;","}","}"].join("")}}class N extends T{constructor(){super(),this.position="string"==typeof DATA.layout&&"bannerTop"===DATA.layout?"top":"bottom",this.stringStyles=this.getStyles(),this.styleElement=this.getStyleTag(this.stringStyles)}getStyles(){const{zindex:e,zindexCustom:t}=DATA;return[`#${this.widgetContainerId} {`,"position: fixed;",`${this.position}: 0;`,"left: 0;","width: 100%;","height: auto;",`z-index: ${"custom"===e?t:e};`,"opacity: 1;","transition: opacity 0.25s ease;","background: none;","}",`#${this.widgetContainerId} .${this.contentClassName} {`,"position: relative;","}"].join("")}}class k extends T{constructor(){super(),this.stringStyles=this.getStyles(),this.styleElement=this.getStyleTag(this.stringStyles)}getStyles(){return[`#${this.widgetContainerId} {`,"width: auto;","height: auto;","margin: 0;","padding: 0;","background: none;","}",`#${this.widgetContainerId} .${this.contentClassName} {`,"position: relative;","}"].join("")}}var _,O,V,L;function D(e,t){return t||(t=e.slice(0)),Object.freeze(Object.defineProperties(e,{raw:{value:Object.freeze(t)}}))}function W(e){for(var t=arguments.length,n=new Array(t>1?t-1:0),r=1;r<t;r++)n[r-1]=arguments[r];return e.reduce(function(e,t,r){return e+n[r-1]+t})}function j(e){return Math.round(100*e)/100}function H(e){var t=this,n=e.reachQuantity,r=e.colorBlindMode,s=e.progressBarStripesColor,i=e.progressBarBackgroundColor,o=e.progressBarColor,a=e.progressBarBorderRadius,c=e.progressBarHeight;function l(e){return"translateX(".concat(Math.min(e,n)/n*100-100,"%)")}this.addStyleRules([".abtasty_progress_pbar {\n background-color: ".concat(i,";\n border-radius: ").concat(a,"px;\n overflow: hidden;\n }"),".abtasty_progress_indicator {\n height: ".concat(c,"px;\n background-color: ").concat(o,";\n transition: transform 0.5s ease-out;\n transform: translateX(-100%);\n border-top-right-radius: ").concat(a,"px;\n border-bottom-right-radius: ").concat(a,"px;\n }"),r?"\n .abtasty_progress_indicator {\n background-image: repeating-linear-gradient(-45deg,\n transparent,\n transparent 7px,\n ".concat(s," 6px,\n ").concat(s," 14px);\n }"):""]);var h=this.parentContainer.domElement.getElementsByClassName("abtasty_progress_indicator");return this.eventHub.on("valueUpdated",function(){Array.from(h).forEach(function(e){e.style.setProperty("transform",l(t.value.targetValue.numericValue),"important")})}),W(_||(_=D(['\n\t\t<div class="abtasty_progress_pbar">\n\t\t\t<div\n\t\t\t\tclass="abtasty_progress_indicator"\n\t\t\t\tstyle="transform: ',' !important;"\n\t\t\t></div>\n\t\t</div>\n\t'])),l(this.value.targetValue.numericValue))}function q(e){var t=this,n=e.reachQuantity,r=e.textLabelContent,s=e.subLayout,i=e.textColor,o=e.textAlign,a=e.fontSize;this.addStyleRules([".abtasty_progress_definition {\n font-size: ".concat(a,"px;\n color: ").concat(i,";\n margin: 7px 0 0 0;\n text-align: ").concat(o,";\n word-break: break-word;\n }"),".abtasty_progress_label {\n margin: 0;\n font-family: inherit;\n color: inherit;\n font-size: inherit;\n word-break: break-word;\n }",".abtasty_progress_value {\n margin: 0;\n font-family: inherit;\n color: inherit;\n font-size: inherit;\n word-break: initial;\n }"]);var c=this.parentContainer.domElement.getElementsByClassName("abtasty_progress_value");return this.eventHub.on("valueUpdated",function(){Array.from(c).forEach(function(e){e.textContent=t.value.targetValue.formatNumber(j(t.value.displayingValue))})}),{customTextVariables:function(){var e=t.textVariablesContent.replace("!variable!",'<span class="abtasty_progress_value">'.concat(t.value.targetValue.formatNumber(j(t.value.displayingValue)),"</span>")).replace("!quantityToReach!",'<span class="abtasty_progress_max">'.concat(t.value.targetValue.formatNumber(n),"</span>"));return W(O||(O=D(['\n\t\t\t\t<p class="abtasty_progress_definition">',"</p>\n\t\t\t"])),e)},customLabelVariables:function(){return t.addStyleRules([".abtasty_progress_definition {\n display: flex;\n justify-content: space-between;\n line-height: 1;\n }",".abtasty_progress_label {\n flex-basis: 66%;\n text-align: left;\n line-height: 1;\n }",".abtasty_progress_value {\n line-height: 1;\n }"]),W(V||(V=D(['\n\t\t\t\t<dl class="abtasty_progress_definition">\n\t\t\t\t\t<dt class="abtasty_progress_label">','</dt>\n\t\t\t\t\t<dd class="abtasty_progress_value">',"</dd>\n\t\t\t\t</dl>\n\t\t\t"])),r,t.value.targetValue.formatNumber(j(t.value.displayingValue)))},progressBarOnly:function(){return""}}[s]()}function M(e){var t=e.reachQuantity,n=e.subLayout,r=e.textLabelContent,s=e.progressBarStripesColor,i=e.progressBarBackgroundColor,o=e.progressBarColor,a=e.colorBlindMode,c=e.progressBarBorderRadius,l=e.progressBarHeight,h=e.textColor,u=e.textAlign,d=e.fontSize;return W(L||(L=D(['\n\t\t<div class="','">\n\t\t\t',"\n\t\t\t","\n\t\t</div>\n\t"])),this.className,H.call(this,{reachQuantity:t,progressBarStripesColor:s,progressBarBackgroundColor:i,progressBarColor:o,colorBlindMode:a,progressBarBorderRadius:c,progressBarHeight:l}),q.call(this,{subLayout:n,textLabelContent:r,reachQuantity:t,textColor:h,textAlign:u,fontSize:d}))}var U=/\s/g,z=/\d(\d|\.|\s|,)*/,F=/(\d)(,)(\d+)/,G=/\d+(,\d{3})+(?!\d)/,K=/\d+(\.\d{3})+(?!\d)/,Q=/\d+\s{1}\d{3,}/,Y=/,\d{2,}/,J=/\.\d{2,}/,X=/\d+/,Z=/\./g,ee=/,/g,te=/(\d{1,3})(\.\d{2}|,\d{2}|\s{1}|\.|,)\s+\d+/i,ne=/(\.|,)(\d+)(\.|,)?\s+\d+/i;function re(e){var t=e.toString().match(z);t||u("could not parse source value, using 0");var n=t?t[0]:"0";return n=n.replace(te,"$1$2").replace(ne,"$1$2").replace(G,function(e){return e.replace(ee,"")}).replace(U,"").replace(K,function(e){return e.replace(Z,"")}).replace(F,"$1.$3"),Number.parseFloat(n)}function se(e){this.encode=e,this.decode=re}function ie(e,t){for(var n=Math.floor(e).toString(),r=n.length;r>3;)r+=-3,n=n.slice(0,r)+t+n.slice(r);return n}function oe(e,t){var n=e.toString();return n.indexOf(".")>0?"".concat(t).concat(n.substring(n.indexOf(".")+1)):""}var ae=function(){function e(t){!function(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")}(this,e),this.originalValue=t,this.formatter=function(e){return G.test(e)?new se(function(e){return"".concat(ie(e,",")).concat(oe(e,"."))}):K.test(e)?new se(function(e){return"".concat(ie(e,".")).concat(oe(e,","))}):Q.test(e)?Y.test(e)?new se(function(e){return"".concat(ie(e," ")).concat(oe(e,","))}):(J.test(e),new se(function(e){return"".concat(ie(e," ")).concat(oe(e,"."))})):Y.test(e)?new se(function(e){return"".concat(ie(e,"")).concat(oe(e,","))}):J.test(e)?new se(function(e){return"".concat(ie(e,"")).concat(oe(e,"."))}):(X.test(e),new se(function(e){return e}))}(t),this.numericValue=this.formatter.decode(t)}var t;return(t=[{key:"formatNumber",value:function(e){return this.formatter.encode(e).toString()}}])&&function(e,t){for(var n=0;n<t.length;n++){var r=t[n];r.enumerable=r.enumerable||!1,r.configurable=!0,"value"in r&&(r.writable=!0),Object.defineProperty(e,r.key,r)}}(e.prototype,t),e}();function ce(e,t){for(var n=0;n<t.length;n++){var r=t[n];r.enumerable=r.enumerable||!1,r.configurable=!0,"value"in r&&(r.writable=!0),Object.defineProperty(e,r.key,r)}}var le=function(){function t(e){var n=e.parentContainer;!function(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")}(this,t),this.eventHub={hub:Object.create(null),emit:function(e,t){(this.hub[e]||[]).forEach(function(e){return e(t)})},on:function(e,t){this.hub[e]||(this.hub[e]=[]),this.hub[e].push(t)},off:function(e,t){var n=(this.hub[e]||[]).findIndex(function(e){return e===t});n>-1&&this.hub[e].splice(n,1),0===this.hub[e].length&&delete this.hub[e]}},this.renderContent=M,this.parentContainer=n,this.baseClassName="progressbar_container",this.className="".concat(this.baseClassName,"_").concat(n.uniqueId),this.styleRules=[],this.externalValue=0,this.value=this.getValue(),this.contentElement=this.getContentElement(),this.styleElement=this.getStyleElement(),this.sourceElementObserver=null,this.sourceValueObserver=new MutationObserver(this.handleValueUpdate.bind(this)),this.parentContainer.children=this}var n,r,s;return n=t,s=[{key:"getValueFromElement",value:function(){var e=DATA.variableElement,t=document.querySelector(e),n=t?t.textContent:"0";return t===document.body&&(n="67"),new ae(n)}}],(r=[{key:"start",value:function(t){var n=this;this.eventHub.on("refreshContent",function(){"element"===t.variableType&&n.eventHub.emit("valueElementUpdated")}),this.eventHub.on("valueElementUpdated",function(){var e,t,r=n.getValue();e=r,t=n.value,Object.keys(t).every(function(n){return e[n]&&e[n]===t[n]})||(n.value=r,n.eventHub.emit("valueUpdated"))}),this.eventHub.on("sourceElementPresence",function(e){e?(n.eventHub.emit("valueElementUpdated"),n.parentContainer.domElement.hidden=!1,n.sourceValueObserver.observe(e,{childList:!0,subtree:!0,attributes:!1,characterData:!0})):(n.sourceValueObserver.disconnect(),n.parentContainer.domElement.hidden=!0,n.sourceElementObserver.observe(),u("source element could not be found, hiding the progress bar widget"))}),this.eventHub.on("externalUpdate",function(e){n.externalValue=Number.parseFloat(e),n.value=n.getValue(),n.eventHub.emit("valueUpdated")}),e()||this.eventHub.on("valueUpdated",function(){n.isGoalReached(t.reachQuantity)}),"javascript"===t.variableType&&this.getValueFromScript(),"element"===t.variableType&&(this.sourceElementObserver=g(t.variableElement,function(e){n.eventHub.emit("sourceElementPresence",e)}))}},{key:"handleValueUpdate",value:function(){this.eventHub.emit("valueElementUpdated")}},{key:"isGoalReached",value:function(e){this.value.numericValue>=e&&(this.parentContainer.recurrence.setValidationRecurrence(),u("target goal has been reached"))}},{key:"insertInParentContainer",value:function(){var e=this.parentContainer.domElement.querySelector(".".concat(this.parentContainer.contentClassName));document.head.appendChild(this.styleElement),e.appendChild(this.contentElement)}},{key:"refreshContent",value:function(){this.eventHub.emit("refreshContent")}},{key:"getValueFromScript",value:function(){var e=DATA.variableJavascript,t=this.eventHub;new Function("(function externalUpdater(update){".concat(e,"})(this.update)")).call({update:function(e){return t.emit("externalUpdate",e),e}})}},{key:"getValue",value:function(){var e=this,n=DATA,r=n.variableType,s=n.variableDisplayingValue,i=n.reachQuantity,o=n.variableUnitType,a={element:function(){return t.getValueFromElement()},javascript:function(){return new ae(e.externalValue)}}[r](),c={remaining:function(){return Math.max(0,i-a.numericValue)},accumulated:function(){return a.numericValue}}[s](),l={value:function(){return c},percent:function(){return Math.min(c,i)/i*100}}[o]();return{targetValue:a,calculatedValue:c,displayingValue:l}}},{key:"getContentElement",value:function(){var e=DATA,t=e.variableDisplayingValue,n=e.variableUnitType;this.textVariablesContent=DATA["textVariablesContent_".concat(n,"_").concat(t)];var r=document.createElement("div");return r.insertAdjacentHTML("beforeend",this.renderContent(DATA)),r}},{key:"addStyleRules",value:function(e){this.styleRules=this.styleRules.concat(e.map(function(e){var t=e.replace(/;/g," !important;");return t.indexOf("{")>1?"#".concat(this.parentContainer.widgetContainerId," .").concat(this.className," ").concat(t):t}.bind(this)))}},{key:"getStyleElement",value:function(){var t=DATA,n=t.textColor,r=t.textAlign,s=document.createElement("style");s.type="text/css",e()&&s.setAttribute("abtasty-script-added","true");var i=void 0!==n?"color: ".concat(n,";"):"",o=void 0!==r?"text-align: ".concat(r,";"):"";return this.addStyleRules(["p {","margin: 0;","white-space: pre-line;",i,o,"}",i&&i.length?["span {",i,"}"].join(""):""]),s.textContent=this.styleRules.join(" "),s}}])&&ce(n.prototype,r),s&&ce(n,s),t}();!function(){u("Widget launch");var e=(()=>{const{layout:e}=DATA;let t;switch(e){case"popin":t=new P;break;case"bannerTop":case"bannerBottom":t=new N;break;case"free":t=new k;break;default:t=new T}return t})(),t=new le({parentContainer:e});e.init(!0).then(function(n){n.response&&(t.insertInParentContainer(),t.start(DATA),e.show())})}()}();
|
1
|
+
!function(){"use strict";const e=()=>Object.prototype.hasOwnProperty.call(window,"ABTastyEditor"),t=()=>{let e;return window.ABTasty||window.ABTASTY_S?(window.ABTASTY_S?.USER?.accountIdentifier?.length?e=window.ABTASTY_S.USER.accountIdentifier:"function"==typeof window.ABTasty?.getAccountSettings?e=window.ABTasty.getAccountSettings().identifier:window.ABTasty?.accountSettings&&(e=window.ABTasty.accountSettings.identifier),e):e},n=()=>{const e=!!document.getElementById("ABTastyPreviewBar"),t=location.href.includes("ab_project=preview");return e||t},s=()=>!e()&&(n()||!!window.ABTasty.getTestsOnPage()[TEST_ID]),r=()=>window.ABTasty&&!0===window.ABTasty.consentReady,i="remove",o="rebuild",a="https://api-social-proof.abtasty.com/clients/",c=()=>{const{type:e}=DATA;return`${PACKAGE.replace("@abtasty/","")}${e?`_${e}`:""}`},l=()=>{const e=c();return`${e.charAt(0).toUpperCase()}${e.slice(1)}`.split("-").join(" ")},h=()=>`${PLUGIN_ID.split("-")[0]}_${TEST_ID}`,u=t=>{if((()=>{if(e()||n())return!1;const t=ABTasty.getTestsOnPage()[TEST_ID];return!!t&&Object.keys(t.targetings.qaParameters).length>0})()){const e=l();window.console.log(`%c${e} - QA Mode for campaign ${TEST_ID}\n${t}`,"background-color: rgba(0, 127, 145, 1); color: rgba(247, 247, 247, 1)")}},d=e=>{const t={promise:null,resolve:null,reject:null,name:e};return t.promise=new Promise((e,n)=>{t.resolve=e,t.reject=n}),t},g=(e,t)=>{const n=()=>{try{return document.querySelector(e)}catch(e){return null}};let s=n();const r=[document.body||document.documentElement,{childList:!0,subtree:!0,attributes:!0}],i=()=>a.disconnect(),o=()=>a.observe(...r),a=new MutationObserver(()=>(s=n(),s&&!i()&&t(s)));return s?setTimeout(()=>t(s),0):o(),{selector:e,clear:i,observe:o}};function m(e,t){return t(e)||!e.parentElement?e:m(e.parentElement,t)}const p=(e,t)=>[...document.querySelectorAll(t)].some(n=>n.isSameNode(e)||!!e.closest(t));class v{constructor(){this.targets=[],this.existingTargets=[],this.inViewportTargets=[],this.visibilityObserver=this.startVisibilityObserver(),this.mutationObserver=this.startMutationObserver(),this.mouseOverEvent=this.mouseOverHandler()}intersectionHandler(e){e.forEach(e=>{e.isIntersecting?(this.existingTargets.forEach(t=>{t.element.isSameNode(e.target)&&(this.inViewportTargets.push(t),this.mouseOverEvent.start())}),this.checkElements()):this.inViewportTargets=this.inViewportTargets.filter(t=>!t.element.isSameNode(e.target)||(this.mouseOverEvent.clear(),!1))})}startVisibilityObserver(){return new IntersectionObserver(this.intersectionHandler.bind(this),{root:null,rootMargin:"0px",threshold:0})}startMutationObserver(){const e=this.mutationObserver||new MutationObserver(this.checkElements.bind(this));return document.body&&e.observe(document.body,{attributes:!0,childList:!0,subtree:!0}),e}onMouseOver({target:e,path:t}){const n=this.inViewportTargets.find(({element:n,selector:s})=>{if(n.isSameNode(e))return!0;const r=[...e.querySelectorAll(s)];if(r.length&&r.includes(n))return!0;if(t.includes(n))return!0;const i=[...e.parentElement.children],o=i.findIndex(t=>t.isSameNode(e)),a=i.filter((e,t)=>t>o);if(a.length){if(a.includes(n))return!0;if(a.some(e=>[...e.querySelectorAll(s)].includes(n)))return!0}return!1});if(n&&this.isElementVisible(n.element)){const{selector:e,element:t,uniqueId:s}=n,r=this.targets.find(t=>t.selector===e&&t.uniqueId===s);r&&r.resolve(t),this.clear(e,s)}}mouseOverHandler(){const e=["mouseover",e=>setTimeout(()=>this.onMouseOver(e),50),!0];return{start:()=>document.addEventListener(...e),clear:()=>document.removeEventListener(...e)}}isElementVisible(e){return this.isElementTopmost(e)&&this.isElementOpaque(e)}isElementOpaque(e){return"HTML"===m(e,e=>"0"===window.getComputedStyle(e).opacity).nodeName}isElementTopmost(e){const t=e.getBoundingClientRect(),n=[[t.left,t.top],[t.right,t.top],[t.left,t.bottom],[t.right,t.bottom],[t.left+t.width/2,t.top],[t.left+t.width/2,t.bottom],[t.left,t.height/2],[t.right,t.height/2],[t.left+t.left/2,t.height/2]];let s=!1,r=0;for(;!s&&r<n.length;){const t=document.elementFromPoint(...n[r]);s=e===t||e.contains(t),r+=1}return s}checkElements(){this.targets.forEach(({selector:e,uniqueId:t})=>{const n=document.querySelector(e);n&&!this.existingTargets.find(n=>n.element.matches(e)&&n.uniqueId===t)&&(this.existingTargets.push({element:n,selector:e,uniqueId:t}),this.visibilityObserver.observe(n))}),this.existingTargets=this.existingTargets.filter(({selector:e,element:t})=>!!document.querySelector(e)||(t&&this.visibilityObserver.unobserve(t),!1)),this.inViewportTargets=this.inViewportTargets.filter(({selector:e,element:t,uniqueId:n})=>{if(t.matches(e)&&this.isElementVisible(t)){const s=this.targets.find(t=>t.selector===e&&t.uniqueId===n);return s&&s.resolve(t),this.clear(e,n),!1}return!0})}watch(e,t,n){this.targets.push({selector:e,resolve:t,uniqueId:n});const s=()=>{this.startMutationObserver(),this.checkElements()};document.body?s():g("body",s)}clear(e,t){[this.targets,this.existingTargets,this.inViewportTargets]=[this.targets,this.existingTargets,this.inViewportTargets].map(n=>n.filter(({selector:n,uniqueId:s})=>n!==e&&s!==t));const n=document.querySelector(e);n&&this.visibilityObserver.unobserve(n),0===this.targets.length&&this.mutationObserver.disconnect(),0===this.inViewportTargets.length&&this.mouseOverEvent.clear()}}class b{constructor({triggerEvent:e,triggerSelector:t,triggerDelay:n}){this.event=e,this.selector=t&&t.length?t:"body",this.delay=1e3*n,this.elementsSelectors=[],this.eventsListeners=[],this.timeouts=[],this.intervals=[],this.observers=[],this.promises=[],this.visibilityObservers=[],this.elementsWaiters=[]}async onElementVisible({promise:e,resolve:t}){const n=d(`${this.event}DomReady`);this.promises.push(n);const s=await this.onPageLoad(n),r=await async function(){let e;return e=await("IntersectionObserver"in window&&"IntersectionObserverEntry"in window&&"intersectionRatio"in window.IntersectionObserverEntry.prototype||new Promise((e,t)=>{const n=window.document.getElementsByTagName("script")[0],s=window.document.createElement("script");s.src="https://polyfill.io/v3/polyfill.min.js?flags=gated&features=IntersectionObserver",n.parentNode.insertBefore(s,n),s.onload=e,s.onerror=t})),e}(),i=new v;if(this.visibilityObservers.push(i),r&&s){const e=h();i.watch(this.selector,t,e)}return e}onPageLoad({promise:e,resolve:t}){const n=()=>"complete"===document.readyState;if(!n()){const s=["readystatechange",({isTrusted:e})=>e&&n()&&t(!0),{passive:!0}];return this.eventsListeners.push([document,...s]),document.addEventListener(...s),e}return t(!0),e}onClick({promise:e,resolve:t}){const n=document.createElement("style");n.type="text/css",n.id=`Click_${h()}`,n.innerHTML=`${this.selector} {\n\t\t\tcursor: pointer !important;\n\t\t\tpointer-events: all !important;\n\t\t}`,document.head.appendChild(n),this.elementsSelectors.push(`#${n.id}`);const s=["click",({isTrusted:e,target:n})=>e&&p(n,this.selector)&&t(!0),{passive:!0,capture:!0}];return this.eventsListeners.push([document,...s]),document.addEventListener(...s),e}onHover({promise:e,resolve:t}){const n=["mouseenter",({isTrusted:e,target:n})=>e&&p(n,this.selector)&&t(!0),{passive:!0,capture:!0}];return this.eventsListeners.push([document.documentElement,...n]),document.documentElement.addEventListener(...n),e}onExitIntent({promise:e,resolve:t}){const n=["mouseleave",({isTrusted:e,clientY:n})=>{e&&n<=0&&t(!0)},{passive:!0}],s=g("body",e=>{this.eventsListeners.push([e,...n]),e.addEventListener(...n),this.elementsWaiters=this.elementsWaiters.filter(e=>e!==s)});return this.elementsWaiters.push(s),e}onReengage({promise:e,resolve:t}){const n=this.delay;let s=n;const r=[({isTrusted:e})=>{e&&(s=n)},{passive:!0}];["click","mousemove","scroll","keypress"].forEach(e=>{this.eventsListeners.push([document,e,...r]),document.addEventListener(e,...r)});const i=setInterval(()=>{s<=0?t(!0):s-=100},100);return this.intervals.push(i),e}onCustomTrigger({promise:e,resolve:t}){const{triggerEventCustomScript:n}=DATA;return new Function(`return new Promise(async resolve => {${n}})`)().then(e=>e&&t(!0)),e}onScrollUp({promise:e,resolve:t}){let n=0;const s=["scroll",({isTrusted:e})=>{e&&(window.pageYOffset<n?t(!0):n=window.pageYOffset)},{passive:!0,capture:!0}];return this.eventsListeners.push([document,...s]),document.addEventListener(...s),e}onScrollPercentReached({promise:e,resolve:t}){const{triggerEventScrollPercent:n}=DATA,s=["scroll",({isTrusted:e})=>{if(!e)return;const s=(()=>{const{documentElement:e,body:t}=document,n=e.scrollTop||t.scrollTop,s=e.scrollHeight||t.scrollHeight;return Math.trunc(n/(s-e.clientHeight)*100,10)})();n<s&&t(!0)},{passive:!0,capture:!0}];return this.eventsListeners.push([document,...s]),document.addEventListener(...s),e}getSocialProofPurchases({promise:e,resolve:n}){const s=window.ABTastyProductKey,r=t(),{viewInterval:i,triggerSocialProofMinPurchases:o,spNoTrim:c}=DATA;return s||(u("Not able to find ABTastyProductKey, impossible to call the API."),n(!1)),s&&r?fetch(`${a}${r}/metrics/i?key=${s}${c?"&noTrim=true":""}`).then(e=>e.ok&&e.json()).then(e=>(e=>{if(void 0===i||void 0===o)return!1;const t=void 0!==e[i]&&e[i]>=o;return t||u(`Widget will not be shown, product has been purchased ${e[i]} times while ${o} are required`),t})(e)&&n(`${e[i]}`)).catch(()=>u("Failed to fetch datas from server.")):n(!1),e}getSocialProofPageViews({promise:e,resolve:n}){const{viewInterval:s,triggerSocialProofMinPageViews:r,spNoTrim:i}=DATA,o=encodeURIComponent(i?window.location.href.replace(window.location.origin,""):`${window.location.pathname}`),c=t();return o&&c?fetch(`${a}${c}/metrics/pv?key=${o}${i?"&noTrim=true":""}`).then(e=>e.ok&&e.json()).then(e=>(e=>{if(void 0===s||void 0===r)return!1;const t=void 0!==e[s]&&e[s]>=r;return t||u(`Widget will not be shown, page has been seen ${e[s]} times while ${r} are required`),t})(e)&&n(`${e[s]}`)).catch(()=>u("Failed to fetch datas from server.")):n(!1),e}onConsent({promise:e,resolve:t}){if(!r()){const n=["abtasty_consentValid",()=>t(!0)];return this.eventsListeners.push(n),window.addEventListener(...n),e}return t(!0),e}onTrackingSent({promise:e,resolve:t}){const{triggerEventTrackingSent:n}=DATA;let s=localStorage.getItem("ABTastyData");const r=()=>JSON.parse(s).ActionTracking.find(({name:e})=>e===n),i=["storage",()=>{s=localStorage.getItem("ABTastyData"),r()&&t(!0)},{passive:!0,capture:!0}];return s&&r()?t(!0):(()=>{this.eventsListeners.push([window,...i]),window.addEventListener(...i)})(),e}onMinPagesViewed({promise:e,resolve:t}){const{triggerEventMinPagesViewed:n}=DATA;let s=localStorage.getItem("ABTastyData");const r=()=>n<=(s?JSON.parse(s).VisitedPages.length:0),i=["storage",()=>{s=localStorage.getItem("ABTastyData"),r()&&t(!0)},{passive:!0,capture:!0}];return s&&r()?t(!0):(()=>{this.eventsListeners.push([window,...i]),window.addEventListener(...i)})(),e}onRageClick({promise:e,resolve:t}){const{triggerEventRageClickQuantity:n,triggerEventRageClickDelay:s}=DATA;let r=0,i=!1;const o=["click",({isTrusted:e})=>{e&&(r+=1,r>=n&&t(!0),i||(i=!0,setTimeout(()=>{r=0,i=!1},s)))},{passive:!0,capture:!0}];return this.eventsListeners.push([document,...o]),document.addEventListener(...o),e}clear(){if(this.elementsSelectors.length&&(this.elementsSelectors.forEach(e=>{document.querySelector(e)&&document.querySelector(e).remove()}),this.elementsSelectors=[]),this.eventsListeners.length&&(this.eventsListeners.forEach(e=>{const[t,...n]=e;t&&n.length>1&&t.removeEventListener(...n)}),this.eventsListeners=[]),this.timeouts.length&&(this.timeouts.forEach(e=>clearTimeout(e)),this.timeouts=[]),this.intervals.length&&(this.intervals.forEach(e=>clearInterval(e)),this.intervals=[]),this.observers.length&&(this.observers.forEach(e=>e.disconnect()),this.observers=[]),this.visibilityObservers.length){const e=h();this.visibilityObservers.forEach(t=>t.clear(this.selector,e)),this.visibilityObservers=[]}return this.promises.length&&(this.promises.forEach(e=>e.resolve(!1)),this.promises=[]),this.elementsWaiters.length&&(this.elementsWaiters.forEach(e=>e.clear()),this.elementsWaiters=[]),this}async isTriggered(){this.clear();const e=d(this.event);this.promises.push(e);const t={consent:()=>this.onConsent(e),direct:()=>!0,pageLoad:()=>this.onPageLoad(e),click:()=>this.onClick(e),exitIntent:()=>this.onExitIntent(e),reengage:()=>this.onReengage(e),elementVisible:()=>this.onElementVisible(e),script:()=>this.onCustomTrigger(e),hover:()=>this.onHover(e),scrollUp:()=>this.onScrollUp(e),scrollPercent:()=>this.onScrollPercentReached(e),rageClick:()=>this.onRageClick(e),minPagesViewed:()=>this.onMinPagesViewed(e),trackingSent:()=>this.onTrackingSent(e),socialProofPurchases:()=>this.getSocialProofPurchases(e),socialProofPageViews:()=>this.getSocialProofPageViews(e)},n=!Object.prototype.hasOwnProperty.call(t,this.event)||await t[this.event]();return this.clear(),"reengage"!==this.event&&this.delay?n&&await(async()=>{const e=d(`${this.event}Delay`);return this.promises.push(e),setTimeout(()=>{e.resolve(!0),this.clear()},this.delay),e.promise})():n}}const f="closing",y="validation",w="ABTastyWidgets",$="ABTastyWidgetsTemporary";class C{constructor({displayRecurrence:e,closingRecurrence:t,validationRecurrence:n},s){this.displayRecurrence=parseFloat(e),this.closingRecurrence=parseFloat(t),this.validationRecurrence=parseFloat(n),this.onSetCallback=s,this.widgetName=c(),this.uniqueId=h(),this.recurrenceKey=`${this.widgetName}_${this.uniqueId}`,this.isListeningStorageEvent=this.listenStorageEvent(),this.pendingRecurrence=!1,this.pendingRecurrenceValue={}}onStorage({key:e}){const t=localStorage.getItem($),n=sessionStorage.getItem(w);"ABTastyData"===e&&!t&&n&&localStorage.setItem($,n)}listenStorageEvent(){return this.isListeningStorageEvent||window.addEventListener("storage",this.onStorage.bind(this)),!0}getGivenRecurrenceStorageParsed(e){try{const t=e.getItem(w);return JSON.parse(t)}catch(t){return e.removeItem(w),!1}}getSessionRecurrenceStorageParsed(){return this.getGivenRecurrenceStorageParsed(window.sessionStorage)}getLocalRecurrenceStorageParsed(){return this.getGivenRecurrenceStorageParsed(window.localStorage)}removeGivenStorage(e,t){const{[this.recurrenceKey]:n,...s}=t;return Object.entries(s).length?(e.setItem(w,JSON.stringify(s)),s):(e.removeItem(w),!1)}removeSessionRecurrenceStorage(){const e=this.getSessionRecurrenceStorageParsed();return!!e&&this.removeGivenStorage(window.sessionStorage,e)}removeLocalRecurrenceStorage(){const e=this.getLocalRecurrenceStorageParsed();return!!e&&this.removeGivenStorage(window.localStorage,e)}getSessionRecurrence(){const e=this.getSessionRecurrenceStorageParsed();return!!e&&e[this.recurrenceKey]}getLocalRecurrence(){const e=this.getLocalRecurrenceStorageParsed();return!!e&&e[this.recurrenceKey]}getCurrentRecurrence(){if(this.pendingRecurrence)return this.pendingRecurrenceValue;const e=this.getSessionRecurrence(),t=this.getLocalRecurrence();return e||t||{type:!1}}isOver(){const e=localStorage.getItem($),t=!(!e||!e.includes(this.recurrenceKey))||this.getSessionRecurrence();e&&(sessionStorage.setItem(w,e),localStorage.removeItem($));const n=this.getLocalRecurrence(),s=(n?parseFloat(n.stamp):0)<(new Date).getTime();return s&&this.removeLocalRecurrenceStorage(),!this.pendingRecurrence&&s&&!this.getLocalRecurrence()&&!t}setRecurrence(e,t){0!==e&&(window.removeEventListener("storage",this.onStorage.bind(this)),this.isListeningStorageEvent=!1);const s=this.getTypeOfStorage(e);if(n()||!s&&"object"!=typeof s)return!1;const{storageString:i,storageMethod:o}=s,a=this.getStamp(e),c={type:t,stamp:a},{type:l}=this.getCurrentRecurrence(),h=async()=>{if(!r()){this.pendingRecurrence=!0,this.pendingRecurrenceValue=c;const e=new b({triggerEvent:"consent"});await e.isTriggered(),this.pendingRecurrence=!1,this.pendingRecurrenceValue={}}const e=this.getSessionRecurrence(),t=this.getLocalRecurrence();let n;"session"===i?e?n=this.removeSessionRecurrenceStorage():(this.removeLocalRecurrenceStorage(),n=this.getSessionRecurrenceStorageParsed()):"local"===i&&(t?n=this.removeLocalRecurrenceStorage():(this.removeSessionRecurrenceStorage(),n=this.getLocalRecurrenceStorageParsed()));const s=n?{[this.recurrenceKey]:c,...n}:{[this.recurrenceKey]:c};o.setItem(w,JSON.stringify(s)),this.onSetCallback&&"function"==typeof this.onSetCallback&&this.onSetCallback()};if(!o)return!1;if(l&&t!==y)if(t===f&&l!==y)h();else{if("display"!==t||l===y||l===f)return!1;h()}else h();return a}setDisplayRecurrence(){this.setRecurrence(this.displayRecurrence,"display")}setClosingRecurrence(){this.setRecurrence(this.closingRecurrence,"closing")}setValidationRecurrence(){this.setRecurrence(this.validationRecurrence,"validation")}getStamp(e){return(new Date).getTime()+864e5*e}getTypeOfStorage(e){return!(isNaN(e)||e<0||0!==e&&!e)&&(e>0?{storageString:"local",storageMethod:window.localStorage}:0===e&&{storageString:"session",storageMethod:window.sessionStorage})}}class S{constructor(e,t,n){this.recurrence=e,this.isWidgetApplied=t,this.callback=n,this.observer=new MutationObserver(this.observerHandler.bind(this)),this.eventListenerParams=["abtasty_resetActionTracking",this.eventHandler.bind(this),{passive:!0}],this.elementsWaiters=[]}recurrenceIsDone(){return!this.recurrence||this.recurrence.isOver()}decisionHandler(e){const t=s(),{type:n}=this.recurrence?this.recurrence.getCurrentRecurrence():{type:!1};let r;const a=this.isWidgetApplied(),c=(()=>{const t=this.recurrenceIsDone();return e&&"display"===n||t})();return!a&&t&&c?r=o:(a&&(!t||!c)||!a&&!t)&&(r=i),"string"==typeof r&&(this.clearWatcher(),this.callback(r,e),this.watch()),this}eventHandler(){let e=s();return[250,500].forEach(t=>{setTimeout(()=>{const n=s();return 500===t&&n===e?this:(e=n,this.decisionHandler(!1))},t)}),this}observerHandler(e){return e.some(e=>["removedNodes","addedNodes"].some(t=>e[t]&&e[t].length))?this.decisionHandler(!0):this}watch(){if(e())return this;this.clearWatcher(),document.addEventListener(...this.eventListenerParams);const t=()=>{const e=[document.body,{childList:!0,subtree:!0}];this.observer.observe(...e)};return document.body?t():(()=>{const e=g("body",()=>{t(),this.elementsWaiters=this.elementsWaiters.filter(t=>t!==e)});this.elementsWaiters.push(e)})(),this}clearWatcher(){return document.removeEventListener(...this.eventListenerParams),this.elementsWaiters.length&&(this.elementsWaiters.forEach(e=>e.clear()),this.elementsWaiters=[]),this.observer.disconnect(),this}}const T=/.+\/([^.]+)\.(otf|ttf)$/;class E{constructor(){this.children=void 0,this.uniqueId=h(),this.widgetName=c(),this.prettyName=l(),this.recurrenceParams=(()=>{const{displayRecurrence:t,closingRecurrence:n,validationRecurrence:s}=DATA;if(e()||!t&&!n&&!s)return!1;const r={everytime:()=>-1,session:()=>0,once:()=>395,day:e=>DATA[`${e}_day`],week:e=>7*DATA[`${e}_week`],month:e=>30.5*DATA[`${e}_month`]},i={};return t&&(i.displayRecurrence=r[t]("displayRecurrence")),n&&(i.closingRecurrence=r[n]("closingRecurrence")),s&&(i.validationRecurrence=r[s]("validationRecurrence")),i})(),this.triggerParams=(()=>{let{triggerEvent:t}=DATA;const{triggerEventClick:n,triggerEventHover:s,triggerEventReengageDelay:r,socialProofContentType:i,triggerEventElementVisible:o,triggerEventDelay:a}=DATA;if(e()||!t&&!i)return!1;const c={click:()=>n,hover:()=>s,elementVisible:()=>o},l=Object.prototype.hasOwnProperty.call(c,t)?c[t]():"body",h="reengage"===t?r:a;return i&&(t=1===i?"socialProofPurchases":"socialProofPageViews"),{triggerEvent:t,triggerSelector:l,triggerDelay:h}})(),this.recurrence=!!this.recurrenceParams&&new C(this.recurrenceParams,this.clearGivenClearables.bind(this)),this.trigger=!!this.triggerParams&&new b(this.triggerParams),this.pageWatcher=new S(this.recurrence,this.isWidgetApplied.bind(this),this.onPageChange.bind(this)),this.hasOncePerPageTrigger=(()=>{const{isOncePerPageTrigger:e,triggerEvent:t}=DATA;return!t||!["click","hover","scrollUp","script"].includes(t)||e})(),this.basicClassName=`ab_widget_container_${this.widgetName}`,this.widgetContainerId=`${this.basicClassName}_${this.uniqueId}`,this.contentClassName=`${this.basicClassName}_content`,this.overlayClassName=`${this.basicClassName}_overlay`,this.closeButtonClassName=`${this.basicClassName}_close_button`,this.hideClassName=`ab_hide_${this.uniqueId}`,this.domElement=this.getDom(),this.hasBeenShown=!1,this.closedByUser=!1,this.eventsListeners=[],this.timeouts=[],this.intervals=[],this.observers=[],this.promises=[],this.elementsWaiters=[]}clearGivenClearables(){this.eventsListeners.length&&(this.eventsListeners.forEach(e=>document.removeEventListener(...e)),this.eventsListeners=[]),this.timeouts.length&&(this.timeouts.forEach(e=>clearTimeout(e)),this.timeouts=[]),this.intervals.length&&(this.intervals.forEach(e=>clearInterval(e)),this.intervals=[]),this.observers.length&&(this.observers.forEach(e=>e.disconnect()),this.observers=[]),this.promises.length&&(this.promises.forEach(e=>e.resolve(!1)),this.promises=[]),this.elementsWaiters.length&&(this.elementsWaiters.forEach(e=>e.clear()),this.elementsWaiters=[])}isWidgetApplied(){return this.domElement&&this.domElement.isConnected}removeOldDomElement(){const e=document.getElementById(this.widgetContainerId);return e&&e.remove(),this}async insert(){if(this.isWidgetApplied())return!1;const e=new Promise(e=>{const t=g("head",t=>{this.elementsWaiters=this.elementsWaiters.filter(({selector:e})=>"head"!==e),e(t.appendChild(this.styleElement))});this.elementsWaiters.push(t)}),t=new Promise(e=>{const{elementReferrer:t="body",referrerInsertType:n="beforeend"}="free"===DATA.layout?DATA:{},s=g(t,s=>{this.elementsWaiters=this.elementsWaiters.filter(e=>e.selector!==t),this.removeOldDomElement(),e(s.insertAdjacentElement(n,this.domElement))});this.elementsWaiters.push(s)});return Promise.all([t,e]).then(()=>this)}remove(){return this.pageWatcher.clearWatcher(),[this.domElement,this.styleElement].forEach(e=>e&&e.isConnected&&e.remove()),this.hasOncePerPageTrigger?this.pageWatcher.watch():e()||this.init().then(({response:e})=>e?this.show():this),this}show(){return e()||this.hasBeenShown&&this.hasOncePerPageTrigger||window.ABTastyEvent(`${this.prettyName} displayed`,null,TEST_ID),this.closedByUser=!1,setTimeout(()=>this.domElement.classList.remove(this.hideClassName),50),this.recurrence&&this.recurrence.setDisplayRecurrence(),this.hasBeenShown=!0,this.pageWatcher.watch(),this}hide(){return!e()&&this.hasBeenShown&&window.ABTastyEvent(`${this.prettyName} closed`,null,TEST_ID),this.closedByUser=!0,this.domElement.classList.add(this.hideClassName),this}async init(t){const n=e(),r=s(),i=this.trigger&&this.trigger.promises.length,o=!this.recurrence||this.recurrence.isOver();if(!n&&!r||i||!o)return!1;this.pageWatcher.watch();const a=n||!this.trigger||this.trigger&&await this.trigger.isTriggered();return!!a&&(await this.insert(),this.addCloseEvent(),n||t||this.hasBeenShown||void 0===this.children||"function"!=typeof this.children.refreshContent||this.children.refreshContent(a),{container:this,response:a})}onPageChange(e,t){const n=()=>this.init().then(({response:e})=>e&&this.show());t||(this.hasBeenShown=!1);const s=this.isWidgetApplied(),r={[i]:()=>{s?this.remove():(this.trigger&&this.trigger.clear(),this.pageWatcher.watch())},[o]:()=>{this.hasBeenShown?this.closedByUser?this.pageWatcher.watch():s||this.insert().then(e=>e.show()).catch(this.pageWatcher.watch):n()}};"function"==typeof r[e]&&r[e]()}addCloseEvent(...t){const{closeButton:n,overlay:s,overlayClickable:r,layout:i,animationDuration:o=1e3}=DATA,a=[];if(void 0!==s&&!0!==s||!0!==r||"popin"!==i||a.push(`.${this.overlayClassName}`),void 0!==n&&n&&a.push(`.${this.closeButtonClassName}`),!a.length)return this;const c=this.domElement.querySelectorAll(a.join(", "));return c.length?(t.push(...c),t.forEach(t=>{e()&&(t.dataset.abtastyActionnable="true"),t.addEventListener("click",t=>{(t=>{e()||(t.preventDefault(),t.stopPropagation(),t.stopImmediatePropagation())})(t),this.recurrence&&this.recurrence.setClosingRecurrence(),this.hide(),setTimeout(()=>this.remove(),1.05*o)},{once:!0,capture:!0})}),this):this}getDom(){const{closeButton:e,layout:t,overlay:n=!0}=DATA,s=document.createElement("div");return s.className=`${this.basicClassName} ${this.hideClassName}`,s.id=this.widgetContainerId,s.innerHTML=`\n\t\t\t${"popin"===t&&!0===n?`<div class="${this.overlayClassName}"></div>`:""}\n\t\t\t<div class="${this.contentClassName}">\n\t\t\t${e?`<button class="${this.closeButtonClassName}"><svg viewBox="0 0 16 16">\n\t<defs><path id="prefix__a" d="M12 4.991L11.009 4 8 7.009 4.991 4 4 4.991 7.009 8 4 11.009 4.991 12 8 8.991 11.009 12 12 11.009 8.991 8z"></path></defs>\n\t<g><use xlink:href="#prefix__a"></use></g>\n</svg></button>`:""}\n\t\t\t</div>`,s}loadFont(e,t){if(!e||"inherit"===e)return;const n=document.createElement("style"),s=t.match(T)?t.match(T)[1]:"";n.innerHTML=`@font-face { font-family: '${e}_${s}'; src: url('${t}');}`,document.head.appendChild(n)}getStyleTag(t="",n=DATA){const{noStyles:s,layout:r}=n,{backgroundColor:i,isBackgroundImage:o,backgroundImage:a,backgroundSize:c,backgroundPosition:l,backgroundRepeat:h,borderColor:u,borderRadius:d,borderWidth:g,textColor:m,textAlign:p,fontName:v,fontStyle:b,fontSize:f,isTitle:y,titleTextAlign:w,titleTextColor:$,titleFontName:C,titleFontStyle:S,titleFontSize:E,overlay:A,overlayColor:x,dropShadow:_,dropShadowColor:k,dropShadowBlur:B,containerMargin:I,containerPadding:R,closeButton:N,closeButtonPosition:P,closeButtonSize:L,closeButtonBorderRadius:O,closeButtonBorderWidth:V,closeButtonBorderColor:D,closeButtonColor:W,closeButtonBackgroundColor:H,buttonsAlign:j,buttonsBorderWidth:M,buttonsBorderColor:q,buttonsBorderRadius:U,buttonsBackgroundColor:F,buttonsTextColor:z,buttonsFontName:G,buttonsFontStyle:K,buttonsFontSize:Q,secondLinkBorderWidth:Y,secondLinkBorderColor:J,secondLinkBorderRadius:X,secondLinkBackgroundColor:Z,secondLinkTextColor:ee,secondLinkFontName:te,secondLinkFontStyle:ne,secondLinkFontSize:se,animation:re,animationDuration:ie,animationBehaviour:oe,animationSlideDirection:ae}=s?{}:n,ce=document.createElement("style");ce.type="text/css",e()&&ce.setAttribute("abtasty-script-added","true"),this.loadFont(v,b),this.loadFont(C,S),this.loadFont(G,K),this.loadFont(te,ne);const le=`background: ${["string"==typeof i?i:"rgba(255, 255, 255, 1)",o&&"string"==typeof a&&a.length?`url(${a})`:"",o&&"string"==typeof l&&"100% 100%"!==c?l:"0 0",o&&"string"==typeof c?`/ ${c}`:"/ auto",o&&h&&!["cover","100% 100%"].includes(c)?"repeat":"no-repeat"].join(" ").trim()};`,he="number"==typeof g&&g>0,ue=`border: ${[he?`${g}px`:"unset",he?"solid":"",he&&"string"==typeof u&&u.length?u:""].join(" ").trim()};`,de=void 0!==d?`border-radius: ${d}px;`:"",ge=void 0!==m?`color: ${m}; fill: ${m}; -webkit-text-fill-color: ${m};`:"",me=void 0!==p?`text-align: ${p};`:"",pe=v&&"inherit"!==v?`font-family:${v}_${b.match(T)?b.match(T)[1]:""};`:b||"",ve=f?`font-size: ${f}px;`:"",be=void 0!==_&&_?`box-shadow: 0 5px ${B}px 0 ${k};`:"",fe=I instanceof Array&&1===I.length&&I[0],ye=fe?`margin: ${fe.top}px ${fe.right}px ${fe.bottom}px ${fe.left}px;`:"",we=fe?`margin: calc(${fe.top}px * 0.5) calc(${fe.right}px * 0.5) calc(${fe.bottom}px * 0.5) calc(${fe.left}px * 0.5);`:"",$e=R instanceof Array&&1===R.length&&R[0],Ce=$e?`padding: ${$e.top}px ${$e.right}px ${$e.bottom}px ${$e.left}px;`:"",Se=$e?`padding: calc(${$e.top}px * 0.5) calc(${$e.right}px * 0.5) calc(${$e.bottom}px * 0.5) calc(${$e.left}px * 0.5);`:"",Te=void 0!==M&&M?`border-width: ${M}px; border-style: solid;`:"",Ee=[q,M].every(e=>void 0!==e)&&M?`border-color: ${q};`:"",Ae=void 0!==U?`border-radius: ${U}px;`:"",xe=void 0!==F?`background-color: ${F};`:"",_e=void 0!==z?`color: ${z}; fill: ${z}; -webkit-text-fill-color: ${z};`:"",ke=G&&"inherit"!==G?`font-family:${G}_${K.match(T)?K.match(T)[1]:""};`:K||"",Be=Q?`font-size: ${Q}px;`:"",Ie=void 0!==Y&&Y?`border-width: ${Y}px; border-style: solid;`:"",Re=[J,Y].every(e=>void 0!==e)&&Y?`border-color: ${J};`:"",Ne=void 0!==X?`border-radius: ${X}px;`:"",Pe=void 0!==Z?`background-color: ${Z};`:"",Le=void 0!==ee?`color: ${ee}; fill: ${ee}; -webkit-text-fill-color: ${ee};`:"",Oe=te&&"inherit"!==te?`font-family:${te}_${ne.match(T)?ne.match(T)[1]:""};`:ne||"",Ve=se?`font-size: ${se}px;`:"",De="popin"!==r||void 0!==A&&!0!==A?"":[`#${this.widgetContainerId} .${this.overlayClassName} {`,`background-color: ${void 0!==x?x:"rgba(0, 0, 0, 0.6)"};`,"}"].join(""),We="number"==typeof L?L:16,He=We/2,je=s||void 0!==N&&N?[`#${this.widgetContainerId} .${this.contentClassName} .${this.closeButtonClassName} {`,"position: absolute;",("out"===P?`bottom: calc(100% + ${He}px)`:`top: ${He}px`)+";",`right: ${He}px;`,"width: auto;","height: auto;","background: none;","border: none;","cursor: pointer;","outline: none;","padding: 0;","margin: 0;","line-height: 0;","z-index: 9;","number"==typeof O?`border-radius: ${O}px;`:"","number"==typeof V&&V>0?`border: ${V}px solid ${void 0!==D?D:"rgba(57, 57, 57, 1)"};`:"","string"==typeof H?`background-color: ${H};`:"","}",`#${this.widgetContainerId} .${this.contentClassName} .${this.closeButtonClassName} svg {`,"pointer-events: none;",`width: ${We}px;`,`height: ${We}px;`,"string"==typeof W?`fill: ${W};`:"","}"].join(""):"",Me=y&&"string"==typeof $?[`#${this.widgetContainerId} .${this.contentClassName} > * h1, `,`#${this.widgetContainerId} .${this.contentClassName} > * h2, `,`#${this.widgetContainerId} .${this.contentClassName} > * h3, `,`#${this.widgetContainerId} .${this.contentClassName} > * h4, `,`#${this.widgetContainerId} .${this.contentClassName} > * h5, `,`#${this.widgetContainerId} .${this.contentClassName} > * h6 {`,`color: ${$}; fill: ${$}; -webkit-text-fill-color: ${$};`,void 0!==w?`text-align: ${w};`:"",C&&"inherit"!==C?`font-family:${C}_${S.match(T)?S.match(T)[1]:""};`:S||"",E?`font-size: ${E}px;`:"","}"].join(""):"";let qe="";if("string"==typeof re){const t=(ie/1e3).toFixed(2),n=["top","bottom"].includes(ae),s=Number(n),r=[(["top","left"].includes(ae)?"-":"")+"100vmax",this.translateValues?this.translateValues[s]:"0"];n&&r.reverse(),qe={none:[],fade:[`#${this.widgetContainerId} {`,`transition: opacity ${t}s ${oe};`,"}"],slide:[`.${this.hideClassName} .${this.overlayClassName} {`,"opacity: 0 !important;","}",`#${this.widgetContainerId} .${this.overlayClassName} {`,`transition: opacity ${t}s ${oe};`,"}",`.${this.hideClassName} .${this.contentClassName} {`,`transform: translate(${r.join(", ")}) !important;`,"}",`#${this.widgetContainerId} .${this.contentClassName} {`,`transition: transform ${t}s ${oe};`,"}"]}[e()&&!ABTASTY_S.WIDGETS.animationChanged?"none":re].join("")}return ce.textContent=[`.${this.hideClassName} {`,"opacity: 0 !important;","pointer-events: none;","}",`#${this.widgetContainerId} {`,"opacity: 1;","}",`#${this.widgetContainerId} .${this.contentClassName} {`,le,de,ue,ge,me,be,ye,pe,ve,"}",`#${this.widgetContainerId} .${this.contentClassName} p {`,ge,me,pe,ve,"}",`#${this.widgetContainerId} .${this.contentClassName} > * {`,"display: block;","line-height: 1;","text-indent: unset;",Ce,pe,ve,"}",`#${this.widgetContainerId} .${this.contentClassName} > * a, `,`#${this.widgetContainerId} .${this.contentClassName} > * button {`,"box-sizing: border-box;","display: inline-block;",Te,Ee,Ae,xe,_e,ke,Be,"}",`#${this.widgetContainerId} .${this.contentClassName} > * a *, `,`#${this.widgetContainerId} .${this.contentClassName} > * button * {`,_e,ke,Be,"}",`#${this.widgetContainerId} .${this.contentClassName} > * a:nth-child(2), `,`#${this.widgetContainerId} .${this.contentClassName} > * button:nth-child(2) {`,`margin-${"fill"===j?"top":"left"}: 8px;`,Ie,Re,Ne,Pe,Le,Oe,Ve,"}",`#${this.widgetContainerId} .${this.contentClassName} > * a:nth-child(2) *, `,`#${this.widgetContainerId} .${this.contentClassName} > * button:nth-child(2) * {`,Le,Oe,Ve,"}","@media screen and (max-width: 579px) {",`#${this.widgetContainerId} .${this.contentClassName} {`,we,"}",`#${this.widgetContainerId} .${this.contentClassName} > * {`,Se,"}","}",De,je,Me,qe,`${t}`].join(""),ce}}const A=["top: 0;","top: 50%;","bottom: 0;"],x=["left: 0;","left: 50%;","right: 0;"],_=e=>1===e?"-50%":0,k=()=>{if(Array.isArray(DATA.popinPosition)){const{popinPosition:[{x:e,y:t}]}=DATA,n=`translate(${_(t)}, ${_(e)});`;return`${A[e]}${x[t]}transform: ${n}`}return"left: 50%;top: 50%;transform: translate(-50%, -50%);"},B=()=>"autoWidth"in DATA&&!0===DATA.autoWidth,I=()=>{if(B())return"width: auto;height: auto;";const{popinPercentWidth:e,popinPixelsWidth:t,widthUnit:n,autoHeight:s,popinPercentHeight:r,popinPixelsHeight:i,heightUnit:o}=DATA;return`width: ${"px"===n?t:e}${n};height: ${s?"auto":`${"px"===o?i:r}${o}`};`};class R extends E{constructor(){super(),this.translateValues=Object.values(DATA.popinPosition[0]).map(e=>_(e)),this.stringStyles=this.getStyles(),this.styleElement=this.getStyleTag(this.stringStyles)}getStyles(){const{zindex:e,zindexCustom:t,overlay:n}=DATA;return[`#${this.widgetContainerId} {`,"position: fixed;","top: 0;","left: 0;","width: 100%;","height: 100%;",`z-index: ${"custom"===e?t:e};`,"background: none;","pointer-events: "+(!1===n?"none":"all"),"}",`#${this.widgetContainerId} .${this.overlayClassName} {`,"position: absolute;","z-index: -1;","top: 0;","left: 0;","width: 100%;","height: 100%;","}",`#${this.widgetContainerId} .${this.contentClassName} {`,"position: absolute;",k(),I(),"pointer-events: all","}",`${B()?"":[`#${this.widgetContainerId} .${this.contentClassName} > div {`,"height: 100%;","overflow: auto;","box-sizing: border-box;","}"].join("")}`,`${B()?"":["@media screen and (max-width: 579px) {",`#${this.widgetContainerId} .${this.contentClassName} {`,"max-width: 94vw;","}","}"].join("")}`].join("")}}class N extends E{constructor(){super(),this.position="string"==typeof DATA.layout&&"bannerTop"===DATA.layout?"top":"bottom",this.stringStyles=this.getStyles(),this.styleElement=this.getStyleTag(this.stringStyles)}getStyles(){const{zindex:e,zindexCustom:t}=DATA;return[`#${this.widgetContainerId} {`,"position: fixed;",`${this.position}: 0;`,"left: 0;","width: 100%;","height: auto;",`z-index: ${"custom"===e?t:e};`,"background: none;","}",`#${this.widgetContainerId} .${this.contentClassName} {`,"position: relative;","}"].join("")}}class P extends E{constructor(){super(),this.stringStyles=this.getStyles(),this.styleElement=this.getStyleTag(this.stringStyles)}getStyles(){return[`#${this.widgetContainerId} {`,"width: auto;","height: auto;","margin: 0;","padding: 0;","background: none;","}",`#${this.widgetContainerId} .${this.contentClassName} {`,"position: relative;","}"].join("")}}const L={button:"button",buttonClose:"buttonClose",widget:"widget",widgetClose:"widgetClose"},O=[{label:"widget_promotionalBanner_content_radio_linkType_option_button",value:L.button},{label:"widget_promotionalBanner_content_radio_linkType_option_buttonClose",value:L.buttonClose},{label:"widget_promotionalBanner_content_radio_linkType_option_wholeBannerClickable",value:L.widget},{label:"widget_promotionalBanner_content_radio_linkType_option_wholeBannerClickableClose",value:L.widgetClose},{label:"widget_promotionalBanner_content_radio_linkType_option_none",value:!1}],V=(L.button,e=>e&&[L.button,L.buttonClose].includes(e));var D,W,H,j;function M(e,t){return t||(t=e.slice(0)),Object.freeze(Object.defineProperties(e,{raw:{value:Object.freeze(t)}}))}function q(e){for(var t=arguments.length,n=new Array(t>1?t-1:0),s=1;s<t;s++)n[s-1]=arguments[s];return e.reduce(function(e,t,s){return e+n[s-1]+t})}function U(e){return Math.round(100*e)/100}function F(e){var t=this,n=e.reachQuantity,s=e.colorBlindMode,r=e.progressBarStripesColor,i=e.progressBarBackgroundColor,o=e.progressBarColor,a=e.progressBarBorderRadius,c=e.progressBarHeight;function l(e){return"translateX(".concat(Math.min(e,n)/n*100-100,"%)")}this.addStyleRules([".abtasty_progress_pbar {\n background-color: ".concat(i,";\n border-radius: ").concat(a,"px;\n overflow: hidden;\n }"),".abtasty_progress_indicator {\n height: ".concat(c,"px;\n background-color: ").concat(o,";\n transition: transform 0.5s ease-out;\n transform: translateX(-100%);\n border-top-right-radius: ").concat(a,"px;\n border-bottom-right-radius: ").concat(a,"px;\n }"),s?"\n .abtasty_progress_indicator {\n background-image: repeating-linear-gradient(-45deg,\n transparent,\n transparent 7px,\n ".concat(r," 6px,\n ").concat(r," 14px);\n }"):""]);var h=this.parentContainer.domElement.getElementsByClassName("abtasty_progress_indicator");return this.eventHub.on("valueUpdated",function(){Array.from(h).forEach(function(e){e.style.setProperty("transform",l(t.value.targetValue.numericValue),"important")})}),q(D||(D=M(['\n\t\t<div class="abtasty_progress_pbar">\n\t\t\t<div\n\t\t\t\tclass="abtasty_progress_indicator"\n\t\t\t\tstyle="transform: ',' !important;"\n\t\t\t></div>\n\t\t</div>\n\t'])),l(this.value.targetValue.numericValue))}function z(e){var t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:this.textVariablesContent;return t.replace("!variable!",'<span class="abtasty_progress_value">'.concat(this.value.targetValue.formatNumber(U(this.value.displayingValue)),"</span>")).replace("!quantityToReach!",'<span class="abtasty_progress_max">'.concat(this.value.targetValue.formatNumber(e),"</span>"))}function G(e){var t=this,n=e.reachQuantity,s=e.textLabelContent,r=e.subLayout,i=e.textColor,o=e.textAlign,a=e.fontSize;this.addStyleRules([".abtasty_progress_definition {\n font-size: ".concat(a,"px;\n color: ").concat(i,";\n margin: 7px 0 0 0;\n text-align: ").concat(o,";\n word-break: break-word;\n }"),".abtasty_progress_label {\n margin: 0;\n font-family: inherit;\n color: inherit;\n font-size: inherit;\n word-break: break-word;\n }",".abtasty_progress_value {\n margin: 0;\n font-family: inherit;\n color: inherit;\n font-size: inherit;\n word-break: initial;\n }"]);var c=this.parentContainer.domElement.getElementsByClassName("abtasty_progress_value");return this.eventHub.on("valueUpdated",function(){Array.from(c).forEach(function(e){e.textContent=t.value.targetValue.formatNumber(U(t.value.displayingValue))})}),{customTextVariables:function(){return q(W||(W=M(['\n\t\t\t\t<p class="abtasty_progress_definition">',"</p>\n\t\t\t"])),z.call(t,n))},customLabelVariables:function(){return t.addStyleRules([".abtasty_progress_definition {\n display: flex;\n justify-content: space-between;\n line-height: 1;\n }",".abtasty_progress_label {\n flex-basis: 66%;\n text-align: left;\n line-height: 1;\n }",".abtasty_progress_value {\n line-height: 1;\n }"]),q(H||(H=M(['\n\t\t\t\t<dl class="abtasty_progress_definition">\n\t\t\t\t\t<dt class="abtasty_progress_label">','</dt>\n\t\t\t\t\t<dd class="abtasty_progress_value">',"</dd>\n\t\t\t\t</dl>\n\t\t\t"])),s,t.value.targetValue.formatNumber(U(t.value.displayingValue)))},progressBarOnly:function(){return""}}[r]()}function K(e){var t=e.reachQuantity,n=e.subLayout,s=e.textLabelContent,r=e.progressBarStripesColor,i=e.progressBarBackgroundColor,o=e.progressBarColor,a=e.colorBlindMode,c=e.progressBarBorderRadius,l=e.progressBarHeight,h=e.textColor,u=e.textAlign,d=e.fontSize;return q(j||(j=M(['\n\t\t<div class="','">\n\t\t\t',"\n\t\t\t","\n\t\t</div>\n\t"])),this.className,F.call(this,{reachQuantity:t,progressBarStripesColor:r,progressBarBackgroundColor:i,progressBarColor:o,colorBlindMode:a,progressBarBorderRadius:c,progressBarHeight:l}),G.call(this,{subLayout:n,textLabelContent:s,reachQuantity:t,textColor:h,textAlign:u,fontSize:d}))}O.filter(({value:e})=>V(e));var Q=/\s/g,Y=/\d(\d|\.|\s|,)*/,J=/(\d)(,)(\d+)/,X=/\d+(,\d{3})+(?!\d)/,Z=/\d+(\.\d{3})+(?!\d)/,ee=/\d+\s{1}\d{3,}/,te=/,\d{2,}/,ne=/\.\d{2,}/,se=/\d+/,re=/\./g,ie=/,/g,oe=/(\d{1,3})(\.\d{2}|,\d{2}|\s{1}|\.|,)\s+\d+/i,ae=/(\.|,)(\d+)(\.|,)?\s+\d+/i;function ce(e){var t=e.toString().match(Y);t||u("could not parse source value, using 0");var n=t?t[0]:"0";return n=n.replace(oe,"$1$2").replace(ae,"$1$2").replace(X,function(e){return e.replace(ie,"")}).replace(Q,"").replace(Z,function(e){return e.replace(re,"")}).replace(J,"$1.$3"),Number.parseFloat(n)}function le(e){this.encode=e,this.decode=ce}function he(e,t){for(var n=Math.floor(e).toString(),s=n.length;s>3;)s+=-3,n=n.slice(0,s)+t+n.slice(s);return n}function ue(e,t){var n=e.toString();return n.indexOf(".")>0?"".concat(t).concat(n.substring(n.indexOf(".")+1)):""}var de=function(){function e(t){!function(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")}(this,e),this.originalValue=t,this.formatter=function(e){return X.test(e)?new le(function(e){return"".concat(he(e,",")).concat(ue(e,"."))}):Z.test(e)?new le(function(e){return"".concat(he(e,".")).concat(ue(e,","))}):ee.test(e)?te.test(e)?new le(function(e){return"".concat(he(e," ")).concat(ue(e,","))}):(ne.test(e),new le(function(e){return"".concat(he(e," ")).concat(ue(e,"."))})):te.test(e)?new le(function(e){return"".concat(he(e,"")).concat(ue(e,","))}):ne.test(e)?new le(function(e){return"".concat(he(e,"")).concat(ue(e,"."))}):(se.test(e),new le(function(e){return e}))}(t),this.numericValue=this.formatter.decode(t)}var t,n;return t=e,(n=[{key:"formatNumber",value:function(e){return this.formatter.encode(e).toString()}}])&&function(e,t){for(var n=0;n<t.length;n++){var s=t[n];s.enumerable=s.enumerable||!1,s.configurable=!0,"value"in s&&(s.writable=!0),Object.defineProperty(e,s.key,s)}}(t.prototype,n),Object.defineProperty(t,"prototype",{writable:!1}),e}();function ge(e,t){for(var n=0;n<t.length;n++){var s=t[n];s.enumerable=s.enumerable||!1,s.configurable=!0,"value"in s&&(s.writable=!0),Object.defineProperty(e,s.key,s)}}var me=function(){function t(e){var n=e.parentContainer;!function(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")}(this,t),this.eventHub={hub:Object.create(null),emit:function(e,t){(this.hub[e]||[]).forEach(function(e){return e(t)})},on:function(e,t){this.hub[e]||(this.hub[e]=[]),this.hub[e].push(t)},off:function(e,t){var n=(this.hub[e]||[]).findIndex(function(e){return e===t});n>-1&&this.hub[e].splice(n,1),0===this.hub[e].length&&delete this.hub[e]}},this.renderContent=K,this.parentContainer=n,this.baseClassName="progressbar_container",this.className="".concat(this.baseClassName,"_").concat(n.uniqueId),this.styleRules=[],this.externalValue=0,this.mainContainer=this.parentContainer.domElement.querySelector(".".concat(this.parentContainer.contentClassName)),this.value=this.getValue(),this.contentElement=this.getContentElement(),this.styleElement=this.getStyleElement(),this.sourceElementObserver=null,this.sourceValueObserver=new MutationObserver(this.handleValueUpdate.bind(this)),this.parentContainer.children=this}var n,s,r;return n=t,r=[{key:"getValueFromElement",value:function(){var e=DATA.variableElement,t=document.querySelector(e),n=t?t.textContent:"0";return t===document.body&&(n="67"),new de(n)}}],(s=[{key:"start",value:function(e){var t=this;this.eventHub.on("refreshContent",function(){"element"===e.variableType&&t.eventHub.emit("valueElementUpdated")}),this.eventHub.on("valueElementUpdated",function(){var e,n,s=t.getValue();e=s,n=t.value,Object.keys(n).every(function(t){return e[t]&&e[t]===n[t]})||(t.value=s,t.eventHub.emit("valueUpdated"))}),this.eventHub.on("sourceElementPresence",function(e){e?(t.eventHub.emit("valueElementUpdated"),t.parentContainer.domElement.hidden=!1,t.sourceValueObserver.observe(e,{childList:!0,subtree:!0,attributes:!1,characterData:!0})):(t.sourceValueObserver.disconnect(),t.parentContainer.domElement.hidden=!0,t.sourceElementObserver.observe(),u("source element could not be found, hiding the progress bar widget"))}),this.eventHub.on("externalUpdate",function(e){t.externalValue=Number.parseFloat(e),t.value=t.getValue(),t.eventHub.emit("valueUpdated")}),this.eventHub.on("valueUpdated",function(){return t.isGoalReached(e.reachQuantity)}),"javascript"===e.variableType&&this.getValueFromScript(),"element"===e.variableType&&(this.sourceElementObserver=g(e.variableElement,function(e){t.eventHub.emit("sourceElementPresence",e)}))}},{key:"handleValueUpdate",value:function(){this.eventHub.emit("valueElementUpdated")}},{key:"isGoalReached",value:function(t){var n=DATA,s=n.displayReachedMessage,r=n.reachedMessage;this.value.targetValue.numericValue>=+t?(s&&this.replaceCurrentMessage(z.call(this,t,r)),e||(this.parentContainer.recurrence.setValidationRecurrence(),u("target goal has been reached"))):s&&this.replaceCurrentMessage(z.call(this,t))}},{key:"replaceCurrentMessage",value:function(e){var t=this.mainContainer.querySelector(".abtasty_progress_definition");t&&(t.innerHTML=e)}},{key:"insertInParentContainer",value:function(){document.head.appendChild(this.styleElement),this.mainContainer.appendChild(this.contentElement)}},{key:"refreshContent",value:function(){this.eventHub.emit("refreshContent")}},{key:"getValueFromScript",value:function(){var e=DATA.variableJavascript,t=this.eventHub;new Function("(function externalUpdater(update){".concat(e,"})(this.update)")).call({update:function(e){return t.emit("externalUpdate",e),e}})}},{key:"getValue",value:function(){var e=this,n=DATA,s=n.variableType,r=n.variableDisplayingValue,i=n.reachQuantity,o=n.variableUnitType,a={element:function(){return t.getValueFromElement()},javascript:function(){return new de(e.externalValue)}}[s](),c={remaining:function(){return Math.max(0,i-a.numericValue)},accumulated:function(){return a.numericValue}}[r](),l={value:function(){return c},percent:function(){return Math.min(c,i)/i*100}}[o]();return{targetValue:a,calculatedValue:c,displayingValue:l}}},{key:"getContentElement",value:function(){var e=DATA,t=e.variableDisplayingValue,n=e.variableUnitType;this.textVariablesContent=DATA["textVariablesContent_".concat(n,"_").concat(t)];var s=document.createElement("div");return s.insertAdjacentHTML("beforeend",this.renderContent(DATA)),s}},{key:"addStyleRules",value:function(e){this.styleRules=this.styleRules.concat(e.map(function(e){var t=e.replace(/;/g," !important;");return t.indexOf("{")>1?"#".concat(this.parentContainer.widgetContainerId," .").concat(this.className," ").concat(t):t}.bind(this)))}},{key:"getStyleElement",value:function(){var t=DATA,n=t.textColor,s=t.textAlign,r=document.createElement("style");r.type="text/css",e()&&r.setAttribute("abtasty-script-added","true");var i=void 0!==n?"color: ".concat(n,";"):"",o=void 0!==s?"text-align: ".concat(s,";"):"";return this.addStyleRules(["p {","margin: 0;","white-space: pre-line;",i,o,"}",i&&i.length?["span {",i,"}"].join(""):""]),r.textContent=this.styleRules.join(" "),r}}])&&ge(n.prototype,s),r&&ge(n,r),Object.defineProperty(n,"prototype",{writable:!1}),t}();!function(){u("Widget launch");var e=(()=>{const{layout:e}=DATA;let t;switch(e){case"popin":t=new R;break;case"bannerTop":case"bannerBottom":t=new N;break;case"free":t=new P;break;default:t=new E}return t})(),t=new me({parentContainer:e});e.init(!0).then(function(n){n.response&&(t.insertInParentContainer(),t.start(DATA),e.show())})}()}();
|
package/package.json
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
{
|
2
2
|
"name": "@abtasty/progress-bar",
|
3
3
|
"description": "Allow you to add a progress bar on you website",
|
4
|
-
"version": "1.
|
4
|
+
"version": "1.2.0-0",
|
5
5
|
"form": "dist/form.js",
|
6
6
|
"main": "dist/main.js",
|
7
7
|
"files": [
|
@@ -38,4 +38,4 @@
|
|
38
38
|
"dependencies": {
|
39
39
|
"@abtasty/widget-utils": "^1.18.19"
|
40
40
|
}
|
41
|
-
}
|
41
|
+
}
|