{"version":3,"file":"js/component-tab.chunk.js","mappings":"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","sources":["webpack:///./assets/src/scripts/utilities/freeze.ts","webpack:///./assets/src/scripts/constants/customMessages.ts","webpack:///./assets/src/scripts/constants/whatInput.ts","webpack:///./assets/src/scripts/utilities/whatInput.ts","webpack:///./assets/src/scripts/base/commonInterface.ts","webpack:///./assets/src/scripts/base/baseComponent.ts","webpack:///./assets/src/scripts/components/tab.ts","webpack:///./assets/src/scripts/utilities/focusableElementUtils.ts"],"sourcesContent":["export default function deepFreeze(o) {\n Object.freeze(o);\n Object.getOwnPropertyNames(o).forEach(function (prop) {\n if (Object.hasOwnProperty.call(o, prop) && o[prop] !== null && (typeof o[prop] === 'object' || typeof o[prop] === 'function') && !Object.isFrozen(o[prop])) {\n deepFreeze(o[prop]);\n }\n });\n return o;\n}\n","import deepFreeze from '../utilities/freeze';\nexport default deepFreeze({\n WINDOW: {\n CLICK_EVENT: 'body:click:event',\n },\n BODY: {\n TOGGLE_OVERLAY: 'toggle:overlay',\n ON_OVERLAY: 'on:overlay',\n OFF_OVERLAY: 'off:overlay',\n },\n HEADER: {\n UPDATE_TRAP: 'header:trap:update',\n IN_PDP: 'header:inPdp',\n },\n BURGER: {\n TOGGLE_MENU: 'menu:toggle',\n },\n BREAKPOINTER: {\n BREAKPOINT_CHANGE: 'breakpoint:change',\n },\n DROP_DOWN: {\n OPEN: 'dropdown:open',\n CLOSE: 'dropdown:close',\n },\n PRODUCT_CAROUSEL: {\n UPDATE_IMAGES: 'product:carousel:update_images',\n UPDATE_ZOOM_IMAGES: 'product:carousel:update_zoom_images',\n },\n BRANDS: {\n UPDATE_GRID: 'brands:update:grid',\n UPDATE_STORES: 'brands:update:stores',\n SEARCH_BY_STORE: 'brands:search:bystore',\n },\n MODAL_EVENTS: {\n show: 'modal:show',\n close: 'modal:close',\n },\n});\n","import deepFreeze from '../utilities/freeze';\nexport default deepFreeze({\n INPUT: {\n KEYBOARD: 'keyboard',\n MOUSE: 'mouse'\n }\n});\n","import whatInput from 'what-input';\nexport const ask = (strategy = 'input') => {\n return whatInput.ask(strategy);\n};\n","import { getAllFocusableElements, getFirstFocusable } from '../utilities/focusableElementUtils';\nimport CustomMessages from '../constants/customMessages';\nimport EventBus from '../libs/eventBus';\nimport WHAT_INPUT from '../constants/whatInput';\nimport { ask } from '../utilities/whatInput';\nimport config from 'gia/config';\nexport default class CommonInterface {\n constructor() {\n config.set('log', true);\n window.EventBus = EventBus;\n window.CUSTOM_MESSAGES = this.CUSTOM_MESSAGES;\n this._grabMessages();\n }\n get CUSTOM_MESSAGES() {\n return CustomMessages;\n }\n get Messages() {\n return {};\n }\n get isKeyboard() {\n return this._isKeyboard();\n }\n get isMouse() {\n return this._isMouse();\n }\n get whatInput() {\n return this._whatInput();\n }\n _checkMessages() {\n for (const message in this.Messages) {\n if (window.eventQueue.get(message)) {\n const ref = this.Messages[message].bind(this);\n window.eventQueue.get(message).map((payload) => {\n ref(payload);\n });\n window.eventQueue.delete(message);\n }\n }\n }\n _grabMessages() {\n this._messages = {};\n for (const message in this.Messages) {\n if (this.Messages[message]) {\n const __ref__ = this.Messages[message].bind(this);\n this._messages[message] = __ref__;\n this.GRAB(message, __ref__);\n }\n }\n }\n _ungrabMessages() {\n for (const message in this._messages) {\n this.UNGRAB(message, this._messages[message]);\n }\n }\n objectIsEmpty(object) {\n for (let key in object) {\n if (object.hasOwnProperty(key))\n return false;\n }\n return true;\n }\n /**\n *\n * EMIT\n *\n * @param {string} message\n * @param {Object} payload\n */\n EMIT(message, payload) {\n return EventBus.emit(message, payload);\n }\n /**\n *\n * GRAB\n *\n * @param {string} message\n * @param {Function} callBack\n */\n GRAB(message, callBack) {\n if (!callBack)\n return;\n EventBus.on(message, callBack);\n }\n /**\n *\n * UNGRAB\n *\n * @param {string} message\n * @param {Function} callBack\n */\n UNGRAB(message, callBack) {\n if (!callBack)\n return;\n EventBus.off(message, callBack);\n }\n getFirstFocusable(parent) {\n return getFirstFocusable(parent);\n }\n getFocusableElements(parent) {\n return getAllFocusableElements(parent);\n }\n _isMouse() {\n return ask() === WHAT_INPUT.INPUT.MOUSE;\n }\n _isKeyboard() {\n return ask() === WHAT_INPUT.INPUT.KEYBOARD;\n }\n _whatInput() {\n return ask();\n }\n _destroy() {\n this._ungrabMessages();\n }\n}\n","import Bean from 'bean';\nimport CommonInterface from './commonInterface';\nimport deepFreeze from '../utilities/freeze';\nexport default class BaseComponent extends CommonInterface {\n /**\n *\n * constructor\n *\n * @param {Element} element\n */\n constructor(element) {\n super();\n this._componentElement = element;\n this._componentElement.setAttribute('data-component-init', 'true');\n this._checkMessages();\n //console.log(`%c[${this.COMPONENT_NAME}]%c initialized`, 'color:orange;', 'color:white;');\n }\n /**\n * @returns {ComponentElement}\n */\n get _el() {\n return this._componentElement;\n }\n get _options() {\n const compOptions = {};\n const options = Object.assign({}, this._el.dataset);\n const optionsEntires = Object.keys(options).filter((entry) => entry.includes('option'));\n optionsEntires.forEach((entry) => {\n const cleanEntry = BaseComponent.cleanOptionKey(entry);\n let optionValue;\n if (options[entry].includes('{') && options[entry].includes('}')) {\n optionValue = JSON.parse(options[entry].replace(/'/g, '\"'));\n }\n else {\n optionValue = BaseComponent.convertType(options[entry]);\n }\n compOptions[cleanEntry] = optionValue;\n });\n return deepFreeze(compOptions);\n }\n get COMPONENT_NAME() {\n return this._el.getAttribute('data-component');\n }\n static convertType(option) {\n let optionReturn;\n switch (option) {\n case 'false':\n optionReturn = false;\n break;\n case 'true':\n optionReturn = true;\n break;\n case 'null':\n optionReturn = null;\n break;\n default:\n optionReturn = option;\n break;\n }\n return optionReturn;\n }\n static cleanOptionKey(key) {\n const str = key.replace('option', '');\n return `${str.charAt(0).toLocaleLowerCase()}${str.slice(1)}`;\n }\n /**\n *\n * $on\n *\n * @param {String} events\n * @param {Function} cb\n * @param {Element} [element = this._el]\n * @param {Array|String|Element} [elements = null]\n */\n $on(events, cb, element = this._el, elements = null) {\n if (!element || !events || !cb)\n return;\n if (!elements) {\n Bean.on(element, events, (e) => {\n if (e)\n e.stopPropagation();\n cb(e);\n });\n }\n else {\n Bean.on(element, events, elements, (e) => {\n if (e)\n e.stopPropagation();\n cb(e);\n });\n }\n }\n /**\n *\n * $one\n *\n * @param {String} events\n * @param {Function} cb\n * @param {Element} [element = this._el]\n */\n $one(events, cb, element = this._el) {\n Bean.one(element, events, cb);\n }\n /**\n *\n * $off\n *\n * @param {String} events\n * @param {Element} [element = this._el]\n */\n $off(events, element = this._el) {\n Bean.off(element, events);\n }\n /**\n *\n * $fire\n *\n * @param {String} events\n * @param {Element} [element = this._el]\n */\n $fire(events, element = this._el) {\n Bean.fire(element, events);\n }\n updateAriaAttributes(element) {\n const attributes = [...element.attributes]\n .filter((attr) => {\n return attr.nodeName.indexOf('has') === -1;\n })\n .filter((attr) => {\n return attr.nodeName.indexOf('aria') > -1 && (attr.nodeValue === 'true' || attr.nodeValue === 'false');\n })\n .map((attr) => {\n return attr.nodeName;\n });\n attributes.forEach((attr) => {\n element.setAttribute(attr, element.getAttribute(attr) === 'true' ? 'false' : 'true');\n });\n }\n}\n","import BaseComponent from '../base/baseComponent';\nexport default class Tab extends BaseComponent {\n constructor(element) {\n super(element);\n this.firstTab = null;\n this.lastTab = null;\n this.init();\n }\n get SELECTORS() {\n return {\n tabBtn: '.tab-btn',\n activeLine: '.active-line',\n tabContent: '.tab-content'\n };\n }\n get CLASSES() {\n return {\n active: 'active'\n };\n }\n init() {\n const tabButtons = [...this._el.querySelectorAll(this.SELECTORS.tabBtn)];\n tabButtons.forEach((btn) => {\n if (!this.firstTab) {\n this.firstTab = btn;\n }\n this.lastTab = btn;\n });\n this.initActiveTab();\n this.handleClick();\n }\n initActiveTab() {\n const tabActive = this._el.querySelector(`${this.SELECTORS.tabBtn}.${this.CLASSES.active}`);\n if (tabActive) {\n let activeLine = this._el.querySelector(this.SELECTORS.activeLine);\n let tabHeight = tabActive.offsetHeight;\n let tabOffset = tabActive.offsetTop;\n activeLine.style.height = `${tabHeight}px`;\n activeLine.style.top = `${tabOffset}px`;\n activeLine.style.display = 'block';\n }\n }\n handleClick() {\n const tabButtons = [...this._el.querySelectorAll(this.SELECTORS.tabBtn)];\n const tabContent = [...this._el.querySelectorAll(this.SELECTORS.tabContent)];\n const activeLine = this._el.querySelector(this.SELECTORS.activeLine);\n tabButtons.forEach((btn) => {\n btn.addEventListener('click', (e) => {\n this.setActiveTab(btn, tabButtons, activeLine, tabContent);\n });\n btn.addEventListener('keydown', (e) => {\n switch (e.key) {\n case 'ArrowUp':\n this.setActivePreviousTab(e.currentTarget, tabButtons, activeLine, tabContent);\n break;\n case 'ArrowDown':\n this.setActiveNextTab(e.currentTarget, tabButtons, activeLine, tabContent);\n break;\n case 'Home':\n this.setActiveTab(this.firstTab, tabButtons, activeLine, tabContent);\n break;\n case 'End':\n this.setActiveTab(this.lastTab, tabButtons, activeLine, tabContent);\n break;\n default:\n break;\n }\n });\n });\n }\n setActiveNextTab(target, tabButtons, activeLine, tabContent) {\n if (this.lastTab === target) {\n this.setActiveTab(this.firstTab, tabButtons, activeLine, tabContent);\n }\n else {\n this.setActiveTab(tabButtons[tabButtons.indexOf(target) + 1], tabButtons, activeLine, tabContent);\n }\n }\n setActivePreviousTab(target, tabButtons, activeLine, tabContent) {\n if (this.firstTab === target) {\n this.setActiveTab(this.lastTab, tabButtons, activeLine, tabContent);\n }\n else {\n this.setActiveTab(tabButtons[tabButtons.indexOf(target) - 1], tabButtons, activeLine, tabContent);\n }\n }\n setActiveTab(btn, tabButtons, activeLine, tabContent) {\n let tabIndex = parseInt(btn.dataset.tabIndex, 10);\n let contentActive = this._el.querySelector(`${this.SELECTORS.tabContent}[data-tab-index=\"${tabIndex}\"]`);\n tabButtons.forEach((tabBtn) => {\n tabBtn.classList.remove(this.CLASSES.active);\n tabBtn.setAttribute('aria-selected', 'false');\n tabBtn.setAttribute('tabindex', -1);\n });\n tabContent.forEach((content) => content.classList.remove(this.CLASSES.active));\n btn.classList.add(this.CLASSES.active);\n btn.setAttribute('aria-selected', 'true');\n btn.tabIndex = 0;\n btn.focus();\n if (contentActive) {\n contentActive.classList.add(this.CLASSES.active);\n }\n let tabHeight = btn.offsetHeight;\n let tabOffset = btn.offsetTop;\n activeLine.style.height = `${tabHeight}px`;\n activeLine.style.top = `${tabOffset}px`;\n activeLine.style.display = 'block';\n }\n}\n","const focusableSelectors = 'button, [href], input, select, textarea, [tabindex]:not([tabindex=\"-1\"]), [role=\"button\"]';\nexport const getFirstFocusable = (parent) => parent.querySelector(focusableSelectors);\nexport const getAllFocusableElements = (parent) => parent.querySelectorAll(focusableSelectors);\n"],"names":["deepFreeze","o","Object","freeze","getOwnPropertyNames","forEach","prop","hasOwnProperty","call","isFrozen","WINDOW","CLICK_EVENT","BODY","TOGGLE_OVERLAY","ON_OVERLAY","OFF_OVERLAY","HEADER","UPDATE_TRAP","IN_PDP","BURGER","TOGGLE_MENU","BREAKPOINTER","BREAKPOINT_CHANGE","DROP_DOWN","OPEN","CLOSE","PRODUCT_CAROUSEL","UPDATE_IMAGES","UPDATE_ZOOM_IMAGES","BRANDS","UPDATE_GRID","UPDATE_STORES","SEARCH_BY_STORE","MODAL_EVENTS","show","close","INPUT","KEYBOARD","MOUSE","ask","strategy","CommonInterface","constructor","config","window","EventBus","CUSTOM_MESSAGES","this","_grabMessages","Messages","isKeyboard","_isKeyboard","isMouse","_isMouse","whatInput","_whatInput","_checkMessages","message","eventQueue","get","ref","bind","map","payload","delete","_messages","__ref__","GRAB","_ungrabMessages","UNGRAB","objectIsEmpty","object","key","EMIT","callBack","getFirstFocusable","parent","getFocusableElements","_destroy","BaseComponent","element","super","_componentElement","setAttribute","_el","_options","compOptions","options","assign","dataset","keys","filter","entry","includes","cleanEntry","cleanOptionKey","optionValue","JSON","parse","replace","convertType","COMPONENT_NAME","getAttribute","static","option","optionReturn","str","charAt","toLocaleLowerCase","slice","$on","events","cb","elements","e","stopPropagation","$one","$off","$fire","updateAriaAttributes","attributes","attr","nodeName","indexOf","nodeValue","Tab","firstTab","lastTab","init","SELECTORS","tabBtn","activeLine","tabContent","CLASSES","active","querySelectorAll","btn","initActiveTab","handleClick","tabActive","querySelector","tabHeight","offsetHeight","tabOffset","offsetTop","style","height","top","display","tabButtons","addEventListener","setActiveTab","setActivePreviousTab","currentTarget","setActiveNextTab","target","tabIndex","parseInt","contentActive","classList","remove","content","add","focus","focusableSelectors","getAllFocusableElements"],"sourceRoot":""}