{"version":3,"file":"LottieUtils.js","names":["defineDs","ApiRequest","lottieFileCache","getDevice","device","window","matchMedia","matches","replaceLottieTokens","_ref","lottieString","lottieReplacements","newString","property","replace","initializeLottie","_ref3","_asyncToGenerator","_ref2","$lottieContainer","settings","prevDevice","addLottie","_ref5","_ref4","lottieMobile","lottieTablet","lottieDesktop","$playerElement","querySelector","src","url","then","response","JSON","stringify","catch","console","warn","load","style","visibility","_x2","apply","arguments","addEventListener","_x"],"sources":["DanskeSpil/Domain/NumberGames/Scripts/Helpers/LottieUtils.js"],"sourcesContent":["defineDs(\r\n 'DanskeSpil/Domain/NumberGames/Scripts/Helpers/LottieUtils',\r\n ['Shared/Framework/Mithril/Scripts/Helpers/ApiRequest'],\r\n function (ApiRequest) {\r\n const lottieFileCache = {};\r\n\r\n const getDevice = () => {\r\n let device = 'mobile';\r\n if (window.matchMedia('(min-width: 1440px)').matches) {\r\n device = 'desktop';\r\n } else if (window.matchMedia('(min-width: 768px)').matches) {\r\n device = 'tablet';\r\n }\r\n return device;\r\n };\r\n\r\n /**\r\n * @param {string} lottieString lottie file string\r\n * @param {object} lottieReplacements e.g. {1234567890: '999', 1234567891: '888'}\r\n * @returns {string}a string with the tokens replaced\r\n */\r\n const replaceLottieTokens = ({ lottieString, lottieReplacements }) => {\r\n let newString = lottieString;\r\n for (const property in lottieReplacements) {\r\n newString = newString.replace(property, lottieReplacements[property]);\r\n }\r\n return newString;\r\n };\r\n\r\n /**\r\n * @param {HTMLElement} $lottieContainer dom container of the lottie player\r\n * @param {object} settings Configuration for the lottie player e.g. {lottieMobile: 'url', lottieTablet: 'url', lottieDesktop: 'url', lottieReplacements: {1234567890: '999', 1234567891: '888'}}\r\n * @returns undefined\r\n */\r\n const initializeLottie = async ({ $lottieContainer, settings }) => {\r\n if (!settings) return;\r\n\r\n let prevDevice;\r\n\r\n const addLottie = async ({ $lottieContainer, settings }) => {\r\n const { lottieMobile, lottieTablet, lottieDesktop, lottieReplacements } = settings;\r\n const $playerElement = $lottieContainer.querySelector('lottie-player');\r\n const device = getDevice();\r\n if (device === prevDevice || !$playerElement) return;\r\n prevDevice = device;\r\n\r\n let src;\r\n if (device === 'desktop') src = lottieDesktop;\r\n if (device === 'tablet') src = lottieTablet;\r\n if (device === 'mobile') src = lottieMobile;\r\n\r\n if (src) {\r\n if (!lottieFileCache[src]) {\r\n await ApiRequest({ url: src })\r\n .then((response) => {\r\n lottieFileCache[src] = JSON.stringify(response);\r\n })\r\n .catch(() => {\r\n console.warn('Failed to load Lottie -> ', src);\r\n });\r\n }\r\n\r\n const lottieString = lottieFileCache[src];\r\n lottieReplacements\r\n ? $playerElement.load(replaceLottieTokens({ lottieString, lottieReplacements }))\r\n : $playerElement.load(lottieString);\r\n $playerElement.style.visibility = 'unset';\r\n } else {\r\n $playerElement.style.visibility = 'hidden';\r\n $playerElement.load({});\r\n }\r\n };\r\n\r\n await addLottie({ $lottieContainer, settings });\r\n window.addEventListener('resize', () => addLottie({ $lottieContainer, settings }));\r\n };\r\n\r\n return {\r\n initializeLottie,\r\n getDevice\r\n };\r\n }\r\n);\r\n"],"mappings":"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","ignoreList":[]}