@freshjuice/zest 2.1.0 → 2.2.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/zest.d.ts +33 -0
- package/dist/zest.de.js +107 -3
- package/dist/zest.de.js.map +1 -1
- package/dist/zest.de.min.js +1 -1
- package/dist/zest.en.js +107 -3
- package/dist/zest.en.js.map +1 -1
- package/dist/zest.en.min.js +1 -1
- package/dist/zest.es.js +107 -3
- package/dist/zest.es.js.map +1 -1
- package/dist/zest.es.min.js +1 -1
- package/dist/zest.esm.js +107 -3
- package/dist/zest.esm.js.map +1 -1
- package/dist/zest.esm.min.js +1 -1
- package/dist/zest.fr.js +107 -3
- package/dist/zest.fr.js.map +1 -1
- package/dist/zest.fr.min.js +1 -1
- package/dist/zest.headless.d.ts +33 -0
- package/dist/zest.headless.esm.js +107 -3
- package/dist/zest.headless.esm.js.map +1 -1
- package/dist/zest.headless.esm.min.js +1 -1
- package/dist/zest.it.js +107 -3
- package/dist/zest.it.js.map +1 -1
- package/dist/zest.it.min.js +1 -1
- package/dist/zest.ja.js +107 -3
- package/dist/zest.ja.js.map +1 -1
- package/dist/zest.ja.min.js +1 -1
- package/dist/zest.js +107 -3
- package/dist/zest.js.map +1 -1
- package/dist/zest.min.js +1 -1
- package/dist/zest.nl.js +107 -3
- package/dist/zest.nl.js.map +1 -1
- package/dist/zest.nl.min.js +1 -1
- package/dist/zest.pl.js +107 -3
- package/dist/zest.pl.js.map +1 -1
- package/dist/zest.pl.min.js +1 -1
- package/dist/zest.pt.js +107 -3
- package/dist/zest.pt.js.map +1 -1
- package/dist/zest.pt.min.js +1 -1
- package/dist/zest.ru.js +107 -3
- package/dist/zest.ru.js.map +1 -1
- package/dist/zest.ru.min.js +1 -1
- package/dist/zest.uk.js +107 -3
- package/dist/zest.uk.js.map +1 -1
- package/dist/zest.uk.min.js +1 -1
- package/dist/zest.zh.js +107 -3
- package/dist/zest.zh.js.map +1 -1
- package/dist/zest.zh.min.js +1 -1
- package/package.json +1 -1
- package/src/config/defaults.js +48 -0
- package/src/core/pattern-matcher.js +37 -0
- package/src/core-lifecycle.js +23 -4
- package/src/types/zest.d.ts +33 -0
- package/src/types/zest.headless.d.ts +33 -0
package/dist/zest.de.min.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
var Zest=function(){"use strict";const t={"&":"&","<":"<",">":">",'"':""","'":"'","`":"`"};function e(e){if(null==e)return"";return("string"==typeof e?e:e+"").replace(/[&<>"'`]/g,e=>t[e])}const n=new Set(["transparent","black","white","red","green","blue","yellow","orange","purple","pink","gray","grey","brown","cyan","magenta","silver","gold","navy","teal","maroon","olive","lime","aqua","fuchsia","indigo","violet","crimson","coral","salmon","tomato"]);const o=[/(\([^)]*[+*][^)]*\)|\[[^\]]*\]|\\w|\\d|\\s)\s*[+*]/,/\(\?[=!][^)]*[+*][^)]*\)[+*]/];function a(t,e){if(t instanceof RegExp)return t;if("string"!=typeof t)return null;if(t.length>500)return null;for(const e of o)if(e.test(t))return null;try{return RegExp(t,e)}catch(t){return null}}const s=new Set(["__proto__","constructor","prototype"]);function r(t,e){if(!t||"object"!=typeof t||Array.isArray(t))return null;const n={version:"string"==typeof t.version?t.version:null,timestamp:"number"==typeof t.timestamp&&Number.isFinite(t.timestamp)?t.timestamp:null,categories:{}},o=t.categories;if(!o||"object"!=typeof o||Array.isArray(o))return null;for(const t of e)s.has(t)||Object.prototype.hasOwnProperty.call(o,t)&&(n.categories[t]=!0===o[t]);return e.includes("essential")&&(n.categories.essential=!0),n}function i(t,...e){if("function"==typeof t)try{return t(...e)}catch(t){try{console.error("[Zest] User callback threw:",t)}catch(t){}return}}const c={essential:[/^zest_/,/^csrf/i,/^xsrf/i,/^session/i,/^__host-/i,/^__secure-/i],functional:[/^lang/i,/^locale/i,/^theme/i,/^preferences/i,/^ui_/i],analytics:[/^_ga/,/^_gid/,/^_gat/,/^_utm/,/^__utm/,/^plausible/i,/^_pk_/,/^matomo/i,/^_hj/,/^ajs_/],marketing:[/^_fbp/,/^_fbc/,/^_gcl/,/^_ttp/,/^ads/i,/^doubleclick/i,/^__gads/,/^__gpi/,/^_pin_/,/^li_/]};let l={...c};function d(t){for(const[e,n]of Object.entries(l))if(n.some(e=>e.test(t)))return e;return"marketing"}let u=null;const p=[];let f=()=>!1;function g(){return u}let m=null,b=null;const h=[],y=[];let z=()=>!1;function w(t,e,n){return new Proxy(t,{get(t,n){if("setItem"===n)return(n,o)=>{const a=d(n);z(a)?t.setItem(n,o):200>e.length&&e.push({key:n,value:o,category:a,timestamp:Date.now()})};const o=t[n];return"function"==typeof o?o.bind(t):o}})}const x={analytics:["google-analytics.com","www.google-analytics.com","analytics.google.com","googletagmanager.com","www.googletagmanager.com","plausible.io","cloudflareinsights.com","static.cloudflareinsights.com"],marketing:["connect.facebook.net","www.facebook.com/tr","ads.google.com","www.googleadservices.com","googleads.g.doubleclick.net","pagead2.googlesyndication.com"]},v={analytics:[...x.analytics,"analytics.tiktok.com","matomo.","hotjar.com","static.hotjar.com","script.hotjar.com","clarity.ms","www.clarity.ms","heapanalytics.com","cdn.heapanalytics.com","mixpanel.com","cdn.mxpnl.com","segment.com","cdn.segment.com","api.segment.io","fullstory.com","rs.fullstory.com","amplitude.com","cdn.amplitude.com","mouseflow.com","cdn.mouseflow.com","luckyorange.com","cdn.luckyorange.net","crazyegg.com","script.crazyegg.com"],marketing:[...x.marketing,"snap.licdn.com","px.ads.linkedin.com","ads.linkedin.com","analytics.twitter.com","static.ads-twitter.com","t.co","analytics.tiktok.com","ads.tiktok.com","sc-static.net","tr.snapchat.com","ct.pinterest.com","pintrk.com","s.pinimg.com","widgets.pinterest.com","bat.bing.com","ads.yahoo.com","sp.analytics.yahoo.com","amazon-adsystem.com","z-na.amazon-adsystem.com","criteo.com","static.criteo.net","dis.criteo.com","taboola.com","cdn.taboola.com","trc.taboola.com","outbrain.com","widgets.outbrain.com","adroll.com","s.adroll.com"],functional:["cdn.onesignal.com","onesignal.com","pusher.com","js.pusher.com","intercom.io","widget.intercom.io","js.intercomcdn.com","crisp.chat","client.crisp.chat","cdn.livechatinc.com","livechatinc.com","tawk.to","embed.tawk.to","zendesk.com","static.zdassets.com"]};function k(t,e){let n;try{n=new URL(t)}catch(t){return!1}const o=n.hostname.toLowerCase(),a=n.pathname.toLowerCase();for(const t of e){if("string"!=typeof t)continue;const e=t.toLowerCase();if(e.endsWith(".")){const t=e.slice(0,-1);if(o.split(".").some(e=>e===t)||o.startsWith(e))return!0;continue}const n=e.indexOf("/");if(-1!==n){const t=e.slice(0,n),s=e.slice(n);if((o===t||o.endsWith("."+t))&&a.startsWith(s))return!0;continue}if(o===e||o.endsWith("."+e))return!0}return!1}function _(t,e="safe"){const n="strict"===e?v:x;for(const[e,o]of Object.entries(n))if(k(t,o))return e;return null}const A=new Set(["functional","analytics","marketing"]),C=[];let S=null,E="safe",j=[],$=()=>!1;function M(t){if(t.hasAttribute("data-zest-allow"))return null;const e=t.getAttribute("data-consent-category"),n=e&&A.has(e)?e:null,o=t.src;if(!o)return n;const a=function(t){if(!t||0===j.length)return null;try{const e=new URL(t).hostname.toLowerCase();for(const t of j){const n="string"==typeof t?t:t.domain,o="string"==typeof t?"marketing":t.category||"marketing";if(e===n||e.endsWith("."+n))return o}}catch(t){}return null}(o);let s=null;switch(E){case"manual":break;case"safe":case"strict":s=_(o,E);break;case"doomsday":(function(t){try{const e=new URL(t).hostname,n=window.location.hostname,o=t=>t.replace(/^www\./,"");return o(e)!==o(n)}catch(t){return!1}})(o)&&(s=_(o,"strict")||"marketing")}return s||a||n}function L(t){if(t.hasAttribute("data-zest-processed"))return!1;const e=M(t);if(!e)return t.setAttribute("data-zest-processed","allowed"),!1;if($(e))return t.setAttribute("data-zest-processed","allowed"),!1;const n={category:e,src:t.src||"",inline:t.textContent,type:t.type,async:t.async,defer:t.defer,element:t,timestamp:Date.now()};return t.setAttribute("data-zest-processed","blocked"),t.setAttribute("data-consent-category",e),t.type="text/plain",t.src&&t.removeAttribute("src"),500>C.length&&C.push(n),!0}function N(t){for(const e of t)for(const t of e.addedNodes)if("SCRIPT"!==t.nodeName||t.hasAttribute("data-zest-processed")||L(t),t.querySelectorAll){t.querySelectorAll("script:not([data-zest-processed])").forEach(L)}}function R(t="safe",e=[]){return E=t,j=e,document.querySelectorAll("script:not([data-zest-processed])").forEach(L),S=new MutationObserver(N),S.observe(document.documentElement,{childList:!0,subtree:!0}),!0}const D={essential:{id:"essential",label:"Essential",description:"Required for the website to function properly. Cannot be disabled.",required:!0,default:!0},functional:{id:"functional",label:"Functional",description:"Enable personalized features like language preferences and themes.",required:!1,default:!1},analytics:{id:"analytics",label:"Analytics",description:"Help us understand how visitors interact with our website.",required:!1,default:!1},marketing:{id:"marketing",label:"Marketing",description:"Used to deliver relevant advertisements and track campaign performance.",required:!1,default:!1}};function W(){return Object.keys(D)}function O(){if("undefined"==typeof navigator)return!1;const t=navigator.doNotTrack||window.doNotTrack||navigator.msDoNotTrack;return"1"===t||"yes"===t||!0===t||!0===navigator.globalPrivacyControl}function q(t,e,n){const o=n?"default":"update";e.consentModeGoogle&&function(t,e){if(window.dataLayer=window.dataLayer||[],"function"==typeof window.gtag)window.gtag("consent",t,e);else{function n(){window.dataLayer.push(arguments)}n("consent",t,e)}}(o,function(t){const e=t=>t?"granted":"denied";return{ad_storage:e(t.marketing),ad_user_data:e(t.marketing),ad_personalization:e(t.marketing),analytics_storage:e(t.analytics),functionality_storage:"granted",personalization_storage:e(t.functional)}}(t)),e.consentModeMicrosoft&&function(t,e){window.uetq=window.uetq||[],window.uetq.push("consent",t,e)}(o,function(t){return{ad_storage:t.marketing?"granted":"denied"}}(t))}const I={labels:{banner:{title:"Wir respektieren Ihre Privatsphäre",description:'Wir verwenden Cookies, um Ihr Surferlebnis zu verbessern, personalisierte Inhalte bereitzustellen und unseren Datenverkehr zu analysieren. Mit einem Klick auf „Alle akzeptieren" stimmen Sie der Verwendung von Cookies zu.',acceptAll:"Alle akzeptieren",rejectAll:"Alle ablehnen",settings:"Einstellungen"},modal:{title:"Datenschutzeinstellungen",description:"Verwalten Sie Ihre Cookie-Einstellungen. Sie können verschiedene Arten von Cookies unten aktivieren oder deaktivieren.",save:"Einstellungen speichern",acceptAll:"Alle akzeptieren",rejectAll:"Alle ablehnen"},widget:{label:"Cookie-Einstellungen"}},categories:{essential:{label:"Notwendig",description:"Erforderlich für die ordnungsgemäße Funktion der Website. Können nicht deaktiviert werden."},functional:{label:"Funktional",description:"Ermöglichen personalisierte Funktionen wie Spracheinstellungen und Designs."},analytics:{label:"Analytisch",description:"Helfen uns zu verstehen, wie Besucher mit unserer Website interagieren."},marketing:{label:"Marketing",description:"Werden verwendet, um relevante Werbung anzuzeigen und die Kampagnenleistung zu messen."}}};const T={lang:"auto",position:"bottom",theme:"auto",accentColor:"#0071e3",categories:D,labels:{banner:{title:"We value your privacy",description:'We use cookies to enhance your browsing experience, serve personalized content, and analyze our traffic. By clicking "Accept All", you consent to our use of cookies.',acceptAll:"Accept All",rejectAll:"Reject All",settings:"Settings"},modal:{title:"Privacy Settings",description:"Manage your cookie preferences. You can enable or disable different types of cookies below.",save:"Save Preferences",acceptAll:"Accept All",rejectAll:"Reject All"},widget:{label:"Cookie Settings"}},autoInit:!0,showWidget:!0,expiration:365,respectDNT:!0,dntBehavior:"reject",customStyles:"",consentModeGoogle:!1,consentModeMicrosoft:!1,mode:"safe",blockedDomains:[],policyUrl:null,imprintUrl:null,callbacks:{onAccept:null,onReject:null,onChange:null,onReady:null}};function Z(t){const e={...T};t||(t={});const n=["lang","position","theme","accentColor","autoInit","showWidget","expiration","policyUrl","imprintUrl","customStyles","mode","blockedDomains","respectDNT","dntBehavior","consentModeGoogle","consentModeMicrosoft"];for(const o of n)void 0!==t[o]&&(e[o]=t[o]);e.lang="de";const o=I,a=o.labels||{},s=t.labels||{};e.labels={banner:{...T.labels.banner,...a.banner,...s.banner},modal:{...T.labels.modal,...a.modal,...s.modal},widget:{...T.labels.widget,...a.widget,...s.widget}};const r=o.categories||{},i=t.categories||{};e.categories={...T.categories};for(const t of Object.keys(T.categories))e.categories[t]={...T.categories[t],...r[t],...i[t]};return t.callbacks&&(e.callbacks={...T.callbacks,...t.callbacks}),t.patterns&&(e.patterns=t.patterns),e}function U(){const t="undefined"!=typeof window&&window.ZestConfig?window.ZestConfig:{},e=function(){const t=document.currentScript||document.querySelector("script[data-zest]")||document.querySelector('script[src*="zest"]');if(!t)return{};const e={},n=t.getAttribute("data-position");n&&(e.position=n);const o=t.getAttribute("data-theme");o&&(e.theme=o);const a=t.getAttribute("data-accent")||t.getAttribute("data-accent-color");a&&(e.accentColor=a);const s=t.getAttribute("data-policy-url")||t.getAttribute("data-privacy-url");s&&(e.policyUrl=s);const r=t.getAttribute("data-imprint-url");r&&(e.imprintUrl=r);const i=t.getAttribute("data-show-widget");null!==i&&(e.showWidget="false"!==i);const c=t.getAttribute("data-auto-init");null!==c&&(e.autoInit="false"!==c);const l=t.getAttribute("data-expiration");l&&(e.expiration=parseInt(l,10));const d=t.getAttribute("data-consent-mode-google");null!==d&&(e.consentModeGoogle="false"!==d);const u=t.getAttribute("data-consent-mode-microsoft");return null!==u&&(e.consentModeMicrosoft="false"!==u),e}();return Z({...t,...e})}let P=null;function H(){return P||(P=U()),P}const Y="zest_consent";function F(){try{return"undefined"!=typeof location&&"https:"===location.protocol?"; Secure":""}catch(t){return""}}let B=null;function G(t){const e=g();e?.set?e.set.call(document,t):document.cookie=t}function J(){const t=g();return t?.get?t.get.call(document):document.cookie}function X(){try{const t=J().match(RegExp(Y+"=([^;]+)"));if(t){const e=r(JSON.parse(decodeURIComponent(t[1])),W());if(e&&e.categories)return B={essential:!0,functional:!1,analytics:!1,marketing:!1,...e.categories},{...B}}}catch(t){}return B={essential:!0,functional:!1,analytics:!1,marketing:!1},{...B}}function K(){return B||(B=X()),{...B}}function V(t,e=365){const n=B?{...B}:{essential:!0,functional:!1,analytics:!1,marketing:!1};return B={essential:!0,functional:!!t.functional,analytics:!!t.analytics,marketing:!!t.marketing},function(t=365){B||(B={essential:!0,functional:!1,analytics:!1,marketing:!1});const e={version:"1.0",timestamp:Date.now(),categories:B},n=new Date(Date.now()+24*t*60*60*1e3).toUTCString();G(`${Y}=${encodeURIComponent(JSON.stringify(e))}; expires=${n}; path=/; SameSite=Lax${F()}`)}(e),{current:{...B},previous:n}}function Q(t){return B||(B=X()),!0===B[t]}function tt(t=365){return V({functional:!1,analytics:!1,marketing:!1},t)}function et(){try{return J().includes(Y)}catch(t){return!1}}const nt={READY:"zest:ready",CONSENT:"zest:consent",REJECT:"zest:reject",CHANGE:"zest:change",SHOW:"zest:show",HIDE:"zest:hide"};function ot(t,e={}){const n=new CustomEvent(t,{detail:e,bubbles:!0,cancelable:!0});return document.dispatchEvent(n),n}function at(t,e){return ot(nt.CONSENT,{consent:t,previous:e})}function st(t){return ot(nt.REJECT,{consent:t})}function rt(t,e){return ot(nt.CHANGE,{consent:t,previous:e})}function it(t="banner"){return ot(nt.SHOW,{type:t})}function ct(t="banner"){return ot(nt.HIDE,{type:t})}let lt=!1,dt=null;function ut(t){return Q(t)}function pt(t){!function(t){const e=[];for(const n of p)t.includes(n.category)?u?.set&&u.set.call(document,n.value):e.push(n);p.length=0,p.push(...e)}(t),function(t){const e=[];for(const n of h)t.includes(n.category)?m?.setItem(n.key,n.value):e.push(n);h.length=0,h.push(...e);const n=[];for(const e of y)t.includes(e.category)?b?.setItem(e.key,e.value):n.push(e);y.length=0,y.push(...n)}(t),function(t){const e=[];for(const n of C){if(!t.includes(n.category)){e.push(n);continue}const o=document.createElement("script");n.src?o.src=n.src:n.inline&&(o.textContent=n.inline),n.async&&(o.async=!0),n.defer&&(o.defer=!0),n.type&&"text/plain"!==n.type&&(o.type=n.type),o.setAttribute("data-zest-processed","executed"),o.setAttribute("data-consent-executed","true");const a=n.element;a&&a.isConnected&&a.parentNode?a.parentNode.replaceChild(o,a):document.head.appendChild(o)}C.length=0,C.push(...e)}(t)}function ft(t={}){if(lt)return{alreadyInitialized:!0,config:dt,consent:X(),hasDecision:et(),dntApplied:!1};P=Z(t),dt=P,q({functional:!1,analytics:!1,marketing:!1},dt,!0),dt.patterns&&function(t){if(l={...c},t&&"object"==typeof t)for(const[e,n]of Object.entries(t)){if(!Array.isArray(n))continue;const t=[];for(const e of n){const n=a(e);if(n)t.push(n);else try{console.warn("[Zest] Rejected unsafe pattern:",e)}catch(t){}}l[e]=t}}(dt.patterns),f=ut,function(t){z=t}(ut),function(t){$=t}(ut),u=Object.getOwnPropertyDescriptor(Document.prototype,"cookie"),u?Object.defineProperty(document,"cookie",{get:()=>u.get.call(document),set(t){const e=function(t){const e=t.match(/^([^=]+)/);return e?e[1].trim():null}(t);if(!e)return;const n=d(e);f(n)?u.set.call(document,t):100>p.length&&p.push({value:t,name:e,category:n,timestamp:Date.now()})},configurable:!1}):console.warn("[Zest] Could not get cookie descriptor"),function(){try{return m=window.localStorage,b=window.sessionStorage,Object.defineProperty(window,"localStorage",{value:w(m,h),configurable:!0,writable:!1}),Object.defineProperty(window,"sessionStorage",{value:w(b,y),configurable:!0,writable:!1}),!0}catch(t){return console.warn("[Zest] Could not intercept storage APIs:",t),!1}}(),R(dt.mode,dt.blockedDomains);const e=X();lt=!0,et()&&q(e,dt,!1);let n=!1;if(O()&&dt.respectDNT&&"ignore"!==dt.dntBehavior&&"reject"===dt.dntBehavior&&!et()){const t=tt(dt.expiration);n=!0,q(t.current,dt,!1),st(t.current),rt(t.current,t.previous),i(dt.callbacks?.onReject),i(dt.callbacks?.onChange,t.current)}return function(t){ot(nt.READY,{consent:t})}(e),i(dt.callbacks?.onReady,e),{alreadyInitialized:!1,config:dt,consent:e,hasDecision:et(),dntApplied:n}}function gt(){if(!lt)return null;const t=function(t=365){return V({functional:!0,analytics:!0,marketing:!0},t)}(dt.expiration);return q(t.current,dt,!1),pt(W()),at(t.current,t.previous),rt(t.current,t.previous),i(dt.callbacks?.onAccept,t.current),i(dt.callbacks?.onChange,t.current),t}function mt(){G(`${Y}=; expires=Thu, 01 Jan 1970 00:00:00 GMT; path=/; SameSite=Lax${F()}`),B=null}function bt(){return lt}function ht(){return dt}const yt="#4F46E5";function zt(t){const e=function(t){if("string"!=typeof t)return null;const e=t.trim();return/^#[0-9a-fA-F]{3,8}$/.test(e)||n.has(e.toLowerCase())||/^(rgb|rgba|hsl|hsla)\(\s*[\d.,%\s/]+\s*\)$/i.test(e)?e:null}(t.accentColor)||yt,o=function(t){if("string"!=typeof t||0===t.length)return"";if(t.length>2e4)return"";let e=t.replace(/\/\*[\s\S]*?\*\//g,"");return e=e.replace(/@import\s+[^;]+;?/gi,""),e=e.replace(/@charset\s+[^;]+;?/gi,""),e=e.replace(/url\(\s*(['"]?)([^)'"]+)\1\s*\)/gi,(t,e,n)=>{const o=n.trim().toLowerCase();return o.startsWith("https:")||o.startsWith("data:image/")||o.startsWith("/")||o.startsWith("#")?t:"url(#)"}),e=e.replace(/\.zest-btn--secondary\s*\{[^}]*\}/gi,""),e=e.replace(/\[data-action\s*=\s*["']reject-all["']\]\s*\{[^}]*\}/gi,""),e=e.replace(/\[data-action\s*=\s*["']accept-all["']\]\s*\{[^}]*\}/gi,""),e=e.replace(/expression\s*\([^)]*\)/gi,""),e=e.replace(/-moz-binding\s*:[^;}]*/gi,""),e}(t.customStyles);return`\n:host {\n --zest-accent: ${e};\n --zest-accent-hover: ${function(t,e){"string"==typeof t&&/^#[0-9a-fA-F]{3,8}$/.test(t.trim())||(t=yt);let n=t.trim().replace("#","");3===n.length&&(n=n.split("").map(t=>t+t).join(""));8===n.length&&(n=n.slice(0,6));6!==n.length&&(n="4F46E5");const o=parseInt(n,16),a=Math.round(2.55*e);return"#"+(16777216+65536*Math.min(255,Math.max(0,(o>>16)+a))+256*Math.min(255,Math.max(0,(o>>8&255)+a))+Math.min(255,Math.max(0,(255&o)+a))).toString(16).slice(1)}(e,-15)};\n --zest-bg: #ffffff;\n --zest-bg-secondary: #f3f4f6;\n --zest-text: #1f2937;\n --zest-text-secondary: #6b7280;\n --zest-border: #e5e7eb;\n --zest-shadow: 0 10px 25px -5px rgba(0, 0, 0, 0.1), 0 8px 10px -6px rgba(0, 0, 0, 0.1);\n --zest-radius: 12px;\n --zest-radius-sm: 8px;\n --zest-font: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;\n\n font-family: var(--zest-font);\n font-size: 14px;\n line-height: 1.5;\n color: var(--zest-text);\n box-sizing: border-box;\n}\n\n:host([data-theme="dark"]) {\n --zest-bg: #1f2937;\n --zest-bg-secondary: #374151;\n --zest-text: #f9fafb;\n --zest-text-secondary: #9ca3af;\n --zest-border: #4b5563;\n --zest-shadow: 0 10px 25px -5px rgba(0, 0, 0, 0.4), 0 8px 10px -6px rgba(0, 0, 0, 0.3);\n}\n\n@media (prefers-color-scheme: dark) {\n :host([data-theme="auto"]) {\n --zest-bg: #1f2937;\n --zest-bg-secondary: #374151;\n --zest-text: #f9fafb;\n --zest-text-secondary: #9ca3af;\n --zest-border: #4b5563;\n --zest-shadow: 0 10px 25px -5px rgba(0, 0, 0, 0.4), 0 8px 10px -6px rgba(0, 0, 0, 0.3);\n }\n}\n\n*, *::before, *::after {\n box-sizing: border-box;\n}\n\n/* Banner */\n.zest-banner {\n position: fixed;\n z-index: 999999;\n max-width: 480px;\n padding: 20px;\n background: var(--zest-bg);\n border-radius: var(--zest-radius);\n box-shadow: var(--zest-shadow);\n animation: zest-slide-in 0.3s ease-out;\n}\n\n.zest-banner--bottom {\n bottom: 20px;\n left: 50%;\n transform: translateX(-50%);\n}\n\n.zest-banner--bottom-left {\n bottom: 20px;\n left: 20px;\n}\n\n.zest-banner--bottom-right {\n bottom: 20px;\n right: 20px;\n}\n\n.zest-banner--top {\n top: 20px;\n left: 50%;\n transform: translateX(-50%);\n}\n\n@keyframes zest-slide-in {\n from {\n opacity: 0;\n transform: translateX(-50%) translateY(20px);\n }\n to {\n opacity: 1;\n transform: translateX(-50%) translateY(0);\n }\n}\n\n.zest-banner--bottom-left {\n animation-name: zest-slide-in-left;\n}\n\n@keyframes zest-slide-in-left {\n from {\n opacity: 0;\n transform: translateY(20px);\n }\n to {\n opacity: 1;\n transform: translateY(0);\n }\n}\n\n.zest-banner--bottom-right {\n animation-name: zest-slide-in-right;\n}\n\n@keyframes zest-slide-in-right {\n from {\n opacity: 0;\n transform: translateY(20px);\n }\n to {\n opacity: 1;\n transform: translateY(0);\n }\n}\n\n@media (prefers-reduced-motion: reduce) {\n .zest-banner,\n .zest-modal {\n animation: none;\n }\n}\n\n.zest-banner__title {\n margin: 0 0 8px 0;\n font-size: 16px;\n font-weight: 600;\n color: var(--zest-text);\n}\n\n.zest-banner__description {\n margin: 0 0 16px 0;\n font-size: 14px;\n color: var(--zest-text-secondary);\n}\n\n.zest-banner__buttons {\n display: flex;\n flex-wrap: wrap;\n gap: 8px;\n}\n\n/* Buttons */\n.zest-btn {\n display: inline-flex;\n align-items: center;\n justify-content: center;\n padding: 10px 16px;\n font-size: 14px;\n font-weight: 500;\n font-family: inherit;\n border: none;\n border-radius: var(--zest-radius-sm);\n cursor: pointer;\n transition: background-color 0.15s ease, transform 0.1s ease;\n}\n\n.zest-btn:hover {\n transform: translateY(-1px);\n}\n\n.zest-btn:active {\n transform: translateY(0);\n}\n\n.zest-btn:focus-visible {\n outline: 2px solid var(--zest-accent);\n outline-offset: 2px;\n}\n\n.zest-btn--primary {\n background: var(--zest-accent);\n color: #ffffff;\n}\n\n.zest-btn--primary:hover {\n background: var(--zest-accent-hover);\n}\n\n.zest-btn--secondary {\n background: var(--zest-bg-secondary);\n color: var(--zest-text);\n}\n\n.zest-btn--secondary:hover {\n background: var(--zest-border);\n}\n\n.zest-btn--ghost {\n background: transparent;\n color: var(--zest-text-secondary);\n}\n\n.zest-btn--ghost:hover {\n background: var(--zest-bg-secondary);\n color: var(--zest-text);\n}\n\n/* Modal */\n.zest-modal-overlay {\n position: fixed;\n inset: 0;\n z-index: 999998;\n display: flex;\n align-items: center;\n justify-content: center;\n padding: 20px;\n background: rgba(0, 0, 0, 0.5);\n animation: zest-fade-in 0.2s ease-out;\n}\n\n@keyframes zest-fade-in {\n from { opacity: 0; }\n to { opacity: 1; }\n}\n\n.zest-modal {\n width: 100%;\n max-width: 500px;\n max-height: 90vh;\n overflow-y: auto;\n background: var(--zest-bg);\n border-radius: var(--zest-radius);\n box-shadow: var(--zest-shadow);\n animation: zest-modal-in 0.3s ease-out;\n}\n\n@keyframes zest-modal-in {\n from {\n opacity: 0;\n transform: scale(0.95);\n }\n to {\n opacity: 1;\n transform: scale(1);\n }\n}\n\n.zest-modal__header {\n padding: 20px 20px 0;\n}\n\n.zest-modal__title {\n margin: 0 0 8px 0;\n font-size: 18px;\n font-weight: 600;\n color: var(--zest-text);\n}\n\n.zest-modal__description {\n margin: 0;\n font-size: 14px;\n color: var(--zest-text-secondary);\n}\n\n.zest-modal__body {\n padding: 20px;\n}\n\n.zest-modal__footer {\n display: flex;\n flex-wrap: wrap;\n gap: 8px;\n padding: 0 20px 20px;\n}\n\n/* Categories */\n.zest-category {\n padding: 16px;\n margin-bottom: 12px;\n background: var(--zest-bg-secondary);\n border-radius: var(--zest-radius-sm);\n}\n\n.zest-category:last-child {\n margin-bottom: 0;\n}\n\n.zest-category__header {\n display: flex;\n align-items: center;\n justify-content: space-between;\n gap: 12px;\n}\n\n.zest-category__info {\n flex: 1;\n}\n\n.zest-category__label {\n display: block;\n font-size: 14px;\n font-weight: 600;\n color: var(--zest-text);\n}\n\n.zest-category__description {\n margin: 4px 0 0;\n font-size: 13px;\n color: var(--zest-text-secondary);\n}\n\n/* Toggle Switch */\n.zest-toggle {\n position: relative;\n width: 44px;\n height: 24px;\n flex-shrink: 0;\n}\n\n.zest-toggle__input {\n position: absolute;\n opacity: 0;\n width: 100%;\n height: 100%;\n cursor: pointer;\n margin: 0;\n}\n\n.zest-toggle__input:disabled {\n cursor: not-allowed;\n}\n\n.zest-toggle__slider {\n position: absolute;\n inset: 0;\n background: var(--zest-border);\n border-radius: 12px;\n transition: background-color 0.2s ease;\n pointer-events: none;\n}\n\n.zest-toggle__slider::before {\n content: '';\n position: absolute;\n top: 2px;\n left: 2px;\n width: 20px;\n height: 20px;\n background: #ffffff;\n border-radius: 50%;\n transition: transform 0.2s ease;\n box-shadow: 0 1px 3px rgba(0, 0, 0, 0.2);\n}\n\n.zest-toggle__input:checked + .zest-toggle__slider {\n background: var(--zest-accent);\n}\n\n.zest-toggle__input:checked + .zest-toggle__slider::before {\n transform: translateX(20px);\n}\n\n.zest-toggle__input:focus-visible + .zest-toggle__slider {\n outline: 2px solid var(--zest-accent);\n outline-offset: 2px;\n}\n\n.zest-toggle__input:disabled + .zest-toggle__slider {\n opacity: 0.6;\n}\n\n/* Widget */\n.zest-widget {\n position: fixed;\n z-index: 999997;\n bottom: 20px;\n left: 20px;\n}\n\n.zest-widget__btn {\n display: flex;\n align-items: center;\n justify-content: center;\n width: 48px;\n height: 48px;\n padding: 0;\n background: var(--zest-bg);\n border: 1px solid var(--zest-border);\n border-radius: 50%;\n box-shadow: var(--zest-shadow);\n cursor: pointer;\n transition: transform 0.2s ease, box-shadow 0.2s ease;\n}\n\n.zest-widget__btn:hover {\n transform: scale(1.05);\n box-shadow: 0 12px 28px -5px rgba(0, 0, 0, 0.15);\n}\n\n.zest-widget__btn:focus-visible {\n outline: 2px solid var(--zest-accent);\n outline-offset: 2px;\n}\n\n.zest-widget__icon {\n width: 24px;\n height: 24px;\n fill: var(--zest-text);\n}\n\n/* Link */\n.zest-link {\n color: var(--zest-accent);\n text-decoration: none;\n}\n\n.zest-link:hover {\n text-decoration: underline;\n}\n\n/* Mobile */\n@media (max-width: 480px) {\n .zest-banner {\n left: 10px;\n right: 10px;\n max-width: none;\n transform: none;\n }\n\n .zest-banner--bottom,\n .zest-banner--bottom-left,\n .zest-banner--bottom-right {\n bottom: 10px;\n }\n\n .zest-banner--top {\n top: 10px;\n transform: none;\n }\n\n @keyframes zest-slide-in {\n from {\n opacity: 0;\n transform: translateY(20px);\n }\n to {\n opacity: 1;\n transform: translateY(0);\n }\n }\n\n .zest-banner__buttons {\n flex-direction: column;\n }\n\n .zest-btn {\n width: 100%;\n }\n\n .zest-modal-overlay {\n padding: 10px;\n }\n\n .zest-widget {\n bottom: 10px;\n left: 10px;\n }\n}\n\n/* Hidden utility */\n.zest-hidden {\n display: none !important;\n}\n${o}\n`}let wt=null,xt=null;const vt=new Set(["bottom","bottom-left","bottom-right","top"]);function kt(t={}){if(wt)return wt;const n=H();wt=document.createElement("zest-banner"),wt.setAttribute("data-theme",n.theme||"light"),xt=wt.attachShadow({mode:"open"});const o=document.createElement("style");o.textContent=zt(n),xt.appendChild(o);const a=document.createElement("div");a.innerHTML=function(t){const n=t.labels.banner,o=t.position||"bottom";return`\n <div class="zest-banner zest-banner--${vt.has(o)?o:"bottom"}" role="dialog" aria-modal="false" aria-label="${e(n.title)}">\n <h2 class="zest-banner__title">${e(n.title)}</h2>\n <p class="zest-banner__description">${e(n.description)}</p>\n <div class="zest-banner__buttons">\n <button type="button" class="zest-btn zest-btn--primary" data-action="accept-all">\n ${e(n.acceptAll)}\n </button>\n <button type="button" class="zest-btn zest-btn--secondary" data-action="reject-all">\n ${e(n.rejectAll)}\n </button>\n <button type="button" class="zest-btn zest-btn--ghost" data-action="settings">\n ${e(n.settings)}\n </button>\n </div>\n </div>\n `}(n),xt.appendChild(a.firstElementChild);const s=xt.querySelector(".zest-banner");return s.addEventListener("click",e=>{const n=e.target.dataset.action;if(n)switch(n){case"accept-all":t.onAcceptAll?.();break;case"reject-all":t.onRejectAll?.();break;case"settings":t.onSettings?.()}}),s.addEventListener("keydown",e=>{"Escape"===e.key&&t.onSettings?.()}),document.body.appendChild(wt),requestAnimationFrame(()=>{const t=xt.querySelector("button");t?.focus()}),wt}function _t(t={}){wt?wt.classList.remove("zest-hidden"):kt(t)}function At(){wt&&(wt.remove(),wt=null,xt=null)}let Ct=null,St=null,Et={};function jt(t,n){const o=t.labels.modal,a=Object.values(t.categories||D).map(t=>function(t,n,o){const a=o?"disabled":"",s=n?"checked":"",r=e(t.id),i=e(t.label);return`\n <div class="zest-category">\n <div class="zest-category__header">\n <div class="zest-category__info">\n <span class="zest-category__label">${i}</span>\n <p class="zest-category__description">${e(t.description)}</p>\n </div>\n <label class="zest-toggle">\n <input\n type="checkbox"\n class="zest-toggle__input"\n data-category="${r}"\n ${s}\n ${a}\n aria-label="${i}"\n >\n <span class="zest-toggle__slider"></span>\n </label>\n </div>\n </div>\n `}(t,n[t.id]??t.default,t.required)).join(""),s=t.policyUrl?function(t){if("string"!=typeof t||0===t.length)return null;const e=t.trim();if(0===e.length)return null;if(/^[/?#]/.test(e))return e;const n=e.match(/^([a-z][a-z0-9+.-]*):/i);if(!n)return e;const o=n[1].toLowerCase();return"http"===o||"https"===o||"mailto"===o||"tel"===o?e:null}(t.policyUrl):null,r=s?`<a href="${e(s)}" class="zest-link" target="_blank" rel="noopener noreferrer">Privacy Policy</a>`:"";return`\n <div class="zest-modal-overlay" role="dialog" aria-modal="true" aria-label="${e(o.title)}">\n <div class="zest-modal">\n <div class="zest-modal__header">\n <h2 class="zest-modal__title">${e(o.title)}</h2>\n <p class="zest-modal__description">${e(o.description)} ${r}</p>\n </div>\n <div class="zest-modal__body">\n ${a}\n </div>\n <div class="zest-modal__footer">\n <button type="button" class="zest-btn zest-btn--primary" data-action="save">\n ${e(o.save)}\n </button>\n <button type="button" class="zest-btn zest-btn--secondary" data-action="accept-all">\n ${e(o.acceptAll)}\n </button>\n <button type="button" class="zest-btn zest-btn--ghost" data-action="reject-all">\n ${e(o.rejectAll)}\n </button>\n </div>\n </div>\n </div>\n `}function $t(){if(!St)return Et;const t=St.querySelectorAll(".zest-toggle__input"),e={essential:!0};return t.forEach(t=>{const n=t.dataset.category;n&&"essential"!==n&&(e[n]=t.checked)}),e}function Mt(){Ct&&(Ct.remove(),Ct=null,St=null)}let Lt=null,Nt=null;function Rt(t={}){if(Lt)return Lt;const n=H();Lt=document.createElement("zest-widget"),Lt.setAttribute("data-theme",n.theme||"light"),Nt=Lt.attachShadow({mode:"open"});const o=document.createElement("style");o.textContent=zt(n),Nt.appendChild(o);const a=document.createElement("div");a.innerHTML=function(t){const n=e(t.labels.widget.label);return`\n <div class="zest-widget">\n <button type="button" class="zest-widget__btn" aria-label="${n}" title="${n}">\n <span class="zest-widget__icon"><svg viewBox="0 0 24 24" xmlns="http://www.w3.org/2000/svg"><path d="M12 2C6.477 2 2 6.477 2 12s4.477 10 10 10 10-4.477 10-10c0-.728-.078-1.437-.225-2.12a1 1 0 0 0-1.482-.63 3 3 0 0 1-4.086-3.72 1 1 0 0 0-.793-1.263A10.05 10.05 0 0 0 12 2zm0 2c.178 0 .354.006.528.017a5 5 0 0 0 5.955 5.955c.011.174.017.35.017.528 0 4.418-3.582 8-8 8s-8-3.582-8-8 3.582-8 8-8zm-4 6a1.5 1.5 0 1 0 0 3 1.5 1.5 0 0 0 0-3zm5 0a1 1 0 1 0 0 2 1 1 0 0 0 0-2zm-2 4a1.5 1.5 0 1 0 0 3 1.5 1.5 0 0 0 0-3z"/></svg></span>\n </button>\n </div>\n `}(n),Nt.appendChild(a.firstElementChild);return Nt.querySelector(".zest-widget__btn").addEventListener("click",()=>{t.onClick?.()}),document.body.appendChild(Lt),Lt}function Dt(t={}){Lt?Lt.style.display="":Rt(t)}function Wt(){Lt&&(Lt.style.display="none")}function Ot(){gt();const t=ht();At(),Mt(),t?.showWidget&&Dt({onClick:Tt})}function qt(){!function(){if(!lt)return null;const t=tt(dt.expiration);q(t.current,dt,!1),st(t.current),rt(t.current,t.previous),i(dt.callbacks?.onReject),i(dt.callbacks?.onChange,t.current)}();const t=ht();At(),Mt(),t?.showWidget&&Dt({onClick:Tt})}function It(t){!function(t){if(!lt)return null;const e=V(t,dt.expiration);q(e.current,dt,!1);const n=Object.keys(e.current).filter(t=>e.current[t]&&!e.previous[t]);n.length>0&&pt(n),Object.entries(t||{}).some(([t,e])=>"essential"!==t&&e)?at(e.current,e.previous):st(e.current),rt(e.current,e.previous),i(dt.callbacks?.onChange,e.current)}(t);const e=ht();Mt(),e?.showWidget&&Dt({onClick:Tt})}function Tt(){At(),Wt(),function(t={},e={}){if(Ct)return Ct;const n=H();Et={...t},Ct=document.createElement("zest-modal"),Ct.setAttribute("data-theme",n.theme||"light"),St=Ct.attachShadow({mode:"open"});const o=document.createElement("style");o.textContent=zt(n),St.appendChild(o);const a=document.createElement("div");a.innerHTML=jt(n,t),St.appendChild(a.firstElementChild);const s=St.querySelector(".zest-modal-overlay");s.addEventListener("click",t=>{const n=t.target.dataset.action;if(n)switch(n){case"save":e.onSave?.($t());break;case"accept-all":e.onAcceptAll?.();break;case"reject-all":e.onRejectAll?.()}else t.target===s&&e.onClose?.()}),s.addEventListener("keydown",t=>{"Escape"===t.key&&e.onClose?.()}),St.querySelectorAll(".zest-toggle__input").forEach(t=>{t.addEventListener("change",()=>{Et=$t()})}),document.body.appendChild(Ct),requestAnimationFrame(()=>{const t=St.querySelector("button");t?.focus()})}(K(),{onSave:It,onAcceptAll:Ot,onRejectAll:qt,onClose:Zt}),it("modal")}function Zt(){Mt(),ct("modal");const t=ht();et()&&t?.showWidget?Dt({onClick:Tt}):_t({onAcceptAll:Ot,onRejectAll:qt,onSettings:Tt})}function Ut(t={}){const{alreadyInitialized:e,hasDecision:n,dntApplied:o}=ft(t);if(e)return console.warn("[Zest] Already initialized"),Pt;const a=ht();return n||o?a?.showWidget&&Dt({onClick:Tt}):(_t({onAcceptAll:Ot,onRejectAll:qt,onSettings:Tt}),it("banner")),Pt}const Pt={init:Ut,show(){bt()?(Mt(),Wt(),_t({onAcceptAll:Ot,onRejectAll:qt,onSettings:Tt}),it("banner")):console.warn("[Zest] Not initialized. Call Zest.init() first.")},hide(){At(),ct("banner")},showSettings(){bt()?Tt():console.warn("[Zest] Not initialized. Call Zest.init() first.")},hideSettings(){Mt(),ct("modal")},getConsent:K,hasConsent:Q,hasConsentDecision:et,getConsentProof:function(){try{const t=J().match(RegExp(Y+"=([^;]+)"));if(t){return r(JSON.parse(decodeURIComponent(t[1])),W())}}catch(t){}return null},isDoNotTrackEnabled:O,getDNTDetails:function(){if("undefined"==typeof navigator)return{enabled:!1,source:null};const t=navigator.doNotTrack||window.doNotTrack||navigator.msDoNotTrack;return"1"===t||"yes"===t||!0===t?{enabled:!0,source:"dnt"}:!0===navigator.globalPrivacyControl?{enabled:!0,source:"gpc"}:{enabled:!1,source:null}},acceptAll(){bt()?Ot():console.warn("[Zest] Not initialized. Call Zest.init() first.")},rejectAll(){bt()?qt():console.warn("[Zest] Not initialized. Call Zest.init() first.")},reset(){mt(),Mt(),Lt&&(Lt.remove(),Lt=null,Nt=null),bt()&&(_t({onAcceptAll:Ot,onRejectAll:qt,onSettings:Tt}),it("banner"))},getConfig:H,on:function(t,e){return document.addEventListener(t,e),()=>document.removeEventListener(t,e)},once:function(t,e){document.addEventListener(t,e,{once:!0})},EVENTS:nt};if("undefined"!=typeof window){try{Object.defineProperty(window,"Zest",{value:Object.freeze(Pt),writable:!1,configurable:!1,enumerable:!0})}catch(t){window.Zest=Pt}const t=()=>{!1!==U().autoInit&&Ut(window.ZestConfig)};"loading"===document.readyState?document.addEventListener("DOMContentLoaded",t):t()}return Pt}();
|
|
1
|
+
var Zest=function(){"use strict";const e={"&":"&","<":"<",">":">",'"':""","'":"'","`":"`"};function t(t){if(null==t)return"";return("string"==typeof t?t:t+"").replace(/[&<>"'`]/g,t=>e[t])}const n=new Set(["transparent","black","white","red","green","blue","yellow","orange","purple","pink","gray","grey","brown","cyan","magenta","silver","gold","navy","teal","maroon","olive","lime","aqua","fuchsia","indigo","violet","crimson","coral","salmon","tomato"]);const o=[/(\([^)]*[+*][^)]*\)|\[[^\]]*\]|\\w|\\d|\\s)\s*[+*]/,/\(\?[=!][^)]*[+*][^)]*\)[+*]/];function s(e,t){if(e instanceof RegExp)return e;if("string"!=typeof e)return null;if(e.length>500)return null;for(const t of o)if(t.test(e))return null;try{return RegExp(e,t)}catch(e){return null}}const a=new Set(["__proto__","constructor","prototype"]);function r(e,t){if(!e||"object"!=typeof e||Array.isArray(e))return null;const n={version:"string"==typeof e.version?e.version:null,timestamp:"number"==typeof e.timestamp&&Number.isFinite(e.timestamp)?e.timestamp:null,categories:{}},o=e.categories;if(!o||"object"!=typeof o||Array.isArray(o))return null;for(const e of t)a.has(e)||Object.prototype.hasOwnProperty.call(o,e)&&(n.categories[e]=!0===o[e]);return t.includes("essential")&&(n.categories.essential=!0),n}function i(e,...t){if("function"==typeof e)try{return e(...t)}catch(e){try{console.error("[Zest] User callback threw:",e)}catch(e){}return}}const c={essential:[/^zest_/,/^csrf/i,/^xsrf/i,/^session/i,/^__host-/i,/^__secure-/i],functional:[/^lang/i,/^locale/i,/^theme/i,/^preferences/i,/^ui_/i],analytics:[/^_ga/,/^_gid/,/^_gat/,/^_utm/,/^__utm/,/^plausible/i,/^_pk_/,/^matomo/i,/^_hj/,/^ajs_/],marketing:[/^_fbp/,/^_fbc/,/^_gcl/,/^_ttp/,/^ads/i,/^doubleclick/i,/^__gads/,/^__gpi/,/^_pin_/,/^li_/]};let l={...c};function d(e){return(e+"").replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function u(e){for(const[t,n]of Object.entries(l))if(n.some(t=>t.test(e)))return t;return"marketing"}let p=null;const f=[];let g=()=>!1;function m(){return p}let b=null,h=null;const y=[],z=[];let w=()=>!1;function x(e,t,n){return new Proxy(e,{get(e,n){if("setItem"===n)return(n,o)=>{const s=u(n);w(s)?e.setItem(n,o):200>t.length&&t.push({key:n,value:o,category:s,timestamp:Date.now()})};const o=e[n];return"function"==typeof o?o.bind(e):o}})}const v={analytics:["google-analytics.com","www.google-analytics.com","analytics.google.com","googletagmanager.com","www.googletagmanager.com","plausible.io","cloudflareinsights.com","static.cloudflareinsights.com"],marketing:["connect.facebook.net","www.facebook.com/tr","ads.google.com","www.googleadservices.com","googleads.g.doubleclick.net","pagead2.googlesyndication.com"]},k={analytics:[...v.analytics,"analytics.tiktok.com","matomo.","hotjar.com","static.hotjar.com","script.hotjar.com","clarity.ms","www.clarity.ms","heapanalytics.com","cdn.heapanalytics.com","mixpanel.com","cdn.mxpnl.com","segment.com","cdn.segment.com","api.segment.io","fullstory.com","rs.fullstory.com","amplitude.com","cdn.amplitude.com","mouseflow.com","cdn.mouseflow.com","luckyorange.com","cdn.luckyorange.net","crazyegg.com","script.crazyegg.com"],marketing:[...v.marketing,"snap.licdn.com","px.ads.linkedin.com","ads.linkedin.com","analytics.twitter.com","static.ads-twitter.com","t.co","analytics.tiktok.com","ads.tiktok.com","sc-static.net","tr.snapchat.com","ct.pinterest.com","pintrk.com","s.pinimg.com","widgets.pinterest.com","bat.bing.com","ads.yahoo.com","sp.analytics.yahoo.com","amazon-adsystem.com","z-na.amazon-adsystem.com","criteo.com","static.criteo.net","dis.criteo.com","taboola.com","cdn.taboola.com","trc.taboola.com","outbrain.com","widgets.outbrain.com","adroll.com","s.adroll.com"],functional:["cdn.onesignal.com","onesignal.com","pusher.com","js.pusher.com","intercom.io","widget.intercom.io","js.intercomcdn.com","crisp.chat","client.crisp.chat","cdn.livechatinc.com","livechatinc.com","tawk.to","embed.tawk.to","zendesk.com","static.zdassets.com"]};function _(e,t){let n;try{n=new URL(e)}catch(e){return!1}const o=n.hostname.toLowerCase(),s=n.pathname.toLowerCase();for(const e of t){if("string"!=typeof e)continue;const t=e.toLowerCase();if(t.endsWith(".")){const e=t.slice(0,-1);if(o.split(".").some(t=>t===e)||o.startsWith(t))return!0;continue}const n=t.indexOf("/");if(-1!==n){const e=t.slice(0,n),a=t.slice(n);if((o===e||o.endsWith("."+e))&&s.startsWith(a))return!0;continue}if(o===t||o.endsWith("."+t))return!0}return!1}function A(e,t="safe"){const n="strict"===t?k:v;for(const[t,o]of Object.entries(n))if(_(e,o))return t;return null}const C=new Set(["functional","analytics","marketing"]),S=[];let E=null,j="safe",$=[],M=()=>!1;function L(e){if(e.hasAttribute("data-zest-allow"))return null;const t=e.getAttribute("data-consent-category"),n=t&&C.has(t)?t:null,o=e.src;if(!o)return n;const s=function(e){if(!e||0===$.length)return null;try{const t=new URL(e).hostname.toLowerCase();for(const e of $){const n="string"==typeof e?e:e.domain,o="string"==typeof e?"marketing":e.category||"marketing";if(t===n||t.endsWith("."+n))return o}}catch(e){}return null}(o);let a=null;switch(j){case"manual":break;case"safe":case"strict":a=A(o,j);break;case"doomsday":(function(e){try{const t=new URL(e).hostname,n=window.location.hostname,o=e=>e.replace(/^www\./,"");return o(t)!==o(n)}catch(e){return!1}})(o)&&(a=A(o,"strict")||"marketing")}return a||s||n}function N(e){if(e.hasAttribute("data-zest-processed"))return!1;const t=L(e);if(!t)return e.setAttribute("data-zest-processed","allowed"),!1;if(M(t))return e.setAttribute("data-zest-processed","allowed"),!1;const n={category:t,src:e.src||"",inline:e.textContent,type:e.type,async:e.async,defer:e.defer,element:e,timestamp:Date.now()};return e.setAttribute("data-zest-processed","blocked"),e.setAttribute("data-consent-category",t),e.type="text/plain",e.src&&e.removeAttribute("src"),500>S.length&&S.push(n),!0}function R(e){for(const t of e)for(const e of t.addedNodes)if("SCRIPT"!==e.nodeName||e.hasAttribute("data-zest-processed")||N(e),e.querySelectorAll){e.querySelectorAll("script:not([data-zest-processed])").forEach(N)}}function D(e="safe",t=[]){return j=e,$=t,document.querySelectorAll("script:not([data-zest-processed])").forEach(N),E=new MutationObserver(R),E.observe(document.documentElement,{childList:!0,subtree:!0}),!0}const W={essential:{id:"essential",label:"Essential",description:"Required for the website to function properly. Cannot be disabled.",required:!0,default:!0},functional:{id:"functional",label:"Functional",description:"Enable personalized features like language preferences and themes.",required:!1,default:!1},analytics:{id:"analytics",label:"Analytics",description:"Help us understand how visitors interact with our website.",required:!1,default:!1},marketing:{id:"marketing",label:"Marketing",description:"Used to deliver relevant advertisements and track campaign performance.",required:!1,default:!1}};function O(){return Object.keys(W)}function q(){if("undefined"==typeof navigator)return!1;const e=navigator.doNotTrack||window.doNotTrack||navigator.msDoNotTrack;return"1"===e||"yes"===e||!0===e||!0===navigator.globalPrivacyControl}function I(e,t,n){const o=n?"default":"update";t.consentModeGoogle&&function(e,t){if(window.dataLayer=window.dataLayer||[],"function"==typeof window.gtag)window.gtag("consent",e,t);else{function n(){window.dataLayer.push(arguments)}n("consent",e,t)}}(o,function(e){const t=e=>e?"granted":"denied";return{ad_storage:t(e.marketing),ad_user_data:t(e.marketing),ad_personalization:t(e.marketing),analytics_storage:t(e.analytics),functionality_storage:"granted",personalization_storage:t(e.functional)}}(e)),t.consentModeMicrosoft&&function(e,t){window.uetq=window.uetq||[],window.uetq.push("consent",e,t)}(o,function(e){return{ad_storage:e.marketing?"granted":"denied"}}(e))}const P={labels:{banner:{title:"Wir respektieren Ihre Privatsphäre",description:'Wir verwenden Cookies, um Ihr Surferlebnis zu verbessern, personalisierte Inhalte bereitzustellen und unseren Datenverkehr zu analysieren. Mit einem Klick auf „Alle akzeptieren" stimmen Sie der Verwendung von Cookies zu.',acceptAll:"Alle akzeptieren",rejectAll:"Alle ablehnen",settings:"Einstellungen"},modal:{title:"Datenschutzeinstellungen",description:"Verwalten Sie Ihre Cookie-Einstellungen. Sie können verschiedene Arten von Cookies unten aktivieren oder deaktivieren.",save:"Einstellungen speichern",acceptAll:"Alle akzeptieren",rejectAll:"Alle ablehnen"},widget:{label:"Cookie-Einstellungen"}},categories:{essential:{label:"Notwendig",description:"Erforderlich für die ordnungsgemäße Funktion der Website. Können nicht deaktiviert werden."},functional:{label:"Funktional",description:"Ermöglichen personalisierte Funktionen wie Spracheinstellungen und Designs."},analytics:{label:"Analytisch",description:"Helfen uns zu verstehen, wie Besucher mit unserer Website interagieren."},marketing:{label:"Marketing",description:"Werden verwendet, um relevante Werbung anzuzeigen und die Kampagnenleistung zu messen."}}};const T={lang:"auto",position:"bottom",theme:"auto",accentColor:"#0071e3",categories:W,labels:{banner:{title:"We value your privacy",description:'We use cookies to enhance your browsing experience, serve personalized content, and analyze our traffic. By clicking "Accept All", you consent to our use of cookies.',acceptAll:"Accept All",rejectAll:"Reject All",settings:"Settings"},modal:{title:"Privacy Settings",description:"Manage your cookie preferences. You can enable or disable different types of cookies below.",save:"Save Preferences",acceptAll:"Accept All",rejectAll:"Reject All"},widget:{label:"Cookie Settings"}},autoInit:!0,showWidget:!0,expiration:365,respectDNT:!0,dntBehavior:"reject",customStyles:"",consentModeGoogle:!1,consentModeMicrosoft:!1,mode:"safe",intercept:{cookies:!0,storage:!0,scripts:!0},essentialKeys:[],essentialPatterns:[],blockedDomains:[],policyUrl:null,imprintUrl:null,callbacks:{onAccept:null,onReject:null,onChange:null,onReady:null}};function Z(e){const t={...T};e||(e={});const n=["lang","position","theme","accentColor","autoInit","showWidget","expiration","policyUrl","imprintUrl","customStyles","mode","blockedDomains","respectDNT","dntBehavior","consentModeGoogle","consentModeMicrosoft"];for(const o of n)void 0!==e[o]&&(t[o]=e[o]);t.lang="de";const o=P,s=o.labels||{},a=e.labels||{};t.labels={banner:{...T.labels.banner,...s.banner,...a.banner},modal:{...T.labels.modal,...s.modal,...a.modal},widget:{...T.labels.widget,...s.widget,...a.widget}};const r=o.categories||{},i=e.categories||{};t.categories={...T.categories};for(const e of Object.keys(T.categories))t.categories[e]={...T.categories[e],...r[e],...i[e]};return e.callbacks&&(t.callbacks={...T.callbacks,...e.callbacks}),e.patterns&&(t.patterns=e.patterns),e.intercept&&"object"==typeof e.intercept&&(t.intercept={...T.intercept,...e.intercept}),Array.isArray(e.essentialKeys)&&(t.essentialKeys=e.essentialKeys.filter(e=>"string"==typeof e&&e.length>0&&200>=e.length)),Array.isArray(e.essentialPatterns)&&(t.essentialPatterns=e.essentialPatterns.filter(e=>"string"==typeof e&&e.length>0&&500>=e.length)),t}function U(){const e="undefined"!=typeof window&&window.ZestConfig?window.ZestConfig:{},t=function(){const e=document.currentScript||document.querySelector("script[data-zest]")||document.querySelector('script[src*="zest"]');if(!e)return{};const t={},n=e.getAttribute("data-position");n&&(t.position=n);const o=e.getAttribute("data-theme");o&&(t.theme=o);const s=e.getAttribute("data-accent")||e.getAttribute("data-accent-color");s&&(t.accentColor=s);const a=e.getAttribute("data-policy-url")||e.getAttribute("data-privacy-url");a&&(t.policyUrl=a);const r=e.getAttribute("data-imprint-url");r&&(t.imprintUrl=r);const i=e.getAttribute("data-show-widget");null!==i&&(t.showWidget="false"!==i);const c=e.getAttribute("data-auto-init");null!==c&&(t.autoInit="false"!==c);const l=e.getAttribute("data-expiration");l&&(t.expiration=parseInt(l,10));const d=e.getAttribute("data-consent-mode-google");null!==d&&(t.consentModeGoogle="false"!==d);const u=e.getAttribute("data-consent-mode-microsoft");return null!==u&&(t.consentModeMicrosoft="false"!==u),t}();return Z({...e,...t})}let H=null;function Y(){return H||(H=U()),H}const F="zest_consent";function B(){try{return"undefined"!=typeof location&&"https:"===location.protocol?"; Secure":""}catch(e){return""}}let K=null;function G(e){const t=m();t?.set?t.set.call(document,e):document.cookie=e}function J(){const e=m();return e?.get?e.get.call(document):document.cookie}function X(){try{const e=J().match(RegExp(F+"=([^;]+)"));if(e){const t=r(JSON.parse(decodeURIComponent(e[1])),O());if(t&&t.categories)return K={essential:!0,functional:!1,analytics:!1,marketing:!1,...t.categories},{...K}}}catch(e){}return K={essential:!0,functional:!1,analytics:!1,marketing:!1},{...K}}function V(){return K||(K=X()),{...K}}function Q(e,t=365){const n=K?{...K}:{essential:!0,functional:!1,analytics:!1,marketing:!1};return K={essential:!0,functional:!!e.functional,analytics:!!e.analytics,marketing:!!e.marketing},function(e=365){K||(K={essential:!0,functional:!1,analytics:!1,marketing:!1});const t={version:"1.0",timestamp:Date.now(),categories:K},n=new Date(Date.now()+24*e*60*60*1e3).toUTCString();G(`${F}=${encodeURIComponent(JSON.stringify(t))}; expires=${n}; path=/; SameSite=Lax${B()}`)}(t),{current:{...K},previous:n}}function ee(e){return K||(K=X()),!0===K[e]}function te(e=365){return Q({functional:!1,analytics:!1,marketing:!1},e)}function ne(){try{return J().includes(F)}catch(e){return!1}}const oe={READY:"zest:ready",CONSENT:"zest:consent",REJECT:"zest:reject",CHANGE:"zest:change",SHOW:"zest:show",HIDE:"zest:hide"};function se(e,t={}){const n=new CustomEvent(e,{detail:t,bubbles:!0,cancelable:!0});return document.dispatchEvent(n),n}function ae(e,t){return se(oe.CONSENT,{consent:e,previous:t})}function re(e){return se(oe.REJECT,{consent:e})}function ie(e,t){return se(oe.CHANGE,{consent:e,previous:t})}function ce(e="banner"){return se(oe.SHOW,{type:e})}function le(e="banner"){return se(oe.HIDE,{type:e})}let de=!1,ue=null;function pe(e){return ee(e)}function fe(e){!function(e){const t=[];for(const n of f)e.includes(n.category)?p?.set&&p.set.call(document,n.value):t.push(n);f.length=0,f.push(...t)}(e),function(e){const t=[];for(const n of y)e.includes(n.category)?b?.setItem(n.key,n.value):t.push(n);y.length=0,y.push(...t);const n=[];for(const t of z)e.includes(t.category)?h?.setItem(t.key,t.value):n.push(t);z.length=0,z.push(...n)}(e),function(e){const t=[];for(const n of S){if(!e.includes(n.category)){t.push(n);continue}const o=document.createElement("script");n.src?o.src=n.src:n.inline&&(o.textContent=n.inline),n.async&&(o.async=!0),n.defer&&(o.defer=!0),n.type&&"text/plain"!==n.type&&(o.type=n.type),o.setAttribute("data-zest-processed","executed"),o.setAttribute("data-consent-executed","true");const s=n.element;s&&s.isConnected&&s.parentNode?s.parentNode.replaceChild(o,s):document.head.appendChild(o)}S.length=0,S.push(...t)}(e)}function ge(e={}){if(de)return{alreadyInitialized:!0,config:ue,consent:X(),hasDecision:ne(),dntApplied:!1};H=Z(e),ue=H,I({functional:!1,analytics:!1,marketing:!1},ue,!0),ue.patterns&&function(e){if(l={...c},e&&"object"==typeof e)for(const[t,n]of Object.entries(e)){if(!Array.isArray(n))continue;const e=[];for(const t of n){const n=s(t);if(n)e.push(n);else try{console.warn("[Zest] Rejected unsafe pattern:",t)}catch(e){}}l[t]=e}}(ue.patterns),(Array.isArray(ue.essentialKeys)&&ue.essentialKeys.length>0||Array.isArray(ue.essentialPatterns)&&ue.essentialPatterns.length>0)&&function(e,{keys:t=[],patternStrings:n=[]}={}){l[e]||(l[e]=[]);for(const n of t){if("string"!=typeof n||!n)continue;const t=s(`^${d(n)}$`);t&&l[e].push(t)}for(const t of n){if("string"!=typeof t||!t)continue;const n=s(t);n&&l[e].push(n)}}("essential",{keys:ue.essentialKeys,patternStrings:ue.essentialPatterns}),g=pe,function(e){w=e}(pe),function(e){M=e}(pe);const t=ue.intercept||{cookies:!0,storage:!0,scripts:!0};!1!==t.cookies&&(p=Object.getOwnPropertyDescriptor(Document.prototype,"cookie"),p?Object.defineProperty(document,"cookie",{get:()=>p.get.call(document),set(e){const t=function(e){const t=e.match(/^([^=]+)/);return t?t[1].trim():null}(e);if(!t)return;const n=u(t);g(n)?p.set.call(document,e):100>f.length&&f.push({value:e,name:t,category:n,timestamp:Date.now()})},configurable:!1}):console.warn("[Zest] Could not get cookie descriptor")),!1!==t.storage&&function(){try{return b=window.localStorage,h=window.sessionStorage,Object.defineProperty(window,"localStorage",{value:x(b,y),configurable:!0,writable:!1}),Object.defineProperty(window,"sessionStorage",{value:x(h,z),configurable:!0,writable:!1}),!0}catch(e){return console.warn("[Zest] Could not intercept storage APIs:",e),!1}}(),!1!==t.scripts&&D(ue.mode,ue.blockedDomains);const n=X();de=!0,ne()&&I(n,ue,!1);let o=!1;if(q()&&ue.respectDNT&&"ignore"!==ue.dntBehavior&&"reject"===ue.dntBehavior&&!ne()){const e=te(ue.expiration);o=!0,I(e.current,ue,!1),re(e.current),ie(e.current,e.previous),i(ue.callbacks?.onReject),i(ue.callbacks?.onChange,e.current)}return function(e){se(oe.READY,{consent:e})}(n),i(ue.callbacks?.onReady,n),{alreadyInitialized:!1,config:ue,consent:n,hasDecision:ne(),dntApplied:o}}function me(){if(!de)return null;const e=function(e=365){return Q({functional:!0,analytics:!0,marketing:!0},e)}(ue.expiration);return I(e.current,ue,!1),fe(O()),ae(e.current,e.previous),ie(e.current,e.previous),i(ue.callbacks?.onAccept,e.current),i(ue.callbacks?.onChange,e.current),e}function be(){G(`${F}=; expires=Thu, 01 Jan 1970 00:00:00 GMT; path=/; SameSite=Lax${B()}`),K=null}function he(){return de}function ye(){return ue}const ze="#4F46E5";function we(e){const t=function(e){if("string"!=typeof e)return null;const t=e.trim();return/^#[0-9a-fA-F]{3,8}$/.test(t)||n.has(t.toLowerCase())||/^(rgb|rgba|hsl|hsla)\(\s*[\d.,%\s/]+\s*\)$/i.test(t)?t:null}(e.accentColor)||ze,o=function(e){if("string"!=typeof e||0===e.length)return"";if(e.length>2e4)return"";let t=e.replace(/\/\*[\s\S]*?\*\//g,"");return t=t.replace(/@import\s+[^;]+;?/gi,""),t=t.replace(/@charset\s+[^;]+;?/gi,""),t=t.replace(/url\(\s*(['"]?)([^)'"]+)\1\s*\)/gi,(e,t,n)=>{const o=n.trim().toLowerCase();return o.startsWith("https:")||o.startsWith("data:image/")||o.startsWith("/")||o.startsWith("#")?e:"url(#)"}),t=t.replace(/\.zest-btn--secondary\s*\{[^}]*\}/gi,""),t=t.replace(/\[data-action\s*=\s*["']reject-all["']\]\s*\{[^}]*\}/gi,""),t=t.replace(/\[data-action\s*=\s*["']accept-all["']\]\s*\{[^}]*\}/gi,""),t=t.replace(/expression\s*\([^)]*\)/gi,""),t=t.replace(/-moz-binding\s*:[^;}]*/gi,""),t}(e.customStyles);return`\n:host {\n --zest-accent: ${t};\n --zest-accent-hover: ${function(e,t){"string"==typeof e&&/^#[0-9a-fA-F]{3,8}$/.test(e.trim())||(e=ze);let n=e.trim().replace("#","");3===n.length&&(n=n.split("").map(e=>e+e).join(""));8===n.length&&(n=n.slice(0,6));6!==n.length&&(n="4F46E5");const o=parseInt(n,16),s=Math.round(2.55*t);return"#"+(16777216+65536*Math.min(255,Math.max(0,(o>>16)+s))+256*Math.min(255,Math.max(0,(o>>8&255)+s))+Math.min(255,Math.max(0,(255&o)+s))).toString(16).slice(1)}(t,-15)};\n --zest-bg: #ffffff;\n --zest-bg-secondary: #f3f4f6;\n --zest-text: #1f2937;\n --zest-text-secondary: #6b7280;\n --zest-border: #e5e7eb;\n --zest-shadow: 0 10px 25px -5px rgba(0, 0, 0, 0.1), 0 8px 10px -6px rgba(0, 0, 0, 0.1);\n --zest-radius: 12px;\n --zest-radius-sm: 8px;\n --zest-font: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;\n\n font-family: var(--zest-font);\n font-size: 14px;\n line-height: 1.5;\n color: var(--zest-text);\n box-sizing: border-box;\n}\n\n:host([data-theme="dark"]) {\n --zest-bg: #1f2937;\n --zest-bg-secondary: #374151;\n --zest-text: #f9fafb;\n --zest-text-secondary: #9ca3af;\n --zest-border: #4b5563;\n --zest-shadow: 0 10px 25px -5px rgba(0, 0, 0, 0.4), 0 8px 10px -6px rgba(0, 0, 0, 0.3);\n}\n\n@media (prefers-color-scheme: dark) {\n :host([data-theme="auto"]) {\n --zest-bg: #1f2937;\n --zest-bg-secondary: #374151;\n --zest-text: #f9fafb;\n --zest-text-secondary: #9ca3af;\n --zest-border: #4b5563;\n --zest-shadow: 0 10px 25px -5px rgba(0, 0, 0, 0.4), 0 8px 10px -6px rgba(0, 0, 0, 0.3);\n }\n}\n\n*, *::before, *::after {\n box-sizing: border-box;\n}\n\n/* Banner */\n.zest-banner {\n position: fixed;\n z-index: 999999;\n max-width: 480px;\n padding: 20px;\n background: var(--zest-bg);\n border-radius: var(--zest-radius);\n box-shadow: var(--zest-shadow);\n animation: zest-slide-in 0.3s ease-out;\n}\n\n.zest-banner--bottom {\n bottom: 20px;\n left: 50%;\n transform: translateX(-50%);\n}\n\n.zest-banner--bottom-left {\n bottom: 20px;\n left: 20px;\n}\n\n.zest-banner--bottom-right {\n bottom: 20px;\n right: 20px;\n}\n\n.zest-banner--top {\n top: 20px;\n left: 50%;\n transform: translateX(-50%);\n}\n\n@keyframes zest-slide-in {\n from {\n opacity: 0;\n transform: translateX(-50%) translateY(20px);\n }\n to {\n opacity: 1;\n transform: translateX(-50%) translateY(0);\n }\n}\n\n.zest-banner--bottom-left {\n animation-name: zest-slide-in-left;\n}\n\n@keyframes zest-slide-in-left {\n from {\n opacity: 0;\n transform: translateY(20px);\n }\n to {\n opacity: 1;\n transform: translateY(0);\n }\n}\n\n.zest-banner--bottom-right {\n animation-name: zest-slide-in-right;\n}\n\n@keyframes zest-slide-in-right {\n from {\n opacity: 0;\n transform: translateY(20px);\n }\n to {\n opacity: 1;\n transform: translateY(0);\n }\n}\n\n@media (prefers-reduced-motion: reduce) {\n .zest-banner,\n .zest-modal {\n animation: none;\n }\n}\n\n.zest-banner__title {\n margin: 0 0 8px 0;\n font-size: 16px;\n font-weight: 600;\n color: var(--zest-text);\n}\n\n.zest-banner__description {\n margin: 0 0 16px 0;\n font-size: 14px;\n color: var(--zest-text-secondary);\n}\n\n.zest-banner__buttons {\n display: flex;\n flex-wrap: wrap;\n gap: 8px;\n}\n\n/* Buttons */\n.zest-btn {\n display: inline-flex;\n align-items: center;\n justify-content: center;\n padding: 10px 16px;\n font-size: 14px;\n font-weight: 500;\n font-family: inherit;\n border: none;\n border-radius: var(--zest-radius-sm);\n cursor: pointer;\n transition: background-color 0.15s ease, transform 0.1s ease;\n}\n\n.zest-btn:hover {\n transform: translateY(-1px);\n}\n\n.zest-btn:active {\n transform: translateY(0);\n}\n\n.zest-btn:focus-visible {\n outline: 2px solid var(--zest-accent);\n outline-offset: 2px;\n}\n\n.zest-btn--primary {\n background: var(--zest-accent);\n color: #ffffff;\n}\n\n.zest-btn--primary:hover {\n background: var(--zest-accent-hover);\n}\n\n.zest-btn--secondary {\n background: var(--zest-bg-secondary);\n color: var(--zest-text);\n}\n\n.zest-btn--secondary:hover {\n background: var(--zest-border);\n}\n\n.zest-btn--ghost {\n background: transparent;\n color: var(--zest-text-secondary);\n}\n\n.zest-btn--ghost:hover {\n background: var(--zest-bg-secondary);\n color: var(--zest-text);\n}\n\n/* Modal */\n.zest-modal-overlay {\n position: fixed;\n inset: 0;\n z-index: 999998;\n display: flex;\n align-items: center;\n justify-content: center;\n padding: 20px;\n background: rgba(0, 0, 0, 0.5);\n animation: zest-fade-in 0.2s ease-out;\n}\n\n@keyframes zest-fade-in {\n from { opacity: 0; }\n to { opacity: 1; }\n}\n\n.zest-modal {\n width: 100%;\n max-width: 500px;\n max-height: 90vh;\n overflow-y: auto;\n background: var(--zest-bg);\n border-radius: var(--zest-radius);\n box-shadow: var(--zest-shadow);\n animation: zest-modal-in 0.3s ease-out;\n}\n\n@keyframes zest-modal-in {\n from {\n opacity: 0;\n transform: scale(0.95);\n }\n to {\n opacity: 1;\n transform: scale(1);\n }\n}\n\n.zest-modal__header {\n padding: 20px 20px 0;\n}\n\n.zest-modal__title {\n margin: 0 0 8px 0;\n font-size: 18px;\n font-weight: 600;\n color: var(--zest-text);\n}\n\n.zest-modal__description {\n margin: 0;\n font-size: 14px;\n color: var(--zest-text-secondary);\n}\n\n.zest-modal__body {\n padding: 20px;\n}\n\n.zest-modal__footer {\n display: flex;\n flex-wrap: wrap;\n gap: 8px;\n padding: 0 20px 20px;\n}\n\n/* Categories */\n.zest-category {\n padding: 16px;\n margin-bottom: 12px;\n background: var(--zest-bg-secondary);\n border-radius: var(--zest-radius-sm);\n}\n\n.zest-category:last-child {\n margin-bottom: 0;\n}\n\n.zest-category__header {\n display: flex;\n align-items: center;\n justify-content: space-between;\n gap: 12px;\n}\n\n.zest-category__info {\n flex: 1;\n}\n\n.zest-category__label {\n display: block;\n font-size: 14px;\n font-weight: 600;\n color: var(--zest-text);\n}\n\n.zest-category__description {\n margin: 4px 0 0;\n font-size: 13px;\n color: var(--zest-text-secondary);\n}\n\n/* Toggle Switch */\n.zest-toggle {\n position: relative;\n width: 44px;\n height: 24px;\n flex-shrink: 0;\n}\n\n.zest-toggle__input {\n position: absolute;\n opacity: 0;\n width: 100%;\n height: 100%;\n cursor: pointer;\n margin: 0;\n}\n\n.zest-toggle__input:disabled {\n cursor: not-allowed;\n}\n\n.zest-toggle__slider {\n position: absolute;\n inset: 0;\n background: var(--zest-border);\n border-radius: 12px;\n transition: background-color 0.2s ease;\n pointer-events: none;\n}\n\n.zest-toggle__slider::before {\n content: '';\n position: absolute;\n top: 2px;\n left: 2px;\n width: 20px;\n height: 20px;\n background: #ffffff;\n border-radius: 50%;\n transition: transform 0.2s ease;\n box-shadow: 0 1px 3px rgba(0, 0, 0, 0.2);\n}\n\n.zest-toggle__input:checked + .zest-toggle__slider {\n background: var(--zest-accent);\n}\n\n.zest-toggle__input:checked + .zest-toggle__slider::before {\n transform: translateX(20px);\n}\n\n.zest-toggle__input:focus-visible + .zest-toggle__slider {\n outline: 2px solid var(--zest-accent);\n outline-offset: 2px;\n}\n\n.zest-toggle__input:disabled + .zest-toggle__slider {\n opacity: 0.6;\n}\n\n/* Widget */\n.zest-widget {\n position: fixed;\n z-index: 999997;\n bottom: 20px;\n left: 20px;\n}\n\n.zest-widget__btn {\n display: flex;\n align-items: center;\n justify-content: center;\n width: 48px;\n height: 48px;\n padding: 0;\n background: var(--zest-bg);\n border: 1px solid var(--zest-border);\n border-radius: 50%;\n box-shadow: var(--zest-shadow);\n cursor: pointer;\n transition: transform 0.2s ease, box-shadow 0.2s ease;\n}\n\n.zest-widget__btn:hover {\n transform: scale(1.05);\n box-shadow: 0 12px 28px -5px rgba(0, 0, 0, 0.15);\n}\n\n.zest-widget__btn:focus-visible {\n outline: 2px solid var(--zest-accent);\n outline-offset: 2px;\n}\n\n.zest-widget__icon {\n width: 24px;\n height: 24px;\n fill: var(--zest-text);\n}\n\n/* Link */\n.zest-link {\n color: var(--zest-accent);\n text-decoration: none;\n}\n\n.zest-link:hover {\n text-decoration: underline;\n}\n\n/* Mobile */\n@media (max-width: 480px) {\n .zest-banner {\n left: 10px;\n right: 10px;\n max-width: none;\n transform: none;\n }\n\n .zest-banner--bottom,\n .zest-banner--bottom-left,\n .zest-banner--bottom-right {\n bottom: 10px;\n }\n\n .zest-banner--top {\n top: 10px;\n transform: none;\n }\n\n @keyframes zest-slide-in {\n from {\n opacity: 0;\n transform: translateY(20px);\n }\n to {\n opacity: 1;\n transform: translateY(0);\n }\n }\n\n .zest-banner__buttons {\n flex-direction: column;\n }\n\n .zest-btn {\n width: 100%;\n }\n\n .zest-modal-overlay {\n padding: 10px;\n }\n\n .zest-widget {\n bottom: 10px;\n left: 10px;\n }\n}\n\n/* Hidden utility */\n.zest-hidden {\n display: none !important;\n}\n${o}\n`}let xe=null,ve=null;const ke=new Set(["bottom","bottom-left","bottom-right","top"]);function _e(e={}){if(xe)return xe;const n=Y();xe=document.createElement("zest-banner"),xe.setAttribute("data-theme",n.theme||"light"),ve=xe.attachShadow({mode:"open"});const o=document.createElement("style");o.textContent=we(n),ve.appendChild(o);const s=document.createElement("div");s.innerHTML=function(e){const n=e.labels.banner,o=e.position||"bottom";return`\n <div class="zest-banner zest-banner--${ke.has(o)?o:"bottom"}" role="dialog" aria-modal="false" aria-label="${t(n.title)}">\n <h2 class="zest-banner__title">${t(n.title)}</h2>\n <p class="zest-banner__description">${t(n.description)}</p>\n <div class="zest-banner__buttons">\n <button type="button" class="zest-btn zest-btn--primary" data-action="accept-all">\n ${t(n.acceptAll)}\n </button>\n <button type="button" class="zest-btn zest-btn--secondary" data-action="reject-all">\n ${t(n.rejectAll)}\n </button>\n <button type="button" class="zest-btn zest-btn--ghost" data-action="settings">\n ${t(n.settings)}\n </button>\n </div>\n </div>\n `}(n),ve.appendChild(s.firstElementChild);const a=ve.querySelector(".zest-banner");return a.addEventListener("click",t=>{const n=t.target.dataset.action;if(n)switch(n){case"accept-all":e.onAcceptAll?.();break;case"reject-all":e.onRejectAll?.();break;case"settings":e.onSettings?.()}}),a.addEventListener("keydown",t=>{"Escape"===t.key&&e.onSettings?.()}),document.body.appendChild(xe),requestAnimationFrame(()=>{const e=ve.querySelector("button");e?.focus()}),xe}function Ae(e={}){xe?xe.classList.remove("zest-hidden"):_e(e)}function Ce(){xe&&(xe.remove(),xe=null,ve=null)}let Se=null,Ee=null,je={};function $e(e,n){const o=e.labels.modal,s=Object.values(e.categories||W).map(e=>function(e,n,o){const s=o?"disabled":"",a=n?"checked":"",r=t(e.id),i=t(e.label);return`\n <div class="zest-category">\n <div class="zest-category__header">\n <div class="zest-category__info">\n <span class="zest-category__label">${i}</span>\n <p class="zest-category__description">${t(e.description)}</p>\n </div>\n <label class="zest-toggle">\n <input\n type="checkbox"\n class="zest-toggle__input"\n data-category="${r}"\n ${a}\n ${s}\n aria-label="${i}"\n >\n <span class="zest-toggle__slider"></span>\n </label>\n </div>\n </div>\n `}(e,n[e.id]??e.default,e.required)).join(""),a=e.policyUrl?function(e){if("string"!=typeof e||0===e.length)return null;const t=e.trim();if(0===t.length)return null;if(/^[/?#]/.test(t))return t;const n=t.match(/^([a-z][a-z0-9+.-]*):/i);if(!n)return t;const o=n[1].toLowerCase();return"http"===o||"https"===o||"mailto"===o||"tel"===o?t:null}(e.policyUrl):null,r=a?`<a href="${t(a)}" class="zest-link" target="_blank" rel="noopener noreferrer">Privacy Policy</a>`:"";return`\n <div class="zest-modal-overlay" role="dialog" aria-modal="true" aria-label="${t(o.title)}">\n <div class="zest-modal">\n <div class="zest-modal__header">\n <h2 class="zest-modal__title">${t(o.title)}</h2>\n <p class="zest-modal__description">${t(o.description)} ${r}</p>\n </div>\n <div class="zest-modal__body">\n ${s}\n </div>\n <div class="zest-modal__footer">\n <button type="button" class="zest-btn zest-btn--primary" data-action="save">\n ${t(o.save)}\n </button>\n <button type="button" class="zest-btn zest-btn--secondary" data-action="accept-all">\n ${t(o.acceptAll)}\n </button>\n <button type="button" class="zest-btn zest-btn--ghost" data-action="reject-all">\n ${t(o.rejectAll)}\n </button>\n </div>\n </div>\n </div>\n `}function Me(){if(!Ee)return je;const e=Ee.querySelectorAll(".zest-toggle__input"),t={essential:!0};return e.forEach(e=>{const n=e.dataset.category;n&&"essential"!==n&&(t[n]=e.checked)}),t}function Le(){Se&&(Se.remove(),Se=null,Ee=null)}let Ne=null,Re=null;function De(e={}){if(Ne)return Ne;const n=Y();Ne=document.createElement("zest-widget"),Ne.setAttribute("data-theme",n.theme||"light"),Re=Ne.attachShadow({mode:"open"});const o=document.createElement("style");o.textContent=we(n),Re.appendChild(o);const s=document.createElement("div");s.innerHTML=function(e){const n=t(e.labels.widget.label);return`\n <div class="zest-widget">\n <button type="button" class="zest-widget__btn" aria-label="${n}" title="${n}">\n <span class="zest-widget__icon"><svg viewBox="0 0 24 24" xmlns="http://www.w3.org/2000/svg"><path d="M12 2C6.477 2 2 6.477 2 12s4.477 10 10 10 10-4.477 10-10c0-.728-.078-1.437-.225-2.12a1 1 0 0 0-1.482-.63 3 3 0 0 1-4.086-3.72 1 1 0 0 0-.793-1.263A10.05 10.05 0 0 0 12 2zm0 2c.178 0 .354.006.528.017a5 5 0 0 0 5.955 5.955c.011.174.017.35.017.528 0 4.418-3.582 8-8 8s-8-3.582-8-8 3.582-8 8-8zm-4 6a1.5 1.5 0 1 0 0 3 1.5 1.5 0 0 0 0-3zm5 0a1 1 0 1 0 0 2 1 1 0 0 0 0-2zm-2 4a1.5 1.5 0 1 0 0 3 1.5 1.5 0 0 0 0-3z"/></svg></span>\n </button>\n </div>\n `}(n),Re.appendChild(s.firstElementChild);return Re.querySelector(".zest-widget__btn").addEventListener("click",()=>{e.onClick?.()}),document.body.appendChild(Ne),Ne}function We(e={}){Ne?Ne.style.display="":De(e)}function Oe(){Ne&&(Ne.style.display="none")}function qe(){me();const e=ye();Ce(),Le(),e?.showWidget&&We({onClick:Te})}function Ie(){!function(){if(!de)return null;const e=te(ue.expiration);I(e.current,ue,!1),re(e.current),ie(e.current,e.previous),i(ue.callbacks?.onReject),i(ue.callbacks?.onChange,e.current)}();const e=ye();Ce(),Le(),e?.showWidget&&We({onClick:Te})}function Pe(e){!function(e){if(!de)return null;const t=Q(e,ue.expiration);I(t.current,ue,!1);const n=Object.keys(t.current).filter(e=>t.current[e]&&!t.previous[e]);n.length>0&&fe(n),Object.entries(e||{}).some(([e,t])=>"essential"!==e&&t)?ae(t.current,t.previous):re(t.current),ie(t.current,t.previous),i(ue.callbacks?.onChange,t.current)}(e);const t=ye();Le(),t?.showWidget&&We({onClick:Te})}function Te(){Ce(),Oe(),function(e={},t={}){if(Se)return Se;const n=Y();je={...e},Se=document.createElement("zest-modal"),Se.setAttribute("data-theme",n.theme||"light"),Ee=Se.attachShadow({mode:"open"});const o=document.createElement("style");o.textContent=we(n),Ee.appendChild(o);const s=document.createElement("div");s.innerHTML=$e(n,e),Ee.appendChild(s.firstElementChild);const a=Ee.querySelector(".zest-modal-overlay");a.addEventListener("click",e=>{const n=e.target.dataset.action;if(n)switch(n){case"save":t.onSave?.(Me());break;case"accept-all":t.onAcceptAll?.();break;case"reject-all":t.onRejectAll?.()}else e.target===a&&t.onClose?.()}),a.addEventListener("keydown",e=>{"Escape"===e.key&&t.onClose?.()}),Ee.querySelectorAll(".zest-toggle__input").forEach(e=>{e.addEventListener("change",()=>{je=Me()})}),document.body.appendChild(Se),requestAnimationFrame(()=>{const e=Ee.querySelector("button");e?.focus()})}(V(),{onSave:Pe,onAcceptAll:qe,onRejectAll:Ie,onClose:Ze}),ce("modal")}function Ze(){Le(),le("modal");const e=ye();ne()&&e?.showWidget?We({onClick:Te}):Ae({onAcceptAll:qe,onRejectAll:Ie,onSettings:Te})}function Ue(e={}){const{alreadyInitialized:t,hasDecision:n,dntApplied:o}=ge(e);if(t)return console.warn("[Zest] Already initialized"),He;const s=ye();return n||o?s?.showWidget&&We({onClick:Te}):(Ae({onAcceptAll:qe,onRejectAll:Ie,onSettings:Te}),ce("banner")),He}const He={init:Ue,show(){he()?(Le(),Oe(),Ae({onAcceptAll:qe,onRejectAll:Ie,onSettings:Te}),ce("banner")):console.warn("[Zest] Not initialized. Call Zest.init() first.")},hide(){Ce(),le("banner")},showSettings(){he()?Te():console.warn("[Zest] Not initialized. Call Zest.init() first.")},hideSettings(){Le(),le("modal")},getConsent:V,hasConsent:ee,hasConsentDecision:ne,getConsentProof:function(){try{const e=J().match(RegExp(F+"=([^;]+)"));if(e){return r(JSON.parse(decodeURIComponent(e[1])),O())}}catch(e){}return null},isDoNotTrackEnabled:q,getDNTDetails:function(){if("undefined"==typeof navigator)return{enabled:!1,source:null};const e=navigator.doNotTrack||window.doNotTrack||navigator.msDoNotTrack;return"1"===e||"yes"===e||!0===e?{enabled:!0,source:"dnt"}:!0===navigator.globalPrivacyControl?{enabled:!0,source:"gpc"}:{enabled:!1,source:null}},acceptAll(){he()?qe():console.warn("[Zest] Not initialized. Call Zest.init() first.")},rejectAll(){he()?Ie():console.warn("[Zest] Not initialized. Call Zest.init() first.")},reset(){be(),Le(),Ne&&(Ne.remove(),Ne=null,Re=null),he()&&(Ae({onAcceptAll:qe,onRejectAll:Ie,onSettings:Te}),ce("banner"))},getConfig:Y,on:function(e,t){return document.addEventListener(e,t),()=>document.removeEventListener(e,t)},once:function(e,t){document.addEventListener(e,t,{once:!0})},EVENTS:oe};if("undefined"!=typeof window){try{Object.defineProperty(window,"Zest",{value:Object.freeze(He),writable:!1,configurable:!1,enumerable:!0})}catch(e){window.Zest=He}const e=()=>{!1!==U().autoInit&&Ue(window.ZestConfig)};"loading"===document.readyState?document.addEventListener("DOMContentLoaded",e):e()}return He}();
|
package/dist/zest.en.js
CHANGED
|
@@ -258,10 +258,47 @@ var Zest = (function () {
|
|
|
258
258
|
|
|
259
259
|
let patterns = { ...DEFAULT_PATTERNS };
|
|
260
260
|
|
|
261
|
+
/** Escape a string so it can be embedded in a regex literal verbatim. */
|
|
262
|
+
function escapeRegex(value) {
|
|
263
|
+
return String(value).replace(/[.*+?^${}()|[\]\\]/g, '\\$&');
|
|
264
|
+
}
|
|
265
|
+
|
|
266
|
+
/**
|
|
267
|
+
* Append patterns to a single category without replacing what's already
|
|
268
|
+
* there. Used by `essentialKeys` and `essentialPatterns` config to extend
|
|
269
|
+
* the strictly-necessary category with consumer-specific entries while
|
|
270
|
+
* keeping the built-in defaults (zest_*, csrf*, xsrf*, etc.).
|
|
271
|
+
*
|
|
272
|
+
* `keys` is an array of exact storage/cookie names; each one is
|
|
273
|
+
* compiled as a fully-anchored regex via `escapeRegex`.
|
|
274
|
+
* `patternStrings` is an array of regex source strings, each validated
|
|
275
|
+
* via `safeRegExp`. Invalid entries are dropped silently.
|
|
276
|
+
*/
|
|
277
|
+
function appendPatternsToCategory(category, { keys = [], patternStrings = [] } = {}) {
|
|
278
|
+
if (!patterns[category]) patterns[category] = [];
|
|
279
|
+
|
|
280
|
+
for (const key of keys) {
|
|
281
|
+
if (typeof key !== 'string' || !key) continue;
|
|
282
|
+
const re = safeRegExp(`^${escapeRegex(key)}$`);
|
|
283
|
+
if (re) patterns[category].push(re);
|
|
284
|
+
}
|
|
285
|
+
|
|
286
|
+
for (const p of patternStrings) {
|
|
287
|
+
if (typeof p !== 'string' || !p) continue;
|
|
288
|
+
const re = safeRegExp(p);
|
|
289
|
+
if (re) patterns[category].push(re);
|
|
290
|
+
}
|
|
291
|
+
}
|
|
292
|
+
|
|
261
293
|
/**
|
|
262
294
|
* Set custom patterns. User-supplied strings are validated with safeRegExp,
|
|
263
295
|
* which rejects catastrophic-backtracking shapes and syntax errors.
|
|
264
296
|
* Invalid patterns are silently dropped with a console warning.
|
|
297
|
+
*
|
|
298
|
+
* Note: this REPLACES the patterns for any category present in
|
|
299
|
+
* `customPatterns`. To extend the essential category without losing the
|
|
300
|
+
* built-in defaults, use `appendPatternsToCategory()` (or pass
|
|
301
|
+
* `essentialKeys` / `essentialPatterns` to `Zest.init()`).
|
|
265
302
|
*/
|
|
266
303
|
function setPatterns(customPatterns) {
|
|
267
304
|
patterns = { ...DEFAULT_PATTERNS };
|
|
@@ -1292,6 +1329,32 @@ var Zest = (function () {
|
|
|
1292
1329
|
// Blocking mode: 'manual' | 'safe' | 'strict' | 'doomsday'
|
|
1293
1330
|
mode: 'safe',
|
|
1294
1331
|
|
|
1332
|
+
// Interceptor toggles. By default Zest installs cookie + storage
|
|
1333
|
+
// interceptors that route writes through the consent layer. Consumers
|
|
1334
|
+
// who manage gating themselves (typically headless mode with custom
|
|
1335
|
+
// analytics integrations) can opt out per channel.
|
|
1336
|
+
intercept: {
|
|
1337
|
+
cookies: true,
|
|
1338
|
+
storage: true,
|
|
1339
|
+
scripts: true
|
|
1340
|
+
},
|
|
1341
|
+
|
|
1342
|
+
// Strictly-necessary declarations. Both fields *append* to whatever
|
|
1343
|
+
// the essential category already matches via the pattern matcher
|
|
1344
|
+
// defaults — they do not replace.
|
|
1345
|
+
//
|
|
1346
|
+
// - essentialKeys: array of exact storage / cookie names to treat
|
|
1347
|
+
// as strictly-necessary. Easiest case.
|
|
1348
|
+
// - essentialPatterns: array of regex source strings, validated via
|
|
1349
|
+
// safeRegExp. For prefix or family matches.
|
|
1350
|
+
//
|
|
1351
|
+
// Use these instead of `patterns.essential` when you only want to
|
|
1352
|
+
// ADD entries to the essential category without replacing the
|
|
1353
|
+
// built-in patterns (zest_*, csrf*, xsrf*, session*, __host-*,
|
|
1354
|
+
// __secure-*).
|
|
1355
|
+
essentialKeys: [],
|
|
1356
|
+
essentialPatterns: [],
|
|
1357
|
+
|
|
1295
1358
|
// Custom domains to block (in addition to mode-based blocking)
|
|
1296
1359
|
blockedDomains: [], // days
|
|
1297
1360
|
|
|
@@ -1374,6 +1437,28 @@ var Zest = (function () {
|
|
|
1374
1437
|
config.patterns = userConfig.patterns;
|
|
1375
1438
|
}
|
|
1376
1439
|
|
|
1440
|
+
// Interceptor toggles — shallow-merge so consumers can pass partial
|
|
1441
|
+
// overrides like `intercept: { storage: false }` without losing the
|
|
1442
|
+
// other defaults.
|
|
1443
|
+
if (userConfig.intercept && typeof userConfig.intercept === 'object') {
|
|
1444
|
+
config.intercept = {
|
|
1445
|
+
...DEFAULTS.intercept,
|
|
1446
|
+
...userConfig.intercept
|
|
1447
|
+
};
|
|
1448
|
+
}
|
|
1449
|
+
|
|
1450
|
+
// Strictly-necessary declarations
|
|
1451
|
+
if (Array.isArray(userConfig.essentialKeys)) {
|
|
1452
|
+
config.essentialKeys = userConfig.essentialKeys.filter(
|
|
1453
|
+
(k) => typeof k === 'string' && k.length > 0 && k.length <= 200
|
|
1454
|
+
);
|
|
1455
|
+
}
|
|
1456
|
+
if (Array.isArray(userConfig.essentialPatterns)) {
|
|
1457
|
+
config.essentialPatterns = userConfig.essentialPatterns.filter(
|
|
1458
|
+
(p) => typeof p === 'string' && p.length > 0 && p.length <= 500
|
|
1459
|
+
);
|
|
1460
|
+
}
|
|
1461
|
+
|
|
1377
1462
|
return config;
|
|
1378
1463
|
}
|
|
1379
1464
|
|
|
@@ -1816,13 +1901,32 @@ var Zest = (function () {
|
|
|
1816
1901
|
setPatterns(currentConfig.patterns);
|
|
1817
1902
|
}
|
|
1818
1903
|
|
|
1904
|
+
// Append consumer-declared strictly-necessary entries on top of
|
|
1905
|
+
// whatever's already in the essential category. This is the friendly
|
|
1906
|
+
// alternative to overriding via `patterns.essential` directly.
|
|
1907
|
+
if (
|
|
1908
|
+
(Array.isArray(currentConfig.essentialKeys) && currentConfig.essentialKeys.length > 0) ||
|
|
1909
|
+
(Array.isArray(currentConfig.essentialPatterns) && currentConfig.essentialPatterns.length > 0)
|
|
1910
|
+
) {
|
|
1911
|
+
appendPatternsToCategory('essential', {
|
|
1912
|
+
keys: currentConfig.essentialKeys,
|
|
1913
|
+
patternStrings: currentConfig.essentialPatterns
|
|
1914
|
+
});
|
|
1915
|
+
}
|
|
1916
|
+
|
|
1819
1917
|
setConsentChecker$2(checkConsent);
|
|
1820
1918
|
setConsentChecker$1(checkConsent);
|
|
1821
1919
|
setConsentChecker(checkConsent);
|
|
1822
1920
|
|
|
1823
|
-
|
|
1824
|
-
|
|
1825
|
-
|
|
1921
|
+
// Interceptor toggles. By default everything is intercepted (back-compat
|
|
1922
|
+
// with v2.0 / v2.1). Consumers that gate scripts and storage themselves
|
|
1923
|
+
// can opt out per channel via `intercept: { storage: false, … }`.
|
|
1924
|
+
const intercept = currentConfig.intercept || { cookies: true, storage: true, scripts: true };
|
|
1925
|
+
if (intercept.cookies !== false) interceptCookies();
|
|
1926
|
+
if (intercept.storage !== false) interceptStorage();
|
|
1927
|
+
if (intercept.scripts !== false) {
|
|
1928
|
+
startScriptBlocking(currentConfig.mode, currentConfig.blockedDomains);
|
|
1929
|
+
}
|
|
1826
1930
|
|
|
1827
1931
|
const consent = loadConsent();
|
|
1828
1932
|
initialized = true;
|