{"version":3,"file":"client/scripts/product.f6e073b1a3f037eb4c33.js","mappings":"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","sources":["webpack://hayppgroup.commerce.web/webpack/runtime/chunk loaded","webpack://hayppgroup.commerce.web/./ClientApp/shared/scripts/easyfy.core.ts","webpack://hayppgroup.commerce.web/./ClientApp/shared/scripts/easyfy.utils.ts","webpack://hayppgroup.commerce.web/./ClientApp/shared/scripts/easyfy.decorators.ts","webpack://hayppgroup.commerce.web/./ClientApp/shared/scripts/easyfy.datalayer.ts","webpack://hayppgroup.commerce.web/./ClientApp/shared/scripts/easyfy.events/easyfy.eventdata.ts","webpack://hayppgroup.commerce.web/./ClientApp/shared/scripts/easyfy.events/exporters/eventExporter.stats.ts","webpack://hayppgroup.commerce.web/./ClientApp/shared/scripts/easyfy.events/easyfy.event.devlogger.ts","webpack://hayppgroup.commerce.web/./ClientApp/shared/scripts/easyfy.events/exporters/eventExporter.ga4.ts","webpack://hayppgroup.commerce.web/./ClientApp/web/scripts/services/features.service.ts","webpack://hayppgroup.commerce.web/./ClientApp/shared/scripts/easyfy.events/exporters/eventExporter.klaviyo.ts","webpack://hayppgroup.commerce.web/./ClientApp/shared/scripts/easyfy.events/easyfy.eventhandler.ts","webpack://hayppgroup.commerce.web/./ClientApp/shared/scripts/easyfy.axios.ts","webpack://hayppgroup.commerce.web/./ClientApp/web/scripts/services/reviews.service.ts","webpack://hayppgroup.commerce.web/./ClientApp/web/scripts/pages/product.ts","webpack://hayppgroup.commerce.web/./ClientApp/web/scripts/services/productoptions.service.ts","webpack://hayppgroup.commerce.web/./ClientApp/web/scripts/shared/utils.ts","webpack://hayppgroup.commerce.web/webpack/bootstrap","webpack://hayppgroup.commerce.web/webpack/runtime/compat get default export","webpack://hayppgroup.commerce.web/webpack/runtime/define property getters","webpack://hayppgroup.commerce.web/webpack/runtime/hasOwnProperty shorthand","webpack://hayppgroup.commerce.web/webpack/runtime/make namespace object","webpack://hayppgroup.commerce.web/webpack/runtime/runtimeId","webpack://hayppgroup.commerce.web/webpack/runtime/jsonp chunk loading","webpack://hayppgroup.commerce.web/webpack/startup"],"sourcesContent":["var deferred = [];\n__webpack_require__.O = (result, chunkIds, fn, priority) => {\n\tif(chunkIds) {\n\t\tpriority = priority || 0;\n\t\tfor(var i = deferred.length; i > 0 && deferred[i - 1][2] > priority; i--) deferred[i] = deferred[i - 1];\n\t\tdeferred[i] = [chunkIds, fn, priority];\n\t\treturn;\n\t}\n\tvar notFulfilled = Infinity;\n\tfor (var i = 0; i < deferred.length; i++) {\n\t\tvar [chunkIds, fn, priority] = deferred[i];\n\t\tvar fulfilled = true;\n\t\tfor (var j = 0; j < chunkIds.length; j++) {\n\t\t\tif ((priority & 1 === 0 || notFulfilled >= priority) && Object.keys(__webpack_require__.O).every((key) => (__webpack_require__.O[key](chunkIds[j])))) {\n\t\t\t\tchunkIds.splice(j--, 1);\n\t\t\t} else {\n\t\t\t\tfulfilled = false;\n\t\t\t\tif(priority < notFulfilled) notFulfilled = priority;\n\t\t\t}\n\t\t}\n\t\tif(fulfilled) {\n\t\t\tdeferred.splice(i--, 1)\n\t\t\tvar r = fn();\n\t\t\tif (r !== undefined) result = r;\n\t\t}\n\t}\n\treturn result;\n};","// exemple\n// element('.about'); //
\n// element('[data-action=\"top-nav\"]'); //
\n//export const element = (query: string) => document.querySelector(query);\nexport const element = (query: string) => document.querySelector(query);\n\nexport const elements = (query: string) => document.querySelectorAll(query);\n\nexport const elementsOf = (element: Element | HTMLElement, query: string) => element.querySelector(query);\n\n// exemple\n// elementContains(document.querySelector('head'), document.querySelector('title')); // true\n// elementContains(document.querySelector('body'), document.querySelector('body')); // false\nexport const elementContains = (parent: Element, child: Element) => parent !== child && parent.contains(child);\n\nexport const on = (action: string | Element, type: string, callback: Function, ref?: object, meta?: object) => {\n docReady(() => {\n type.split(' ').forEach(function (t) {\n (action instanceof Element ? action : element(action)).addEventListener(\n t,\n (e) => {\n try {\n callback.call(e.target, e, ref ?? null, meta ?? null);\n } catch (err) { }\n },\n { once: false, passive: true }\n );\n });\n });\n};\n\nexport const one = (action: string | Element, type: string, callback: Function) => {\n docReady(() => {\n type.split(' ').forEach(function (e) {\n (action instanceof Element ? action : element(action)).addEventListener(e, callback, { once: true });\n });\n });\n};\n\nexport const event = (action: string, type: string, callback: EventListener | EventListenerObject) => {\n docReady(() => {\n element(`[data-event=\"${action}\"]`)?.addEventListener(type, callback, false);\n });\n};\n\nexport const events = (action: string, type: string, callback: EventListener | EventListenerObject) => {\n docReady(() => {\n elements(`[data-event=\"${action}\"]`)?.forEach((item) => {\n item.addEventListener(type, callback, false);\n });\n });\n};\n\nexport const action = (action: string, type: string, callback: EventListener | EventListenerObject) => {\n docReady(() => {\n element(`[data-action=\"${action}\"]`)?.addEventListener(type, callback, false);\n });\n};\n\nexport const actions = (action: string, type: string, callback: EventListener | EventListenerObject | Function) => {\n docReady(() => {\n elements(`[data-action=\"${action}\"]`)?.forEach((el) => el?.addEventListener(type, callback, false));\n });\n};\n\nexport const bind = (action: string, type: string, callback: EventListener | EventListenerObject) => {\n docReady(() => {\n elements(action || '')?.forEach((item) => {\n type.split(' ').forEach(t => {\n item.addEventListener(t, callback, false);\n });\n });\n });\n};\n\nexport const off = (action: string | Element | HTMLElement | Array, type: string, callback: EventListener | EventListenerObject) => {\n if (action instanceof String || action instanceof Element || action instanceof HTMLElement) {\n (action instanceof Element || action instanceof HTMLElement ? action : element(action)).removeEventListener(type, callback, false);\n }\n\n if (action instanceof Array) {\n for (let x of action) {\n let item: any = x;\n (item instanceof Element || item instanceof HTMLElement ? item : element(item)).removeEventListener(type, callback, false);\n }\n }\n};\n\nexport const offAll = (action: string, type: string, callback: EventListener | EventListenerObject) => {\n elements(action).forEach((item) => {\n item.removeEventListener(type, callback, false);\n });\n};\n\nexport interface IEventChain {\n target: string;\n type: string;\n events: Array;\n}\n\nexport interface IEventChainItem {\n action?: string;\n event?: string;\n callback?: Function;\n}\n\nexport const eventChain = (arg: IEventChain) => {\n bind(arg.target, arg.type, (e) => {\n const target: any = e.target;\n let eventTarget = target?.attributes['data-action']?.value ?? target?.attributes['data-event']?.value;\n\n if (!eventTarget) eventTarget = target.parentNode?.attributes['data-action']?.value ?? target.parentNode?.attributes['data-event']?.value;\n\n if (!eventTarget) return;\n\n const item: any = arg.events.find(({ action, event }) => (action ?? event).includes(eventTarget));\n if (item?.callback) item.callback(e);\n });\n};\n\nexport const getBlazorEditMode = () => {\n if (!window.isAdminModeEnabled) {\n return false;\n }\n if (window.isEditModeEnabled !== undefined) {\n // Return value to avoid parsing cookies constantly\n return window.isEditModeEnabled;\n }\n const cookies = document.cookie.split(\";\");\n const editModeCookie = cookies.find(cookie => cookie.trim().startsWith(\"_AdminEditMode\"));\n window.isEditModeEnabled = editModeCookie?.split(\"=\")[1].toLowerCase() === \"true\";\n return window.isEditModeEnabled;\n}\n\n\n// Need to wait for blazor\n\nexport const docReady = (callback?: Function, context?: Object | string | number | boolean) => {\n\n let blazorFinishedLoadingEventRegistered: boolean = true;\n\n // Method to trigger window events\n if (!window.EasyfyMethods) {\n window.EasyfyMethods = {};\n window.EasyfyMethods.triggerWindowEvent = (eventName, eventData) => {\n if (eventName) {\n let event = new CustomEvent(eventName, {\n detail: eventData\n });\n window.dispatchEvent(event);\n }\n }\n }\n\n if (getBlazorEditMode()) {\n blazorFinishedLoadingEventRegistered = false;\n }\n\n // The public function name defaults to window.docReady\n // but you can pass in your own object and own function name and those will be used\n // if you want to put them in a different namespace\n // funcName = funcName || \"docReady\";\n // baseObj = baseObj || window;\n let readyList = [];\n let readyFired = false;\n let readyEventHandlersInstalled = false;\n\n // call this when the document is ready\n // this function protects itself against being called more than once\n const ready = () => {\n const readyBody = () => {\n if (!readyFired) {\n // this must be set to true before we start calling callbacks\n readyFired = true;\n for (var i = 0; i < readyList.length; i++) {\n // if a callback here happens to add new ready handlers,\n // the docReady() function will see that it already fired\n // and will schedule the callback to run right after\n // this event loop finishes so all handlers will still execute\n // in order and no new ones will be added to the readyList\n // while we are processing the list\n readyList[i].fn.call(window, readyList[i].ctx);\n // allow any closures held by these functions to free\n }\n readyList = [];\n }\n }\n if (getBlazorEditMode() && !window.blazorFinishedLoading) {\n if (!blazorFinishedLoadingEventRegistered) {\n blazorFinishedLoadingEventRegistered = true;\n window.addEventListener('blazorFinishedLoading', () => {\n window.blazorFinishedLoading = true;\n readyBody();\n }, false);\n }\n }\n else {\n readyBody();\n }\n\n };\n\n const readyStateChange = () => {\n if (document.readyState === 'complete') {\n ready();\n }\n };\n\n // This is the one public interface\n // docReady(fn, context);\n // the context argument is optional - if present, it will be passed\n // as an argument to the callback\n\n if (typeof callback !== 'function') {\n throw new TypeError('callback for docReady(fn) must be a function');\n }\n // if ready has already fired, then just schedule the callback\n // to fire asynchronously, but right away\n if (readyFired) {\n setTimeout(function () {\n callback(context);\n }, 1);\n return;\n } else {\n // add the function and context to the list\n readyList.push({ fn: callback, ctx: context });\n }\n // if document already ready to go, schedule the ready function to run\n if (document.readyState === 'complete') {\n setTimeout(ready, 1);\n } else if (!readyEventHandlersInstalled) {\n // otherwise if we don't have event handlers installed, install them\n if (document.addEventListener) {\n // first choice is DOMContentLoaded event\n document.addEventListener('DOMContentLoaded', ready, false);\n // backup is window load event\n window.addEventListener('load', ready, false);\n }\n readyEventHandlersInstalled = true;\n }\n};\n\nexport interface IEvent {\n type: string;\n event?: IEventItem;\n events?: Array;\n}\n\nexport interface IEventItem {\n action?: string;\n event?: string;\n callback?: Function;\n}\n\ninterface IGlobalEventItem {\n type: string;\n action?: string;\n event?: string;\n callback?: Array;\n}\n\n// Global event\nexport let globalEventList: Array = [];\n\nexport const globalEvent = (event: IEvent) => {\n event.type.split(' ').forEach((type) => {\n if (event.event) event.events = [...(event.events ?? []), ...[event.event]];\n\n if (event.events) {\n for (let item of event.events) {\n let foundItem;\n\n if (item?.action) {\n let actionFound: IGlobalEventItem = globalFindAction(type, item?.action);\n if (actionFound) {\n foundItem = actionFound;\n }\n }\n\n if (item?.event) {\n let eventFound: IGlobalEventItem = globalFindEvent(type, item?.event);\n if (eventFound) {\n foundItem = eventFound;\n }\n }\n\n if (!item?.event && !item?.action) {\n // check global state.\n let globalFound: IGlobalEventItem = globalFind(type);\n if (globalFound) {\n foundItem = globalFound;\n }\n }\n\n foundItem ? foundItem.callback.push(item.callback) : globalEventAdd(type, item);\n }\n }\n\n document.body.removeEventListener(type, globalEventHandler);\n document.body.addEventListener(type, globalEventHandler);\n });\n};\n\nexport const debounce = (func, wait) => {\n let timeout;\n\n return function executedFunction(...args) {\n const later = () => {\n clearTimeout(timeout);\n func(...args);\n };\n\n clearTimeout(timeout);\n timeout = setTimeout(later, wait);\n };\n};\n\nconst globalEventHandler = (e) => {\n const target: any = e.target;\n\n // check action\n let eventTarget = globalGetTargetAction(target);\n if (eventTarget) {\n const item: IGlobalEventItem = globalFindAction(e.type, eventTarget);\n if (item?.callback) {\n globalEventInvokeCallback(item?.callback, e);\n }\n return;\n }\n\n // check event\n eventTarget = globalGetTargetEvent(target);\n if (eventTarget) {\n const item: IGlobalEventItem = globalFindEvent(e.type, eventTarget);\n if (item?.callback) {\n globalEventInvokeCallback(item?.callback, e);\n }\n return;\n }\n\n // check event\n const item = globalMatchType(e.type);\n if (item?.callback) {\n globalEventInvokeCallback(item?.callback, e);\n return;\n }\n};\n\nconst globalEventInvokeCallback = (cbs: Array, e: any) => {\n for (let item of cbs) {\n item?.call(null, e);\n }\n};\n\nconst globalEventAdd = (type: string, item: IEventItem): void => {\n globalEventList.push({\n type: type,\n action: item?.action,\n event: item?.event,\n callback: [item?.callback],\n });\n};\n\nconst globalFind = (itemType: string): IGlobalEventItem => {\n return globalEventList.find(({ type, action, event }) => type === itemType && !action && !event);\n};\n\nconst globalFindEvent = (itemType: string, eventType: string): IGlobalEventItem => globalEventList.find(({ type, event }) => type === itemType && (event ?? '') === (eventType ?? ''));\n\nconst globalFindAction = (itemType: string, actionType: string): IGlobalEventItem => globalEventList.find(({ type, action }) => type === itemType && (action ?? '') === (actionType ?? ''));\n\nconst globalMatchType = (itemType: string): IGlobalEventItem => globalEventList.find(({ type, action, event }) => type === itemType && !action && !event);\n\nconst globalGetTargetAction = (target) => globalGetTarget(target, 'data-action');\n\nconst globalGetTargetEvent = (target) => globalGetTarget(target, 'data-event');\n\nconst globalGetTarget = (target, dataTarget: string) => {\n let eventTarget = target?.attributes[dataTarget]?.value;\n if (!eventTarget) eventTarget = target.parentNode?.attributes[dataTarget]?.value;\n return eventTarget;\n};","import { element, elements } from './easyfy.core';\n/*import mobileDetect from 'mobile-detect';*/\n\nexport interface Attribute {\n name: string;\n value: string;\n}\n\n/*export const detector = new mobileDetect(window.navigator.userAgent);*/\n\n// exemple\n// findKey(\n// {\n// barney: { age: 36, active: true },\n// fred: { age: 40, active: false },\n// pebbles: { age: 1, active: true }\n// },\n// o => o['active']\n// ); // 'barney\nexport const findKey = (obj: any, fn: any) => Object.keys(obj).find((key) => fn(obj[key], key, obj));\n\n// exemple\n// findLast([1, 2, 3, 4], n => n % 2 === 1); // 3\nexport const findLast = (arr: Array, fn: any) => arr.filter(fn).pop();\n\n// exemple\n// all([4, 2, 3], x => x > 1); // true\n// all([1, 2, 3]); // true\nexport const all = (arr: Array, fn = Boolean) => arr.every(fn);\n\n// exemple\n// allEqual([1, 2, 3, 4, 5, 6]); // false\n// allEqual([1, 1, 1, 1]); // true\nexport const allEqual = (arr: Array) => arr.every((val) => val === arr[0]);\n\n// exemple\n// arrayToHtmlList('#myListID', 'li' ,['item 1', 'item 2']);\nexport const arrayToHtmlList = (selector: string, elementType: string, arr: Array) => ((el) => ((el = document.querySelector(selector)), (el.innerHTML += arr.map((item) => `<${elementType}>${item}`).join(''))))();\n\n// exemple\n//hasClass(document.querySelector('p.special'), 'special'); // true\nexport const hasClass = (el: HTMLElement, className: string) => el?.classList?.contains(className);\n\n// exemple\n// isBrowserTabFocused(); // true\nexport const isBrowserTabFocused = () => !document.hidden;\n\n// exemple\n// isNil(null); // true\n// isNil(undefined); // true\nexport const isNil = (val: any) => val === undefined || val === null;\n\n// exemple\n// isNull(null); // true\nexport const isNull = (val: any) => val === null;\n\n// exemple\n// isNumber('1'); // false\n// isNumber(1); // true\nfunction isNumber(n: any) {\n return !isNaN(parseFloat(n)) && isFinite(n);\n}\n\n// exemple\n// isObject([1, 2, 3, 4]); // true\n// isObject([]); // true\n// isObject(['Hello!']); // true\n// isObject({ a: 1 }); // true\n// isObject({}); // true\n// isObject(true); // false\nexport const isObject = (obj: any) => obj === Object(obj);\n\n// exemple\n// isObjectLike({}); // true\n// isObjectLike([1, 2, 3]); // true\n// isObjectLike(x => x); // false\n// isObjectLike(null); // false\nexport const isObjectLike = (val: any) => val !== null && typeof val === 'object';\n\n// exemple\n// isPlainObject({ a: 1 }); // true\n// isPlainObject(new Map()); // false\n// export const isPlainObject = (val: any) =>\n// !!val && typeof val === \"object\" && val.export && constructor === Object;\n\n// exemple\n// isString('10'); // true\nexport const isString = (val: any) => typeof val === 'string';\n\n// exemple\n// isUndefined(undefined); // true\nexport const isUndefined = (val: any) => val === undefined;\n\n// exemple\n// parse string into boolean\nexport const parseToBoolean = (val: string) => isString(val) && val?.toLowerCase() === 'true';\n\n// exemple\n// isValidJSON('{\"name\":\"Adam\",\"age\":20}'); // true\n// isValidJSON('{\"name\":\"Adam\",age:\"20\"}'); // false\n// isValidJSON(null); // true\nexport const isValidJSON = (str: string) => {\n try {\n JSON.parse(str);\n return true;\n } catch (e) {\n return false;\n }\n};\n\nexport const replaceHtml = (element: HTMLElement, html: string) => {\n if (element?.outerHTML) {\n element.outerHTML = html;\n }\n else {\n let tmpElement = document.createElement(\"div\");\n tmpElement.innerHTML = html;\n element?.parentNode?.replaceChild(tmpElement, element);\n }\n};\n\n// exemple\n// matches({ age: 25, hair: 'long', beard: true }, { hair: 'long', beard: true }); // true\n// matches({ hair: 'long', beard: true }, { age: 25, hair: 'long', beard: true }); // false\nexport const matches = (obj: any, source: any) => Object.keys(source).every((key) => obj.hasOwnProperty(key) && obj[key] === source[key]);\n\n// exemple\n// randomHexColorCode(); // \"#e34155\"\nexport const randomHexColorCode = () => {\n let n = (Math.random() * 0xfffff * 1000000).toString(16);\n return '#' + n.slice(0, 6);\n};\n\n// exemple\n// redirect('https://google.com');\nexport const redirect = (url, asLink = true) => (asLink ? (window.location.href = url) : window.location.replace(url));\n\n// exemple\n// scrollToTop();\nexport const scrollToTop = () => {\n const c = document.documentElement.scrollTop || document.body.scrollTop;\n if (c > 0) {\n window.requestAnimationFrame(scrollToTop);\n window.scrollTo(0, c - c / 8);\n }\n};\n\n// exemple\n// setStyle('p', 'font-size', '20px');\nexport const setStyle = (selector: string, ruleName: string, val: string) => (element(selector).style[ruleName] = val);\n\n// exemple\n// getStyle('p', 'font-size');\nexport const getStyle = (selector: string, ruleName: string) => element(selector).style[ruleName];\n\n// exemple\n// show(...document.querySelectorAll(\"img\")); // Shows all elements on the page\nexport const showAll = (el: Array, displayType?: string) => [...el].forEach((e) => (e.style.display = displayType || 'block'));\n\n// exemple\n// hide(document.querySelectorAll('img')); // Hides all elements on the page\nexport const hideAll = (el: Array | NodeListOf) => el.forEach((e) => (e.style.display = 'none'));\n\nexport const show = (selector: string | Element, displayType?: string) => showAll([selector instanceof Element ? selector : element(selector)], displayType);\n\nexport const hide = (selector: string | Element) => hideAll([selector instanceof Element ? selector : element(selector)]);\n\nexport const toggleShow = (selector: string, displayType?: string) => {\n const el = element(selector);\n visible(el) ? hideAll([el]) : showAll([el], displayType);\n};\n\nexport const removeCss = (el: HTMLElement | Element | Array | NodeListOf, className: string | Array) => {\n if (Array.isArray(el) || el instanceof NodeList) {\n el.forEach((element) => {\n Array.isArray(className) ? element?.classList?.remove(...className) : element?.classList?.remove(className);\n });\n } else {\n Array.isArray(className) ? (el as HTMLElement | Element)?.classList?.remove(...className) : (el as HTMLElement | Element)?.classList?.remove(className);\n return el;\n }\n};\n\nexport const addCss = (el: HTMLElement | Element, className: string | Array) => {\n if (Array.isArray(className)) {\n el?.classList?.add(...className);\n return el;\n }\n\n el?.classList?.add(className);\n return el;\n};\n\n// exemple\n// async function sleepyWork() {\n// console.log(\"I'm going to sleep for 1 second.\");\n// await sleep(1000);\n// console.log('I woke up after 1 second.');\n// }\nexport const sleep = (ms: number) => new Promise((resolve) => setTimeout(resolve, ms));\n\nexport const visible = (element: HTMLElement): boolean => {\n return !!(element.offsetWidth || element.offsetHeight || element.getClientRects().length);\n};\n\n// exemple\n// smoothScroll('#fooBar'); // scrolls smoothly to the element with the id fooBar\n// smoothScroll('.fooBar'); // scrolls smoothly to the first element with a class of fooBar\nexport const smoothScroll = (element: any) =>\n document.querySelector(element).scrollIntoView({\n behavior: 'smooth',\n });\n\n// exemple\n// splitLines('This\\nis a\\nmultiline\\nstring.\\n'); // ['This', 'is a', 'multiline', 'string.' , '']\nexport const splitLines = (str: string) => str.split(/\\r?\\n/);\n\n// exemple\n// stripHTMLTags('

lorem ipsum

'); // 'lorem ipsum'\nexport const stripHTMLTags = (str: string) => str.replace(/<[^>]*>/g, '');\n\n// exemple\n// sum(1, 2, 3, 4); // 10\n// sum(...[1, 2, 3, 4]); // 10\nexport const sum = (...arr: any) => [...arr].reduce((acc, val) => acc + val, 0);\n\n// exemple\n// timeTaken(() => Math.pow(2, 10)); // 1024, (logged): timeTaken: 0.02099609375ms\nexport const timeTaken = (callback: any) => {\n console.time(\"timeTaken\");\n const r = callback();\n console.timeEnd(\"timeTaken\");\n return r;\n};\n\n// exemple\n// toCurrency(123456.789, \"EUR\"); // €123,456.79 | currency: Euro | currencyLangFormat: Local\n// toCurrency(123456.789, 'USD', 'en-us'); // $123,456.79 | currency: US Dollar | currencyLangFormat: English (United States)\n// toCurrency(123456.789, 'USD', 'fa'); // ۱۲۳٬۴۵۶٫۷۹ ؜$ | currency: US Dollar | currencyLangFormat: Farsi\n// toCurrency(322342436423.2435, 'JPY'); // ¥322,342,436,423 | currency: Japanese Yen | currencyLangFormat: Local\n// toCurrency(322342436423.2435, 'JPY', 'fi'); // 322 342 436 423 ¥ | currency: Japanese Yen | currencyLangFormat: Finnish\nexport const toCurrency = (n: any, curr: any, languageFormat = undefined) =>\n Intl.NumberFormat(languageFormat, {\n style: 'currency',\n currency: curr,\n }).format(n);\n\n// exemple\n// toDecimalMark(12305030388.9087); // \"12,305,030,388.909\"\n// toDecimalMark(12305030388.9087, \"en-us\"); // \"12,305,030,388.909\"\nexport const toDecimalMark = (num: any, languageFormat = undefined) => num.toLocaleString(languageFormat);\n\n// exemple\n// toggleClass('p.special', 'special'); // The paragraph will not have the 'special' class anymore\nexport const toggleClass = (selector: string | HTMLElement, className: any, force?: boolean) => {\n //if (selector instanceof String) easyfyCore.element(selector as string).classList.toggle(className);\n\n if (selector instanceof HTMLElement) selector.classList.toggle(className, force);\n};\n\nexport const debounce = any>(func: F, waitFor: number) => {\n let timeout;\n\n return (...args: Parameters): Promise> =>\n new Promise((resolve) => {\n if (timeout) {\n clearTimeout(timeout);\n }\n\n timeout = setTimeout(() => resolve(func(...args)), waitFor);\n });\n};\n\nexport const isFunction = (f: Function) => {\n return f && {}.toString.call(f) === '[object Function]';\n};\n\nexport const Id = (len: number) => {\n return '_' + Math.random().toString(36).substr(2, len);\n};\n\nexport const toggleClassBySelector = (selector: string, className: string, toggle: boolean) => {\n let els = elements(selector);\n els.forEach((item) => {\n if (toggle) {\n addCss(item, className);\n } else {\n removeCss(item, className);\n }\n });\n};\n\nexport const setAttributes = (element: HTMLElement, attributes: Array): HTMLElement | Element => {\n attributes.forEach((item) => {\n if (item?.name && item?.value) {\n element.setAttribute(item.name, item.value);\n }\n });\n return element;\n};\n\nexport const offset = (element: HTMLElement): { top: number; left: number } => {\n const rect = element.getBoundingClientRect(),\n scrollLeft = window.pageXOffset || document.documentElement.scrollLeft,\n scrollTop = window.pageYOffset || document.documentElement.scrollTop;\n return { top: rect.top + scrollTop, left: rect.left + scrollLeft };\n};\n\nexport const winHeight = () => window.innerHeight || document.documentElement.clientHeight || document.body.clientHeight;\nexport const winWidth = () => window.innerWidth || document.documentElement.clientWidth || document.body.clientWidth;\nexport const isMobile = () => window.innerWidth <= 768 ? true : false;\n\nexport const isBetweenDates = (startDate: Date, endDate: Date, checkDate: Date) => {\n if (checkDate > startDate && checkDate < endDate) {\n return true;\n }\n return false;\n};\n\n//todo: support other short date string formats other then 2020-01-01\nexport const getDate = (date: string) => {\n if (date !== \"\") {\n var d = date.split(\"-\");\n if (d.length == 3) {\n return new Date(parseInt(d[0]), parseInt(d[1]) - 1, parseInt(d[2]));\n }\n }\n return new Date();\n};\nexport const getSelectedValue = (select: HTMLSelectElement) => {\n if (select) {\n const selectedOption = select.options[select.selectedIndex];\n return { text: selectedOption.text, value: selectedOption.value };\n }\n return;\n};\n\nexport const removeHash = () => {\n var scrollV, scrollH, loc = window.location;\n if (\"pushState\" in history) {\n history.pushState(\"\", document.title, loc.pathname + loc.search);\n } else {\n // Prevent scrolling by storing the page's current scroll offset\n scrollV = document.body.scrollTop;\n scrollH = document.body.scrollLeft;\n\n loc.hash = \"\";\n\n // Restore the scroll offset, should be flicker free\n document.body.scrollTop = scrollV;\n document.body.scrollLeft = scrollH;\n }\n};","import { docReady, event as eventHandler, events as eventsHandler, action as actionHandler, actions as actionsHandler, bind as bindHandler } from './easyfy.core';\nimport { Id } from './easyfy.utils';\n\nexport interface Idependencies {\n func: { new(...args: any[]): {} };\n data?: any;\n}\n\ninterface IActionEvent {\n target: string;\n type: string;\n meta?: object;\n}\n\ninterface IInjectorDependencies {\n name: string;\n func: object;\n}\n\ninterface IInjector {\n dependencies: {\n [key: string]: IInjectorDependencies;\n };\n resolveOnload: Array;\n resolve: (depends: Array, ctor: any, cb: Function) => void;\n}\n\nexport const invoke = function (ctor: T): void {\n let newClass: Object;\n\n const readyAfter = () => {\n // call class function onInit\n try {\n ctor?.prototype?.onInit?.apply(newClass);\n } catch (error) {\n console.log('Invoke onInit error', error);\n }\n };\n\n const init = (resolves?: Array) => {\n try {\n newClass = new ctor(...(resolves || []));\n } catch (err) {\n console.log('Error ', err);\n }\n\n if (ctor.prototype.hasOwnProperty('onInit')) {\n // Use the handy event callback\n docReady(readyAfter);\n }\n };\n\n const depends = ctor['depends'];\n depends\n ? injector.resolve(ctor['depends'], ctor, (resolves) => {\n delete ctor['depends'];\n init(resolves);\n })\n : init();\n};\n\n\nconst injector: IInjector = {\n dependencies: {},\n resolveOnload: [],\n resolve: function (depends: Array, ctor: any, cb?: Function): void {\n depends.forEach((item) => {\n const id = Id(10);\n injector.dependencies[id] = { name: id, func: new item.func(item.data || {}) };\n if (injector.dependencies[id].func.hasOwnProperty('loaded')) {\n injector.resolveOnload.push(id);\n }\n });\n\n if (injector.resolveOnload.length > 0) {\n injector.resolveOnload.forEach((item, index) => {\n if (injector.dependencies[item].func.hasOwnProperty('loaded')) {\n const dependencyItem = injector.dependencies[item].func;\n\n let loadedVal = dependencyItem['loaded'];\n Object.defineProperty(dependencyItem, 'loaded', {\n get: () => {\n return loadedVal;\n },\n set: function (val) {\n if (val !== loadedVal) {\n if (val) {\n if (dependencyItem) {\n injector.resolveOnload.splice(index, 1);\n delete dependencyItem['loaded'];\n\n if (injector.resolveOnload.length === 0 && cb) {\n let dependencyFunc: Array = [];\n for (const key in injector.dependencies) {\n if (injector.dependencies.hasOwnProperty(key)) {\n const item = injector.dependencies[key];\n dependencyFunc.push(item.func);\n }\n }\n cb.call(this, dependencyFunc);\n }\n }\n }\n }\n\n loadedVal = val;\n },\n enumerable: true,\n configurable: true,\n });\n }\n });\n } else {\n cb?.call(this);\n }\n },\n};\n\ntype InferValue = Desc extends { get(): any; value: any } ? never : Desc extends { value: infer T } ? Record : Desc extends { get(): infer T } ? Record : never;\n\ntype DefineProperty = Desc extends { writable: any; set(val: any): any }\n ? never\n : Desc extends { writable: any; get(): any }\n ? never\n : Desc extends { writable: false }\n ? Readonly>\n : Desc extends { writable: true }\n ? InferValue\n : Readonly>;\n\nfunction defineProperty(obj: Obj, prop: Key, val: PDesc): asserts obj is Obj & DefineProperty {\n Object.defineProperty(obj, prop, val);\n}\n\ndefineProperty(Object.prototype, 'watch', {\n enumerable: false,\n configurable: true,\n writable: false,\n value(this: any, prop, handler) {\n let oldval: any = this[prop],\n newval: any = oldval,\n getter = function () {\n return newval;\n },\n setter = function (this: any, val) {\n oldval = newval;\n return (newval = handler.call(this, prop, oldval, val));\n };\n\n if (delete this[prop]) {\n // can't watch constants\n Object.defineProperty(this, prop, {\n get: getter,\n set: setter,\n enumerable: true,\n configurable: true,\n });\n }\n },\n});\n\nexport const event = (event: IActionEvent) => {\n return (_target: any, _key: string, descriptor: PropertyDescriptor) => {\n eventHandler(event.target, event.type, actionEventHelper(descriptor, event.meta).value);\n };\n};\n\nexport const events = (event: IActionEvent) => {\n return (_target: any, _key: string, descriptor: PropertyDescriptor) => {\n eventsHandler(event.target, event.type, actionEventHelper(descriptor, event.meta).value);\n };\n};\n\nexport const action = (event: IActionEvent) => {\n return (_target: any, _key: string, descriptor: PropertyDescriptor) => {\n actionHandler(event.target, event.type, actionEventHelper(descriptor, event.meta).value);\n };\n};\n\nexport const actions = (event: IActionEvent) => {\n return (_target: any, _key: string, descriptor: PropertyDescriptor) => {\n actionsHandler(event.target, event.type, actionEventHelper(descriptor, event.meta).value);\n };\n};\n\nexport const bind = (event: IActionEvent) => {\n return (_target: any, _key: string, descriptor: PropertyDescriptor) => {\n bindHandler(event.target, event.type, actionEventHelper(descriptor, event.meta).value);\n };\n};\n\nconst actionEventHelper = (descriptor: PropertyDescriptor, meta?: object) => {\n const decorated: Function = descriptor.value;\n descriptor.value = function (event: Event) {\n if (event?.preventDefault) event?.preventDefault();\n\n return decorated.apply(this, [...Array.from(arguments), meta]);\n };\n return descriptor;\n};","\nnamespace Easyfy.Shared.Scripts {\n export interface IGtmEvent {\n event: string;\n ecommerce: object;\n }\n\n export interface IActionField {\n list: string;\n }\n\n export interface ICheckoutActionField {\n step: number;\n option: string;\n }\n export interface IGtmImpressionProduct extends ProductBase {\n position: number;\n list: string;\n }\n\n export interface IGtmClickProduct extends ProductBase {\n position: number;\n dimension6: string; // depict-recommendation\n }\n\n export interface IGtmBasketProduct extends ProductBase {\n quantity: number;\n }\n\n export interface IGtmDetailProduct extends ProductBase { };\n\n interface ProductBase {\n name: string;\n id: string;\n price: number;\n brand: string,\n category: string;\n variant: string;\n dimension3: string; // product-type\n dimension4: string; // ean\n dimension5: string; // all-categories\n dimension7: string; //prescriptive (excluded for facebook)\n }\n\n\n export interface IGtmProductImpressionEvent {\n impressions: IGtmImpressionProduct[];\n currencyCode: string;\n };\n\n export interface IGtmProductClickEvent {\n click: {\n actionField: IActionField;\n products: IGtmClickProduct[];\n currencyCode: string;\n }\n };\n\n export interface IGtmProductDetailEvent {\n detail: {\n actionField: IActionField;\n products: IGtmDetailProduct[];\n currencyCode: string;\n }\n }\n\n export interface IGtmProductRemoveEvent {\n remove: {\n actionField: IActionField;\n products: IGtmBasketProduct[];\n }\n };\n\n export interface IGtmProductAddEvent {\n add: {\n actionField: IActionField;\n products: IGtmBasketProduct[];\n currencyCode: string;\n }\n };\n\n export interface IGtmCheckoutEvent {\n checkout: {\n actionField: ICheckoutActionField;\n products: IGtmBasketProduct[];\n }\n };\n\n export const PushProductImpressionEvent = async (eventProducts: IGtmImpressionProduct[], listName: string, currencyCode: string): Promise => {\n let impressionEvent: IGtmProductImpressionEvent = {\n impressions: eventProducts,\n currencyCode: currencyCode\n };\n let gtmEvent: IGtmEvent = {\n event: \"impressions\",\n ecommerce: impressionEvent\n }\n PushToDataLayer(gtmEvent);\n };\n\n export const PushProductClickEvent = async (eventProducts: IGtmClickProduct[], listName: string, currencyCode: string): Promise => {\n let clickEvent: IGtmProductClickEvent = {\n click: {\n actionField: {\n list: ListNameCleanUp(listName)\n },\n products: eventProducts,\n currencyCode: currencyCode\n }\n };\n let gtmEvent: IGtmEvent = {\n event: \"productClick\",\n ecommerce: clickEvent\n }\n PushToDataLayer(gtmEvent);\n };\n\n export const PushProductDetailEvent = async (eventProducts: IGtmDetailProduct[], listName: string, currencyCode): Promise => {\n let detailEvent: IGtmProductDetailEvent = {\n detail: {\n actionField: {\n list: ListNameCleanUp(listName)\n },\n products: eventProducts,\n currencyCode: currencyCode\n }\n };\n let gtmEvent: IGtmEvent = {\n event: \"productDetail\",\n ecommerce: detailEvent\n }\n PushToDataLayer(gtmEvent);\n };\n\n export const PushProductAddEvent = async (eventProducts: IGtmBasketProduct[], listName: string, currencyCode: string): Promise => {\n let removeEvent: IGtmProductAddEvent = {\n add: {\n actionField: {\n list: ListNameCleanUp(listName)\n },\n products: eventProducts,\n currencyCode: currencyCode\n }\n };\n let gtmEvent: IGtmEvent = {\n event: \"addToCart\",\n ecommerce: removeEvent\n }\n PushToDataLayer(gtmEvent);\n };\n\n export const PushProductRemoveEvent = async (eventProducts: IGtmBasketProduct[], listName: string): Promise => {\n let removeEvent: IGtmProductRemoveEvent = {\n remove: {\n actionField: {\n list: ListNameCleanUp(listName)\n },\n products: eventProducts,\n }\n };\n let gtmEvent: IGtmEvent = {\n event: \"removeFromCart\",\n ecommerce: removeEvent\n }\n PushToDataLayer(gtmEvent);\n };\n\n export const PushCheckoutEvent = async (eventProducts: IGtmBasketProduct[], step: number, option: string): Promise => {\n let checkoutEvent: IGtmCheckoutEvent = {\n checkout: {\n actionField: {\n step: step,\n option: option\n },\n products: eventProducts,\n }\n };\n let gtmEvent: IGtmEvent = {\n event: \"checkout\",\n ecommerce: checkoutEvent\n }\n PushToDataLayer(gtmEvent);\n };\n\n export const HandleDataEvents = async (response: any): Promise => {\n if (response?.data?.dataLayer) {\n BuildAndPushEvents(response.data.dataLayer);\n }\n return response;\n };\n\n export const BuildAndPushEvents = async (dataEvents: any): Promise => {\n if (!dataEvents) return;\n\n dataEvents.forEach(dataEvent => {\n let gtmEvent: IGtmEvent = null;\n if (!dataEvent?.eventName) return;\n\n switch (dataEvent.eventName) {\n case 'addToCart': {\n let products: IGtmBasketProduct[] = [];\n dataEvent.products.forEach(dataProduct => {\n let product: IGtmBasketProduct = {\n brand: dataProduct.brand,\n category: dataProduct.category,\n id: dataProduct.id,\n name: dataProduct.name,\n price: dataProduct.price,\n variant: dataProduct.variant,\n quantity: dataProduct.quantity,\n dimension3: dataProduct.dimension3,\n dimension4: dataProduct.dimension4,\n dimension5: dataProduct.dimension5,\n dimension7: dataProduct.dimension7\n };\n products.push(product);\n });\n PushProductAddEvent(products, dataEvent.listName, dataEvent.currencyCode);\n break;\n }\n case 'removeFromCart': {\n let products: IGtmBasketProduct[] = [];\n dataEvent.products.forEach(dataProduct => {\n let product: IGtmBasketProduct = {\n brand: dataProduct.brand,\n category: dataProduct.category,\n id: dataProduct.id,\n name: dataProduct.name,\n price: dataProduct.price,\n variant: dataProduct.variant,\n quantity: dataProduct.quantity,\n dimension3: dataProduct.dimension3,\n dimension4: dataProduct.dimension4,\n dimension5: dataProduct.dimension5,\n dimension7: dataProduct.dimension7\n };\n products.push(product);\n });\n PushProductRemoveEvent(products, dataEvent.listName)\n break;\n }\n case 'productClick': {\n let clickProducts: IGtmClickProduct[] = [];\n dataEvent.products.forEach(dataProduct => {\n let clickProduct: IGtmClickProduct = {\n brand: dataProduct.brand,\n category: dataProduct.category,\n id: dataProduct.id,\n name: dataProduct.name,\n price: dataProduct.price,\n variant: dataProduct.variant,\n position: dataProduct.position,\n dimension3: dataProduct.dimension3,\n dimension4: dataProduct.dimension4,\n dimension5: dataProduct.dimension5,\n dimension6: \"\",\n dimension7: dataProduct.dimension7\n };\n clickProducts.push(clickProduct);\n });\n PushProductClickEvent(clickProducts, dataEvent.listName, dataEvent.currencyCode)\n break;\n }\n case 'impressions': {\n let impressionProducts: IGtmImpressionProduct[] = [];\n dataEvent.products.forEach(dataProduct => {\n let impressionProduct: IGtmImpressionProduct = {\n brand: dataProduct.brand,\n category: dataProduct.category,\n id: dataProduct.id,\n name: dataProduct.name,\n price: dataProduct.price,\n variant: dataProduct.variant,\n position: dataProduct.position,\n list: ListNameCleanUp(dataProduct.list),\n dimension3: dataProduct.dimension3,\n dimension4: dataProduct.dimension4,\n dimension5: dataProduct.dimension5,\n dimension7: dataProduct.dimension7\n };\n impressionProducts.push(impressionProduct);\n });\n PushProductImpressionEvent(impressionProducts, dataEvent.listName, dataEvent.currencyCode)\n break;\n }\n case 'checkout': {\n let products: IGtmBasketProduct[] = [];\n dataEvent.products.forEach(dataProduct => {\n let product: IGtmBasketProduct = {\n brand: dataProduct.brand,\n category: dataProduct.category,\n id: dataProduct.id,\n name: dataProduct.name,\n price: dataProduct.price,\n variant: dataProduct.variant,\n quantity: dataProduct.quantity,\n dimension3: dataProduct.dimension3,\n dimension4: dataProduct.dimension4,\n dimension5: dataProduct.dimension5,\n dimension7: dataProduct.dimension7\n };\n products.push(product);\n });\n PushCheckoutEvent(products, dataEvent.step, dataEvent.option)\n break;\n }\n case 'productDetail': {\n let detailProducts: IGtmDetailProduct[] = [];\n dataEvent.products.forEach(dataProduct => {\n let detailProduct: IGtmDetailProduct = {\n brand: dataProduct.brand,\n category: dataProduct.category,\n id: dataProduct.id,\n name: dataProduct.name,\n price: dataProduct.price,\n variant: dataProduct.variant,\n dimension3: dataProduct.dimension3,\n dimension4: dataProduct.dimension4,\n dimension5: dataProduct.dimension5,\n dimension7: dataProduct.dimension7\n };\n detailProducts.push(detailProduct);\n });\n PushProductDetailEvent(detailProducts, dataEvent.listName, dataEvent.currencyCode)\n break;\n }\n default: {\n console.warn(\"Faulty data event: propterties name?\")\n console.dir(dataEvent);\n }\n }\n });\n };\n\n async function PushToDataLayer(gtmEvent: any): Promise {\n if (!gtmEvent) return;\n window['dataLayer'] = window['dataLayer'] || [];\n window['dataLayer'].push(gtmEvent);\n\n /* - For debugging the dataLayer - */\n //console.group('%c GA DataLayer ', 'color: #bada55');\n //console.dir(window['dataLayer']);\n //console.groupEnd();\n };\n\n const ListNameCleanUp = (listname: string): string => {\n if (!listname) return null;\n let cleanedListName = listname.replace(/\\s+/g, '').replace('&', '').toLowerCase();\n\n return cleanedListName;\n };\n}\n\nexport default Easyfy.Shared.Scripts;","import { event } from \"../easyfy.core\";\nimport { LocalStorageKeys } from \"./easyfy.eventhandler\";\nimport { parseToBoolean } from '../easyfy.utils';\n\ndeclare global {\n interface Window {\n EasyfyEventLayer: any,\n EasyfyEventLayerInstance: any\n isEditModeEnabled?: boolean;\n isAdminModeEnabled?: boolean;\n blazorFinishedLoading?: boolean;\n EasyfyMethods: any;\n }\n}\n\nexport interface IDataMapper {\n MapEventData(event: IEasyfyEvent): any;\n}\n\nexport interface IEasyfyEventExporter {\n mapper: IDataMapper;\n WithMapper(mapper: IDataMapper): void;\n RegisterEvent(event: IEasyfyEvent): Promise;\n};\n\nexport interface IEasyfyEvent {\n eventName: string;\n data: any;\n}\n\nexport interface IEasyfyEventService {\n name: string;\n includeAllEvents: boolean;\n events: string;\n enabled: boolean;\n}\n\nexport interface IEasyfySiteInfo {\n currencyCode: string;\n checkoutPath: string;\n}\n\nexport interface IEasyfyPageInfo {\n PageType: string;\n ViewName: string;\n}\n\nexport interface IProductData {\n Id: any;\n DomainId: any;\n Ean: any;\n DisplayName: any;\n Brand: any;\n Categories: any[];\n Price: number;\n PriceExVat: number;\n CampaignCode: string;\n AbsoluteProductUrl: string;\n RelativeProductUrl: string;\n ProductImageUrl: string;\n}\n\nexport interface IProductSalesUnitPrice {\n salesUnitsCode: string;\n packSize: number;\n priceExVat: number;\n priceIncVat: number;\n}\n\nexport interface IBasket {\n priceIncVat: number;\n priceExVat: number;\n priceIncVatExShipping: number;\n vat: number;\n rows: IBasketRow[];\n}\n\nexport interface IBasketRow {\n productIdentifier: string;\n qty: number;\n salesUnitCode: string;\n purchaseFlow: string;\n}\n\nexport interface IProductList {\n ListName: string;\n ListId: string;\n ProductIds: string[];\n}\n\nexport interface IBannerData {\n Id: any;\n DisplayName: any;\n PageUrl: any;\n LinkUrl: any;\n}\n\nexport interface ISearchPerformedData {\n searchString: string;\n source: string;\n productIdentifiers: any[];\n productHits: number;\n articleHits: number;\n brandHits: number;\n pageHits: number;\n totalProductResults: number;\n suggestions: any[];\n}\n\nexport interface IPageViewData {\n pageId: string;\n searchPageId: string;\n}\n\nexport interface IEventNotification {\n message: string;\n severity: string;\n}\n\nexport interface IQuantityChangedData {\n productIdentifier: string;\n listName: string;\n salesUnitCode: string;\n oldQuantity: number;\n newQuantity: number;\n}\n\nexport interface ISessionStarted {\n Culture: string;\n Currency: string;\n IsDesktop: boolean;\n IsMobilePhone: boolean;\n IsTablet: boolean;\n RecurringUser: boolean;\n Referrer: string;\n Path: string;\n UserAgent: string;\n SessionId: string;\n ClientId: string;\n UserId: string;\n VisitorId: string;\n}\n\nexport interface IWorkerJob {\n readonly Type: string;\n Data: any;\n Runs: number;\n MaxRuns: number;\n\n RunJob(data: any): Promise;\n AnonymizeWithDbId(db_id: any): any;\n}\n\nexport interface IWorkerMessage {\n Message: string;\n Data: any;\n}\n\nexport interface ITrackableElement {\n Id: any;\n Type: any;\n Properties: Map;\n}\n\nexport interface IClientEventMetaData {\n ClientId: string;\n UserId: string;\n SessionId: string;\n IsDesktop: boolean;\n IsMobilePhone: boolean;\n IsTablet: boolean;\n IPAddress: string;\n}\n\nexport interface IStatsEventData {\n ClientMetaData: IClientEventMetaData;\n EventRequests: any[];\n}\n\nexport module EasyfyEventData {\n export function AddDataToEventLayer(data: any): void {\n if (data) {\n window.EasyfyEventLayer = window.EasyfyEventLayer || {};\n data.events.forEach((event: any) => {\n if (!window.EasyfyEventLayer.events) {\n window.EasyfyEventLayer.events = [];\n }\n window.EasyfyEventLayer.events.push(event);\n });\n\n window.EasyfyEventLayer.products = window.EasyfyEventLayer.products || {};\n\n for (const product in data.products) {\n if (!window.EasyfyEventLayer.products || window.EasyfyEventLayer.products[product]) continue;\n window.EasyfyEventLayer.products[product] = data.products[product];\n }\n\n window.EasyfyEventLayer.productLists = window.EasyfyEventLayer.productLists || {};\n\n for (const productList in data.productLists) {\n //overwrite product list values when updated\n if (!window.EasyfyEventLayer.productLists || !window.EasyfyEventLayer.productLists[productList]) continue;\n window.EasyfyEventLayer.productLists[productList] = data.productLists[productList];\n }\n\n window.EasyfyEventLayer.productPrices = window.EasyfyEventLayer.productPrices || {};\n\n for (const price in data.productPrices) {\n //no need to overwrite price entries already in place\n if (!window.EasyfyEventLayer.productPrices || window.EasyfyEventLayer.productPrices[price]) continue;\n window.EasyfyEventLayer.productPrices[price] = data.productPrices[price];\n }\n\n window.EasyfyEventLayer.basket = window.EasyfyEventLayer.basket || {};\n\n if (data.basket) {\n window.EasyfyEventLayer.basket = data.basket;\n }\n\n for (const notification in data.notifications) {\n if (!window.EasyfyEventLayer.notifications) continue;\n window.EasyfyEventLayer.notifications.push(notification);\n }\n }\n }\n\n export function AddCustomDataToEventLayer(data: Map): void {\n\n if (!data) return;\n\n if (!window.EasyfyEventLayer.customData) {\n window.EasyfyEventLayer.customData = {};\n }\n data.forEach((value: object, key: string) => {\n window.EasyfyEventLayer.customData[key] = value;\n })\n }\n\n export function GlobalIgnoreEvents(): boolean {\n window.EasyfyEventLayer = window.EasyfyEventLayer || {};\n var result: boolean;\n if (window.EasyfyEventLayer.configuration?.addProductImpressionsServerSide != undefined) {\n result = (window.EasyfyEventLayer.configuration.addProductImpressionsServerSide as boolean) == false;\n }\n\n return result;\n }\n\n export function SiteInfo(): IEasyfySiteInfo {\n window.EasyfyEventLayer = window.EasyfyEventLayer || {};\n var result: IEasyfySiteInfo;\n if (window.EasyfyEventLayer.site) {\n result = window.EasyfyEventLayer.site as IEasyfySiteInfo;\n }\n\n return result;\n }\n\n export function PageInfo(): IEasyfyPageInfo {\n window.EasyfyEventLayer = window.EasyfyEventLayer || {};\n var result: IEasyfyPageInfo;\n if (window.EasyfyEventLayer.pageInfo) {\n result = window.EasyfyEventLayer.pageInfo as IEasyfyPageInfo;\n }\n\n return result;\n }\n\n export function Events(): IEasyfyEvent[] {\n window.EasyfyEventLayer = window.EasyfyEventLayer || {};\n var result: IEasyfyEvent[] = [];\n if (window.EasyfyEventLayer.events) {\n result = window.EasyfyEventLayer.events as IEasyfyEvent[];\n }\n\n return result;\n }\n\n export function ClearEvents(): void {\n window.EasyfyEventLayer = window.EasyfyEventLayer || {};\n if (window.EasyfyEventLayer.events) {\n window.EasyfyEventLayer.events = [];\n }\n }\n\n export function ShouldRegisterProductImpressions(): boolean {\n window.EasyfyEventLayer = window.EasyfyEventLayer || {};\n var result: boolean;\n if (window.EasyfyEventLayer.configuration?.addProductImpressionsServerSide != undefined) {\n result = (window.EasyfyEventLayer.configuration.addProductImpressionsServerSide as boolean) == false;\n }\n\n return result;\n }\n\n export function ShouldRegisterBannerImpressions(): boolean {\n window.EasyfyEventLayer = window.EasyfyEventLayer || {};\n var result: boolean;\n if (window.EasyfyEventLayer.configuration?.addBannerImpressionsServerSide != undefined) {\n result = (window.EasyfyEventLayer.configuration.addBannerImpressionsServerSide as boolean) == false;\n }\n\n return result;\n }\n\n export function GetAllServices(): IEasyfyEventService[] {\n window.EasyfyEventLayer = window.EasyfyEventLayer || {};\n var result: IEasyfyEventService[] = [];\n if (window.EasyfyEventLayer?.configuration?.services) {\n result = window.EasyfyEventLayer.configuration.services as IEasyfyEventService[];\n }\n\n return result;\n }\n\n export function GetService(serviceName: string): IEasyfyEventService {\n var service = EasyfyEventData.GetAllServices().find(serviceInstance => serviceInstance.name.toLowerCase() == serviceName.toLowerCase());\n return service;\n }\n\n export function GetServiceNames(): string[] {\n var result: string[] = [];\n EasyfyEventData.GetAllServices().forEach(service => result.push(service.name));\n return result;\n }\n\n export function ServiceIsActive(serviceName: string): boolean {\n var service = EasyfyEventData.GetAllServices().find(serviceInstance => serviceInstance.name.toLowerCase() == serviceName.toLowerCase());\n return (service && service.enabled);\n }\n\n export function ConsumesEvent(serviceName: string, eventName: string): boolean {\n var service = EasyfyEventData.GetService(serviceName);\n if (!service || !service.enabled) return false;\n if (service.includeAllEvents) {\n return true;\n }\n else {\n var serviceConsumables = service.events?.trim().replace(/\\s/g, '').split(\",\");\n return serviceConsumables.find(event => event.trim().toLowerCase() == eventName.toLowerCase()) != undefined ?? false;\n }\n }\n\n export function Product(id: string): T | undefined {\n window.EasyfyEventLayer = window.EasyfyEventLayer || {};\n var result: T = null;\n if (window.EasyfyEventLayer.products) {\n result = window.EasyfyEventLayer.products[id] as T;\n }\n return result;\n }\n\n export function ProductAt(atIndex: number): T | undefined {\n window.EasyfyEventLayer = window.EasyfyEventLayer || {};\n var result: T = null;\n try {\n if (window.EasyfyEventLayer.products) {\n result = window.EasyfyEventLayer.products[atIndex] as T;\n }\n }\n catch (error) { }\n\n return result;\n }\n\n export function Products(ids: string[]): T[] {\n var productDataSet: T[] = [];\n ids.forEach((id) => {\n productDataSet.push(EasyfyEventData.Product(id));\n });\n return productDataSet;\n }\n\n export function ProductsAt(indexes: number[]): T[] {\n var productDataSet: T[] = [];\n indexes.forEach((index) => {\n productDataSet.push(EasyfyEventData.ProductAt(index));\n });\n return productDataSet;\n }\n\n export function AllProducts(): T[] {\n window.EasyfyEventLayer = window.EasyfyEventLayer || {};\n var result: T[] = [];\n if (window.EasyfyEventLayer.products) {\n result = window.EasyfyEventLayer.products as T[];\n }\n return result;\n }\n export function AllProductLists(): IProductList[] {\n window.EasyfyEventLayer = window.EasyfyEventLayer || {};\n var result = [];\n if (window.EasyfyEventLayer.productLists) {\n result = window.EasyfyEventLayer.productLists;\n }\n return result;\n }\n\n export function ProductIndexInList(listName: string, productId: string): number | null {\n if (!listName || !productId) return null;\n var productsInList = window.EasyfyEventLayer.productLists[listName] as IProductList;\n if (!productsInList || !productsInList?.ProductIds) return null;\n var indexOfProduct = productsInList.ProductIds.indexOf(productId);\n\n return indexOfProduct;\n }\n\n export function ProductSalesUnitPrice(id: string): IProductSalesUnitPrice | undefined {\n window.EasyfyEventLayer = window.EasyfyEventLayer || {};\n var result: IProductSalesUnitPrice = null;\n\n if (window.EasyfyEventLayer.productPrices) {\n result = window.EasyfyEventLayer.productPrices[id] as IProductSalesUnitPrice;\n }\n\n return result;\n }\n\n export function ProductSalesUnitPrices(ids: string[]): IProductSalesUnitPrice[] | undefined {\n var prices: IProductSalesUnitPrice[] = [];\n ids.forEach((id) => {\n prices.push(EasyfyEventData.ProductSalesUnitPrice(id));\n });\n return prices;\n }\n\n export function AllProductSalesUnitPrices(): IProductSalesUnitPrice[] {\n window.EasyfyEventLayer = window.EasyfyEventLayer || {};\n var result: IProductSalesUnitPrice[] = [];\n\n if (window.EasyfyEventLayer.productPrices) {\n result = window.EasyfyEventLayer.productPrices as IProductSalesUnitPrice[];\n }\n\n return result;\n }\n\n export function Banner(id: string): IBannerData | undefined {\n window.EasyfyEventLayer = window.EasyfyEventLayer || {};\n var result: IBannerData = null;\n if (window.EasyfyEventLayer.banners) {\n result = window.EasyfyEventLayer.banners[id] as IBannerData;\n }\n return result;\n }\n\n export function AllBanners(): IBannerData[] {\n window.EasyfyEventLayer = window.EasyfyEventLayer || {};\n var result: IBannerData[] = [];\n if (window.EasyfyEventLayer.banners) {\n result = window.EasyfyEventLayer.banners as IBannerData[];\n }\n return result;\n }\n\n export function HasNotifications(): boolean {\n window.EasyfyEventLayer = window.EasyfyEventLayer || {};\n return (window.EasyfyEventLayer && window.EasyfyEventLayer.notifications?.length > 0);\n }\n\n export function Notifications(): IEventNotification[] {\n window.EasyfyEventLayer = window.EasyfyEventLayer || {};\n var result: IEventNotification[] = [];\n if (window.EasyfyEventLayer.notifications) {\n result = window.EasyfyEventLayer.notifications as IEventNotification[];\n }\n return result;\n }\n export function ClearNotifications():void {\n window.EasyfyEventLayer = window.EasyfyEventLayer || {};\n if (window.EasyfyEventLayer.notifications) {\n window.EasyfyEventLayer.notifications = [];\n }\n }\n\n export function HasEvents(): boolean {\n window.EasyfyEventLayer = window.EasyfyEventLayer || {};\n return (window.EasyfyEventLayer && window.EasyfyEventLayer.events?.length > 0);\n };\n\n export function Basket(): IBasket {\n window.EasyfyEventLayer.basket = window.EasyfyEventLayer.basket || {};\n var result: IBasket;\n if (window.EasyfyEventLayer.basket) {\n result = window.EasyfyEventLayer.basket as IBasket;\n }\n return result;\n };\n\n export function GetCurrencyCode(): string {\n var returnValue = null;\n window.EasyfyEventLayer = window.EasyfyEventLayer || {};\n if (window.EasyfyEventLayer && window.EasyfyEventLayer.site) {\n returnValue = window.EasyfyEventLayer.site.currencyCode as string;\n }\n\n return returnValue;\n };\n\n export function GetCustomData(key: string): any {\n if (!window.EasyfyEventLayer.customData) {\n window.EasyfyEventLayer.customData = {};\n }\n return window.EasyfyEventLayer.customData[key];\n }\n\n export function GetClientEventMetaData(): IClientEventMetaData {\n var result: IClientEventMetaData = {\n SessionId: localStorage.getItem(LocalStorageKeys.SessionId),\n UserId: localStorage.getItem(LocalStorageKeys.UserId),\n ClientId: localStorage.getItem(LocalStorageKeys.ClientId),\n IsDesktop: parseToBoolean(localStorage.getItem(LocalStorageKeys.IsDekstop)),\n IsMobilePhone: parseToBoolean(localStorage.getItem(LocalStorageKeys.IsMobilePhone)),\n IsTablet: parseToBoolean(localStorage.getItem(LocalStorageKeys.IsTablet)),\n IPAddress: localStorage.getItem(LocalStorageKeys.IPAddress)\n }\n return result;\n }\n\n export function IsRecurringUser(flagAsRecurringAfterCheck: boolean): boolean {\n var cookieKey = localStorage.getItem(LocalStorageKeys.UserIdCookieKey);\n var userId = EasyfyEventData.GetCookieValue(cookieKey);\n var lastCheckedUserId = localStorage.getItem(LocalStorageKeys.LastCheckedUserId);\n var result = false\n\n if (userId == lastCheckedUserId) {\n result = true;\n }\n\n if (flagAsRecurringAfterCheck) {\n localStorage.setItem(LocalStorageKeys.LastCheckedUserId, userId);\n }\n\n return result;\n }\n\n export function GetCookieValue(cookieName) {\n let cookie = {};\n document.cookie.split(';').forEach(function (el) {\n let [key, value] = el.split('=');\n cookie[key.trim()] = value;\n })\n return cookie[cookieName];\n }\n export function SetStatsApiBlock(block: boolean) {\n if (block) {\n localStorage.setItem(LocalStorageKeys.StatsIsBlocked, \"1\");\n }\n else {\n localStorage.removeItem(LocalStorageKeys.StatsIsBlocked);\n }\n }\n export function StatsApiIsBlocked(): boolean {\n var blockedFlag = localStorage.getItem(LocalStorageKeys.StatsIsBlocked);\n\n if (blockedFlag) {\n return true;\n }\n\n return false;\n }\n}\n\n","import { IEasyfyEvent, IDataMapper, IEasyfyEventExporter, EasyfyEventData, IStatsEventData } from '@shared/easyfy.events/easyfy.eventdata';\nimport { EventNames, LocalStorageKeys } from '../easyfy.eventhandler';\n\n/* Stats Exporter class */\nexport class StatsEventExporter implements IEasyfyEventExporter {\n private _eventData: IStatsEventData;\n private _blob: Blob;\n private readonly _payloadKbThreshold: number = 50;\n private readonly _eventThreshold: number = 3;\n private _eventThresholdRemoved: boolean = false;\n\n mapper: IDataMapper;\n async WithMapper(mapper: IDataMapper): Promise {\n this.mapper = mapper;\n await this.LoadAndSetTransitionStatus();\n document.addEventListener(\"visibilitychange\", this.CheckVisibility.bind(this));\n }\n\n public RegisterEvent(event: IEasyfyEvent): Promise {\n return new Promise(async (resolve) => {\n if (this.mapper) {\n if (!EasyfyEventData.StatsApiIsBlocked()) {\n const eventData = this.mapper.MapEventData(event);\n if (eventData) {\n if (Array.isArray(eventData)) {\n eventData.forEach(async (event) => {\n await this.AccumulateEvent(event);\n });\n }\n else {\n await this.AccumulateEvent(eventData);\n }\n }\n }\n }\n resolve();\n });\n }\n\n private async LoadAndSetTransitionStatus(): Promise {\n const eventThresholdRemoved = localStorage.getItem(LocalStorageKeys.StatsEventsThresholdRemoved);\n if (eventThresholdRemoved === \"true\") {\n this._eventThresholdRemoved = true;\n return;\n }\n\n const storedDataString = localStorage.getItem(LocalStorageKeys.StatsEventsTransitionObj);\n if (storedDataString) {\n\n try {\n this._eventData = JSON.parse(storedDataString) as IStatsEventData;\n } catch (error) {\n this._eventData = {\n ClientMetaData: null,\n EventRequests: []\n };\n }\n }\n }\n\n private async RecheckAndSetTransitionStatus(): Promise {\n\n let eventsMatch = 0;\n const skipEventNames = [EventNames.BannerImpression, EventNames.ElementImpression, EventNames.ProductImpression];\n\n for (const event of this._eventData?.EventRequests) {\n if (skipEventNames.includes(event?.Event?.type?.toLowerCase()) == false) {\n eventsMatch++;\n }\n }\n\n if (eventsMatch >= this._eventThreshold) {\n localStorage.setItem(LocalStorageKeys.StatsEventsThresholdRemoved, \"true\");\n this._eventThresholdRemoved = true;\n localStorage.removeItem(LocalStorageKeys.StatsEventsTransitionObj);\n }\n else {\n localStorage.setItem(LocalStorageKeys.StatsEventsTransitionObj, JSON.stringify(this._eventData));\n }\n }\n\n private async AccumulateEvent(event: any): Promise {\n return new Promise(async (resolve) => {\n if (!this._eventData || !this._eventData?.ClientMetaData || !this._eventData?.EventRequests) {\n this._eventData = {\n ClientMetaData: EasyfyEventData.GetClientEventMetaData(),\n EventRequests: []\n }\n }\n\n this._eventData.EventRequests.push({ \"Event\": event });\n\n const str = JSON.stringify(this._eventData);\n const bytes = new TextEncoder().encode(str);\n const blob = new Blob([bytes], {\n type: \"application/json;charset=utf-8\"\n });\n\n this._blob = blob;\n\n if (this._eventThresholdRemoved) {\n const payloadSize = await this.GetObjectSizeInKB(this._eventData);\n if (payloadSize > this._payloadKbThreshold) {\n await this.SendEventsToStatsApi();\n }\n }\n else {\n await this.RecheckAndSetTransitionStatus();\n }\n\n resolve();\n });\n }\n\n private async SendEventsToStatsApi(): Promise {\n if (this._eventData?.ClientMetaData && this._eventData?.EventRequests?.length > 0 && this._blob) {\n navigator.sendBeacon(\"/api/stats/events\", this._blob);\n this._eventData = null;\n this._blob = null;\n }\n }\n\n private async CheckVisibility() {\n if (document.visibilityState === \"hidden\" && this._eventThresholdRemoved) {\n await this.SendEventsToStatsApi();\n }\n }\n\n async GetObjectSizeInKB(obj: any): Promise {\n\n const jsonString = JSON.stringify(obj);\n const bytes = new TextEncoder().encode(jsonString).length;\n const kilobytes = bytes / 1024;\n\n return kilobytes;\n }\n}","import { EasyfyEventData, IEventNotification } from '@shared/easyfy.events/easyfy.eventdata';\nimport { IEasyfyEvent } from './easyfy.eventdata';\n\ndeclare var process: {\n env: {\n NODE_ENV: string\n }\n}\n\nexport module EasyfyEventLogger {\n\n const topParagraphStyle: string = \"line-height:6px; border-radius: 5px; width: fit-content;\";\n const paragraphStyle: string = \"line-height:6px; padding:6px; border-radius: 5px; width: fit-content;\";\n\n let _channelName: string = \"event_logger_channel\";\n let _broadcastChannel: BroadcastChannel = new BroadcastChannel(_channelName);\n\n export function ConsoleLog(message: string, prefix?: string, color?: string, bgColor?: string) {\n if (process.env.NODE_ENV === \"development\") {\n if (color == undefined) {\n color = '#ffffff';\n }\n\n var style = `color: ${color};`;\n\n if (bgColor) {\n style += `background: ${bgColor};`;\n }\n\n console.log(`%c ${prefix}${message}`, style);\n }\n }\n\n export function Log(this: any, obj): void {\n if (process.env.NODE_ENV === \"development\") {\n //return;\n\n try {\n var haveInjectedCss = window[\"injectedCss\"];\n if (!haveInjectedCss) {\n window[\"injectedCss\"] = true;\n var injectedCss = window.document.styleSheets[0];\n injectedCss.insertRule(`\n @keyframes messageFlash {\n 0% { background-color: rgba(255, 255, 255, 0);}\n 50% { background-color: rgba(255, 255, 255, 0.5);}\n 100% { background-color: rgba(255, 255, 255, 0);}\n }\n `, injectedCss.cssRules.length);\n\n injectedCss.insertRule(`.flash{\n animation: messageFlash 0.2s 2;\n }`, injectedCss.cssRules.length);\n\n injectedCss.insertRule(`\n @keyframes impressionBorder {\n 0% { border: 0px solid #ff7600; }\n 100% { border: 8px solid #ff7600; }\n }\n `, injectedCss.cssRules.length);\n\n injectedCss.insertRule(`.impressionSeen{\n animation: impressionBorder 0.8s 1;\n border: 8px solid #ff7600;\n }`, injectedCss.cssRules.length);\n\n injectedCss.insertRule(`#debugEventConsumer div{\n font-size: 12px;\n margin: 0px;\n padding: 0px;\n display: flex;\n\n .time{\n color:#8f8f8f;\n }\n\n pre {\n margin: 0 5px;\n\n span{\n color: #1fb5ff;\n }\n }\n }`, injectedCss.cssRules.length);\n\n \n }\n }\n catch (error) {\n console.warn(error);\n }\n\n var devEventLogButton = document.querySelector(\"#devEventLogButton\");\n if (!devEventLogButton) {\n var logButtonElem = document.createElement('div');\n logButtonElem.id = \"devEventLogButton\";\n logButtonElem.style.position = \"fixed\";\n logButtonElem.style.cursor = \"pointer\";\n logButtonElem.style.bottom = \"5px\";\n logButtonElem.style.left = \"5px\";\n logButtonElem.style.width = \"10px\";\n logButtonElem.style.height = \"10px\";\n logButtonElem.style.fontSize = \"10px\";\n logButtonElem.style.zIndex = \"2147483645\";\n\n logButtonElem.onclick = this.EnableLog;\n logButtonElem.innerHTML = \"🖥️\";\n\n document.querySelector('body').appendChild(logButtonElem);\n }\n\n var devEventOutput = document.querySelector(\"#devEventOutput\");\n if (!devEventOutput) {\n var outputDiv = document.createElement('div');\n outputDiv.id = \"devEventOutput\";\n outputDiv.style.position = \"fixed\";\n outputDiv.style.backgroundColor = \"#000000de\";\n outputDiv.style.color = \"#c4c4c4\";\n outputDiv.style.zIndex = \"2147483646\";\n outputDiv.style.width = \"100%\";\n outputDiv.style.height = \"200px\";\n outputDiv.style.bottom = \"0\";\n outputDiv.style.fontSize = \"10px\";\n outputDiv.style.fontFamily = \"Roboto, Helvetica\";\n outputDiv.style.lineHeight = \"4px\";\n outputDiv.style.display = \"grid\";\n outputDiv.style.gridTemplateColumns = \"120px 1fr\";\n outputDiv.style.gridTemplateRows = \"30px 1fr\";\n\n var topElement = document.createElement('div');\n topElement.style.position = \"sticky\";\n topElement.style.top = \"0px\";\n topElement.style.width = \"100%\";\n topElement.style.height = \"30px\";\n topElement.style.padding = \"7px 5px\";\n topElement.style.color = \"#73ff69\";\n topElement.style.display = \"flex\";\n topElement.style.gridGap = \"20px\";\n topElement.style.gridColumn = \"2\";\n topElement.style.gridRow = \"1\";\n\n topElement.innerHTML = '

EventLayer.Services: No registered

' +\n '

EventLayer.Products: 0

' +\n '

EventLayer.ProductLists: 0

' +\n '

EventLayer.ProductPrices: 0

' +\n '

EventLayer.Banners: 0

' +\n '

Product impressions: 0

' +\n '

' +\n '

';\n\n var leftElement = document.createElement('div');\n leftElement.style.width = \"120px;\"\n leftElement.style.height = \"30px\";\n leftElement.style.gridColumn = \"1\";\n leftElement.style.gridRow = \"1\";\n leftElement.style.display = \"flex\";\n\n var iconParagraph1 = document.createElement('p');\n iconParagraph1.style.cursor = \"pointer\";\n iconParagraph1.style.width = \"30px\";\n iconParagraph1.style.height = \"30px\";\n iconParagraph1.style.padding = \"0px 6px\";\n iconParagraph1.style.lineHeight = \"30px\";\n iconParagraph1.onclick = EasyfyEventLogger.DisableLog;\n iconParagraph1.innerHTML = \"🖥️\";\n\n leftElement.appendChild(iconParagraph1);\n\n var iconParagraph2 = document.createElement('p');\n iconParagraph2.style.cursor = \"pointer\";\n iconParagraph2.style.width = \"30px\";\n iconParagraph2.style.height = \"30px\";\n iconParagraph2.style.padding = \"0px 6px\";\n iconParagraph2.style.lineHeight = \"30px\";\n iconParagraph2.onclick = EasyfyEventLogger.PrintEventLayer;\n iconParagraph2.innerHTML = \"📄\";\n\n leftElement.appendChild(iconParagraph2);\n\n var iconParagraph3 = document.createElement('p');\n iconParagraph3.style.cursor = \"pointer\";\n iconParagraph3.style.width = \"30px\";\n iconParagraph3.style.height = \"30px\";\n iconParagraph3.style.padding = \"0px 8px\";\n iconParagraph3.style.lineHeight = \"30px\";\n iconParagraph3.style.transform = \"scale(1.6)\";\n\n if (ImpressionVisualizerIsOn()) {\n iconParagraph3.style.color = \"#ff7600\";\n } else {\n iconParagraph3.style.color = \"#c4c4c4\";\n }\n\n iconParagraph3.id = \"toggleImpressionBtn\"\n iconParagraph3.onclick = EasyfyEventLogger.ToggleImpressionVisualizer;\n iconParagraph3.innerHTML = \"👁\";\n\n leftElement.appendChild(iconParagraph3);\n\n var iconParagraph4 = document.createElement('p');\n iconParagraph4.style.cursor = \"pointer\";\n iconParagraph4.style.width = \"30px\";\n iconParagraph4.style.height = \"30px\";\n iconParagraph4.style.padding = \"0px 8px\";\n iconParagraph4.style.lineHeight = \"30px\";\n iconParagraph4.style.transform = \"scale(1.6)\";\n iconParagraph4.onclick = EasyfyEventLogger.RunEventConsumer;\n iconParagraph4.innerHTML = \"📡\";\n\n leftElement.appendChild(iconParagraph4);\n\n\n var textElement = document.createElement('div');\n textElement.id = \"outputText\";\n textElement.style.padding = \"5px\";\n textElement.style.overflowY = \"scroll\";\n textElement.style.height = \"170px\";\n textElement.style.gridColumn = \"2\";\n textElement.style.gridRow = \"2\";\n textElement.style.borderRadius = \"5px\";\n\n outputDiv.appendChild(topElement);\n outputDiv.appendChild(leftElement);\n outputDiv.appendChild(textElement);\n document.querySelector('body').appendChild(outputDiv);\n\n this.CheckLogStatus();\n }\n\n devEventOutput = document.querySelector(\"#devEventOutput\");\n if (!devEventOutput) return;\n\n if (obj.type == \"productimpression\") {\n var textOutput = devEventOutput.querySelector('#outputText');\n textOutput.innerHTML += \"

\" + obj.message + \"

\";\n var productImpressions = Number.parseInt(devEventOutput.querySelector('#devProductImpressions').innerHTML);\n devEventOutput.querySelector('#devProductImpressions').innerHTML = (productImpressions + 1).toString();\n\n textOutput.scrollTop = textOutput.scrollHeight;\n\n if (obj.target && ImpressionVisualizerIsOn()) {\n (obj.target as HTMLElement).classList.add(\"impressionSeen\")\n }\n\n BroadcastToLogger(obj.message);\n }\n else if (obj.type == \"servicesregistered\") {\n devEventOutput.querySelector('#devEventServices').innerHTML = obj.message;\n\n BroadcastToLogger(obj.message);\n }\n else if (obj.type == \"updateeventlayerstatus\") {\n var lists = EasyfyEventData.AllProductLists();\n var products = EasyfyEventData.AllProducts();\n var banners = EasyfyEventData.AllBanners();\n var prices = EasyfyEventData.AllProductSalesUnitPrices();\n\n var eventLayerProductsCount = Object.keys(products).length;\n var eventLayerProductListsCount = Object.keys(lists).length;\n var eventLayerBannersCount = Object.keys(banners).length;\n var eventLayerPricesCount = Object.keys(prices).length;\n\n devEventOutput.querySelector('#devLayerLists').innerHTML = eventLayerProductListsCount.toString();\n devEventOutput.querySelector('#devLayerProducts').innerHTML = eventLayerProductsCount.toString();\n devEventOutput.querySelector('#devEventServices').innerHTML = EasyfyEventData.GetServiceNames().join(\", \");\n devEventOutput.querySelector('#devLayerBanners').innerHTML = eventLayerBannersCount.toString();\n devEventOutput.querySelector('#devLayerPrices').innerHTML = eventLayerPricesCount.toString();\n\n var notifications = EasyfyEventData.Notifications();\n\n var textOutput = devEventOutput.querySelector('#outputText');\n notifications.forEach((notification: IEventNotification) => {\n\n var color = \"#ffffff\";\n var message = notification.severity + \": \" + notification.message;\n switch (notification?.severity) {\n case \"Warning\":\n color = \"#ffd76a\";\n console.warn(message);\n let warn = devEventOutput.querySelector('#devlogger-warning-sign') as HTMLElement;\n warn.style.display = \"block\";\n break;\n case \"Error\":\n color = \"#ff6a6a\";\n console.error(message);\n let err = devEventOutput.querySelector('#devlogger-warning-sign') as HTMLElement;\n err.style.display = \"block\";\n break;\n }\n textOutput.innerHTML += \"

\" + notification.message + \"

\";\n\n BroadcastToLogger(notification);\n });\n textOutput.scrollTop = textOutput.scrollHeight;\n EasyfyEventData.ClearNotifications();\n }\n else if (obj.type == \"event\") {\n var textOutput = devEventOutput.querySelector('#outputText');\n textOutput.className = \"\";\n textOutput.innerHTML += \"

\" + obj.message + \"

\";\n textOutput.scrollTop = textOutput.scrollHeight;\n setTimeout(() => {\n var textOutput = devEventOutput.querySelector('#outputText');\n textOutput.className = \"flash\";\n }, 20);\n }\n else if (obj.type == \"warning\") {\n var textOutput = devEventOutput.querySelector('#outputText');\n textOutput.innerHTML += \"

\" + obj.message + \"

\";\n textOutput.scrollTop = textOutput.scrollHeight;\n BroadcastToLogger(obj.message);\n }\n else if (obj.type == \"error\") {\n var textOutput = devEventOutput.querySelector('#outputText');\n textOutput.innerHTML += \"

\" + obj.message + \"

\";\n textOutput.scrollTop = textOutput.scrollHeight;\n BroadcastToLogger(obj.message);\n\n }\n else {\n var textOutput = devEventOutput.querySelector('#outputText');\n textOutput.innerHTML += \"

\" + obj.message + \"

\";\n textOutput.scrollTop = textOutput.scrollHeight;\n BroadcastToLogger(obj.message);\n\n }\n }\n };\n\n export function CheckLogStatus(this: any): void {\n if (process.env.NODE_ENV === \"development\") {\n var useEventLog = localStorage.getItem(\"easyfyDevEventLog\") == \"true\";\n\n useEventLog ? this.EnableLog() : this.DisableLog();\n }\n };\n\n export function EnableLog(): void {\n if (process.env.NODE_ENV === \"development\") {\n localStorage.setItem(\"easyfyDevEventLog\", \"true\");\n var devEventOutput = document.querySelector(\"#devEventOutput\") as HTMLElement;\n if (devEventOutput) {\n devEventOutput.style.display = \"grid\";\n }\n }\n };\n\n export function DisableLog(): void {\n if (process.env.NODE_ENV === \"development\") {\n localStorage.setItem(\"easyfyDevEventLog\", \"false\");\n var devEventOutput = document.querySelector(\"#devEventOutput\") as HTMLElement;\n if (devEventOutput) {\n devEventOutput.style.display = \"none\";\n }\n }\n };\n\n export function ToggleImpressionVisualizer(): void {\n if (process.env.NODE_ENV === \"development\") {\n var date = new Date();\n date.setDate(date.getDate() + 30);\n var visualizerValue = localStorage.getItem(\"easyfyDevImpVisualizer\");\n var btn = document.querySelector(\"#toggleImpressionBtn\") as HTMLElement;\n\n if (visualizerValue == \"true\") {\n localStorage.setItem(\"easyfyDevImpVisualizer\", \"false\");\n btn.style.color = \"#c4c4c4\";\n\n document.querySelectorAll('.impressionSeen').forEach((elem) => {\n elem.classList.remove('impressionSeen');\n });\n }\n else {\n localStorage.setItem(\"easyfyDevImpVisualizer\", \"true\");\n btn.style.color = \"#ff7600\";\n document.querySelectorAll('[data-track-product][data-track-impression=\"True\"]').forEach((elem) => {\n elem.classList.add('impressionSeen');\n });\n }\n }\n };\n\n function ImpressionVisualizerIsOn(): boolean {\n var visualizerValue = localStorage.getItem(\"easyfyDevImpVisualizer\");\n if (visualizerValue == \"true\") {\n return true;\n }\n else {\n return false;\n }\n }\n\n export function PrintEventLayer(): void {\n if (process.env.NODE_ENV === \"development\") {\n\n var devEventLayerOutput = document.querySelector(\"#devEventLayerOutput\") as HTMLDivElement;\n if (!devEventLayerOutput) {\n var outputDiv = document.createElement('div');\n outputDiv.id = \"devEventLayerOutput\";\n outputDiv.style.position = \"fixed\";\n outputDiv.style.height = \"66%\";\n outputDiv.style.width = \"70%\";\n outputDiv.style.top = \"100px\";\n outputDiv.style.left = \"15%\";\n outputDiv.style.backgroundColor = \"#000000de\";\n outputDiv.style.color = \"#c4c4c4\";\n outputDiv.style.zIndex = \"2147483646\";\n outputDiv.style.borderRadius = \"5px\";\n outputDiv.style.boxShadow = \"1px 0px 14px 1px rgba(0,0,0,0.3)\";\n outputDiv.style.fontSize = \"11px\";\n outputDiv.style.overflow = \"auto\";\n\n var iconParagraph = document.createElement('p');\n iconParagraph.style.cursor = \"pointer\";\n iconParagraph.style.width = \"30px\";\n iconParagraph.style.height = \"30px\";\n iconParagraph.style.padding = \"0px 8px\";\n iconParagraph.style.lineHeight = \"30px\";\n iconParagraph.style.position = \"fixed\";\n iconParagraph.onclick = EasyfyEventLogger.HidePrintedEventLayer;\n iconParagraph.innerHTML = \"✖\";\n\n var textElement = document.createElement('div');\n textElement.id = \"devEventLayerOutputText\";\n textElement.style.padding = \"30px\";\n textElement.style.fontFamily = \"monospace\";\n textElement.style.whiteSpace = \"pre\";\n\n outputDiv.appendChild(iconParagraph);\n outputDiv.appendChild(textElement);\n\n\n document.querySelector('body').appendChild(outputDiv);\n devEventLayerOutput = document.querySelector(\"#devEventLayerOutput\") as HTMLDivElement;\n\n }\n\n devEventLayerOutput.style.display = \"block\";\n const brace = {\n brace: 0\n };\n\n var jsonstring = JSON.stringify(window.EasyfyEventLayer, null, 2);\n var outputElement = document.querySelector(\"#devEventLayerOutputText\") as HTMLDivElement;\n outputElement.innerHTML = \"

Event layer:

\" + jsonstring;\n //console.log(JSON.stringify(window.EasyfyEventLayer, null, 2));\n }\n };\n\n export function HidePrintedEventLayer(): void {\n if (process.env.NODE_ENV === \"development\") {\n var devEventLayerOutput = document.querySelector(\"#devEventLayerOutput\") as HTMLDivElement;\n if (devEventLayerOutput) {\n devEventLayerOutput.style.display = \"none\";\n }\n }\n };\n\n export function RunEventConsumer(): void {\n if (process.env.NODE_ENV === \"development\") {\n\n var debugDiv = document.createElement('div');\n debugDiv.id = \"debugEventConsumer\";\n debugDiv.style.padding = \"10px\";\n debugDiv.style.backgroundColor = \"#101010\";\n debugDiv.style.overflowY = \"auto\";\n debugDiv.style.height = \"100%\";\n debugDiv.style.width = \"100%\";\n debugDiv.style.position = \"fixed\";\n debugDiv.style.top = \"0\";\n debugDiv.style.left = \"0\";\n debugDiv.style.zIndex = \"2147483647\";\n debugDiv.style.color = \"#c5c5c5\";\n\n document.body.appendChild(debugDiv);\n\n document.body.style.overflowY = \"hidden\";\n\n _broadcastChannel.addEventListener(\"message\", (event) => {\n DisplayEventMessage(event.data);\n });\n }\n };\n\n export function DisplayEventMessage(data: object): void {\n if (process.env.NODE_ENV === \"development\") {\n let outputElement = document.querySelector('#debugEventConsumer');\n if (outputElement) {\n\n let jsonString = JSON.stringify(data);\n let highlightedJsonString = HighlightEventNameValue(jsonString);\n\n outputElement.innerHTML += '
' + GetCurrentTime() + ':
' + highlightedJsonString + '
';\n outputElement.scrollTop = outputElement.scrollHeight;\n }\n }\n }\n\n export function BroadcastToLogger(data: any): void {\n if (process.env.NODE_ENV === \"development\") {\n if (_broadcastChannel) {\n _broadcastChannel.postMessage(data);\n }\n }\n }\n function HighlightEventNameValue(jsonString: string): string {\n // Regular expression to find `\"eventName\":\"value\"`\n const regex = /\"eventName\":\"([^\"]+)\"/g;\n\n // Replace matched `\"eventName\":\"value\"` with `\"eventName\":\"value\"`\n const highlightedJsonString = jsonString.replace(regex, '\"eventName\":\"$1\"');\n\n return highlightedJsonString;\n }\n\n export function GetCurrentTime(): string {\n const now = new Date();\n\n const hours = (now.getHours() < 10 ? '0' : '') + now.getHours();\n const minutes = (now.getMinutes() < 10 ? '0' : '') + now.getMinutes();\n const seconds = (now.getSeconds() < 10 ? '0' : '') + now.getSeconds();\n const milliseconds = (now.getMilliseconds() < 10 ? '00' : (now.getMilliseconds() < 100 ? '0' : '')) + now.getMilliseconds();\n\n return `${hours}:${minutes}:${seconds}.${milliseconds}`;\n }\n}\n\n","import { IEasyfyEvent, IDataMapper, IEasyfyEventExporter } from '@shared/easyfy.events/easyfy.eventdata';\n\n/* Ga4 Exporter class */\nexport class Ga4EventExporter implements IEasyfyEventExporter {\n mapper: IDataMapper;\n WithMapper(mapper: IDataMapper): void {\n this.mapper = mapper;\n }\n\n RegisterEvent(event: IEasyfyEvent): Promise {\n return new Promise(async (resolve) => {\n if (!this.mapper) return;\n var eventData = this.mapper.MapEventData(event);\n await this.PushToDataLayer(eventData);\n resolve();\n })\n }\n\n async PushToDataLayer(ga4Event: any): Promise {\n return new Promise(async (resolve) => {\n if (ga4Event) {\n window['dataLayer'] = window['dataLayer'] || [];\n window['dataLayer'].push({ ecommerce: null });\n if (Array.isArray(ga4Event)) {\n window['dataLayer'].push(...ga4Event);\n } else {\n window['dataLayer'].push(ga4Event);\n }\n }\n resolve();\n })\n\n //console.group('%c GA DataLayer ', 'color: #bada55');\n //console.dir(window['dataLayer']);\n //console.groupEnd();\n }\n}","\nexport class FeatureNames {\n static EventTracking: string = \"eventtracking\";\n}\n\nexport class Features {\n static FeatureIsActive = (featureName: string): boolean => {\n var featureIsActiveForClient = document.querySelector('html').hasAttribute(featureName);\n return featureIsActiveForClient;\n }\n}\n\n\n\n","import { IEasyfyEvent, IDataMapper, IEasyfyEventExporter } from '@shared/easyfy.events/easyfy.eventdata';\n\n/* Klaviyo Exporter class */\nexport class KlaviyoEventExporter implements IEasyfyEventExporter {\n mapper: IDataMapper;\n WithMapper(mapper: IDataMapper): void {\n this.mapper = mapper;\n }\n\n RegisterEvent(event: IEasyfyEvent): Promise {\n return new Promise(async (resolve) => {\n if (this.mapper) {\n var eventData = this.mapper.MapEventData(event);\n\n if (eventData?.event && eventData?.data) {\n await this.PushToKlaviyo(eventData);\n }\n\n if (eventData?.identify) {\n await this.IdentifyUser(eventData.identify);\n }\n }\n resolve();\n });\n }\n\n async PushToKlaviyo(klaviyoEvent: any): Promise {\n return new Promise(async (resolve) => {\n if (klaviyoEvent) {\n window['klaviyo'] = window?.['klaviyo'] || [];\n window['klaviyo'].push([\"track\", klaviyoEvent.event, klaviyoEvent.data])\n\n //console.group('%c Klaviyo ', 'color: #bada55');\n //console.dir(window['klaviyo']);\n //console.groupEnd();\n resolve(true)\n }\n else {\n resolve(false);\n }\n });\n }\n async IdentifyUser(emailToRegister: any): Promise {\n return new Promise(async (resolve) => {\n if (emailToRegister) {\n window['klaviyo'] = window?.['klaviyo'] || [];\n window['klaviyo'].identify({\n 'email': emailToRegister\n });\n\n resolve(true)\n }\n else {\n resolve(false);\n }\n });\n }\n}","import { element } from '@shared/easyfy.core';\nimport { StatsEventExporter } from '@shared/easyfy.events/exporters/eventExporter.stats';\nimport { Ga4EventExporter } from '@shared/easyfy.events/exporters/eventExporter.ga4';\nimport { EasyfyEventData, IDataMapper, IEasyfyEvent, IEasyfyEventExporter, IWorkerJob, ITrackableElement, ISessionStarted, IClientEventMetaData, IWorkerMessage } from '@shared/easyfy.events/easyfy.eventdata';\nimport { EasyfyEventLogger } from '@shared/easyfy.events/easyfy.event.devlogger';\nimport { FeatureNames, Features } from '@webServices/features.service';\nimport { KlaviyoEventExporter } from './exporters/eventExporter.klaviyo';\n\nexport class ServiceNames {\n static Stats: string = \"stats\";\n static Ga4: string = \"ga4\";\n static Klaviyo: string = \"klaviyo\";\n}\nexport class EventNames {\n static PageView: string = \"pageview\";\n static ProductImpression: string = \"productimpression\";\n static ProductClick: string = \"productclick\";\n static ProductPageView: string = \"productpageview\";\n static BannerImpression = \"bannerimpression\";\n static BannerClick = \"bannerclick\";\n static ElementImpression = \"elementimpression\";\n static ElementClick = \"elementclick\";\n static AddToCart: string = \"addtocart\";\n static RemoveFromCart: string = \"removefromcart\";\n static QuantityChanged: string = \"quantitychanged\";\n static StartedCheckout: string = \"startedcheckout\";\n static CompletedCheckout: string = \"completedcheckout\";\n static SearchPerformed: string = \"searchperformed\";\n static ContinueToPayment: string = \"continuetopayment\";\n static SessionStarted: string = \"sessionstarted\";\n static LoggedIn: string = \"loggedin\";\n static LoggedOut: string = \"loggedout\";\n}\n\nexport class Message {\n static FetchClientMetaData = \"cmd_fetch_client_meta_data\";\n static BlockStatsApi = \"cmd_block_stats_api\";\n}\n\nexport class LocalStorageKeys {\n static SessionTimer = \"e_sessionTimer\";\n static SessionId = \"e_sessionId\";\n static ClientId = \"e_clientId\";\n static UserId = \"e_userId\";\n static LastCheckedUserId = \"e_lastCheckedUserId\";\n static IsTablet = \"e_tablet\";\n static IsMobilePhone = \"e_mobilephone\";\n static IsDekstop = \"e_desktop\";\n static UserIdCookieKey = \"e_userIdCookieKey\";\n static IPAddress = \"e_ipAddress\";\n static StatsIsBlocked = \"e_statsServiceBlocked\";\n static StatsEventsThresholdRemoved = \"e_StatsEventsTresholdRemoved\"\n static StatsEventsTransitionObj = \"e_statsEventsTransitionObj\"\n}\n\nnamespace Easyfy.Modules {\n\n export class EasyfyEventHandler {\n private eventExporters: Map = new Map();\n private observedElements: string[] = [];\n private intersectionObserver: IntersectionObserver;\n private bannerIntersectionObserver: IntersectionObserver;\n private mutationObserver: MutationObserver;\n public static instance: EasyfyEventHandler;\n private featureFlag: boolean;\n private initiated: boolean = false;\n\n constructor(eventMappers: Map) {\n EasyfyEventHandler.instance = this;\n EasyfyEventHandler.instance.featureFlag = Features.FeatureIsActive(FeatureNames.EventTracking);\n window.EasyfyEventLayerInstance = this;\n\n if (!EasyfyEventHandler.instance.featureFlag) return;\n\n EasyfyEventData.GetAllServices().forEach(service => {\n var eventExporter: IEasyfyEventExporter;\n switch (service.name.toLowerCase()) {\n case ServiceNames.Stats: {\n eventExporter = new StatsEventExporter();\n break;\n }\n case ServiceNames.Klaviyo: {\n eventExporter = new KlaviyoEventExporter();\n break;\n }\n case ServiceNames.Ga4: {\n eventExporter = new Ga4EventExporter();\n break;\n }\n }\n if (eventExporter) {\n eventExporter.WithMapper(eventMappers.get(service.name));\n this.eventExporters.set(service.name, eventExporter);\n }\n })\n\n EasyfyEventLogger.Log({\n type: \"updateeventlayerstatus\",\n });\n\n EasyfyEventHandler.CheckSessionStart().then(() => {\n EasyfyEventHandler.RunEvents().then(() => {\n if (EasyfyEventData.ShouldRegisterProductImpressions()) {\n EasyfyEventHandler.InitProductIntersectionObserver();\n EasyfyEventHandler.InitMutationObserver();\n }\n if (EasyfyEventData.ShouldRegisterBannerImpressions()) {\n EasyfyEventHandler.InitBannerIntersectionObserver();\n }\n EasyfyEventHandler.InitElementIntersectionObserver();\n window.addEventListener('click', EasyfyEventHandler.ClickEventChecker);\n EasyfyEventHandler.instance.initiated = true;\n });\n });\n };\n\n static async RunEvents(): Promise {\n return new Promise(async (resolve) => {\n var inlineScript = element('[data-container=\"easyfy-preload-tracking-events\"]');\n if (inlineScript) {\n inlineScript.remove();\n }\n\n if (!EasyfyEventData.HasEvents()) {\n resolve();\n return;\n }\n for await (const event of EasyfyEventData.Events()) {\n await EasyfyEventHandler.RunEvent(event);\n };\n\n EasyfyEventData.ClearEvents();\n resolve();\n });\n };\n\n static async CheckSessionStart(): Promise {\n return new Promise(async (resolve) => {\n if (EasyfyEventData.ServiceIsActive(ServiceNames.Stats) !== true) {\n resolve();\n return;\n }\n var sessionTimer = localStorage.getItem(LocalStorageKeys.SessionTimer);\n if (!sessionTimer) {\n localStorage.setItem(LocalStorageKeys.SessionTimer, new Date(Date.now()).toUTCString());\n sessionTimer = localStorage.getItem(LocalStorageKeys.SessionTimer);\n await EasyfyEventHandler.FetchClientMetaData();\n await EasyfyEventHandler.SendStartSessionEvent();\n resolve();\n }\n\n var checkTime = new Date(sessionTimer);\n var now = new Date(Date.now());\n\n var diff = (checkTime.getTime() - now.getTime()) / 1000;\n diff /= 60;\n var minutesBetween = Math.abs(Math.round(diff));\n\n if (minutesBetween >= 20) {\n var oldSessionId = localStorage.getItem(LocalStorageKeys.SessionId);\n await EasyfyEventHandler.FetchClientMetaData();\n var newSessionId = localStorage.getItem(LocalStorageKeys.SessionId);\n if (oldSessionId != newSessionId) {\n await EasyfyEventHandler.SendStartSessionEvent();\n }\n }\n\n localStorage.setItem(LocalStorageKeys.SessionTimer, new Date(Date.now()).toUTCString());\n\n resolve();\n });\n }\n\n static async FetchClientMetaData(): Promise {\n return new Promise(async (resolve) => {\n\n EasyfyEventData.SetStatsApiBlock(false);\n\n const response = await fetch(\"/api/stats/clientmetadata/\");\n\n if (!response.ok) {\n if (response.status == 428 || response.status == 404) {\n EasyfyEventData.SetStatsApiBlock(true);\n }\n\n localStorage.setItem(LocalStorageKeys.SessionId, null);\n localStorage.setItem(LocalStorageKeys.ClientId, null);\n localStorage.setItem(LocalStorageKeys.UserId, null);\n localStorage.setItem(LocalStorageKeys.IsDekstop, null);\n localStorage.setItem(LocalStorageKeys.IsMobilePhone, null);\n localStorage.setItem(LocalStorageKeys.IsTablet, null);\n localStorage.setItem(LocalStorageKeys.UserIdCookieKey, null);\n localStorage.setItem(LocalStorageKeys.IPAddress, null);\n\n resolve(false);\n return;\n }\n\n var clientMetaData = await response.json()\n\n localStorage.setItem(LocalStorageKeys.SessionId, clientMetaData.sessionId);\n localStorage.setItem(LocalStorageKeys.ClientId, clientMetaData.clientId);\n localStorage.setItem(LocalStorageKeys.UserId, clientMetaData.userId);\n localStorage.setItem(LocalStorageKeys.IsDekstop, clientMetaData.isDesktop);\n localStorage.setItem(LocalStorageKeys.IsMobilePhone, clientMetaData.isMobilePhone);\n localStorage.setItem(LocalStorageKeys.IsTablet, clientMetaData.isTablet);\n localStorage.setItem(LocalStorageKeys.UserIdCookieKey, clientMetaData.userIdCookieKey);\n localStorage.setItem(LocalStorageKeys.IPAddress, clientMetaData.ipAddress);\n\n\n var data: IClientEventMetaData = {\n ClientId: clientMetaData.clientId,\n SessionId: clientMetaData.sessionId,\n UserId: clientMetaData.userId,\n IsDesktop: clientMetaData.isDesktop,\n IsMobilePhone: clientMetaData.isMobilePhone,\n IsTablet: clientMetaData.isTablet,\n IPAddress: clientMetaData.ipAddress\n }\n resolve(true);\n });\n }\n\n static BlockStatsApi(): void {\n EasyfyEventData.SetStatsApiBlock(true);\n }\n\n static HandleWorkerMessage(message) {\n var typedMessage = message.data as IWorkerMessage\n switch (typedMessage.Message) {\n case Message.FetchClientMetaData: {\n EasyfyEventHandler.FetchClientMetaData()\n break;\n }\n case Message.BlockStatsApi: {\n EasyfyEventHandler.BlockStatsApi()\n break;\n }\n }\n }\n\n static SendStartSessionEvent(): Promise {\n return new Promise(async (resolve) => {\n var clientMetaData: IClientEventMetaData = EasyfyEventData.GetClientEventMetaData();\n var clientData: ISessionStarted = {\n Culture: \"not-set-yet\", //todo -> ? \n Currency: EasyfyEventData.SiteInfo().currencyCode,\n IsDesktop: clientMetaData.IsDesktop,\n IsMobilePhone: clientMetaData.IsMobilePhone,\n IsTablet: clientMetaData.IsTablet,\n RecurringUser: EasyfyEventData.IsRecurringUser(true),\n Referrer: document.referrer,\n Path: window.location.pathname,\n UserAgent: window.navigator.userAgent,\n ClientId: clientMetaData.ClientId,\n SessionId: clientMetaData.SessionId,\n UserId: clientMetaData.UserId,\n VisitorId: clientMetaData.UserId\n };\n\n var sessionStartedEvent: IEasyfyEvent = {\n eventName: EventNames.SessionStarted,\n data: clientData\n };\n\n await EasyfyEventHandler.RunEvent(sessionStartedEvent);\n resolve();\n });\n }\n\n static InitMutationObserver(): void {\n let options = {\n childList: true,\n subtree: true,\n attributes: false,\n characterData: false\n };\n\n let targets = document.querySelectorAll('[data-track-list], [data-container=\"search-result\"]');\n EasyfyEventHandler.instance.mutationObserver = new MutationObserver(this.ElementMutated);\n targets.forEach(target => EasyfyEventHandler.instance.mutationObserver.observe(target, options));\n }\n\n static ElementMutated(mutations: MutationRecord[]) {\n mutations.forEach(mutation => {\n EasyfyEventHandler.RebindObserveProducts();\n });\n }\n\n static BannerElementMutated(mutations: MutationRecord[]) {\n mutations.forEach(mutation => {\n EasyfyEventHandler.RebindObserveBanners();\n });\n }\n\n static InitProductIntersectionObserver(): void {\n let options = {\n root: null,\n rootMargin: '0px',\n threshold: 0.1\n };\n EasyfyEventHandler.instance.intersectionObserver = new IntersectionObserver(this.ProductCardObserved, options);\n let targets = document.querySelectorAll('[data-track-product]');\n targets.forEach(target => EasyfyEventHandler.instance.intersectionObserver.observe(target));\n }\n\n static InitBannerIntersectionObserver(): void {\n let options = {\n root: null,\n rootMargin: '0px',\n threshold: 0.1\n };\n EasyfyEventHandler.instance.bannerIntersectionObserver = new IntersectionObserver(this.BannerElementObserved, options);\n let bannerTargets = document.querySelectorAll('[data-track-banner]');\n bannerTargets.forEach(target => EasyfyEventHandler.instance.bannerIntersectionObserver.observe(target));\n }\n\n static InitElementIntersectionObserver(): void {\n let options = {\n root: null,\n rootMargin: '0px',\n threshold: 0.1\n };\n EasyfyEventHandler.instance.bannerIntersectionObserver = new IntersectionObserver(this.TrackableElementObserved, options);\n let bannerTargets = document.querySelectorAll('[data-track-element]');\n bannerTargets.forEach(target => EasyfyEventHandler.instance.bannerIntersectionObserver.observe(target));\n }\n\n static RebindObserveProducts() {\n EasyfyEventHandler.instance.intersectionObserver.disconnect();\n let targets = document.querySelectorAll('[data-track-product]');\n targets.forEach(target => EasyfyEventHandler.instance.intersectionObserver.observe(target));\n }\n\n static RebindObserveBanners() {\n EasyfyEventHandler.instance.bannerIntersectionObserver.disconnect();\n let targets = document.querySelectorAll('[data-track-banner]');\n targets.forEach(target => EasyfyEventHandler.instance.bannerIntersectionObserver.observe(target));\n }\n\n static ProductCardObserved(entries: IntersectionObserverEntry[], observer: any) {\n var eventProductIds: string[] = [];\n var eventProductSalesUnitCodes: string[] = [];\n var listIds: string[] = [];\n var promotedProducts: boolean[] = [];\n\n entries.forEach(entry => {\n if (entry.isIntersecting) {\n EasyfyEventHandler.instance.intersectionObserver.unobserve(entry.target);\n var elementIsRegisteredForImpression = entry.target.getAttribute(\"data-track-impression\").toLowerCase() === 'true';\n if (!elementIsRegisteredForImpression) return;\n\n // points to a product but could appear multiple times on a page\n var productIdentifier = entry.target.getAttribute(\"data-product-event-id\");\n // id of product card element, always unique\n var elementIdentifier = entry.target.getAttribute(\"data-element-event-id\");\n var defaultSalesUnitCode = entry.target.getAttribute(\"data-default-sales-unit-code\");\n var isPromotedProduct = entry.target.getAttribute(\"data-event-property-is-promotion\")?.toLowerCase() === 'true';\n\n if (productIdentifier && elementIdentifier) {\n if (!EasyfyEventHandler.instance.observedElements.includes(elementIdentifier)) {\n EasyfyEventHandler.instance.observedElements.push(elementIdentifier);\n EasyfyEventLogger.Log({\n type: \"productimpression\",\n message: (`Product '${productIdentifier}' with SalesCodeUnit '${defaultSalesUnitCode}' seen`),\n target: entry.target\n });\n eventProductIds.push(productIdentifier);\n eventProductSalesUnitCodes.push(defaultSalesUnitCode);\n promotedProducts.push(isPromotedProduct);\n var node = entry.target;\n while (true) {\n node = node.parentElement;\n if (node.hasAttribute(\"data-track-list\")) {\n let listId = node.getAttribute(\"data-list-name\");\n if (listId) {\n listIds.push(listId);\n break;\n }\n }\n else if (node.nodeName == 'BODY') {\n listIds.push(null);\n break;\n }\n }\n }\n }\n else {\n EasyfyEventLogger.Log({\n type: \"error\",\n message: \"Product impression failed: missing event product ID\"\n });\n }\n }\n });\n\n if (eventProductIds.length > 0) {\n let event: IEasyfyEvent = {\n eventName: EventNames.ProductImpression,\n data: {\n productIdentifiers: eventProductIds,\n salesUnitCodes: eventProductSalesUnitCodes,\n listIds: listIds,\n promotedProducts\n }\n }\n EasyfyEventHandler.RunEvent(event);\n }\n }\n\n static BannerElementObserved(entries: IntersectionObserverEntry[], observer: any) {\n var bannerIds: string[] = [];\n entries.forEach(entry => {\n if (entry.isIntersecting) {\n EasyfyEventHandler.instance.bannerIntersectionObserver.unobserve(entry.target);\n var elementIsRegisteredForImpression = entry.target.getAttribute(\"data-track-impression\").toLowerCase() === 'true';\n if (!elementIsRegisteredForImpression) return;\n var bannerIdentifier = entry.target.getAttribute(\"data-banner-event-id\");\n if (bannerIdentifier) {\n if (!EasyfyEventHandler.instance.observedElements.includes(bannerIdentifier)) {\n EasyfyEventHandler.instance.observedElements.push(bannerIdentifier);\n EasyfyEventLogger.Log({\n type: \"bannerimpression\",\n message: (\"Banner '\" + bannerIdentifier + \"' seen\")\n });\n bannerIds.push(bannerIdentifier);\n }\n }\n else {\n EasyfyEventLogger.Log({\n type: \"error\",\n message: \"Banner impression failed: missing event banner ID\"\n });\n }\n }\n });\n\n if (bannerIds.length > 0) {\n bannerIds.forEach(id => {\n let event: IEasyfyEvent = {\n eventName: EventNames.BannerImpression,\n data: { bannerIdentifier: id }\n }\n EasyfyEventHandler.RunEvent(event);\n });\n }\n }\n\n static TrackableElementObserved(entries: IntersectionObserverEntry[], observer: any) {\n var elements: ITrackableElement[] = [];\n entries.forEach(entry => {\n if (entry.isIntersecting) {\n var elementIsRegisteredForImpression = entry.target.getAttribute(\"data-track-impression\")?.toLowerCase() === 'true';\n if (!elementIsRegisteredForImpression) return;\n\n var elementIdentifier = entry.target.getAttribute(\"data-event-id\");\n if (elementIdentifier) {\n var multiObserve = entry.target.getAttribute(\"data-multi-observe\").toLowerCase() === 'true';\n if (multiObserve == false) {\n EasyfyEventHandler.instance.bannerIntersectionObserver.unobserve(entry.target);\n if (!EasyfyEventHandler.instance.observedElements.includes(elementIdentifier)) {\n EasyfyEventHandler.instance.observedElements.push(elementIdentifier);\n }\n }\n\n var trackType = entry.target.getAttribute(\"data-track-type\");\n var properties = new Map();\n\n for (const attribute of entry.target.getAttributeNames()) {\n if (attribute.startsWith(\"data-event-property-\")) {\n const value = entry.target.getAttribute(attribute);\n var key = attribute.replace(\"data-event-property-\", \"\");\n properties.set(key, value);\n }\n }\n\n elements.push({\n Id: elementIdentifier,\n Type: trackType,\n Properties: properties\n });\n\n EasyfyEventLogger.Log({\n type: \"elementimpression\",\n message: (\"Element '\" + elementIdentifier + \"' seen\")\n });\n\n }\n else {\n EasyfyEventLogger.Log({\n type: \"error\",\n message: \"Element impression failed: missing event ID on element\"\n });\n }\n }\n });\n\n if (elements.length > 0) {\n elements.forEach(element => {\n let event: IEasyfyEvent = {\n eventName: EventNames.ElementImpression,\n data: element\n }\n EasyfyEventHandler.RunEvent(event);\n });\n }\n }\n\n static ClickEventChecker(event: any) {\n if (event.target.closest('A') != null) {\n var node = event.target.closest('A');\n var targetUrl = node.href;\n if (node.closest('[data-track-product]') != null) {\n EasyfyEventHandler.ClickEventProduct(event, node, targetUrl);\n return;\n }\n else if (node.closest('[data-track-banner]') != null) {\n EasyfyEventHandler.ClickEventBanner(event, node, targetUrl);\n return;\n }\n else if (node.closest('[data-track-element]') != null) {\n EasyfyEventHandler.ClickEventElement(event, node, targetUrl);\n return;\n }\n }\n else {\n var node = event.target;\n if (node.closest('[data-track-element]') != null) {\n EasyfyEventHandler.ClickEventElement(event, node);\n return;\n }\n }\n }\n\n static ClickEventProduct(event: any, node: any, targetUrl: any) {\n node = node.closest('[data-track-product]');\n var elementIsRegisteredForClick = node.getAttribute(\"data-track-click\").toLowerCase() === 'true';\n if (elementIsRegisteredForClick) {\n event.stopPropagation();\n event.preventDefault();\n\n var defaultSalesUnitCode = node.getAttribute(\"data-default-sales-unit-code\");\n var productId = node.getAttribute('data-product-event-id');\n var isPromotedProduct = node.getAttribute(\"data-event-property-is-promotion\")?.toLowerCase() === 'true';\n\n if (productId) {\n var listName\n while (true) {\n node = node.parentElement;\n if (!node) {\n break;\n }\n if (node.hasAttribute(\"data-track-list\")) {\n listName = node.getAttribute(\"data-list-name\");\n break;\n }\n else if (node.nodeName == 'body') {\n listName = null;\n break;\n }\n }\n\n let event: IEasyfyEvent = {\n eventName: EventNames.ProductClick,\n data: {\n productIdentifier: productId,\n salesUnitCode: defaultSalesUnitCode,\n listName: listName,\n isPromotedProduct: isPromotedProduct\n }\n }\n EasyfyEventHandler.RunEvent(event);\n window.location = targetUrl;\n }\n else {\n //Don't block links\n window.location = targetUrl;\n }\n }\n }\n\n static ClickEventBanner(event: any, node: any, targetUrl: any) {\n node = node.closest('[data-track-banner]');\n var elementIsRegisteredForClick = node.getAttribute(\"data-track-click\").toLowerCase() === 'true';\n if (elementIsRegisteredForClick) {\n event.stopPropagation();\n event.preventDefault();\n\n var bannerId = node.getAttribute('data-banner-event-id');\n if (bannerId) {\n let event: IEasyfyEvent = {\n eventName: EventNames.BannerClick,\n data: {\n bannerIdentifier: bannerId,\n }\n }\n EasyfyEventHandler.RunEvent(event);\n window.location = targetUrl;\n }\n else {\n //Don't block links\n window.location = targetUrl;\n }\n }\n }\n\n static ClickEventElement(event: any, node: any, targetUrl?: any) {\n node = node.closest('[data-track-element]');\n var elementIsRegisteredForClick = node.getAttribute(\"data-track-click\")?.toLowerCase() === 'true' ?? false;\n if (elementIsRegisteredForClick) {\n\n if (targetUrl) {\n event.stopPropagation();\n event.preventDefault();\n }\n\n var elementId = node.getAttribute('data-event-id');\n\n if (elementId) {\n var trackType = node.getAttribute('data-track-type');\n var properties = new Map();\n\n for (const attribute of node.getAttributeNames()) {\n if (attribute.startsWith(\"data-event-property-\")) {\n const value = node.getAttribute(attribute);\n var key = attribute.replace(\"data-event-property-\", \"\");\n properties.set(key, value);\n }\n }\n\n var data: ITrackableElement = {\n Id: elementId,\n Type: trackType,\n Properties: properties\n }\n\n let event: IEasyfyEvent = {\n eventName: EventNames.ElementClick,\n data\n }\n\n EasyfyEventHandler.RunEvent(event);\n\n const singleClick = node.dataset['singleClick'];\n if (singleClick) node.removeAttribute('data-track-element');\n\n if (targetUrl) {\n window.location = targetUrl;\n }\n }\n else if (targetUrl) {\n //Don't block links\n window.location = targetUrl;\n }\n }\n }\n\n static GetCurrentInstance(): EasyfyEventHandler {\n var instance: EasyfyEventHandler;\n if (EasyfyEventHandler.instance) {\n instance = EasyfyEventHandler.instance\n }\n else if (window.EasyfyEventLayerInstance) {\n instance = window.EasyfyEventLayerInstance as EasyfyEventHandler;\n }\n\n return instance;\n }\n\n static RunEvent(event: IEasyfyEvent): Promise {\n return new Promise(async (resolve) => {\n var dispatchedToServices = [];\n var errors = new Map();\n for await (const service of EasyfyEventData.GetAllServices()) {\n if (EasyfyEventData.ConsumesEvent(service.name, event.eventName)) {\n try {\n var instance = EasyfyEventHandler.GetCurrentInstance();\n\n await instance.eventExporters.get(service.name)?.RegisterEvent(event);\n dispatchedToServices.push(service.name);\n\n }\n catch (error) {\n errors.set(service.name, event.eventName);\n console.warn(error);\n }\n }\n };\n\n EasyfyEventLogger.BroadcastToLogger(event);\n\n if (dispatchedToServices.length > 0) {\n EasyfyEventLogger.Log({ type: \"event\", message: `Event '${event.eventName}' dispatched to: ${dispatchedToServices.join(', ')}` });\n } else {\n EasyfyEventLogger.Log({ type: \"event\", message: `Event '${event.eventName}' fired but not dispatched to any services` });\n }\n errors.forEach((value, key) => {\n EasyfyEventLogger.Log({ type: \"error\", message: `Error when trying to dispatch event '${value}' to: ${key}` });\n });\n\n resolve();\n });\n }\n\n static async RegisterResponseData(responseData: any): Promise {\n return new Promise(async (resolve) => {\n var instance = EasyfyEventHandler.GetCurrentInstance();\n if (instance?.initiated) {\n await EasyfyEventHandler.CheckSessionStart();\n if (responseData?.data?.eventLayer) {\n EasyfyEventLogger.Log({\n message: \"Event layer data added from response\",\n });\n\n EasyfyEventData.AddDataToEventLayer(responseData.data.eventLayer);\n\n EasyfyEventLogger.Log({\n type: \"updateeventlayerstatus\",\n });\n await EasyfyEventHandler.RunEvents();\n }\n }\n resolve();\n });\n }\n\n static GetCookie(cookieName) {\n let cookie = {};\n document.cookie.split(';').forEach(function (el) {\n let [key, value] = el.split('=');\n cookie[key.trim()] = value;\n })\n return cookie[cookieName];\n }\n\n }\n}\n\nexport default Easyfy.Modules;\n","import axios, { AxiosRequestConfig } from 'axios';\nimport EasyfyDataLayer from '@shared/easyfy.datalayer';\nimport Event from './easyfy.events/easyfy.eventhandler';\n\nnamespace Easyfy.Shared.Scripts {\n export interface IExtraHeaders {\n key: string;\n value: string;\n }\n\n export const get = async (url: string, config?: AxiosRequestConfig): Promise => {\n axios.defaults.headers.common[\"IsAxiosRequest\"] = true;\n axios.defaults.headers.common[\"OriginalUrl\"] = window.location.href;\n\n url = generateFullPathWithPrefix(url);\n\n var response = await axios.get(url, config);\n Event.EasyfyEventHandler.RegisterResponseData(response);\n return await EasyfyDataLayer.HandleDataEvents(response);\n };\n\n export const post = async (url: string, data: any, token?: string, config?: AxiosRequestConfig) => {\n if (token) {\n axios.defaults.headers.common[\"RequestVerificationToken\"] = token;\n }\n axios.defaults.headers.common[\"IsAxiosRequest\"] = true;\n axios.defaults.headers.common[\"OriginalUrl\"] = window.location.href;\n\n url = generateFullPathWithPrefix(url);\n\n var response = await axios.post(url, data, config);\n Event.EasyfyEventHandler.RegisterResponseData(response);\n return await EasyfyDataLayer.HandleDataEvents(response);\n };\n\n export const patch = async (url: string, data: any, token?: string, config?: AxiosRequestConfig) => {\n if (token) {\n axios.defaults.headers.common[\"RequestVerificationToken\"] = token;\n }\n axios.defaults.headers.common[\"IsAxiosRequest\"] = true;\n axios.defaults.headers.common[\"OriginalUrl\"] = window.location.href;\n\n url = generateFullPathWithPrefix(url);\n\n var response = await axios.patch(url, data, config);\n Event.EasyfyEventHandler.RegisterResponseData(response);\n return await EasyfyDataLayer.HandleDataEvents(response)\n };\n\n export const axiosDelete = async (url: string, token?: string, config?: AxiosRequestConfig) => {\n if (token) {\n axios.defaults.headers.common[\"RequestVerificationToken\"] = token;\n }\n axios.defaults.headers.common[\"IsAxiosRequest\"] = true;\n axios.defaults.headers.common[\"OriginalUrl\"] = window.location.href;\n\n url = generateFullPathWithPrefix(url);\n\n var response = await axios.delete(url, config);\n Event.EasyfyEventHandler.RegisterResponseData(response);\n return await EasyfyDataLayer.HandleDataEvents(response)\n };\n\n function generateFullPathWithPrefix(url: string): string {\n var prefixPath = document.documentElement?.getAttribute(\"data-prefix-path\");\n if (url && !url.startsWith(\"/\"))\n url = \"/\" + url;\n if (prefixPath) {\n prefixPath = prefixPath.endsWith(\"/\") ? prefixPath.slice(0, -1) : prefixPath;\n if (prefixPath.length > 1 && !prefixPath.startsWith(\"/\"))\n prefixPath = \"/\" + prefixPath;\n if (url)\n return prefixPath + url;\n else\n return prefixPath;\n }\n else\n return url;\n }\n}\n\nexport default Easyfy.Shared.Scripts;","import easyfyAxios from '@shared/easyfy.axios';\n\nexport interface IReviewListData {\n productid: string;\n page: number;\n pageSize: number;\n}\n\nnamespace Easyfy.Web.Services.Reviews {\n export const ReviewListGetMore = async (data: IReviewListData, token: string): Promise => {\n return await easyfyAxios.post(`/product?handler=getmorereviews`, data, token);\n };\n}\n\nexport default Easyfy.Web.Services.Reviews;\n","import { invoke } from '@shared/easyfy.decorators';\nimport { element, globalEvent } from '@shared/easyfy.core';\nimport { addCss, isMobile, removeCss } from '@shared/easyfy.utils';\nimport { replaceContent } from '@clientShared/utils';\nimport Splide from '@splidejs/splide';\nimport { GetSubscriptionFlyoutView } from '@clientWebServices/productoptions.service';\nimport reviewsService from '@clientWebServices/reviews.service';\n\n@invoke\n// eslint-disable-next-line @typescript-eslint/no-unused-vars\nclass Product {\n constructor() {}\n\n onInit() {\n globalEvent({\n type: 'click',\n events: [\n {\n event: 'change-image',\n callback: this.changeImage.bind(this),\n },\n {\n event: 'scroll-to-salesunit-selector',\n callback: this.scrollToSalesunitSelector,\n },\n {\n action: 'get-more-reviews',\n callback: this.loadMoreReviews,\n },\n {\n event: 'scroll-to-reviews',\n callback: this.scrollToReviews\n }\n ],\n });\n\n window.addEventListener('update-subs-flyout', (() => {\n this.onUpdateSubscFlyout();\n }) as EventListener);\n\n document.querySelectorAll('[data-container=\"product-images-slider\"]').forEach((item) => {\n item.classList.add('splide');\n\n const slider = new Splide(item as HTMLElement, {\n type: 'slide',\n rewind: true,\n arrows: false,\n lazyLoad: 'nearby',\n });\n\n slider.on('pagination:mounted', function (data) {\n data.list.classList.add('with-dots');\n });\n\n slider.mount();\n });\n }\n\n changeImage(e: Event) {\n e.preventDefault();\n\n const element: HTMLElement = e.target as HTMLElement;\n const imageContainer: HTMLElement = document.querySelector('[data-container=\"product-images\"]') as HTMLElement;\n const img = imageContainer.querySelector('img');\n let imageSrc = element.getAttribute('href');\n\n if (!imageSrc) {\n imageSrc = element.parentElement.getAttribute('href');\n }\n\n img.setAttribute('src', imageSrc);\n img.setAttribute('srcset', imageSrc);\n\n removeCss(document.querySelectorAll('[data-event=\"change-image\"]'), 'active');\n addCss(element, 'active');\n\n return false;\n }\n\n scrollToSalesunitSelector(e: Event) {\n if (!isMobile()) return;\n const el = e?.target as HTMLElement;\n const elParent = el?.closest('.info') as HTMLElement;\n const hasSalesUnit = elParent?.dataset?.salesunits;\n if (hasSalesUnit && hasSalesUnit.toLowerCase() == 'true') {\n document.getElementById('salesunit-selector')?.scrollIntoView({ behavior: 'smooth', block: 'center' });\n }\n return false;\n }\n\n scrollToReviews() {\n const container = document.getElementById('review-container') as HTMLElement;\n const reviewDetails = container?.querySelector('details') as HTMLElement;\n\n reviewDetails?.setAttribute('open', '');\n container?.scrollIntoView({ behavior: 'smooth', block: 'center' });\n \n return false;\n }\n\n onUpdateSubscFlyout() {\n const subButton = element('[data-container=\"subscription-button\"]') as HTMLElement;\n const searchProdId = subButton?.dataset?.searchproductid;\n if (subButton && searchProdId) {\n GetSubscriptionFlyoutView(searchProdId)\n .then((res) => {\n if (res?.data?.success && res?.data?.partialHtml != null) {\n const freqSelector = element('[data-container=\"subscription-freq\"]');\n if (freqSelector) {\n replaceContent(freqSelector, res?.data?.partialHtml, 'replaceInnerHtml');\n freqSelector.setAttribute('data-updateflyout', 'false');\n }\n }\n })\n .catch((err) => {\n console.log(err);\n });\n }\n return false;\n }\n\n loadMoreReviews(e: Event) {\n e.preventDefault();\n e.stopPropagation();\n\n const target: HTMLElement = e.target as HTMLElement;\n const container: HTMLElement = target.closest('[data-container=\"product-reviews\"]');\n const reviewsContainer = container?.querySelector('[data-container=\"reviews-container\"]');\n const buttonContainer = container?.querySelector('[data-container=\"reviews-container-button\"]');\n const button = container?.querySelector('[data-action=\"get-more-reviews\"]');\n const page = button?.attributes['data-page']?.value;\n const productid = button?.attributes['data-product']?.value;\n const pagesize = button?.attributes['data-pagesize']?.value;\n const token = button?.attributes['data-token']?.value;\n\n reviewsService.ReviewListGetMore({ page: Number(page) + 1, productid: productid, pageSize: Number(pagesize) }, token).then((response) => {\n if (response?.data != null) {\n reviewsContainer.insertAdjacentHTML('beforeend', response.data.partial);\n buttonContainer.innerHTML = response.data.buttonpartial;\n }\n });\n }\n}\n","import easyfyAxios from '@shared/easyfy.axios';\n\nexport const GetProductOption = async (optionId: string): Promise => {\n return await easyfyAxios.get(`/api/productoptionsselector?searchProductId=${optionId}`);\n};\n\nexport const GetSubscriptionFlyoutView = async (productId: string): Promise => {\n return await easyfyAxios.get(`/product?handler=subscriptionflyoutview&searchProdId=${productId}`);\n};\n\nexport const GetSubscriptionFlyoutViewForProductList = async (productId: string, variantId: string): Promise => {\n return await easyfyAxios.get(`/product?handler=subscriptionflyoutviewforproductlist&searchProdId=${productId}&variantId=${variantId}`);\n};\n","import { addCss } from '@shared/easyfy.utils';\n\nexport const isMobile = () => (window.innerWidth <= 768 ? true : false);\n\nexport const isDesktop = () => (window.innerWidth >= 1100 ? true : false);\n\nexport const toggleProp = (el: HTMLElement): void => {\n !('open' in el.dataset) ? (el.dataset.open = '') : delete el.dataset.open;\n};\n\nexport const animationEnded = (el: Element | HTMLElement, func: EventListenerOrEventListenerObject) =>\n el.addEventListener('animationend', func, { once: true });\n\nexport const deleteCookie = (name: string) => {\n const expirationTime = Date.now() - 30 * 60 * 1000;\n document.cookie = `${name}= ; expires=${new Date(expirationTime).toUTCString()}; path=/; domain=${window.location.hostname}`;\n};\n\nexport const setCookie = (contentCookie: string, cookieName: string, expirationDate?: Date) => {\n deleteCookie(cookieName);\n\n const expiration = expirationDate || new Date();\n\n if (!expirationDate) {\n expiration.setTime(expiration.getTime() + 30 * 60 * 1000); // default to 30 minutes\n }\n\n document.cookie = `${cookieName}=${contentCookie}; expires=\"${expiration.toUTCString()}\"; path=/; domain=${window.location.hostname}`;\n};\n\nexport const delay = (ms: number) => new Promise((resolve) => setTimeout(resolve, ms));\n\nexport const clearContent = (container) => {\n container.innerHTML = '';\n};\n\nexport const replaceContent = (container, data: string, type: string = 'append', clearData: boolean = true) => {\n if (clearData) container.innerHTML = '';\n\n const content = document.createRange().createContextualFragment(data).firstElementChild;\n\n switch (type) {\n case 'after':\n container.after(content);\n break;\n case 'replaceInnerHtml':\n container.innerHTML = content.innerHTML;\n break;\n case 'append':\n default:\n container.appendChild(content);\n break;\n }\n};\n\nexport const createElementWithClasses = (tag: string, classes: string | string[], innerText?: string | undefined): HTMLElement => {\n const element = document.createElement(tag);\n addCss(element, classes);\n\n if (innerText) element.innerText = innerText;\n return element;\n};\n\nexport const createLink = (href: string | undefined, text: string, classes: string | string[]): HTMLAnchorElement => {\n const link = document.createElement('a');\n link.href = href || '#';\n link.innerText = text;\n addCss(link, classes);\n return link;\n};\n\nexport const createEventButton = (text: string, event: string, classes: string | string[]): HTMLButtonElement => {\n const button = document.createElement('button');\n button.innerText = text;\n button.dataset.event = event;\n addCss(button, classes);\n return button;\n};\n\nexport interface UrlHistoryContent {\n appendType: string;\n data: string;\n}\n","// The module cache\nvar __webpack_module_cache__ = {};\n\n// The require function\nfunction __webpack_require__(moduleId) {\n\t// Check if module is in cache\n\tvar cachedModule = __webpack_module_cache__[moduleId];\n\tif (cachedModule !== undefined) {\n\t\treturn cachedModule.exports;\n\t}\n\t// Create a new module (and put it into the cache)\n\tvar module = __webpack_module_cache__[moduleId] = {\n\t\t// no module.id needed\n\t\t// no module.loaded needed\n\t\texports: {}\n\t};\n\n\t// Execute the module function\n\t__webpack_modules__[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n\t// Return the exports of the module\n\treturn module.exports;\n}\n\n// expose the modules object (__webpack_modules__)\n__webpack_require__.m = __webpack_modules__;\n\n","// getDefaultExport function for compatibility with non-harmony modules\n__webpack_require__.n = (module) => {\n\tvar getter = module && module.__esModule ?\n\t\t() => (module['default']) :\n\t\t() => (module);\n\t__webpack_require__.d(getter, { a: getter });\n\treturn getter;\n};","// define getter functions for harmony exports\n__webpack_require__.d = (exports, definition) => {\n\tfor(var key in definition) {\n\t\tif(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {\n\t\t\tObject.defineProperty(exports, key, { enumerable: true, get: definition[key] });\n\t\t}\n\t}\n};","__webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop))","// define __esModule on exports\n__webpack_require__.r = (exports) => {\n\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\t}\n\tObject.defineProperty(exports, '__esModule', { value: true });\n};","__webpack_require__.j = 9423;","// no baseURI\n\n// object to store loaded and loading chunks\n// undefined = chunk not loaded, null = chunk preloaded/prefetched\n// [resolve, reject, Promise] = chunk loading, 0 = chunk loaded\nvar installedChunks = {\n\t9423: 0\n};\n\n// no chunk on demand loading\n\n// no prefetching\n\n// no preloaded\n\n// no HMR\n\n// no HMR manifest\n\n__webpack_require__.O.j = (chunkId) => (installedChunks[chunkId] === 0);\n\n// install a JSONP callback for chunk loading\nvar webpackJsonpCallback = (parentChunkLoadingFunction, data) => {\n\tvar [chunkIds, moreModules, runtime] = data;\n\t// add \"moreModules\" to the modules object,\n\t// then flag all \"chunkIds\" as loaded and fire callback\n\tvar moduleId, chunkId, i = 0;\n\tif(chunkIds.some((id) => (installedChunks[id] !== 0))) {\n\t\tfor(moduleId in moreModules) {\n\t\t\tif(__webpack_require__.o(moreModules, moduleId)) {\n\t\t\t\t__webpack_require__.m[moduleId] = moreModules[moduleId];\n\t\t\t}\n\t\t}\n\t\tif(runtime) var result = runtime(__webpack_require__);\n\t}\n\tif(parentChunkLoadingFunction) parentChunkLoadingFunction(data);\n\tfor(;i < chunkIds.length; i++) {\n\t\tchunkId = chunkIds[i];\n\t\tif(__webpack_require__.o(installedChunks, chunkId) && installedChunks[chunkId]) {\n\t\t\tinstalledChunks[chunkId][0]();\n\t\t}\n\t\tinstalledChunks[chunkId] = 0;\n\t}\n\treturn __webpack_require__.O(result);\n}\n\nvar chunkLoadingGlobal = self[\"webpackJsonpWeb\"] = self[\"webpackJsonpWeb\"] || [];\nchunkLoadingGlobal.forEach(webpackJsonpCallback.bind(null, 0));\nchunkLoadingGlobal.push = webpackJsonpCallback.bind(null, chunkLoadingGlobal.push.bind(chunkLoadingGlobal));","// startup\n// Load entry module and return exports\n// This entry module depends on other loaded chunks and execution need to be delayed\nvar __webpack_exports__ = __webpack_require__.O(undefined, [6017], () => (__webpack_require__(4204)))\n__webpack_exports__ = __webpack_require__.O(__webpack_exports__);\n"],"names":["deferred","query","document","querySelector","getBlazorEditMode","window","isAdminModeEnabled","undefined","isEditModeEnabled","editModeCookie","cookie","split","find","trim","startsWith","toLowerCase","docReady","callback","context","blazorFinishedLoadingEventRegistered","EasyfyMethods","triggerWindowEvent","eventName","eventData","event","CustomEvent","detail","dispatchEvent","readyList","readyFired","readyEventHandlersInstalled","ready","readyBody","i","length","fn","call","ctx","blazorFinishedLoading","addEventListener","TypeError","setTimeout","push","readyState","globalEventList","globalEventHandler","e","target","eventTarget","globalGetTargetAction","item","globalFindAction","type","globalEventInvokeCallback","globalGetTargetEvent","globalFindEvent","globalMatchType","cbs","globalEventAdd","action","globalFind","itemType","eventType","actionType","globalGetTarget","dataTarget","attributes","value","parentNode","parseToBoolean","val","isString","removeCss","el","className","Array","isArray","NodeList","classList","remove","forEach","element","add","injector","dependencies","resolveOnload","resolve","depends","ctor","cb","id","len","Math","random","toString","substr","name","func","data","hasOwnProperty","index","dependencyItem","loadedVal","Object","defineProperty","get","set","splice","dependencyFunc","key","this","enumerable","configurable","obj","prop","prototype","writable","handler","oldval","newval","getter","setter","Easyfy","Shared","Scripts","PushToDataLayer","gtmEvent","PushProductImpressionEvent","eventProducts","listName","currencyCode","ecommerce","impressions","PushProductClickEvent","click","actionField","list","ListNameCleanUp","products","PushProductDetailEvent","PushProductAddEvent","PushProductRemoveEvent","PushCheckoutEvent","step","option","checkout","HandleDataEvents","response","dataLayer","BuildAndPushEvents","dataEvents","dataEvent","dataProduct","product","brand","category","price","variant","quantity","dimension3","dimension4","dimension5","dimension7","clickProducts","clickProduct","position","dimension6","impressionProducts","impressionProduct","detailProducts","detailProduct","console","dir","listname","replace","EasyfyEventData","AddDataToEventLayer","EasyfyEventLayer","events","productLists","productList","productPrices","basket","notification","notifications","AddCustomDataToEventLayer","customData","GlobalIgnoreEvents","result","configuration","addProductImpressionsServerSide","SiteInfo","site","PageInfo","pageInfo","Events","ClearEvents","ShouldRegisterProductImpressions","ShouldRegisterBannerImpressions","addBannerImpressionsServerSide","GetAllServices","services","GetService","serviceName","serviceInstance","GetServiceNames","service","ServiceIsActive","enabled","ConsumesEvent","includeAllEvents","Product","ProductAt","atIndex","error","Products","ids","productDataSet","ProductsAt","indexes","AllProducts","AllProductLists","ProductIndexInList","productId","productsInList","ProductIds","indexOf","ProductSalesUnitPrice","ProductSalesUnitPrices","prices","AllProductSalesUnitPrices","Banner","banners","AllBanners","HasNotifications","Notifications","ClearNotifications","HasEvents","Basket","GetCurrencyCode","returnValue","GetCustomData","GetClientEventMetaData","SessionId","localStorage","getItem","LocalStorageKeys","UserId","ClientId","IsDesktop","IsDekstop","IsMobilePhone","IsTablet","IPAddress","IsRecurringUser","flagAsRecurringAfterCheck","cookieKey","UserIdCookieKey","userId","GetCookieValue","LastCheckedUserId","setItem","cookieName","SetStatsApiBlock","block","StatsIsBlocked","removeItem","StatsApiIsBlocked","StatsEventExporter","_payloadKbThreshold","_eventThreshold","_eventThresholdRemoved","WithMapper","mapper","LoadAndSetTransitionStatus","CheckVisibility","bind","RegisterEvent","Promise","MapEventData","AccumulateEvent","StatsEventsThresholdRemoved","storedDataString","StatsEventsTransitionObj","_eventData","JSON","parse","ClientMetaData","EventRequests","RecheckAndSetTransitionStatus","eventsMatch","skipEventNames","EventNames","BannerImpression","ElementImpression","ProductImpression","includes","Event","stringify","str","bytes","TextEncoder","encode","blob","Blob","_blob","GetObjectSizeInKB","SendEventsToStatsApi","navigator","sendBeacon","visibilityState","jsonString","EasyfyEventLogger","Ga4EventExporter","ga4Event","BroadcastChannel","ConsoleLog","message","prefix","color","bgColor","Log","CheckLogStatus","EnableLog","DisableLog","ToggleImpressionVisualizer","PrintEventLayer","HidePrintedEventLayer","RunEventConsumer","DisplayEventMessage","BroadcastToLogger","GetCurrentTime","now","Date","getHours","getMinutes","getSeconds","getMilliseconds","FeatureNames","EventTracking","Features","FeatureIsActive","featureName","hasAttribute","KlaviyoEventExporter","PushToKlaviyo","identify","IdentifyUser","klaviyoEvent","emailToRegister","ServiceNames","Stats","Ga4","Klaviyo","PageView","ProductClick","ProductPageView","BannerClick","ElementClick","AddToCart","RemoveFromCart","QuantityChanged","StartedCheckout","CompletedCheckout","SearchPerformed","ContinueToPayment","SessionStarted","LoggedIn","LoggedOut","Message","FetchClientMetaData","BlockStatsApi","SessionTimer","Modules","EasyfyEventHandler","constructor","eventMappers","eventExporters","Map","observedElements","initiated","instance","featureFlag","EasyfyEventLayerInstance","eventExporter","CheckSessionStart","then","RunEvents","InitProductIntersectionObserver","InitMutationObserver","InitBannerIntersectionObserver","InitElementIntersectionObserver","ClickEventChecker","inlineScript","RunEvent","sessionTimer","toUTCString","SendStartSessionEvent","checkTime","diff","getTime","abs","round","oldSessionId","fetch","ok","status","clientMetaData","json","sessionId","clientId","isDesktop","isMobilePhone","isTablet","userIdCookieKey","ipAddress","HandleWorkerMessage","clientData","Culture","Currency","RecurringUser","Referrer","referrer","Path","location","pathname","UserAgent","userAgent","VisitorId","sessionStartedEvent","options","childList","subtree","characterData","targets","querySelectorAll","mutationObserver","MutationObserver","ElementMutated","observe","mutations","mutation","RebindObserveProducts","BannerElementMutated","RebindObserveBanners","intersectionObserver","IntersectionObserver","ProductCardObserved","root","rootMargin","threshold","bannerIntersectionObserver","BannerElementObserved","TrackableElementObserved","disconnect","entries","observer","eventProductIds","eventProductSalesUnitCodes","listIds","promotedProducts","entry","isIntersecting","unobserve","getAttribute","productIdentifier","elementIdentifier","defaultSalesUnitCode","isPromotedProduct","node","parentElement","listId","nodeName","productIdentifiers","salesUnitCodes","bannerIds","bannerIdentifier","elements","trackType","properties","attribute","getAttributeNames","Id","Type","Properties","closest","targetUrl","href","ClickEventProduct","ClickEventBanner","ClickEventElement","stopPropagation","preventDefault","salesUnitCode","bannerId","elementId","dataset","removeAttribute","GetCurrentInstance","dispatchedToServices","errors","join","RegisterResponseData","responseData","eventLayer","GetCookie","generateFullPathWithPrefix","url","prefixPath","documentElement","endsWith","slice","config","axios","defaults","headers","common","post","token","patch","axiosDelete","delete","Web","Services","Reviews","ReviewListGetMore","onInit","changeImage","scrollToSalesunitSelector","loadMoreReviews","scrollToReviews","foundItem","actionFound","eventFound","globalFound","body","removeEventListener","onUpdateSubscFlyout","slider","rewind","arrows","lazyLoad","on","mount","img","imageSrc","setAttribute","innerWidth","elParent","hasSalesUnit","salesunits","getElementById","scrollIntoView","behavior","container","reviewDetails","subButton","searchProdId","searchproductid","res","success","partialHtml","freqSelector","clearData","innerHTML","content","createRange","createContextualFragment","firstElementChild","after","appendChild","replaceContent","catch","err","reviewsContainer","buttonContainer","button","page","productid","pagesize","Number","pageSize","insertAdjacentHTML","partial","buttonpartial","newClass","readyAfter","apply","init","resolves","__webpack_module_cache__","__webpack_require__","moduleId","cachedModule","exports","module","__webpack_modules__","m","O","chunkIds","priority","notFulfilled","Infinity","fulfilled","j","keys","every","r","n","__esModule","d","a","definition","o","Symbol","toStringTag","installedChunks","chunkId","webpackJsonpCallback","parentChunkLoadingFunction","moreModules","runtime","some","chunkLoadingGlobal","self","__webpack_exports__"],"sourceRoot":""}