{"version":3,"sources":["webpack:///./src/js/abstracts/BaseComponent.js","webpack:///./src/js/libs/Axios.js","webpack:///./src/js/utilities/SerializeForm.js","webpack:///./src/js/utilities/FormErros.js","webpack:///./src/js/abstracts/BaseFormComponent.js","webpack:///./src/js/components/ContatcFormComponent.js"],"names":["BaseComponent","element","_componentElement","setAttribute","this","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","EMIT","CUSTOM_MESSAGES","LOADER_EVENTS","show","icon","hide","option","optionReturn","Number","key","str","charAt","toLocaleLowerCase","slice","CommonInterface","recaptchaToken","a","googleRecaptchaAction","googleRecaptchaClientSide","Promise","resolve","reject","window","grecaptcha","ready","execute","action","then","token","axios","Axios","create","transformRequest","data","headers","entries","formData","FormData","value","append","interceptors","request","use","config","googleRecaptchaToken","CancelToken","get","post","all","spread","SerializeForm","form","serialize","dataType","getFormDataArray","getFormDataObject","join","map","tempData","split","name","newArrayString","nodeName","el","disabled","BLACK_LIST","type","isValidForm","isvalidElement","push","opt","selected","checked","scrollConfig","behavior","block","inline","inputErrorMsg","messageEl","document","createElement","classList","add","innerText","showFieldsErrors","errors","querySelector","parent","closest","appendChild","scrollIntoView","showFieldError","fieldName","addEventListener","handleFocus","currentTarget","parentElement","remove","removeAttribute","removeChild","removeEventListener","showGlobalError","button","parentNode","errorEl","innerHTML","insertBefore","BaseFormComponent","$on","preventDefault","stopImmediatePropagation","formButton","cleanCustomError","res","handleRes","errorFields","errorMessage","errorMsg","stringError","endLoading","querySelectorAll","globaError","length","err","Serialize","ContatcFormComponent","handleSubmit","apply","hidden","SELECTORS","onSubmit","loading","serializeForm","toObject","CLASSES"],"mappings":"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","file":"js/component-ContatcFormComponent-js.chunks.js","sourcesContent":["\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 Axios from 'axios';\n\nconst recaptchaToken = async ({ googleRecaptchaAction, googleRecaptchaClientSide }) => new Promise((resolve, reject) => {\n window.grecaptcha.ready(() => {\n window.grecaptcha.execute(googleRecaptchaClientSide, { action: googleRecaptchaAction }).then((token) => {\n resolve(token);\n });\n });\n});\n\nconst axios = Axios.create({\n transformRequest: [function (data, headers) {\n if (data && Object.entries(data)) {\n const formData = new FormData();\n for (const [key, value] of Object.entries(data)) {\n formData.append(key, value);\n }\n return formData;\n }\n }],\n});\n\n// Add a request interceptor\naxios.interceptors.request.use(async (config) => {\n // Do something before request is sent\n if (config.data && config.data.googleRecaptchaAction && config.data.googleRecaptchaClientSide) {\n const token = await recaptchaToken(config.data);\n config.data.googleRecaptchaToken = token;\n return config;\n }\n return config;\n}, function (error) {\n // Do something with request error\n return Promise.reject(error);\n});\n\nexport const { CancelToken } = Axios;\n\nexport const {\n get, post, all, spread\n} = axios;\n","class SerializeForm {\n static get BLACK_LIST() {\n return {\n elements: ['button', 'file', 'reset', 'submit']\n };\n }\n\n /**\n *\n * @param {HTMLFormElement} form\n */\n constructor(form) {\n this.form = SerializeForm.serialize(form);\n }\n\n /**\n * Get the form serialization data by format\n *\n * @param {String} [dataType] The data type to return ('array', 'object' or empty to return string)\n * @returns {*}\n */\n getData(dataType) {\n switch (dataType) {\n case 'array':\n return SerializeForm.getFormDataArray(this.form);\n case 'object':\n return SerializeForm.getFormDataObject(this.form);\n default:\n return this.form.join('&')\n .replace(/%20/g, '+');\n }\n }\n\n /**\n * Get the form serialization data string\n *\n * @returns {String}\n */\n toString() {\n return this.form.join('&').replace(/%20/g, '+');\n }\n\n /**\n * Get the form serialization data array\n *\n * @returns {Array}\n */\n toArray() {\n return SerializeForm.getFormDataArray(this.form);\n }\n\n /**\n * Get the form serialization data object\n *\n * @returns {Object}\n */\n toObject() {\n return SerializeForm.getFormDataObject(this.form);\n }\n\n /**\n *\n * @param {HTMLFormElement} form\n * @return {Array}\n */\n static getFormDataArray(form) {\n return [\n ...form.map((data) => {\n const tempData = data.split('=');\n return {\n name: tempData[0],\n value: tempData[1]\n };\n })\n ];\n }\n\n /**\n *\n * @param {HTMLFormElement} form\n */\n static getFormDataObject(form) {\n const formData = {};\n form.forEach((data) => {\n const tempData = data.split('=');\n if (formData[tempData[0]]) {\n const newArrayString = `${typeof formData[tempData[0]] === 'object' ? formData[tempData[0]].join('&') : formData[tempData[0]]}&${tempData[1]}`;\n formData[tempData[0]] = newArrayString.split('&');\n } else {\n formData[tempData[0]] = tempData[1];\n }\n });\n\n return formData;\n }\n\n /**\n *\n * @param {HTMLFormElement} form\n * @return {boolean}\n */\n static isValidForm(form) {\n return typeof form === 'object' && form.nodeName === 'FORM';\n }\n\n /**\n *\n * @param {HTMLElement} el\n * @return {boolean}\n */\n static isvalidElement(el) {\n return el.name && !el.disabled && !SerializeForm.BLACK_LIST.elements.includes(el.type);\n }\n\n /**\n *\n * @param {HTMLFormElement} form\n * @return {Array}\n */\n static serialize(form) {\n const data = [];\n if (SerializeForm.isValidForm(form)) {\n [...form.elements].forEach((el) => {\n if (SerializeForm.isvalidElement(el)) {\n if (el.type !== 'checkbox' && el.type !== 'radio') {\n let value = el.value || '';\n data.push(`${el.name}=${value}`);\n } else if (el.type === 'select-multiple') {\n el.options.forEach((opt) => {\n if (opt.selected) data.push(`${el.name}=${opt.value}`);\n });\n } else if (el.checked && el.type === 'checkbox') {\n let value = el.value || true;\n data.push(`${el.name}=${value}`);\n } else if (el.checked && el.type === 'radio' && el.value) {\n let value = el.value;\n data.push(`${el.name}=${value}`);\n }\n }\n });\n }\n return data;\n }\n}\n\nexport default SerializeForm;\n","const scrollConfig = {\n behavior: 'smooth',\n block: 'center',\n inline: 'center'\n};\n\nconst inputErrorMsg = (message) => {\n const messageEl = document.createElement('div');\n messageEl.classList.add('error-message', 'js-error-message');\n messageEl.innerText = message;\n return messageEl;\n};\n\nconst formErroMessage = (message) => {\n const messageEl = document.createElement('div');\n messageEl.classList.add('warning', 'js-form-warning');\n messageEl.innerHTML += '';\n messageEl.innerHTML += message;\n return messageEl;\n};\n\nexport const cleanInputs = (form, cb) => {\n const inputs = form.querySelectorAll('input, select');\n [...inputs].forEach((el) => {\n const parent = error.parentElement;\n const error = parent.querySelector('.error-message');\n el.classList.remove('error');\n el.removeAttribute('aria-describedby');\n el.removeAttribute('aria-invalid');\n parent.removeChild(error);\n });\n};\n\n/**\n * @param {Element}\n */\nexport const showFieldsErrors = (form, errors) => {\n for (const [key, value] of Object.entries(errors)) {\n const el = form.querySelector(`[name=\"${key}\"]`);\n const parent = el.closest('.js-form-input');\n el.classList.add('error');\n el.setAttribute('aria-describedby', `bouncer-error_${key}`);\n el.setAttribute('aria-invalid', true);\n parent.appendChild(inputErrorMsg(value));\n }\n const error = form.querySelector('.error-message');\n if (error) {\n error.scrollIntoView(scrollConfig);\n }\n};\n\nexport const showFieldError = (fieldName, message) => {\n const el = document.querySelector(`[name*=\"${fieldName}\"]`);\n const parent = el.closest('.js-form-input');\n el.classList.add('error');\n el.setAttribute('aria-describedby', `bouncer-error_${el.name}`);\n el.setAttribute('aria-invalid', true);\n if (message) parent.appendChild(inputErrorMsg(message));\n parent.scrollIntoView(scrollConfig);\n el.addEventListener('focus', handleFocus, false);\n};\n\nconst handleFocus = (e) => {\n const el = e.currentTarget;\n const parent = el.parentElement;\n const error = parent.querySelector('.error-message');\n el.classList.remove('error');\n el.removeAttribute('aria-describedby');\n el.removeAttribute('aria-invalid');\n parent.removeChild(error);\n el.removeEventListener('focus', handleFocus, false);\n};\n\nexport const showGlobalError = (form, error) => {\n const button = form.querySelector('button[type=\"submit\"]');\n const parent = button.parentNode;\n const errorEl = formErroMessage(error);\n parent.insertBefore(errorEl, button);\n};\n","import Serialize from '../utilities/SerializeForm';\nimport BaseComponent from './BaseComponent';\nimport { showFieldsErrors, showGlobalError } from '../utilities/FormErros';\n\nexport default class BaseFormComponent extends BaseComponent {\n constructor(element) {\n super(element);\n }\n\n /**\n *\n * @param {CallableFunction} cb - The callback function\n * @return {function}\n */\n onSubmit(cb) {\n return this.$on('bouncerFormValid', async (e) => {\n e.preventDefault();\n e.stopImmediatePropagation();\n const formButton = e.currentTarget.querySelector('button[type=\"submit\"]');\n const action = e.currentTarget.getAttribute('action');\n this.cleanCustomError();\n const res = await cb(e, action, formButton);\n if (res) this.handleRes(res, formButton);\n });\n }\n\n handleRes(res, formButton) {\n const {\n error, errorFields, errorMessage, errorMsg\n } = res;\n if (errorFields) {\n showFieldsErrors(this.$el, errorFields);\n }\n const stringError = errorMessage || errorMsg;\n if (stringError) {\n showGlobalError(this.$el, stringError);\n } else if (error) {\n showGlobalError(this.$el, error);\n }\n\n if (error || errorFields || errorMessage || errorMsg) {\n this.endLoading(formButton);\n }\n }\n\n cleanCustomError() {\n const errorFields = this.$el.querySelectorAll('.js-error-message');\n const globaError = this.$el.querySelectorAll('.js-form-warning');\n\n if (globaError.length > 0) {\n [...globaError].forEach((err) => {\n const parent = err.parentElement;\n parent.removeChild(err);\n });\n }\n if (errorFields.length > 0) {\n [...errorFields].forEach((err) => {\n try {\n const parent = err.parentElement;\n parent.classList.remove(err);\n parent.removeChild(err);\n err.removeAttribute('aria-describedby');\n err.removeAttribute('aria-invalid');\n } catch (e) {\n // TODO error...\n }\n });\n }\n }\n\n /**\n *\n * @param {String} action\n *\n */\n recaptchaClientSide(action) {\n const googleRecaptchaClientSide = document.querySelector('input[name=\"googleRecaptchaClientSide\"]');\n if (googleRecaptchaClientSide) {\n window.grecaptcha.ready(() => {\n window.grecaptcha.execute(googleRecaptchaClientSide.value, { action }).then((token) => {\n this.$el.innerHTML += ``;\n this.$el.innerHTML += ``;\n });\n });\n }\n }\n\n\n /**\n *\n * @param {HTMLFormElement} form\n * @return {SerializeForm}\n */\n serializeForm(form) {\n return new Serialize(form);\n }\n}\n","import { post } from '../libs/Axios';\nimport BaseFormComponent from '../abstracts/BaseFormComponent';\nimport SerializeForm from '../utilities/SerializeForm';\n\nexport default class ContatcFormComponent extends BaseFormComponent {\n get SELECTORS() {\n return {\n error: '.js-error',\n apply: '.js-apply',\n };\n }\n\n get CLASSES() {\n return {\n hidden: 'hide'\n };\n }\n\n constructor(element) {\n super(element);\n this.handleSubmit();\n }\n\n handleSubmit() {\n const formButton = this.$el.querySelector(this.SELECTORS.apply);\n this.onSubmit(async (e, action) => {\n this.loading(formButton);\n const formData = this.serializeForm(e.currentTarget).toObject();\n try {\n const { data } = await post(action, formData);\n\n if (data.error) {\n const error = this.$el.querySelector(this.SELECTORS.error);\n error.innerHTML = data.message;\n error.classList.remove(this.CLASSES.hidden);\n } else {\n document.querySelector('.js-contactus-text1').remove();\n document.querySelector('.js-contactus-text2').remove();\n this.$el.innerHTML = data;\n }\n this.endLoading(formButton);\n return data;\n } catch (err) {\n console.error(err);\n this.endLoading(formButton);\n }\n });\n }\n}\n"],"sourceRoot":""}