{"version":3,"sources":["webpack:///./src/client/default/js/components/thumbnailsComponent.js","webpack:///./src/client/default/js/base/baseComponent.js"],"names":["ThumbnailsComponent","element","bindEvents","this","CUSTOM_MESSAGES","ZOOM_EVENTS","click","bindZoom","document","querySelector","compOptions","options","$elCar","dataset","Object","keys","filter","entry","includes","forEach","optionValue","cleanEntry","BaseComponent","cleanOptionKey","JSON","parse","replace","convertType","deepFreeze","thumbnail","templateElement","thumbnailBtn","active","thumbnails","classList","remove","CLASSES","thumb","EMIT","MODAL_EVENTS","show","selector","SELECTORS","className","showCloseButton","afterOpen","contains","swiperInstance","Swiper","$optionsCar","slideTo","img","index","e","thumbaniImg","match","removeActiveClass","add","THUMBNAIL_EVENTS","url","src","srcset","$el","querySelectorAll","$on","handleThumbnailEvent","key","preventDefault","_componentElement","setAttribute","_checkMessages","getAttribute","events","cb","elements","Bean","on","stopPropagation","one","off","fire","container","message","_loading","LOADER_EVENTS","body","error","icon","setTimeout","hide","option","optionReturn","str","charAt","toLocaleLowerCase","slice","BaseGiaComponent"],"mappings":"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","file":"js/component-thumbnailsComponent-js.chunks.js","sourcesContent":["import BaseComponent from '../base/baseComponent';\nimport { match } from '../utilities/resolutionHandler';\nimport Swiper from 'swiper';\nimport deepFreeze from '../utilities/freeze';\n\nexport default class ThumbnailsComponent extends BaseComponent {\n get Messages() {\n return {\n [this.CUSTOM_MESSAGES.ZOOM_EVENTS.click]: this.bindZoom\n };\n }\n\n get $elCar() {\n return /** @type {HTMLElement} */ (document.querySelector('.pdpCarousel'));\n }\n\n get $optionsCar() {\n const compOptions = {};\n const options = { ...this.$elCar.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 SELECTORS() {\n return {\n thumbnail: '.js-thumb-img',\n templateElement: '#pdp-zoom-carousel',\n thumbnailBtn: '.js-thumb-btn'\n };\n }\n\n get CLASSES() {\n return {\n active: 'is-active'\n };\n }\n\n constructor(element) {\n super(element);\n this.bindEvents();\n }\n\n removeActiveClass(thumbnails) {\n thumbnails.forEach((thumbnail) => {\n thumbnail.classList.remove(this.CLASSES.active);\n });\n }\n\n bindZoom(thumb) {\n this.EMIT(this.CUSTOM_MESSAGES.MODAL_EVENTS.show, {\n selector: this.SELECTORS.templateElement,\n className: 'full-modal zoom-carousel',\n showCloseButton: true,\n afterOpen: () => {\n if (this.$elCar.classList.contains('bind-carousel')) {\n this.swiperInstance = new Swiper(this.$elCar, this.$optionsCar);\n this.swiperInstance.slideTo(thumb.img ? thumb.img.dataset.index - 1 : thumb.dataset.index - 1, 22, false);\n }\n }\n });\n }\n\n handleThumbnailEvent(thumbnail, thumbnails, e) {\n let thumbaniImg = thumbnail.querySelector(this.SELECTORS.thumbnail);\n if (match(null, 'md')) {\n this.removeActiveClass(thumbnails);\n thumbnail.classList.add(this.CLASSES.active);\n this.EMIT(this.CUSTOM_MESSAGES.THUMBNAIL_EVENTS.click, {\n url: thumbaniImg.src,\n srcset: thumbaniImg.srcset,\n index: thumbaniImg.dataset.index\n });\n } else {\n this.bindZoom(thumbaniImg);\n }\n }\n\n bindEvents() {\n const thumbnails = this.$el.querySelectorAll(this.SELECTORS.thumbnailBtn);\n thumbnails.forEach((thumbnail) => {\n this.$on(\n 'click.thumb',\n (e) => {\n this.handleThumbnailEvent(thumbnail, thumbnails, e);\n },\n thumbnail\n );\n this.$on(\n 'keydown.thumb',\n (e) => {\n if (e.key === 'Enter') {\n e.preventDefault();\n this.handleThumbnailEvent(thumbnail, thumbnails, e);\n }\n },\n thumbnail\n );\n });\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":""}