{"version":3,"sources":["webpack:///webpack/bootstrap","webpack:///./Components/banner/assets/scripts/banner.js","webpack:///./Components/banner/assets/scripts/modules/ModuleBanner.js","webpack:///./Components/banner/assets/scripts/modules/Module.js"],"names":["installedModules","__webpack_require__","moduleId","exports","module","i","l","modules","call","m","c","d","name","getter","o","Object","defineProperty","enumerable","get","r","Symbol","toStringTag","value","t","mode","__esModule","ns","create","key","bind","n","object","property","prototype","hasOwnProperty","p","s","ModuleBanner","Module","require","Banner","window","Modules","constructor","el","super","this","view","document","querySelector","mainHeader","nav","querySelectorAll","closeBtn","dom","dataView","mediaQuery","matchMedia","init","checkCookies","hideBanner","managePaddingTop","setCSSCustomProps","bindEvents","setResponsiveClasses","setCloseBannerButton","showBanner","cookieName","dataset","contentSid","contentFid","cookie","split","some","item","trim","startsWith","setCookies","sessionCookieName","foreverCookieName","cookieDate","Date","setMonth","getMonth","toGMTString","style","display","setAttribute","banners","forEach","banner","desktopBgColor","desktopBackgroundcolor","mobileBgColor","mobileBackgroundcolor","desktopTxtColor","desktopTextcolor","mobileTxtColor","mobileTextcolor","setProperty","handleBannerIcon","handleBannerImage","initCountdown","triggerTracking","extraPadding","getComputedStyle","paddingTop","isLegacyNav","length","navClientHeight","clientHeight","newPaddingTop","addEventListener","target","elements","elem","e","handleResponsiveClasses","dataDesktop","desktopClasses","dataMobile","mobileClasses","elemDesktopClass","elemMobileClass","matches","classList","remove","add","mobileBgimage","handleCloseBannerButton","imageMobile","imageDesktop","desktopBgimage","backgroundImage","setBannerMedia","selector","media","desktopMediaUrl","handleBannerMedia","mobileMediaUrl","mobileMediaAlt","desktopMediaAlt","ecommerceGa4","events","cleanJSON","pushDatalayer","datalayerEvent","dataLayer","Array","isArray","push","strJSON","replace","JSON","parse","countdown","currentTime","parseFloat","eventTime","endTime","$sec","$min","$hours","$days","interval","setInterval","updateTimer","diff","clearInterval","textContent","seconds","Math","floor","slice","minutes","hours","days","$el","body","html","site","w"],"mappings":"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","file":"components.banner.js","sourcesContent":[" \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId]) {\n \t\t\treturn installedModules[moduleId].exports;\n \t\t}\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n \t\t}\n \t};\n\n \t// define __esModule on exports\n \t__webpack_require__.r = function(exports) {\n \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n \t\t}\n \t\tObject.defineProperty(exports, '__esModule', { value: true });\n \t};\n\n \t// create a fake namespace object\n \t// mode & 1: value is a module id, require it\n \t// mode & 2: merge all properties of value into the ns\n \t// mode & 4: return value when already ns object\n \t// mode & 8|1: behave like require\n \t__webpack_require__.t = function(value, mode) {\n \t\tif(mode & 1) value = __webpack_require__(value);\n \t\tif(mode & 8) return value;\n \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n \t\tvar ns = Object.create(null);\n \t\t__webpack_require__.r(ns);\n \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n \t\treturn ns;\n \t};\n\n \t// getDefaultExport function for compatibility with non-harmony modules\n \t__webpack_require__.n = function(module) {\n \t\tvar getter = module && module.__esModule ?\n \t\t\tfunction getDefault() { return module['default']; } :\n \t\t\tfunction getModuleExports() { return module; };\n \t\t__webpack_require__.d(getter, 'a', getter);\n \t\treturn getter;\n \t};\n\n \t// Object.prototype.hasOwnProperty.call\n \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"\";\n\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = 14);\n","let ModuleBanner = {\r\n Module: require(\"./modules/Module\"),\r\n Banner: require(\"./modules/ModuleBanner\")\r\n};\r\nwindow.Modules = { ...window.Modules, ...ModuleBanner };","import Module from './Module';\r\n\r\nexport default class ModuleBanner extends Module {\r\n\tconstructor(el) {\r\n\t\tsuper(el);\r\n\t\tthis.view = document.querySelector('#site');\r\n\t\tthis.mainHeader = document.querySelector('header.main-header');\r\n\t\tthis.nav = document.querySelectorAll('header.main-header nav');\r\n\t\tthis.closeBtn = this.dom.el.querySelector('.banner__button');\r\n\t\tthis.dataView = document.querySelector('[data-view]');\r\n\t\tthis.mediaQuery = window.matchMedia('(max-width: 990px)');\r\n\t}\r\n\r\n\tinit() {\r\n\t\tif (this.checkCookies()) {\r\n\t\t\tthis.hideBanner();\r\n\t\t\tthis.managePaddingTop();\r\n\t\t} else {\r\n\t\t\tthis.setCSSCustomProps();\r\n\t\t\tthis.bindEvents();\r\n\t\t\tthis.setResponsiveClasses();\r\n\t\t\tthis.setResponsiveClasses('banner__item');\r\n\t\t\tthis.setResponsiveClasses('cta');\r\n\t\t\tthis.setCloseBannerButton();\r\n\t\t\tthis.showBanner();\r\n\t\t\tthis.managePaddingTop();\r\n\t\t}\r\n\t}\r\n\r\n\tcheckCookies() {\r\n\t\tconst cookieName =\r\n\t\t\tthis.dom.el.dataset.contentSid || this.dom.el.dataset.contentFid;\r\n\t\treturn document.cookie\r\n\t\t\t.split(';')\r\n\t\t\t.some((item) => item.trim().startsWith(`${cookieName}=`));\r\n\t}\r\n\r\n\tsetCookies() {\r\n\t\tconst sessionCookieName = this.dom.el.dataset.contentSid;\r\n\t\tif (sessionCookieName) {\r\n\t\t\tdocument.cookie = `${sessionCookieName}=true; path=/`;\r\n\t\t}\r\n\t\tconst foreverCookieName = this.dom.el.dataset.contentFid;\r\n\t\tif (foreverCookieName) {\r\n\t\t\tlet cookieDate = new Date();\r\n\t\t\tcookieDate.setMonth(cookieDate.getMonth() + 1);\r\n\t\t\tdocument.cookie = `${foreverCookieName}=true; expires=${cookieDate.toGMTString()}; path=/`;\r\n\t\t}\r\n\t}\r\n\r\n\tshowBanner() {\r\n\t\tthis.dom.el.style.display = 'flex';\r\n\t\tthis.dom.el.setAttribute('aria-hidden', 'false');\r\n\t}\r\n\r\n\thideBanner() {\r\n\t\tthis.dom.el.style.display = 'none';\r\n\t\tthis.dom.el.setAttribute('aria-hidden', 'true');\r\n\t}\r\n\r\n\tsetCSSCustomProps() {\r\n\t\tconst banners = this.dom.el.querySelectorAll('.banner__item');\r\n\t\tif (banners) {\r\n\t\t\t[].forEach.call(banners, (banner) => {\r\n\t\t\t\tconst desktopBgColor = banner.dataset.desktopBackgroundcolor;\r\n\t\t\t\tconst mobileBgColor = banner.dataset.mobileBackgroundcolor;\r\n\t\t\t\tconst desktopTxtColor = banner.dataset.desktopTextcolor;\r\n\t\t\t\tconst mobileTxtColor = banner.dataset.mobileTextcolor;\r\n\r\n\t\t\t\tif (desktopBgColor && mobileBgColor) {\r\n\t\t\t\t\tbanner.style.setProperty('--bg-desktop-color', `${desktopBgColor}`);\r\n\t\t\t\t\tbanner.style.setProperty('--bg-mobile-color', `${mobileBgColor}`);\r\n\t\t\t\t}\r\n\t\t\t\tif (desktopTxtColor && mobileTxtColor) {\r\n\t\t\t\t\tbanner.style.setProperty('--txt-desktop-color', `${desktopTxtColor}`);\r\n\t\t\t\t\tbanner.style.setProperty('--txt-mobile-color', `${mobileTxtColor}`);\r\n\t\t\t\t}\r\n\t\t\t\tthis.handleBannerIcon(banner);\r\n\t\t\t\tthis.handleBannerImage(banner);\r\n\t\t\t\tthis.initCountdown(banner);\r\n\t\t\t\tthis.triggerTracking(banner);\r\n\t\t\t});\r\n\t\t}\r\n\t}\r\n\r\n\tmanagePaddingTop() {\r\n\t\t// this is to handle the difference betweeen the legacy nav and universal nav\r\n\t\t// Legacy Nav was 48px of height / Universal Nav is 60 px of height\r\n\t\t// Once the legacy nav is not on the website anymmore and that [data-view] doesnt have 48px padding top anymore\r\n\t\t// then you can remove that extraPadding\r\n\t\t// Similar functions are in\r\n\t\t// C:\\Git\\CDS1024\\Components\\src\\Foundation\\Theming\\code\\src\\Components\\universal-nav\\assets\\scripts\\modules\\LegacySupport.js\r\n\t\t// C:\\Git\\CDS1024\\Components\\src\\Foundation\\Theming\\code\\src\\Components\\banner\\assets\\scripts\\modules\\ModuleBanner.js\r\n\t\t// C:\\Git\\CDS1024\\CdsDotCom\\src\\Foundation\\Frontend\\code\\front-end\\component\\core\\src\\js\\modules\\ModulePromoBanner.js\r\n\t\tif (this.mainHeader && this.nav) {\r\n\t\t\tlet extraPadding = 0;\r\n\t\t\tif (\r\n\t\t\t\tthis.dataView &&\r\n\t\t\t\tgetComputedStyle(this.dataView).paddingTop === '48px'\r\n\t\t\t) {\r\n\t\t\t\textraPadding += 12;\r\n\t\t\t}\r\n\t\t\tconst isLegacyNav = this.nav.length > 1;\r\n\r\n\t\t\tlet navClientHeight = 0;\r\n\t\t\tif (this.nav.length > 0) {\r\n\t\t\t\tnavClientHeight =\r\n\t\t\t\t\tthis.nav[0].clientHeight +\r\n\t\t\t\t\t(this.nav[1] ? this.nav[1].clientHeight : 0);\r\n\t\t\t}\r\n\r\n\t\t\tconst newPaddingTop =\r\n\t\t\t\tthis.mainHeader.clientHeight -\r\n\t\t\t\tnavClientHeight +\r\n\t\t\t\t(isLegacyNav ? 0 : extraPadding);\r\n\r\n\t\t\tthis.view.style.paddingTop = `${newPaddingTop}px`;\r\n\t\t}\r\n\t}\r\n\r\n\tbindEvents() {\r\n\t\tconst mediaQuery = window.matchMedia('(max-width: 990px)');\r\n\r\n\t\tif (this.closeBtn) {\r\n\t\t\tthis.closeBtn.addEventListener('click', () => {\r\n\t\t\t\tthis.setCookies();\r\n\t\t\t\tthis.hideBanner();\r\n\t\t\t});\r\n\t\t}\r\n\t\tmediaQuery.addEventListener('change', this.managePaddingTop);\r\n\t}\r\n\r\n\tsetResponsiveClasses(target) {\r\n\t\tconst mediaQuery = window.matchMedia('(max-width: 990px)');\r\n\r\n\t\tlet elements = [this.dom.el];\r\n\t\tif (target) {\r\n\t\t\telements = this.dom.el.querySelectorAll(`.${target}`);\r\n\t\t}\r\n\t\tif (elements) {\r\n\t\t\t[].forEach.call(elements, (elem) => {\r\n\t\t\t\tmediaQuery.addEventListener('change', (e) => {\r\n\t\t\t\t\tthis.handleResponsiveClasses(e, elem);\r\n\t\t\t\t});\r\n\t\t\t\tthis.handleResponsiveClasses(mediaQuery, elem);\r\n\t\t\t});\r\n\t\t}\r\n\t}\r\n\r\n\thandleResponsiveClasses(e, elem) {\r\n\t\tconst dataDesktop = elem.dataset.desktopClasses;\r\n\t\tconst dataMobile = elem.dataset.mobileClasses;\r\n\r\n\t\tif (dataDesktop && dataMobile) {\r\n\t\t\tconst elemDesktopClass = dataDesktop.split(' ');\r\n\t\t\tconst elemMobileClass = dataMobile.split(' ');\r\n\t\t\tif (e.matches) {\r\n\t\t\t\telemDesktopClass.forEach((item) => {\r\n\t\t\t\t\telem.classList.remove(`${item}`);\r\n\t\t\t\t});\r\n\t\t\t\telemMobileClass.forEach((item) => {\r\n\t\t\t\t\telem.classList.add(`${item}`);\r\n\t\t\t\t});\r\n\t\t\t} else {\r\n\t\t\t\telemMobileClass.forEach((item) => {\r\n\t\t\t\t\telem.classList.remove(`${item}`);\r\n\t\t\t\t});\r\n\t\t\t\telemDesktopClass.forEach((item) => {\r\n\t\t\t\t\telem.classList.add(`${item}`);\r\n\t\t\t\t});\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n\r\n\tsetCloseBannerButton() {\r\n\t\tconst mediaQuery = window.matchMedia('(max-width: 990px)');\r\n\t\tif (this.closeBtn && this.closeBtn.dataset.mobileBgimage) {\r\n\t\t\tmediaQuery.addEventListener('change', (e) => {\r\n\t\t\t\tthis.handleCloseBannerButton(e);\r\n\t\t\t});\r\n\t\t\tthis.handleCloseBannerButton(mediaQuery);\r\n\t\t}\r\n\t}\r\n\r\n\thandleCloseBannerButton(e) {\r\n\t\tconst imageMobile = this.closeBtn.dataset.mobileBgimage;\r\n\t\tconst imageDesktop = this.closeBtn.dataset.desktopBgimage;\r\n\t\tif (e.matches) {\r\n\t\t\tthis.closeBtn.style.backgroundImage = `url('${imageMobile}')`;\r\n\t\t} else {\r\n\t\t\tthis.closeBtn.style.backgroundImage = `url('${imageDesktop}')`;\r\n\t\t}\r\n\t}\r\n\r\n\thandleBannerImage(banner) {\r\n\t\tthis.setBannerMedia(banner, '.banner__image');\r\n\t}\r\n\r\n\thandleBannerIcon(banner) {\r\n\t\tthis.setBannerMedia(banner, '.banner__icon');\r\n\t}\r\n\r\n\tsetBannerMedia(banner, selector) {\r\n\t\tconst mediaQuery = window.matchMedia('(max-width: 990px)');\r\n\t\tconst media = banner.querySelector(selector);\r\n\t\tif (media && media.dataset.desktopMediaUrl) {\r\n\t\t\tmediaQuery.addEventListener('change', (e) => {\r\n\t\t\t\tthis.handleBannerMedia(e, media);\r\n\t\t\t});\r\n\t\t\tthis.handleBannerMedia(mediaQuery, media);\r\n\t\t}\r\n\t}\r\n\r\n\thandleBannerMedia(e, media) {\r\n\t\tconst mobileMediaUrl = media.dataset.mobileMediaUrl;\r\n\t\tconst mobileMediaAlt = media.dataset.mobileMediaAlt;\r\n\t\tconst desktopMediaUrl = media.dataset.desktopMediaUrl;\r\n\t\tconst desktopMediaAlt = media.dataset.desktopMediaAlt;\r\n\r\n\t\tif (e.matches) {\r\n\t\t\tmedia.setAttribute('src', mobileMediaUrl);\r\n\t\t\tmedia.setAttribute('alt', mobileMediaAlt);\r\n\t\t} else {\r\n\t\t\tmedia.setAttribute('src', desktopMediaUrl);\r\n\t\t\tmedia.setAttribute('alt', desktopMediaAlt);\r\n\t\t}\r\n\t}\r\n\r\n\ttriggerTracking(banner) {\r\n\t\tif (banner.dataset.ecommerceGa4) {\r\n\t\t\tconst events = this.cleanJSON(banner.dataset.ecommerceGa4);\r\n\t\t\tthis.pushDatalayer(events);\r\n\t\t}\r\n\t}\r\n\r\n\tpushDatalayer(datalayerEvent) {\r\n\t\tif (!datalayerEvent) return;\r\n\t\tif (!window.dataLayer) window.dataLayer = [];\r\n\t\tif (Array.isArray(datalayerEvent)) {\r\n\t\t\tfor (let i = 0; i < datalayerEvent.length; i += 1) {\r\n\t\t\t\twindow.dataLayer.push(datalayerEvent[i]);\r\n\t\t\t}\r\n\t\t} else {\r\n\t\t\twindow.dataLayer.push(datalayerEvent);\r\n\t\t}\r\n\t}\r\n\r\n\tcleanJSON(strJSON) {\r\n\t\tif (!strJSON) return;\r\n\t\tif (typeof strJSON !== 'string') return strJSON;\r\n\r\n\t\tlet s = strJSON\r\n\t\t\t.replace(/\\\\n/g, '\\\\n')\r\n\t\t\t.replace(/\\\\'/g, \"\\\\'\")\r\n\t\t\t.replace(/\\\\\"/g, '\\\\\"')\r\n\t\t\t.replace(/\\\\&/g, '\\\\&')\r\n\t\t\t.replace(/\\\\r/g, '\\\\r')\r\n\t\t\t.replace(/\\\\t/g, '\\\\t')\r\n\t\t\t.replace(/\\\\b/g, '\\\\b')\r\n\t\t\t.replace(/\\\\f/g, '\\\\f');\r\n\r\n\t\t// remove non-printable and other non-valid JSON chars\r\n\t\ts = s.replace(/[\\u0000-\\u0019]+/g, '');\r\n\t\treturn JSON.parse(s);\r\n\t}\r\n\r\n\tinitCountdown(banner) {\r\n\t\tvar countdown = banner.querySelector('.banner__countdown');\r\n\r\n\t\tif (countdown) {\r\n\t\t\tlet currentTime = parseFloat(countdown.dataset.currentTime);\r\n\t\t\tlet eventTime = parseFloat(countdown.dataset.endTime);\r\n\t\t\tlet $sec = countdown.querySelector('.countdown__seconds');\r\n\t\t\tlet $min = countdown.querySelector('.countdown__minutes');\r\n\t\t\tlet $hours = countdown.querySelector('.countdown__hours');\r\n\t\t\tlet $days = countdown.querySelector('.countdown__days');\r\n\r\n\t\t\tlet updateTimer = () => {\r\n\t\t\t\tcurrentTime += 1000;\r\n\t\t\t\tlet diff = eventTime - currentTime;\r\n\r\n\t\t\t\tif (diff <= 0) {\r\n\t\t\t\t\tclearInterval(interval);\r\n\t\t\t\t\t$sec.textContent = '00';\r\n\t\t\t\t\t$min.textContent = '00';\r\n\t\t\t\t\t$hours.textContent = '00';\r\n\t\t\t\t\t$days.textContent = '0';\r\n\t\t\t\t} else {\r\n\t\t\t\t\tif ($sec) {\r\n\t\t\t\t\t\tlet seconds = Math.floor((diff / 1000) % 60);\r\n\t\t\t\t\t\t$sec.textContent = `0${seconds}`.slice(-2);\r\n\t\t\t\t\t}\r\n\r\n\t\t\t\t\tif ($min) {\r\n\t\t\t\t\t\tlet minutes = Math.floor((diff % (1000 * 60 * 60)) / (1000 * 60));\r\n\t\t\t\t\t\t$min.textContent = minutes;\r\n\t\t\t\t\t}\r\n\r\n\t\t\t\t\tif ($hours) {\r\n\t\t\t\t\t\tlet hours = Math.floor(\r\n\t\t\t\t\t\t\t(diff % (1000 * 60 * 60 * 24)) / (1000 * 60 * 60)\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\t\t$hours.textContent = hours;\r\n\t\t\t\t\t}\r\n\r\n\t\t\t\t\tif ($days) {\r\n\t\t\t\t\t\tlet days = Math.floor(diff / (1000 * 60 * 60 * 24));\r\n\t\t\t\t\t\t$days.textContent = days;\r\n\t\t\t\t\t}\r\n\t\t\t\t}\r\n\r\n\t\t\t\tcountdown.classList.add('banner__countdown--isLoaded');\r\n\t\t\t};\r\n\r\n\t\t\tlet interval = setInterval(updateTimer, 1000);\r\n\t\t}\r\n\t}\r\n}\r\n","export default class Module {\r\n constructor(el) {\r\n this.dom = {\r\n el: el,\r\n $el: el,\r\n body: document.querySelector(\"body\"),\r\n html: document.querySelector(\"html\"),\r\n site: document.querySelector(\"#site\"),\r\n w: window\r\n };\r\n }\r\n}\r\n"],"sourceRoot":""}