{"version":3,"sources":["webpack:///./src/client/default/js/components/switchFlyerViewComponent.js","webpack:///./src/client/default/js/base/baseComponent.js"],"names":["switchFlyerViewComponent","element","bindEvent","checkInitialPosition","switchCounter","radios","target","document","querySelectorAll","this","SELECTORS","forEach","radio","addEventListener","e","switchView","querySelector","classList","add","radioFirst","checked","$options","label","remove","EMIT","CUSTOM_MESSAGES","TABS_EVENTS","FLYERVIEWLIST","CAROUSEL_REMOUNT","value","TRACKING_EVENTS","update","eventCategory","eventAction","eventLabel","baseComponent","BaseComponent","_componentElement","setAttribute","_checkMessages","compOptions","options","$el","dataset","Object","keys","filter","entry","includes","optionValue","cleanEntry","cleanOptionKey","JSON","parse","replace","convertType","deepFreeze","getAttribute","events","cb","elements","Bean","on","stopPropagation","one","off","fire","container","message","_loading","LOADER_EVENTS","show","body","error","icon","setTimeout","hide","option","optionReturn","key","str","charAt","toLocaleLowerCase","slice","BaseGiaComponent"],"mappings":"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","file":"js/component-switchFlyerViewComponent-js.chunks.js","sourcesContent":["import baseComponent from '../base/baseComponent';\n\nexport default class switchFlyerViewComponent extends baseComponent {\n  get SELECTORS() {\n    return {\n      radios: \"input[type=radio][name='view']\",\n      target: 'body'\n    };\n  }\n\n  constructor(element) {\n    super(element);\n    this.bindEvent();\n    this.checkInitialPosition();\n    this.switchCounter = 0;\n  }\n\n  bindEvent() {\n    var radios = document.querySelectorAll(this.SELECTORS.radios);\n    radios.forEach((radio) => radio.addEventListener('change', (e) => this.switchView(e)));\n  }\n\n  checkInitialPosition() {\n    document.querySelector(this.SELECTORS.target).classList.add('sfogliatore');\n    var radioFirst = document.querySelector(this.SELECTORS.radios);\n\n    if ((radioFirst && !radioFirst.checked) || this.$options.label) {\n      document.querySelector(this.SELECTORS.target).classList.add('list-view');\n      document.querySelector(this.SELECTORS.target).classList.remove('sfogliatore');\n      this.EMIT(this.CUSTOM_MESSAGES.TABS_EVENTS.FLYERVIEWLIST);\n    } else {\n      document.querySelector(this.SELECTORS.target).classList.add('sfogliatore');\n      document.querySelector(this.SELECTORS.target).classList.remove('list-view');\n    }\n    this.EMIT(this.CUSTOM_MESSAGES.TABS_EVENTS.CAROUSEL_REMOUNT);\n  }\n\n  switchView(e) {\n    if (e.target.value === 'lista') {\n      document.querySelector(this.SELECTORS.target).classList.add('list-view');\n      document.querySelector(this.SELECTORS.target).classList.remove('sfogliatore');\n      if (this.switchCounter < 2) {\n        this.EMIT(this.CUSTOM_MESSAGES.TABS_EVENTS.FLYERVIEWLIST);\n      }\n    } else {\n      document.querySelector(this.SELECTORS.target).classList.remove('list-view');\n      document.querySelector(this.SELECTORS.target).classList.add('sfogliatore');\n    }\n    this.EMIT(this.CUSTOM_MESSAGES.TABS_EVENTS.CAROUSEL_REMOUNT);\n    this.EMIT(this.CUSTOM_MESSAGES.TRACKING_EVENTS.update, {\n      eventCategory: 'Volantini',\n      eventAction: 'View Mode',\n      eventLabel: e.target.value === 'lista' ? 'List' : 'Pdf'\n    });\n    this.switchCounter++;\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":""}