{"version":3,"sources":["webpack:///./src/client/default/js/components/truncatedTextComponent.js","webpack:///./src/client/default/js/base/baseComponent.js"],"names":["TruncatedTextComponent","props","maxLength","fullText","$el","querySelector","SELECTORS","innerText","trim","init","readMoreClick","readLessClick","shortText","readMore","readLess","hide","shortTextEl","this","length","innerHTML","substring","classList","remove","CLASSES","fullTextEl","add","readMoreCta","readLessCta","addEventListener","e","pushToDatalayer","label","window","dataLayer","push","event","area","type","action","text","baseComponent","BaseComponent","element","_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","option","optionReturn","key","str","charAt","toLocaleLowerCase","slice","BaseGiaComponent"],"mappings":"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","file":"js/component-truncatedTextComponent-js.chunks.js","sourcesContent":["import baseComponent from '../base/baseComponent';\n\nexport default class TruncatedTextComponent extends baseComponent {\n get SELECTORS() {\n return {\n shortText: '.short-text',\n fullText: '.full-text',\n readMore: '.read-more',\n readLess: '.read-less'\n };\n }\n\n get CLASSES() {\n return {\n hide: 'd-none'\n };\n }\n\n constructor(props) {\n super(props);\n this.maxLength = 180;\n this.fullText = this.$el.querySelector(this.SELECTORS.fullText).innerText?.trim();\n this.init();\n this.readMoreClick();\n this.readLessClick();\n }\n\n init() {\n const shortTextEl = this.$el.querySelector(this.SELECTORS.shortText);\n if (this.fullText.length > this.maxLength) {\n let readMore = this.$el.querySelector(this.SELECTORS.readMore);\n shortTextEl.innerHTML = this.fullText.substring(0, this.maxLength);\n readMore.classList.remove(this.CLASSES.hide);\n } else {\n let fullTextEl = this.$el.querySelector(this.SELECTORS.fullText);\n shortTextEl.classList.add(this.CLASSES.hide);\n fullTextEl.classList.remove(this.CLASSES.hide);\n }\n }\n\n readMoreClick() {\n const readMoreCta = this.$el.querySelector(this.SELECTORS.readMore);\n const readLessCta = this.$el.querySelector(this.SELECTORS.readLess);\n const fullTextEl = this.$el.querySelector(this.SELECTORS.fullText);\n const shortTextEl = this.$el.querySelector(this.SELECTORS.shortText);\n\n readMoreCta.addEventListener('click', (e) => {\n readMoreCta.classList.add(this.CLASSES.hide);\n shortTextEl.classList.add(this.CLASSES.hide);\n fullTextEl.classList.remove(this.CLASSES.hide);\n readLessCta.classList.remove(this.CLASSES.hide);\n this.pushToDatalayer('Leggi di più');\n });\n }\n\n readLessClick() {\n const readMoreCta = this.$el.querySelector(this.SELECTORS.readMore);\n const readLessCta = this.$el.querySelector(this.SELECTORS.readLess);\n const fullTextEl = this.$el.querySelector(this.SELECTORS.fullText);\n const shortTextEl = this.$el.querySelector(this.SELECTORS.shortText);\n\n readLessCta.addEventListener('click', (e) => {\n readLessCta.classList.add(this.CLASSES.hide);\n fullTextEl.classList.add(this.CLASSES.hide);\n shortTextEl.classList.remove(this.CLASSES.hide);\n readMoreCta.classList.remove(this.CLASSES.hide);\n this.pushToDatalayer('Leggi di meno');\n });\n }\n\n pushToDatalayer(label) {\n if (!window.dataLayer) return;\n window.dataLayer.push({\n event: 'button_click',\n area: 'product',\n type: 'generic_button',\n action: 'button_click',\n text: label\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":""}