{"version":3,"sources":["webpack:///./src/client/default/js/components/omnibusModalComponent.js","webpack:///./src/client/default/js/base/baseComponent.js"],"names":["OmnibusModalComponent","element","handleClick","handleBack","handleCloseModal","this","$el","addEventListener","panel","parentElement","querySelector","sortOrder","classList","remove","closest","add","document","dropdownPanel","omnibusPanel","MutationObserver","mutationList","observer","forEach","mutation","type","attributeName","contains","observe","attributes","baseComponent","BaseComponent","_componentElement","setAttribute","_checkMessages","compOptions","options","dataset","Object","keys","filter","entry","includes","optionValue","cleanEntry","cleanOptionKey","JSON","parse","replace","convertType","deepFreeze","getAttribute","events","cb","elements","Bean","on","e","stopPropagation","one","off","fire","container","message","_loading","EMIT","CUSTOM_MESSAGES","LOADER_EVENTS","show","body","error","icon","setTimeout","hide","option","optionReturn","key","str","charAt","toLocaleLowerCase","slice","BaseGiaComponent"],"mappings":"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","file":"js/component-omnibusModalComponent-js.chunks.js","sourcesContent":["import baseComponent from '../base/baseComponent';\n\nexport default class OmnibusModalComponent extends baseComponent {\n constructor(element) {\n super(element);\n this.handleClick();\n this.handleBack();\n this.handleCloseModal();\n }\n\n handleClick() {\n this.$el.addEventListener('click', () => {\n let panel = this.$el.parentElement.querySelector('.js-omnibus-panel');\n let sortOrder = this.$el.parentElement.querySelector('ul[name=\"sort-order\"]');\n if (panel) {\n panel.classList.remove('d-none');\n panel.closest('.dropdown-panel').classList.add('no-shadow');\n if (document.querySelector('.search-orderby.nds')) {\n sortOrder.classList.add('d-none');\n }\n }\n });\n }\n\n handleBack() {\n this.$el.parentElement.querySelector('.js-omnibus-back')?.addEventListener('click', () => {\n let panel = this.$el.parentElement.querySelector('.js-omnibus-panel');\n let sortOrder = this.$el.parentElement.querySelector('ul[name=\"sort-order\"]');\n if (panel) {\n panel.classList.add('d-none');\n panel.closest('.dropdown-panel').classList.remove('no-shadow');\n if (document.querySelector('.search-orderby.nds')) {\n sortOrder.classList.remove('d-none');\n }\n }\n });\n }\n handleCloseModal() {\n let dropdownPanel = this.$el.closest('.js-dropdown-container');\n let omnibusPanel = this.$el.parentElement.querySelector('.js-omnibus-panel');\n let sortOrder = this.$el.parentElement.querySelector('ul[name=\"sort-order\"]');\n const options = {\n attributes: true\n };\n\n function callback(mutationList, observer) {\n mutationList.forEach(function(mutation) {\n if (mutation.type === 'attributes' && mutation.attributeName === 'class' && !dropdownPanel.classList.contains('open')) {\n omnibusPanel.classList.add('d-none');\n omnibusPanel.closest('.dropdown-panel').classList.remove('no-shadow');\n if (document.querySelector('.search-orderby.nds')) {\n sortOrder.classList.remove('d-none');\n }\n }\n });\n }\n\n const observer = new MutationObserver(callback);\n observer.observe(dropdownPanel, options);\n }\n}\n","/* eslint-disable new-cap */\n/* eslint-disable valid-jsdoc */\n/* eslint-disable no-underscore-dangle */\n\nimport Bean from 'bean';\nimport deepFreeze from '../utilities/freeze';\nimport BaseGiaComponent from './baseGiaComponent';\n\nexport default class BaseComponent extends BaseGiaComponent {\n /**\n * @returns {HTMLElement}\n */\n get $el() {\n return /** @type {HTMLElement} */ (this._componentElement);\n }\n\n get $options() {\n const compOptions = {};\n const options = { ...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 } else {\n optionValue = BaseComponent.convertType(options[entry]);\n }\n compOptions[cleanEntry] = optionValue;\n });\n return deepFreeze(compOptions);\n }\n\n get COMPONENT_NAME() {\n return this.$el.getAttribute('data-component');\n }\n\n /**\n *\n * constructor\n *\n * @param {Element} element\n */\n constructor(element) {\n super(element);\n this._componentElement = element;\n this._componentElement.setAttribute('data-component-init', 'true');\n this._checkMessages();\n }\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\n return optionReturn;\n }\n\n static cleanOptionKey(key) {\n const str = key.replace('option', '');\n return `${str.charAt(0).toLocaleLowerCase()}${str.slice(1)}`;\n }\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) return;\n if (!elements) {\n Bean.on(element, events, (e) => {\n if (e) e.stopPropagation();\n cb(e);\n });\n } else {\n Bean.on(element, events, elements, (e) => {\n if (e) e.stopPropagation();\n cb(e);\n });\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 *\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 *\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\n /**\n *\n * Activate loader\n *\n * @param {HTMLElement} [container]\n * @param {String} [message]\n */\n loading(container, message) {\n this._loading = true;\n this.EMIT(this.CUSTOM_MESSAGES.LOADER_EVENTS.show, {\n container: container || document.body,\n message: message ?? null\n });\n }\n\n /**\n *\n * Deactivate loader\n *\n * @param {HTMLElement} [container]\n * @param {String} [message]\n * @param {Boolean} [error=false]\n * @param {String} [icon]\n */\n endLoading(container, message, error = false, icon) {\n this._loading = false;\n setTimeout(() => {\n if (!this._loading) {\n this.EMIT(this.CUSTOM_MESSAGES.LOADER_EVENTS.hide, {\n container: container || document.body,\n message,\n error,\n icon\n });\n }\n }, 400);\n }\n}\n"],"sourceRoot":""}