{"version":3,"sources":["webpack:///./src/js/components/SizeGuideTrigger.js","webpack:///./src/js/abstracts/BaseComponent.js","webpack:///./src/js/components/ModalTriggerComponent.js"],"names":["SizeGuideTrigger","this","$options","element","close","EMIT","CUSTOM_MESSAGES","MODAL_EVENTS","show","selector","match","SELECTORS","mobileModal","desktopModal","className","classname","ModalTriggerComponent","BaseComponent","_componentElement","setAttribute","compOptions","options","$el","dataset","Object","keys","filter","entry","includes","forEach","optionValue","cleanEntry","cleanOptionKey","JSON","parse","replace","e2","convertType","e","console","error","Freeze","getAttribute","events","cb","elements","Bean","on","stopPropagation","one","off","fire","container","message","LOADER_EVENTS","icon","hide","option","optionReturn","Number","key","str","charAt","toLocaleLowerCase","slice","CommonInterface","init","immediate","open","handleClick","$on"],"mappings":"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","file":"js/component-SizeGuideTrigger-js.chunks.js","sourcesContent":["import { match } from '../utilities/ResolutionHandler';\nimport ModalTriggerComponent from './ModalTriggerComponent';\n\nexport default class SizeGuideTrigger extends ModalTriggerComponent {\n  get SELECTORS() {\n    return {\n      desktopModal: '#js-size-guide-desktop',\n      mobileModal: '#js-size-guide-mobile'\n    };\n  }\n\n  open() {\n    if (this.$options.element && !this.$options.close) {\n      this.EMIT(this.CUSTOM_MESSAGES.MODAL_EVENTS.show, {\n        selector: match('medium') ? this.SELECTORS.mobileModal : this.SELECTORS.desktopModal,\n        className: this.$options.classname || ''\n      });\n    } else {\n      this.EMIT(this.CUSTOM_MESSAGES.MODAL_EVENTS.close);\n    }\n  }\n}\n","\nimport Bean from 'bean';\nimport Freeze from '../utilities/Freeze';\nimport CommonInterface from './CommonInterface';\n\nexport default class BaseComponent extends CommonInterface {\n  get $el() {\n    return 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      try {\n        const cleanEntry = BaseComponent.cleanOptionKey(entry);\n        let optionValue;\n        if (options[entry].includes('{') && options[entry].includes('}')) {\n\n          // PDB-786 JSON.parse(\"{\\\"address1\\\":\\\"2 Rue d'Orsel\\\"}\".replace(/'/g, '\"')) => SyntaxError: Unexpected token O in JSON at position 21\n          try {\n            optionValue = JSON.parse(options[entry].replace(/'/g, '\"'));\n          } catch (e2) {\n            optionValue = JSON.parse(options[entry]);\n          }\n\n        } else {\n          optionValue = BaseComponent.convertType(options[entry]);\n        }\n        compOptions[cleanEntry] = optionValue;\n      } catch (e) {\n        console.error('get $options() from component => ', this._componentElement, e);\n      }\n    });\n    return Freeze(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();\n    this._componentElement = element;\n    this._componentElement.setAttribute('data-component-init', true);\n  }\n\n  static convertType(option) {\n    let optionReturn;\n    if (Number(option)) return Number(option);\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    const cleanedKey = `${str.charAt(0).toLocaleLowerCase()}${str.slice(1)}`;\n    return cleanedKey;\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   * @param {HTMLElement} [container]\n   */\n  loading(container, message) {\n    this.EMIT(this.CUSTOM_MESSAGES.LOADER_EVENTS.show, {\n      container: container || this.$el,\n      message\n    });\n  }\n\n  /**\n   *\n   * @param {HTMLElement} [container]\n   * @param {String} [message]\n   * @param {String} [icon]\n   * @param {Boolean} [error=false]\n   */\n  endLoading(container, message, error = false, icon) {\n    this.EMIT(this.CUSTOM_MESSAGES.LOADER_EVENTS.hide, {\n      container: container || this.$el,\n      message,\n      icon,\n      error\n    });\n  }\n}\n","import BaseComponent from '../abstracts/BaseComponent';\n\nexport default class ModalTriggerComponent extends BaseComponent {\n  constructor(element) {\n    super(element);\n    this.init();\n  }\n\n  init() {\n    if (this.$options.immediate) {\n      this.open();\n    }\n    this.handleClick();\n  }\n\n\n  open(e) {\n    if (this.$options.element && !this.$options.close) {\n      this.EMIT(this.CUSTOM_MESSAGES.MODAL_EVENTS.show, {\n        selector: this.$options.element,\n        className: this.$options.classname || ''\n      });\n    } else {\n      this.EMIT(this.CUSTOM_MESSAGES.MODAL_EVENTS.close);\n    }\n  }\n\n  async handleClick() {\n    this.$on('click.modal', (e) => {\n      this.open(e);\n    });\n  }\n}\n"],"sourceRoot":""}