{"version":3,"file":"692.63a0aa9002aa6209de96.js","mappings":"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","sources":["webpack://iflyworld.web/./wwwroot/app/src/js/global.js","webpack://iflyworld.web/./wwwroot/app/src/js/viewport-size.js"],"sourcesContent":["// ***********************************\r\n// ***** global site variables *****\r\n// ***********************************\r\n\r\n// language detection\r\n\r\nconst siteLang = document.querySelector('html').getAttribute('lang').toLowerCase();\r\n\r\nconst translations = {\r\n 'en': {\r\n 'site settings': 'Site settings',\r\n 'close': 'Close',\r\n 'manage effects': 'Manage the visual effects on this site',\r\n 'snow': 'Snow'\r\n },\r\n \"fr\": {\r\n \"site settings\": \"Paramètres du site\",\r\n 'close': 'Fermer',\r\n 'manage effects': 'Gérer les effets visuels sur ce site',\r\n 'snow': 'Neige'\r\n }\r\n}\r\n\r\n// other settings\r\n\r\nconst detectReducedMotionPref = window.matchMedia('(prefers-reduced-motion: reduce)');\r\nlet settingsLinksAdded = false,\r\n settingsModalContent = null;\r\n\r\n// site settings\r\n\r\nconst addSettingsLinks = () => {\r\n // utility bar link?\r\n let utilityBar = document.body.querySelector('.header--utility-bar--links ul');\r\n if(utilityBar != null) {\r\n let li = document.createElement('li');\r\n li.classList.add('list-inline-item','ms-2');\r\n li.innerHTML = ``;\r\n utilityBar.appendChild(li);\r\n }\r\n // update state\r\n settingsLinksAdded = true;\r\n};\r\n\r\nconst refreshModalContent = () => {\r\n if(!settingsModalContent) {\r\n let settingsModal = document.createElement('div');\r\n settingsModal.setAttribute('id','site-settings');\r\n settingsModal.setAttribute('class','modal fade');\r\n settingsModal.setAttribute('data-bs-backdrop','static');\r\n settingsModal.setAttribute('data-bs-keyboard','false');\r\n settingsModal.setAttribute('tabindex','-1');\r\n settingsModal.setAttribute('aria-hidden','true');\r\n settingsModal.innerHTML = `
${translations[siteLang]['manage effects']}
`;\r\n siteSettings.fx.forEach(i => {\r\n settingsModalContent.appendChild(i.controller);\r\n });\r\n }\r\n}\r\n\r\nexport const siteSettings = {\r\n siteLang: siteLang,\r\n translate: (key) => {\r\n return translations[siteLang][key];\r\n },\r\n reducedMotionPref: detectReducedMotionPref.matches,\r\n fx: [],\r\n fxAdd: (fxType, fxEnable, fxCallback = null) => {\r\n let exists = false;\r\n siteSettings.fx.forEach(i => {\r\n if(i.type == fxType) exists = true;\r\n });\r\n if(!exists) {\r\n siteSettings.fx.push({\r\n type: fxType,\r\n enabled: fxEnable,\r\n callback: fxCallback,\r\n controller: document.createElement('div')\r\n });\r\n let thisIndex = siteSettings.fx.length - 1,\r\n thisFX = siteSettings.fx[thisIndex];\r\n thisFX.controller.setAttribute('class','form-check form-switch');\r\n let checkbox = document.createElement('input');\r\n checkbox.setAttribute('id',`site-settings--fx--${thisIndex}`);\r\n checkbox.setAttribute('class','form-check-input');\r\n checkbox.setAttribute('type','checkbox');\r\n checkbox.setAttribute('role','switch');\r\n if(fxEnable) checkbox.setAttribute('checked',true);\r\n checkbox.addEventListener('click',() => {\r\n siteSettings.fxToggle(thisFX.type,checkbox.checked);\r\n });\r\n thisFX.controller.appendChild(checkbox);\r\n let label = document.createElement('label');\r\n label.setAttribute('for',`site-settings--fx--${thisIndex}`);\r\n label.setAttribute('class','form-check-label');\r\n label.innerHTML = thisFX.type;\r\n thisFX.controller.appendChild(label);\r\n }\r\n if(fxCallback) fxCallback(fxEnable);\r\n // add settings links if not already added\r\n if(!settingsLinksAdded) addSettingsLinks();\r\n // refresh modal content\r\n refreshModalContent();\r\n },\r\n fxToggle: (fxType, mode) => {\r\n siteSettings.fx.forEach(i => {\r\n if(i.type == fxType) {\r\n i.enabled = mode;\r\n if(i.callback) i.callback(mode);\r\n }\r\n });\r\n }\r\n};\r\n\r\n// viewport size\r\n\r\nexport const viewport = {\r\n vw: 0,\r\n vh: 0,\r\n setVw: (val) => {\r\n viewport.vw = val;\r\n },\r\n setVh: (val) => {\r\n viewport.vh = val;\r\n }\r\n};\r\n\r\n// component states\r\n\r\nexport const mainNavigation = {\r\n mobileActive: false,\r\n setMobileActive: (mode) => {\r\n mainNavigation.mobileActive = mode;\r\n },\r\n desktopActive: false,\r\n setDesktopActive: (mode) => {\r\n mainNavigation.desktopActive = mode;\r\n }\r\n};\r\n\r\nexport const headerSearch = {\r\n active: false,\r\n setActive: (mode) => {\r\n headerSearch.active = mode;\r\n }\r\n};","import { viewport } from './global';\r\nimport { ResizeObserver as Polyfill } from '@juggle/resize-observer';\r\nconst ResizeObserver = window.ResizeObserver || Polyfill;\r\n\r\n// add element to body for accurately reporting viewport size\r\n\r\nlet $body = document.querySelector('body');\r\n\r\nconst vpSizeCheck = (w,h) => {\r\n if(w != viewport.vw || h != viewport.vh) {\r\n window.requestAnimationFrame(() => {\r\n if(w != viewport.vw) {\r\n viewport.setVw(w);\r\n document.documentElement.style.setProperty('--vpWidth', `${viewport.vw}px`);\r\n }\r\n if(h != viewport.vh) {\r\n viewport.setVh(h);\r\n document.documentElement.style.setProperty('--vpHeight', `${viewport.vh}px`);\r\n }\r\n });\r\n }\r\n};\r\n\r\n// add element to body\r\n\r\nconst vpSizer = document.createElement('div');\r\nvpSizer.setAttribute('id','vp-sizer');\r\nvpSizer.setAttribute('aria-hidden','true');\r\nvpSizer.setAttribute('style','position:fixed;z-index:-1;top:0;left:0;bottom:0;right:0;pointer-events:none');\r\n$body.appendChild(vpSizer);\r\n\r\n// add resize observer\r\n\r\nconst vpSizerResizeObserver = new ResizeObserver(entries => {\r\n for (let entry of entries) {\r\n const cr = entry.contentRect;\r\n vpSizeCheck(cr.width,cr.height);\r\n }\r\n});\r\n\r\nvpSizerResizeObserver.observe(vpSizer);"],"names":["siteLang","document","querySelector","getAttribute","toLowerCase","translations","detectReducedMotionPref","window","matchMedia","settingsLinksAdded","settingsModalContent","siteSettings","translate","key","reducedMotionPref","matches","fx","fxAdd","fxType","fxEnable","fxCallback","exists","forEach","i","type","push","enabled","callback","controller","createElement","thisIndex","length","thisFX","setAttribute","checkbox","addEventListener","fxToggle","checked","appendChild","label","innerHTML","utilityBar","body","li","classList","add","addSettingsLinks","settingsModal","refreshModalContent","mode","viewport","vw","vh","setVw","val","setVh","mainNavigation","mobileActive","setMobileActive","desktopActive","setDesktopActive","headerSearch","active","setActive","ResizeObserver","Polyfill","$body","vpSizeCheck","w","h","requestAnimationFrame","documentElement","style","setProperty","vpSizer","entries","entry","cr","contentRect","width","height","observe"],"sourceRoot":""}