{"version":3,"sources":["webpack:///./src/client/default/js/components/promoImpressionComponent.js","webpack:///./src/client/default/js/base/baseComponent.js"],"names":["PromoImpressionComponent","element","promoTitle","$options","promoType","promoTemplate","promoFormat","pushDataLayer","handleClick","link","this","$el","querySelector","SELECTORS","matches","$on","e","eventName","window","dataLayer","push","event","promo_title","promo_template","promo_type","promo_format","BaseComponent","_componentElement","setAttribute","_checkMessages","compOptions","options","dataset","Object","keys","filter","entry","includes","forEach","optionValue","cleanEntry","cleanOptionKey","JSON","parse","replace","convertType","deepFreeze","getAttribute","events","cb","elements","Bean","on","stopPropagation","one","off","fire","container","message","_loading","EMIT","CUSTOM_MESSAGES","LOADER_EVENTS","show","document","body","error","icon","setTimeout","hide","option","optionReturn","key","str","charAt","toLocaleLowerCase","slice","BaseGiaComponent"],"mappings":"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","file":"js/component-promoImpressionComponent-js.chunks.js","sourcesContent":["import BaseComponent from '../base/baseComponent';\n\nexport default class PromoImpressionComponent extends BaseComponent {\n  get Messages() {\n    return {};\n  }\n\n  get SELECTORS() {\n    return {\n      link: 'a.tracking-link'\n    };\n  }\n\n  get CLASSES() {\n    return {};\n  }\n\n  constructor(element) {\n    super(element);\n    this.promoTitle = this.$options.promoTitle;\n    this.promoType = this.$options.promoType;\n    this.promoTemplate =\n      this.$options.promoTemplate && this.$options.promoTemplate == 'no_template' ? '' : this.$options.promoTemplate ? this.$options.promoTemplate : 'product_listing';\n    this.promoFormat = this.$options.promoFormat;\n    this.pushDataLayer('promo_impression');\n    this.handleClick();\n  }\n\n  handleClick() {\n    let link = this.$el.querySelector(this.SELECTORS.link) || (this.$el.matches(this.SELECTORS.link) && this.$el);\n    if (link) {\n      this.$on(\n        'click.promoImpression',\n        (e) => {\n          this.pushDataLayer('promo_click');\n        },\n        link\n      );\n    }\n  }\n\n  pushDataLayer(eventName) {\n    if (window && window.dataLayer) {\n      window.dataLayer.push({\n        event: eventName,\n        promo_title: this.promoTitle,\n        promo_template: this.promoTemplate,\n        promo_type: this.promoType,\n        promo_format: this.promoFormat\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":""}