') !== '7';\n});\n\n// @@replace logic\nfixRegExpWellKnownSymbolLogic('replace', function (_, nativeReplace, maybeCallNative) {\n var UNSAFE_SUBSTITUTE = REGEXP_REPLACE_SUBSTITUTES_UNDEFINED_CAPTURE ? '$' : '$0';\n\n return [\n // `String.prototype.replace` method\n // https://tc39.es/ecma262/#sec-string.prototype.replace\n function replace(searchValue, replaceValue) {\n var O = requireObjectCoercible(this);\n var replacer = isNullOrUndefined(searchValue) ? undefined : getMethod(searchValue, REPLACE);\n return replacer\n ? call(replacer, searchValue, O, replaceValue)\n : call(nativeReplace, toString(O), searchValue, replaceValue);\n },\n // `RegExp.prototype[@@replace]` method\n // https://tc39.es/ecma262/#sec-regexp.prototype-@@replace\n function (string, replaceValue) {\n var rx = anObject(this);\n var S = toString(string);\n\n if (\n typeof replaceValue == 'string' &&\n stringIndexOf(replaceValue, UNSAFE_SUBSTITUTE) === -1 &&\n stringIndexOf(replaceValue, '$<') === -1\n ) {\n var res = maybeCallNative(nativeReplace, rx, S, replaceValue);\n if (res.done) return res.value;\n }\n\n var functionalReplace = isCallable(replaceValue);\n if (!functionalReplace) replaceValue = toString(replaceValue);\n\n var global = rx.global;\n var fullUnicode;\n if (global) {\n fullUnicode = rx.unicode;\n rx.lastIndex = 0;\n }\n\n var results = [];\n var result;\n while (true) {\n result = regExpExec(rx, S);\n if (result === null) break;\n\n push(results, result);\n if (!global) break;\n\n var matchStr = toString(result[0]);\n if (matchStr === '') rx.lastIndex = advanceStringIndex(S, toLength(rx.lastIndex), fullUnicode);\n }\n\n var accumulatedResult = '';\n var nextSourcePosition = 0;\n for (var i = 0; i < results.length; i++) {\n result = results[i];\n\n var matched = toString(result[0]);\n var position = max(min(toIntegerOrInfinity(result.index), S.length), 0);\n var captures = [];\n var replacement;\n // NOTE: This is equivalent to\n // captures = result.slice(1).map(maybeToString)\n // but for some reason `nativeSlice.call(result, 1, result.length)` (called in\n // the slice polyfill when slicing native arrays) \"doesn't work\" in safari 9 and\n // causes a crash (https://pastebin.com/N21QzeQA) when trying to debug it.\n for (var j = 1; j < result.length; j++) push(captures, maybeToString(result[j]));\n var namedCaptures = result.groups;\n if (functionalReplace) {\n var replacerArgs = concat([matched], captures, position, S);\n if (namedCaptures !== undefined) push(replacerArgs, namedCaptures);\n replacement = toString(apply(replaceValue, undefined, replacerArgs));\n } else {\n replacement = getSubstitution(matched, S, position, captures, namedCaptures, replaceValue);\n }\n if (position >= nextSourcePosition) {\n accumulatedResult += stringSlice(S, nextSourcePosition, position) + replacement;\n nextSourcePosition = position + matched.length;\n }\n }\n\n return accumulatedResult + stringSlice(S, nextSourcePosition);\n }\n ];\n}, !REPLACE_SUPPORTS_NAMED_GROUPS || !REPLACE_KEEPS_$0 || REGEXP_REPLACE_SUBSTITUTES_UNDEFINED_CAPTURE);\n","'use strict';\nvar uncurryThis = require('../internals/function-uncurry-this');\nvar toObject = require('../internals/to-object');\n\nvar floor = Math.floor;\nvar charAt = uncurryThis(''.charAt);\nvar replace = uncurryThis(''.replace);\nvar stringSlice = uncurryThis(''.slice);\n// eslint-disable-next-line redos/no-vulnerable -- safe\nvar SUBSTITUTION_SYMBOLS = /\\$([$&'`]|\\d{1,2}|<[^>]*>)/g;\nvar SUBSTITUTION_SYMBOLS_NO_NAMED = /\\$([$&'`]|\\d{1,2})/g;\n\n// `GetSubstitution` abstract operation\n// https://tc39.es/ecma262/#sec-getsubstitution\nmodule.exports = function (matched, str, position, captures, namedCaptures, replacement) {\n var tailPos = position + matched.length;\n var m = captures.length;\n var symbols = SUBSTITUTION_SYMBOLS_NO_NAMED;\n if (namedCaptures !== undefined) {\n namedCaptures = toObject(namedCaptures);\n symbols = SUBSTITUTION_SYMBOLS;\n }\n return replace(replacement, symbols, function (match, ch) {\n var capture;\n switch (charAt(ch, 0)) {\n case '$': return '$';\n case '&': return matched;\n case '`': return stringSlice(str, 0, position);\n case \"'\": return stringSlice(str, tailPos);\n case '<':\n capture = namedCaptures[stringSlice(ch, 1, -1)];\n break;\n default: // \\d\\d?\n var n = +ch;\n if (n === 0) return match;\n if (n > m) {\n var f = floor(n / 10);\n if (f === 0) return match;\n if (f <= m) return captures[f - 1] === undefined ? charAt(ch, 1) : captures[f - 1] + charAt(ch, 1);\n return match;\n }\n capture = captures[n - 1];\n }\n return capture === undefined ? '' : capture;\n });\n};\n","'use strict';\nvar $ = require('../internals/export');\nvar global = require('../internals/global');\nvar schedulersFix = require('../internals/schedulers-fix');\n\nvar setInterval = schedulersFix(global.setInterval, true);\n\n// Bun / IE9- setInterval additional parameters fix\n// https://html.spec.whatwg.org/multipage/timers-and-user-prompts.html#dom-setinterval\n$({ global: true, bind: true, forced: global.setInterval !== setInterval }, {\n setInterval: setInterval\n});\n","'use strict';\n/* global Bun -- Bun case */\nmodule.exports = typeof Bun == 'function' && Bun && typeof Bun.version == 'string';\n","'use strict';\nvar $ = require('../internals/export');\nvar global = require('../internals/global');\nvar schedulersFix = require('../internals/schedulers-fix');\n\nvar setTimeout = schedulersFix(global.setTimeout, true);\n\n// Bun / IE9- setTimeout additional parameters fix\n// https://html.spec.whatwg.org/multipage/timers-and-user-prompts.html#dom-settimeout\n$({ global: true, bind: true, forced: global.setTimeout !== setTimeout }, {\n setTimeout: setTimeout\n});\n","'use strict';\nvar $ = require('../internals/export');\nvar $find = require('../internals/array-iteration').find;\nvar addToUnscopables = require('../internals/add-to-unscopables');\n\nvar FIND = 'find';\nvar SKIPS_HOLES = true;\n\n// Shouldn't skip holes\n// eslint-disable-next-line es/no-array-prototype-find -- testing\nif (FIND in []) Array(1)[FIND](function () { SKIPS_HOLES = false; });\n\n// `Array.prototype.find` method\n// https://tc39.es/ecma262/#sec-array.prototype.find\n$({ target: 'Array', proto: true, forced: SKIPS_HOLES }, {\n find: function find(callbackfn /* , that = undefined */) {\n return $find(this, callbackfn, arguments.length > 1 ? arguments[1] : undefined);\n }\n});\n\n// https://tc39.es/ecma262/#sec-array.prototype-@@unscopables\naddToUnscopables(FIND);\n","'use strict';\n// TODO: Remove from `core-js@4`\nvar $ = require('../internals/export');\nvar bind = require('../internals/function-bind');\n\n// `Function.prototype.bind` method\n// https://tc39.es/ecma262/#sec-function.prototype.bind\n// eslint-disable-next-line es/no-function-prototype-bind -- detection\n$({ target: 'Function', proto: true, forced: Function.bind !== bind }, {\n bind: bind\n});\n","'use strict';\n// TODO: Remove from `core-js@4`\nvar $ = require('../internals/export');\nvar DESCRIPTORS = require('../internals/descriptors');\nvar create = require('../internals/object-create');\n\n// `Object.create` method\n// https://tc39.es/ecma262/#sec-object.create\n$({ target: 'Object', stat: true, sham: !DESCRIPTORS }, {\n create: create\n});\n","'use strict';\nvar $ = require('../internals/export');\nvar fails = require('../internals/fails');\nvar toObject = require('../internals/to-object');\nvar nativeGetPrototypeOf = require('../internals/object-get-prototype-of');\nvar CORRECT_PROTOTYPE_GETTER = require('../internals/correct-prototype-getter');\n\nvar FAILS_ON_PRIMITIVES = fails(function () { nativeGetPrototypeOf(1); });\n\n// `Object.getPrototypeOf` method\n// https://tc39.es/ecma262/#sec-object.getprototypeof\n$({ target: 'Object', stat: true, forced: FAILS_ON_PRIMITIVES, sham: !CORRECT_PROTOTYPE_GETTER }, {\n getPrototypeOf: function getPrototypeOf(it) {\n return nativeGetPrototypeOf(toObject(it));\n }\n});\n\n","'use strict';\nvar $ = require('../internals/export');\nvar setPrototypeOf = require('../internals/object-set-prototype-of');\n\n// `Object.setPrototypeOf` method\n// https://tc39.es/ecma262/#sec-object.setprototypeof\n$({ target: 'Object', stat: true }, {\n setPrototypeOf: setPrototypeOf\n});\n","'use strict';\nvar $ = require('../internals/export');\nvar getBuiltIn = require('../internals/get-built-in');\nvar apply = require('../internals/function-apply');\nvar bind = require('../internals/function-bind');\nvar aConstructor = require('../internals/a-constructor');\nvar anObject = require('../internals/an-object');\nvar isObject = require('../internals/is-object');\nvar create = require('../internals/object-create');\nvar fails = require('../internals/fails');\n\nvar nativeConstruct = getBuiltIn('Reflect', 'construct');\nvar ObjectPrototype = Object.prototype;\nvar push = [].push;\n\n// `Reflect.construct` method\n// https://tc39.es/ecma262/#sec-reflect.construct\n// MS Edge supports only 2 arguments and argumentsList argument is optional\n// FF Nightly sets third argument as `new.target`, but does not create `this` from it\nvar NEW_TARGET_BUG = fails(function () {\n function F() { /* empty */ }\n return !(nativeConstruct(function () { /* empty */ }, [], F) instanceof F);\n});\n\nvar ARGS_BUG = !fails(function () {\n nativeConstruct(function () { /* empty */ });\n});\n\nvar FORCED = NEW_TARGET_BUG || ARGS_BUG;\n\n$({ target: 'Reflect', stat: true, forced: FORCED, sham: FORCED }, {\n construct: function construct(Target, args /* , newTarget */) {\n aConstructor(Target);\n anObject(args);\n var newTarget = arguments.length < 3 ? Target : aConstructor(arguments[2]);\n if (ARGS_BUG && !NEW_TARGET_BUG) return nativeConstruct(Target, args, newTarget);\n if (Target === newTarget) {\n // w/o altered newTarget, optimization for 0-4 arguments\n switch (args.length) {\n case 0: return new Target();\n case 1: return new Target(args[0]);\n case 2: return new Target(args[0], args[1]);\n case 3: return new Target(args[0], args[1], args[2]);\n case 4: return new Target(args[0], args[1], args[2], args[3]);\n }\n // w/o altered newTarget, lot of arguments case\n var $args = [null];\n apply(push, $args, args);\n return new (apply(bind, Target, $args))();\n }\n // with altered newTarget, not support built-in constructors\n var proto = newTarget.prototype;\n var instance = create(isObject(proto) ? proto : ObjectPrototype);\n var result = apply(Target, instance, args);\n return isObject(result) ? result : instance;\n }\n});\n","module.exports = __webpack_public_path__ + \"CSS/main.css\";","const regex = {\r\n spaces: / +/gi,\r\n slashes: /\\/+/gi,\r\n not_digits: /[^0-9]+/gi,\r\n not_alpha: /[^-'a-zA-ZÀ-ÖØ-öø-ſ ]+/gi,\r\n not_date_chars: /[^0-9/]/gi,\r\n postal: /^(\\d{5})-?(\\d{1,3})/,\r\n tel: /^(\\d{2})(\\d{1,5})?(\\d{4})?$/,\r\n rg: /^(\\d{1,2})(\\d{1,3})?(\\d{1,3})?(\\d)?$/,\r\n iscnpj: /^(\\d{2})(\\d{3})(\\d{3})(\\d{4})(\\d{1,2})?/,\r\n cnpj: /^(\\d{2})(\\d{1,3})?(\\d{1,3})?(\\d{1,4})?(\\d{1,2})?/,\r\n cpf: /^(\\d{1,3})?(\\d{1,3})?(\\d{1,3})?(\\d{1,2})?/,\r\n date: /^(\\d\\/|\\d{2})\\/*(\\d\\/|\\d{2})?\\/*(\\d{1,4})?/,\r\n};\r\n\r\nexport const name = val => val\r\n .replace(regex.not_alpha, '')\r\n .replace(regex.spaces, ' ');\r\n\r\nexport const number = val => val\r\n .replace(regex.not_digits, '');\r\n\r\nexport const postalCode = val => val\r\n .replace(regex.not_digits, '')\r\n .substr(0, 8)\r\n .replace(regex.postal, '$1-$2');\r\n\r\nexport const cep = postalCode;\r\n\r\nexport const tel = val => val\r\n .replace(regex.not_digits, '')\r\n .substr(0, 11)\r\n .replace(regex.tel, (\r\n all, ddd, area, final,\r\n ) => (\r\n `${\r\n ddd ? `(${ddd}` : ''\r\n }${\r\n area ? `) ${area}` : ''\r\n }${\r\n final ? `-${final}` : ''\r\n }`\r\n ));\r\n\r\nexport const rg = val => val\r\n .replace(regex.not_digits, '')\r\n .substr(0, 9)\r\n .replace(regex.rg, (\r\n all, p1, p2, p3, p4,\r\n ) => {\r\n const lastChar = val.substr(-1, 1);\r\n const x = lastChar.toUpperCase() === 'X' ? '-X' : '';\r\n return `${\r\n p1 || ''\r\n }${\r\n p2 ? `.${p2}` : ''\r\n }${\r\n p3 ? `.${p3}` : ''\r\n }${\r\n p4 ? `-${p4}` : x\r\n }`;\r\n });\r\n\r\nexport const cnpj = val => val\r\n .replace(regex.not_digits, '')\r\n .substr(0, 14)\r\n .replace(regex.cnpj, (\r\n all, p1, p2, p3, p4, p5,\r\n ) => `${\r\n p1 || ''\r\n }${\r\n p2 ? `.${p2}` : ''\r\n }${\r\n p3 ? `.${p3}` : ''\r\n }${\r\n p4 ? `/${p4}` : ''\r\n }${\r\n p5 ? `-${p5}` : ''\r\n }`)\r\n\r\nexport const cpf = val => val\r\n .replace(regex.not_digits, '')\r\n .substr(0, 11)\r\n .replace(regex.cpf, (\r\n all, p1, p2, p3, p4,\r\n ) => `${\r\n p1 || ''\r\n }${\r\n p2 ? `.${p2}` : ''\r\n }${\r\n p3 ? `.${p3}` : ''\r\n }${\r\n p4 ? `-${p4}` : ''\r\n }`);\r\n\r\nconst isCNPJ = val => regex.iscnpj.test(\r\n val.replace(regex.not_digits, ''),\r\n);\r\n\r\nexport const cpfcnpj = val => isCNPJ(val) ? cnpj(val) : cpf(val);\r\n\r\nconst padZero = (str) => {\r\n if (str === null || typeof str === 'undefined') {\r\n return '';\r\n }\r\n const n = str.replace(regex.slashes, '');\r\n if (n.toString().length === 1 && Number(n) > 0) {\r\n return `0${n}`;\r\n }\r\n return n;\r\n}\r\n\r\nexport const date = val => val\r\n .replace(regex.slashes, '/')\r\n .replace(regex.not_date_chars, '')\r\n .replace(regex.date, (\r\n all, dd, mm, yyyy,\r\n ) => `${\r\n padZero(dd) || ''\r\n }${\r\n mm ? `/${padZero(mm)}` : ''\r\n }${\r\n yyyy ? `/${yyyy}` : ''\r\n }`)\r\n .substr(0, 10);\r\n","class A11y {\r\n static get theme() {\r\n return A11y.get('theme');\r\n }\r\n \r\n static set theme(value) {\r\n const val = typeof value === 'string' ? value : '';\r\n document.body.setAttribute('data-theme', val);\r\n return A11y.set('theme', val);\r\n }\r\n \r\n static get minFontSize() {\r\n return -2;\r\n }\r\n \r\n static get maxFontSize() {\r\n return 2;\r\n }\r\n \r\n static get fontSize() {\r\n return +A11y.get('font-size') || 0;\r\n }\r\n \r\n static set fontSize(value) {\r\n const n = +value || 0;\r\n \r\n if (n < A11y.minFontSize || n > A11y.maxFontSize) {\r\n return A11y.set('font-size', A11y.fontSize);\r\n }\r\n \r\n document.body.setAttribute('data-font-size', n);\r\n return A11y.set('font-size', n);\r\n }\r\n \r\n static get prefix() {\r\n return '@a11y';\r\n }\r\n \r\n static get(key) {\r\n return localStorage.getItem(`${A11y.prefix}/${key}`);\r\n }\r\n \r\n static set(key, val) {\r\n return localStorage.setItem(`${A11y.prefix}/${key}`, val);\r\n }\r\n }\r\n\r\n A11y.theme = localStorage.getItem(`${A11y.prefix}/theme`);\r\n \r\n A11y.fontSize = localStorage.getItem(`${A11y.prefix}/font-size`);\r\n \r\n window.A11y = A11y;\r\n \r\n export default A11y;\r\n ","export const $ = (query, context = document) => {\r\n const ctx = context instanceof Node\r\n ? context\r\n : (\r\n document.querySelector(context)\r\n || document\r\n );\r\n \r\n const nodeList = typeof query === 'string'\r\n ? ctx.querySelectorAll(query)\r\n : query;\r\n \r\n return nodeList instanceof NodeList\r\n ? Array.prototype.slice.call(nodeList)\r\n : [nodeList];\r\n };\r\n \r\n const show = (query) => $(query).map((element) => {\r\n element.removeAttribute('hidden');\r\n return element;\r\n });\r\n \r\n const hide = (query) => $(query).map((element) => {\r\n element.setAttribute('hidden', true);\r\n return element;\r\n });\r\n \r\n const toggle = (query, display) => $(query).map((element) => {\r\n const visible = display != null\r\n ? !!display\r\n : element.hasAttribute('hidden');\r\n const action = visible ? show : hide;\r\n \r\n action(element);\r\n \r\n return element;\r\n });\r\n \r\n const render = (node, {\r\n style, events, children, attrs, ...props\r\n } = {}) => {\r\n const element = (\r\n typeof node === 'string'\r\n ? document.createElement(node)\r\n : node\r\n );\r\n \r\n if (!(element instanceof Node)) {\r\n // eslint-disable-next-line no-console\r\n console.warn('Elemento inválido.', element);\r\n return null;\r\n }\r\n \r\n if (props) {\r\n Object.entries(props).forEach(([key, val]) => {\r\n element[key] = val;\r\n });\r\n }\r\n \r\n if (attrs) {\r\n Object.entries(attrs).forEach(([key, val]) => {\r\n element.setAttribute(key, val);\r\n });\r\n }\r\n \r\n if (style) {\r\n Object.entries(style).forEach(([key, val]) => {\r\n element.style[key] = val;\r\n });\r\n }\r\n \r\n if (children instanceof Array) {\r\n children.forEach((kid) => {\r\n if (kid instanceof Node) {\r\n element.appendChild(kid);\r\n }\r\n });\r\n }\r\n \r\n if (events) {\r\n Object.entries(events).forEach(([name, fn]) => {\r\n if (typeof name === 'string' && fn instanceof Function) {\r\n element.addEventListener(name, fn);\r\n }\r\n });\r\n }\r\n \r\n return element;\r\n };\r\n \r\n $.show = show;\r\n $.hide = hide;\r\n $.toggle = toggle;\r\n $.render = render;\r\n \r\n export const isInViewport = (elem) => {\r\n const {\r\n top, left, bottom, right,\r\n } = elem.getBoundingClientRect();\r\n return (\r\n top >= 0 && left >= 0\r\n && bottom <= (window.innerHeight || document.documentElement.clientHeight)\r\n && right <= (window.innerWidth || document.documentElement.clientWidth)\r\n );\r\n };\r\n \r\n export const trigger = (el, name, detail) => {\r\n const customEvent = window.CustomEvent && typeof window.CustomEvent === 'function';\r\n const event = (\r\n customEvent\r\n ? new CustomEvent(name, { detail })\r\n : document.createEvent('CustomEvent')\r\n );\r\n \r\n event.initCustomEvent(name, true, true, detail);\r\n \r\n el.dispatchEvent(event);\r\n };\r\n \r\n const reticencias = document.querySelectorAll('[data-reticencias]')\r\n if(reticencias.length) {\r\n reticencias.forEach((elemento) => {\r\n const limite = elemento.dataset.reticencias.split(\" \")[0]\r\n const typePointer = elemento.dataset.reticencias.split(\" \")[1] ? elemento.dataset.reticencias.split(\" \")[1] : '...'\r\n const acimaLimite = elemento.innerText.length > limite;\r\n const pontoOuVazio = acimaLimite ? typePointer : '';\r\n elemento.innerText = elemento.innerText.substring(0, limite) + pontoOuVazio.trim();\r\n })\r\n }","import A11y from '../components/A11y';\r\nimport { $ } from '../util/DOM';\r\n\r\nconst initA11y = () => {\r\n $('.a11y-controls__theme').forEach((btn) => {\r\n btn.addEventListener('click', () => {\r\n A11y.theme = A11y.theme === '' ? 'dark' : '';\r\n });\r\n });\r\n\r\n $('.a11y-controls__inc-font').forEach((btn) => {\r\n btn.addEventListener('click', () => {\r\n A11y.fontSize += 1;\r\n });\r\n });\r\n\r\n $('.a11y-controls__dec-font').forEach((btn) => {\r\n btn.addEventListener('click', () => {\r\n A11y.fontSize -= 1;\r\n });\r\n });\r\n};\r\n\r\nexport default initA11y;\r\n","import { $ } from '../util/DOM';\r\n\r\nconst regex = {\r\n not_digits: /[^\\d]+/g,\r\n iscnpj: /^(\\d{2})(\\d{3})(\\d{3})(\\d{4})(\\d{1,2})?/,\r\n};\r\n\r\nconst isCNPJ = (val) => regex.iscnpj.test(\r\n val.replace(regex.not_digits, ''),\r\n);\r\n\r\nfunction validateRequiredCheckboxes(elements) {\r\n const isValid = elements.some((el) => el.checked);\r\n const el = elements[elements.length - 1];\r\n\r\n if (isValid) {\r\n el.removeAttribute('required');\r\n } else {\r\n el.setAttribute('required', 'required');\r\n }\r\n}\r\n\r\nfunction manageRequiredCheckbox(name) {\r\n if (!name) {\r\n return;\r\n }\r\n\r\n const elements = Array.prototype.slice.call(document.getElementsByName(name));\r\n\r\n validateRequiredCheckboxes(elements);\r\n\r\n elements.forEach((el) => {\r\n el.addEventListener('change', () => {\r\n validateRequiredCheckboxes(elements);\r\n });\r\n });\r\n}\r\n\r\nfunction validarCampoRepetido(input) {\r\n const url = `${APIform}/VerificarValorRepetido/?idCampo=${input.name}&valor=${input.value}${MasterKey}`;\r\n\r\n fetch(url)\r\n .then((response) => response.json())\r\n .then((data) => {\r\n !data ? input.classList.remove('invalid') : input.classList.add('invalid');\r\n });\r\n}\r\n\r\nfunction validarCPF(input) {\r\n const val = input.value;\r\n const strCPF = val.replace(regex.not_digits, '');\r\n let Soma;\r\n let Resto;\r\n Soma = 0;\r\n if (strCPF === '00000000000') {\r\n return false;\r\n }\r\n\r\n for (let i = 1; i <= 9; i += 1) {\r\n Soma += parseInt(strCPF.substring(i - 1, i), 10) * (11 - i);\r\n }\r\n Resto = (Soma * 10) % 11;\r\n\r\n if ((Resto === 10) || (Resto === 11)) {\r\n Resto = 0;\r\n }\r\n if (Resto !== parseInt(strCPF.substring(9, 10), 10)) {\r\n return false;\r\n }\r\n\r\n Soma = 0;\r\n for (let i = 1; i <= 10; i += 1) {\r\n Soma += parseInt(strCPF.substring(i - 1, i), 10) * (12 - i);\r\n }\r\n Resto = (Soma * 10) % 11;\r\n\r\n if ((Resto === 10) || (Resto === 11)) {\r\n Resto = 0;\r\n }\r\n if (Resto !== parseInt(strCPF.substring(10, 11), 10)) {\r\n return false;\r\n }\r\n return true;\r\n}\r\n\r\nfunction validarCNPJ(input) {\r\n const { value } = input;\r\n const cnpj = value.replace(regex.not_digits, '');\r\n\r\n // Valida a quantidade de caracteres\r\n if (cnpj.length !== 14) return false;\r\n\r\n // Elimina inválidos com todos os caracteres iguais\r\n if (/^(\\d)\\1+$/.test(cnpj)) return false;\r\n\r\n // Cáculo de validação\r\n const t = cnpj.length - 2;\r\n const d = cnpj.substring(t);\r\n const d1 = parseInt(d.charAt(0), 10);\r\n const d2 = parseInt(d.charAt(1), 10);\r\n const calc = (x) => {\r\n const n = cnpj.substring(0, x);\r\n let y = x - 7;\r\n let s = 0;\r\n let r = 0;\r\n\r\n for (let i = x; i >= 1; i -= 1) {\r\n // eslint-disable-next-line no-plusplus\r\n s += n.charAt(x - i) * y--;\r\n if (y < 2) {\r\n y = 9;\r\n }\r\n }\r\n\r\n r = 11 - (s % 11);\r\n return r > 9 ? 0 : r;\r\n };\r\n\r\n return calc(t) === d1 && calc(t + 1) === d2;\r\n}\r\n\r\nconst setValidity = (input, test, message) => () => {\r\n const msg = test(input) || input.value === '' ? '' : message;\r\n input.setCustomValidity(msg);\r\n};\r\n\r\nconst setCampoValidity = (input) => setValidity(\r\n input, validarCampoRepetido, 'Já está cadastrado no sistema.',\r\n);\r\n\r\nconst setCPFValidity = (input) => setValidity(\r\n input, validarCPF, 'O CPF informado não é válido',\r\n);\r\n\r\nconst setCNPJValidity = (input) => setValidity(\r\n input, validarCNPJ, 'O CNPJF informado não é válido.',\r\n);\r\n\r\nconst initFormValidations = () => {\r\n $('[data-checkbox-required]').forEach((container) => {\r\n const checkboxName = container.getAttribute('data-checkbox-required');\r\n manageRequiredCheckbox(checkboxName);\r\n });\r\n\r\n $('[data-mask=\"cpf\"]').forEach((input) => {\r\n input.addEventListener('input', setCPFValidity(input));\r\n });\r\n\r\n $('[data-mask=\"cnpj\"').forEach((input) => {\r\n input.addEventListener('input', setCNPJValidity(input));\r\n });\r\n\r\n $('[data-mask=\"cpfcnpj\"]').forEach((input) => {\r\n input.addEventListener('input', () => {\r\n if (isCNPJ(input.value)) {\r\n setCNPJValidity(input);\r\n return;\r\n }\r\n setCPFValidity(input);\r\n });\r\n });\r\n\r\n $('input[type=\"file\"]').forEach((input) => {\r\n const formats = input.getAttribute('data-accept');\r\n const maxSize = parseInt(input.getAttribute('data-max-size'), 10);\r\n const extRX = /\\.([^.]+)$/;\r\n const ext = (file) => (file.name.match(extRX)[1] || '').toLowerCase();\r\n const constraints = {\r\n format: () => {\r\n if (!formats) {\r\n return $(input.files);\r\n }\r\n const validFormats = formats.split(',');\r\n return $(input.files).filter((f) => validFormats.includes(ext(f)));\r\n },\r\n size: () => {\r\n if (!maxSize) {\r\n return $(input.files);\r\n }\r\n\r\n return $(input.files).filter((f) => f.size < maxSize);\r\n },\r\n };\r\n\r\n input.addEventListener('change', () => {\r\n const validation = {\r\n format: constraints.format().length === input.files.length,\r\n size: constraints.size().length === input.files.length,\r\n };\r\n const message = [\r\n validation.format\r\n ? ''\r\n : `Arquivo incorreto. Selecione um formato válido: ${formats.replace(/,/g, ', ')}`,\r\n validation.size\r\n ? ''\r\n : 'Limite de upload excedido. Selecione um arquivo menor.',\r\n ]\r\n .filter((m) => !!m)\r\n .join(' ')\r\n .trim();\r\n\r\n input.setCustomValidity(message);\r\n });\r\n });\r\n\r\n $('form').forEach((form) => {\r\n if(form.id === 'ecrie-form') {\r\n return;\r\n };\r\n form.addEventListener('submit', (e) => {\r\n const btn = form.querySelector('[type=\"submit\"]') || form.querySelector('button');\r\n const loader = form.querySelector('.loader') || form.querySelector('.loader2');\r\n\r\n btn.setAttribute('hidden', true);\r\n \r\n loader.removeAttribute('hidden');\r\n\r\n $(form.elements).forEach((input) => {\r\n if (form.id === 'ecrie-form') {\r\n return;\r\n }\r\n if (input.value === '' && input.hasAttribute('required')) {\r\n // eslint-disable-next-line no-param-reassign\r\n input.value = '';\r\n input.focus();\r\n e.preventDefault();\r\n btn.removeAttribute('hidden');\r\n loader.setAttribute('hidden', true);\r\n }\r\n });\r\n });\r\n });\r\n};\r\n\r\nexport default initFormValidations;\r\n","import { $ } from '../util/DOM';\r\n\r\nconst closeSVG = '';\r\n\r\nconst createModal = (content, keepInDoc) => {\r\n\r\n const container = $.render('div', {\r\n className: 'modal',\r\n innerHTML: /* html */ `${\r\n (content && content.outerHTML) || content || ''\r\n }
`,\r\n });\r\n\r\n document.body.appendChild(container);\r\n\r\n const stopAllYouTubeVideos = () => {\r\n const iframes = document.querySelectorAll('iframe');\r\n Array.prototype.forEach.call(iframes, (iframe) => {\r\n if (iframe) {\r\n const iframeSrc = iframe.src;\r\n // eslint-disable-next-line no-param-reassign\r\n iframe.src = iframeSrc;\r\n }\r\n });\r\n };\r\n\r\n const open = () => {\r\n container.classList.add('open');\r\n document.body.classList.add('has-modal');\r\n };\r\n\r\n let fechar = document.querySelectorAll('.close').forEach(item =>{\r\n item.addEventListener('click', (keep = keepInDoc)=>{\r\n container.classList.remove('open');\r\n document.body.classList.remove('has-modal');\r\n stopAllYouTubeVideos();\r\n if (!keep) {\r\n setTimeout(() => {\r\n container.remove();\r\n }, 500);\r\n }\r\n })\r\n })\r\n\r\nconst close = (keep = keepInDoc) => {\r\n container.classList.remove('open');\r\n document.body.classList.remove('has-modal');\r\n if (!keep) {\r\n setTimeout(() => {\r\n container.remove();\r\n }, 500);\r\n }\r\n};\r\n\r\n document.body.appendChild(container);\r\n\r\n const modal = {\r\n container,\r\n open,\r\n close,\r\n };\r\n\r\n container.modal = modal;\r\n\r\n return modal;\r\n};\r\n\r\nexport default createModal;\r\n","import createModal from '../components/createModal';\r\nimport { $ } from '../util/DOM';\r\n\r\nconst svg = {\r\n prev: '',\r\n next: '',\r\n};\r\n\r\nconst imageView = ({ href, title }, onclick) => {\r\n const modal = createModal(/* html */ `\r\n
\r\n`, true);\r\n\r\n $.render(modal.container, {\r\n children: [\r\n $.render('button', {\r\n type: 'button',\r\n className: 'modal__prev-button',\r\n innerHTML: svg.prev,\r\n events: {\r\n click: () => onclick(-1),\r\n },\r\n }),\r\n $.render('button', {\r\n type: 'button',\r\n className: 'modal__next-button',\r\n innerHTML: svg.next,\r\n events: {\r\n click: () => onclick(+1),\r\n },\r\n }),\r\n ],\r\n });\r\n\r\n return modal;\r\n};\r\n\r\nconst initGallery = () => {\r\n $('.gallery__container').forEach((container) => {\r\n const photos = $('.gallery__item', container);\r\n photos.forEach((p, index) => {\r\n // eslint-disable-next-line no-param-reassign\r\n p.modal = imageView(p, (i) => {\r\n const selectedIndex = index + i;\r\n p.modal.close();\r\n if (selectedIndex < 0) {\r\n photos[photos.length - 1].modal.open();\r\n return;\r\n }\r\n if (selectedIndex >= photos.length) {\r\n photos[0].modal.open();\r\n return;\r\n }\r\n photos[selectedIndex].modal.open();\r\n });\r\n\r\n p.addEventListener('click', (e) => {\r\n e.preventDefault();\r\n p.modal.open();\r\n });\r\n });\r\n });\r\n};\r\n\r\nexport default initGallery;\r\n","import createModal from '../components/createModal';\r\nimport { $ } from '../util/DOM';\r\n\r\nconst videoView = (p) => {\r\n const html = $('.videos__template', p);\r\n\r\n const modal = createModal(html[0].innerHTML, true);\r\n\r\n return modal;\r\n};\r\n\r\nconst initVideos = () => {\r\n $('.videos__container').forEach((container) => {\r\n const photos = $('.videos__item', container);\r\n photos.forEach((p, index) => {\r\n // eslint-disable-next-line no-param-reassign\r\n p.modal = videoView(p, (i) => {\r\n const selectedIndex = index + i;\r\n p.modal.close();\r\n if (selectedIndex < 0) {\r\n photos[photos.length - 1].modal.open();\r\n return;\r\n }\r\n if (selectedIndex >= photos.length) {\r\n photos[0].modal.open();\r\n return;\r\n }\r\n photos[selectedIndex].modal.open();\r\n });\r\n\r\n p.addEventListener('click', (e) => {\r\n e.preventDefault();\r\n p.modal.open();\r\n });\r\n });\r\n });\r\n};\r\n\r\nexport default initVideos;\r\n","import { $ } from '../util/DOM';\r\n\r\nconst initMenuFX = () => {\r\n const buttons = $('[aria-haspopup=\"true\"]');\r\n\r\n const targets = buttons.map((btn) => {\r\n const target = document.getElementById(btn.getAttribute('aria-controls'));\r\n if (!target) {\r\n return null;\r\n }\r\n\r\n btn.addEventListener('click', (e) => {\r\n e.preventDefault();\r\n e.stopPropagation();\r\n const isOpen = btn.getAttribute('aria-expanded') === 'true';\r\n const groupName = btn.getAttribute('data-group-name');\r\n if (groupName) {\r\n $(`[data-group-name=\"${groupName}\"]`).forEach((b) => {\r\n b.setAttribute('aria-expanded', false);\r\n });\r\n }\r\n btn.setAttribute('aria-expanded', !isOpen);\r\n });\r\n\r\n return target;\r\n }).filter((el) => !!el);\r\n\r\n window.addEventListener('click', ({ target }) => {\r\n const foundTarget = targets.find((el) => el === target || el.contains(target));\r\n if (foundTarget) {\r\n return;\r\n }\r\n buttons.forEach((button) => button.setAttribute('aria-expanded', false));\r\n });\r\n};\r\n\r\nexport default initMenuFX;\r\n","import { $, _hasParent } from \"../util/DOM\";\r\n\r\nconst initMenuButtons = () => {\r\n const menuIcons = $('.menu-icon');\r\n\r\n menuIcons.forEach((btn) => btn.addEventListener('click', function (e) {\r\n e.preventDefault();\r\n this.classList.toggle('hover');\r\n }));\r\n\r\n document.body.addEventListener('click', function (e) {\r\n menuIcons.forEach((btn) => {\r\n const isTarget = (el) => e.target === el || _hasParent(e.target, el);\r\n const menuContainer = btn.parentElement.querySelector('.trigger');\r\n if (isTarget(btn) || isTarget(menuContainer)) return;\r\n btn.classList.remove('hover');\r\n });\r\n }, false);\r\n}\r\n\r\nexport default initMenuButtons;\r\n","import createModal from '../components/createModal';\r\nimport { $ } from '../util/DOM';\r\n\r\nconst initModals = () => {\r\n $('.modal-template').forEach((container) => {\r\n const keep = container.hasAttribute('keep');\r\n const modal = createModal(container.innerHTML, keep);\r\n\r\n if (container.hasAttribute('open')) {\r\n modal.open();\r\n }\r\n\r\n container.remove();\r\n });\r\n};\r\n\r\nexport default initModals;\r\n","import { $ } from '../util/DOM';\r\n\r\nconst closeSVG = '';\r\n\r\nconst createModalClick = (content) => {\r\n const container = $.render('div', {\r\n className: 'modal',\r\n innerHTML: `${\r\n (content && content.outerHTML) || content || ''\r\n }
`,\r\n });\r\n\r\n document.body.appendChild(container);\r\n\r\n const open = () => {\r\n container.classList.add('open');\r\n document.body.classList.add('has-modal');\r\n };\r\n\r\n const close = () => {\r\n container.classList.remove('open');\r\n document.body.classList.remove('has-modal');\r\n container.remove();\r\n };\r\n\r\n const closeButton = $.render('button', {\r\n type: 'button',\r\n className: 'close',\r\n innerHTML: closeSVG,\r\n events: {\r\n click: () => close(),\r\n },\r\n });\r\n\r\n document.body.appendChild(container);\r\n\r\n container.querySelector('[class=\"modal-content onclick\"]').appendChild(closeButton);\r\n\r\n const modal = {\r\n container,\r\n closeButton,\r\n open,\r\n close,\r\n };\r\n\r\n container.modal = modal;\r\n\r\n return modal;\r\n};\r\n\r\nexport default createModalClick;\r\n","import createModalClick from '../components/createModalClick';\r\nimport { $ } from '../util/DOM';\r\n\r\nconst ModalView = (p) => {\r\n const html = $('.modal__click', p);\r\n\r\n const modal = createModalClick(html[0].innerHTML, true);\r\n\r\n return modal;\r\n};\r\n\r\nconst initModalClick = () => {\r\n $('.modal-click__container').forEach((container) => {\r\n const item = $('.modal-click__item', container);\r\n item.forEach((p) => {\r\n p.addEventListener('click', (e) => {\r\n // eslint-disable-next-line no-param-reassign\r\n p.modal = ModalView(p, () => {\r\n item.modal.open();\r\n });\r\n\r\n e.preventDefault();\r\n p.modal.open();\r\n });\r\n });\r\n });\r\n};\r\n\r\nexport default initModalClick;\r\n","import smoothscroll from 'smoothscroll-polyfill';\r\nimport { $ } from '../util/DOM';\r\n\r\nconst initBackTopButton = () => {\r\n const backTopButton = document.querySelector('.back-to-top');\r\n window.addEventListener('scroll', () => {\r\n $.toggle(backTopButton, window.scrollY > 0);\r\n });\r\n\r\n backTopButton.addEventListener('click', () => {\r\n window.scrollTo({\r\n behavior: 'smooth',\r\n top: 0,\r\n left: 0,\r\n });\r\n window.location.hash = '';\r\n });\r\n};\r\n\r\nconst initScrollFX = () => {\r\n smoothscroll.polyfill();\r\n initBackTopButton();\r\n};\r\n\r\nexport default initScrollFX;\r\n","import { trigger } from '../util/DOM';\r\n\r\nconst CONTAINER = Symbol('CONTAINER');\r\nconst CHILDREN = Symbol('CHILDREN');\r\nconst OPTIONS = Symbol('OPTIONS');\r\nconst INDEX = Symbol('INDEX');\r\nconst STATE = Symbol('STATE');\r\nconst DIRECTION = Symbol('DIRECTION');\r\n\r\nclass Slider {\r\n constructor(container, options) {\r\n this.init(container, {\r\n interval: 3000,\r\n initClassName: 'slider-set',\r\n childSelector: '.slider__item',\r\n ...options,\r\n });\r\n }\r\n\r\n init(container, options) {\r\n this[CONTAINER] = container;\r\n this[OPTIONS] = options;\r\n this[INDEX] = 0;\r\n\r\n const { childSelector, initClassName } = this.options;\r\n this[CHILDREN] = (\r\n childSelector\r\n ? this.container.querySelectorAll(childSelector)\r\n : this.container.children\r\n );\r\n\r\n this.container.classList.add(initClassName);\r\n this.container.slider = this;\r\n setTimeout(() => this.render(), 100);\r\n }\r\n\r\n get container() {\r\n return this[CONTAINER];\r\n }\r\n\r\n get options() {\r\n return this[OPTIONS];\r\n }\r\n\r\n get direction() {\r\n return this[DIRECTION] || 0;\r\n }\r\n\r\n get state() {\r\n return this[STATE] || {\r\n isPlayng: false,\r\n };\r\n }\r\n\r\n get index() {\r\n return this[INDEX];\r\n }\r\n\r\n set index(i) {\r\n const dir = i < this[INDEX] ? -1 : +1;\r\n if (i >= this.children.length) {\r\n this[INDEX] = 0;\r\n } else if (i < 0) {\r\n this[INDEX] = this.children.length - 1;\r\n } else {\r\n this[INDEX] = i;\r\n }\r\n this[DIRECTION] = dir;\r\n this.render();\r\n setTimeout(() => {\r\n if (!this.state.isPlayng) {\r\n this[DIRECTION] = 0;\r\n }\r\n }, 100);\r\n }\r\n\r\n get children() {\r\n return [...this[CHILDREN]];\r\n }\r\n\r\n get currentElement() {\r\n return this.children[this.index];\r\n }\r\n\r\n get prevElement() {\r\n if (this.index === 0) {\r\n return this.children[this.children.length - 1];\r\n }\r\n return this.children[this.index - 1];\r\n }\r\n\r\n get nextElement() {\r\n if (this.index === this.children.length - 1) {\r\n return this.children[0];\r\n }\r\n return this.children[this.index + 1];\r\n }\r\n\r\n goTo(index) {\r\n const { isPlayng, id } = this.state;\r\n if (isPlayng) {\r\n this[STATE] = {\r\n ...this.state,\r\n id: clearInterval(id),\r\n };\r\n }\r\n this.index = index;\r\n if (isPlayng) {\r\n this.play();\r\n }\r\n return this;\r\n }\r\n\r\n goPrev() {\r\n return this.goTo(this.index - 1);\r\n }\r\n\r\n goNext() {\r\n return this.goTo(this.index + 1);\r\n }\r\n\r\n play() {\r\n if (this.children.length === 1) {\r\n return this.pause();\r\n }\r\n this[STATE] = {\r\n ...this.state,\r\n id: setInterval(() => this.goNext(), this.options.interval),\r\n isPlayng: true,\r\n };\r\n return this;\r\n }\r\n\r\n pause() {\r\n const { id } = this.state;\r\n\r\n this[STATE] = {\r\n ...this.state,\r\n id: clearInterval(id),\r\n isPlayng: false,\r\n };\r\n\r\n return this;\r\n }\r\n\r\n on(name, fn, el) {\r\n if (!el) {\r\n this.container.addEventListener(name, fn);\r\n return this;\r\n }\r\n\r\n this.container.addEventListener(name, (e) => {\r\n for (let { target } = e; target && target !== this.container; target = target.parentNode) {\r\n if (target.matches(el)) {\r\n fn.call(target, e);\r\n break;\r\n }\r\n }\r\n }, false);\r\n\r\n return this;\r\n }\r\n\r\n trigger(name, detail) {\r\n trigger(this.container, name, {\r\n ...detail, slider: this,\r\n });\r\n }\r\n\r\n render() {\r\n if (!this.children.length) {\r\n // eslint-disable-next-line no-console\r\n console.trace('Elementos filhos não encontrados.', this);\r\n this.pause();\r\n return;\r\n }\r\n\r\n this.children.forEach((slide) => {\r\n slide.classList.remove('prev');\r\n slide.classList.remove('next');\r\n slide.classList.remove('current');\r\n });\r\n this.currentElement.classList.add('current');\r\n this.prevElement.classList.add('prev');\r\n this.nextElement.classList.add('next');\r\n this.trigger('render');\r\n }\r\n}\r\n\r\nexport default Slider;\r\n","import Slider from './Slider';\r\n\r\nconst addAnimationClassName = (el, className) => {\r\n const removeClassName = () => {\r\n el.removeEventListener('animationend', removeClassName);\r\n el.classList.remove(className);\r\n };\r\n el.classList.add(className);\r\n el.addEventListener('animationend', removeClassName);\r\n};\r\n\r\nclass Carousel extends Slider {\r\n constructor(container, options) {\r\n super(container, {\r\n initClassName: 'carousel-set',\r\n childSelector: '.carousel__item',\r\n ...options,\r\n });\r\n }\r\n\r\n render() {\r\n if (!this.children.length) {\r\n // eslint-disable-next-line no-console\r\n console.trace('Elementos filhos não encontrados.', this);\r\n this.pause();\r\n return;\r\n }\r\n\r\n this.children.forEach((el, i) => {\r\n const pos = i - this.index;\r\n const order = pos < 0 ? this.children.length + pos : pos;\r\n\r\n // eslint-disable-next-line no-param-reassign\r\n el.style.order = order;\r\n el.setAttribute('data-order', order);\r\n\r\n el.classList.remove('slide-to-left');\r\n el.classList.remove('slide-to-right');\r\n\r\n if (this.direction < 0) {\r\n addAnimationClassName(el, 'slide-to-right');\r\n }\r\n\r\n if (this.direction > 0) {\r\n addAnimationClassName(el, 'slide-to-left');\r\n }\r\n });\r\n\r\n this.trigger('render');\r\n }\r\n}\r\n\r\nexport default Carousel;\r\n","import Carousel from '../components/Carousel';\r\nimport Slider from '../components/Slider';\r\nimport { $ } from '../util/DOM';\r\n\r\nconst getLinkHtml = (el) => {\r\n const qs = el.getAttribute('data-link-content');\r\n if (!qs) {\r\n return '';\r\n }\r\n const content = el.querySelector(qs);\r\n if (!content) {\r\n return '';\r\n }\r\n return content.innerHTML;\r\n};\r\n\r\nconst sliderControlComponents = {\r\n arrows: (slider) => $.render('div', {\r\n className: 'slider-controls__arrows',\r\n children: [\r\n $.render('button', {\r\n type: 'button',\r\n className: 'prev',\r\n attrs: { 'aria-label': 'Voltar slide' },\r\n innerHTML: /* html */ `\r\n \r\n `,\r\n events: {\r\n click: () => {\r\n slider.goPrev();\r\n },\r\n },\r\n }),\r\n $.render('button', {\r\n type: 'button',\r\n className: 'next',\r\n attrs: { 'aria-label': 'Avançar slide' },\r\n innerHTML: /* html */ ` `,\r\n events: {\r\n click: () => {\r\n slider.goNext();\r\n },\r\n },\r\n }),\r\n ],\r\n }),\r\n counters: (slider) => {\r\n const children = slider.children.map((el, i) => $.render('button', {\r\n type: 'button',\r\n textContent: i + 1,\r\n attrs: { 'aria-label': `Ver o slide ${i + 1}` },\r\n events: { click: () => slider.goTo(i) },\r\n }));\r\n\r\n slider.on('render', () => {\r\n children.forEach((btn, btnIndex) => {\r\n if (btnIndex === slider.index) {\r\n btn.classList.add('is-active');\r\n } else {\r\n btn.classList.remove('is-active');\r\n }\r\n });\r\n });\r\n\r\n return $.render('div', {\r\n className: 'slider-controls__counters',\r\n children,\r\n });\r\n },\r\n links: (slider) => {\r\n const children = slider.children.map((el, i) => $.render('div', {\r\n innerHTML: getLinkHtml(el),\r\n tabindex: '-1',\r\n events: { click: () => slider.goTo(i) },\r\n }));\r\n\r\n slider.on('render', () => {\r\n children.forEach((btn, btnIndex) => {\r\n if (btnIndex === slider.index) {\r\n btn.classList.add('is-active');\r\n } else {\r\n btn.classList.remove('is-active');\r\n }\r\n });\r\n });\r\n\r\n return $.render('div', {\r\n className: 'slider-controls__links',\r\n children,\r\n });\r\n },\r\n};\r\n\r\nconst generateControls = (slider, keys) => keys.map((key) => {\r\n if (!(key in sliderControlComponents)) {\r\n // eslint-disable-next-line no-console\r\n console.warn(`Opção de controle inválida: ${key}. As opções disponíveis são ${\r\n Object.keys(sliderControlComponents).join(', ')\r\n }`);\r\n return null;\r\n }\r\n return sliderControlComponents[key](slider);\r\n});\r\n\r\nconst setSliderControls = (slider, controlOptions) => {\r\n if (!controlOptions) {\r\n return;\r\n }\r\n const controlKeys = controlOptions.trim().split(' ');\r\n if (!controlKeys.length) {\r\n return;\r\n }\r\n\r\n const container = $.render('div', {\r\n className: 'slider-controls__container',\r\n children: generateControls(slider, controlKeys),\r\n });\r\n\r\n slider.container.insertAdjacentElement('afterEnd', container);\r\n};\r\n\r\nconst createSlider = (container, type) => {\r\n const play = container.hasAttribute('data-play');\r\n const interval = container.getAttribute('data-interval') || 3000;\r\n const height = container.getAttribute('data-height');\r\n const controls = container.getAttribute('data-controls');\r\n\r\n const slider = (\r\n type === 'carousel'\r\n ? new Carousel(container, { interval })\r\n : new Slider(container, { interval })\r\n );\r\n\r\n if (play) {\r\n slider\r\n .on('mouseover', () => slider.pause())\r\n .on('mouseout', () => slider.play())\r\n .play();\r\n }\r\n\r\n if (height) {\r\n slider.container.style.height = height;\r\n }\r\n\r\n if (controls) {\r\n setSliderControls(slider, controls);\r\n }\r\n\r\n return slider;\r\n};\r\n\r\nconst createCarousel = (container) => {\r\n createSlider(container, 'carousel');\r\n};\r\n\r\nconst initSliders = () => {\r\n $('.slider').forEach(createSlider);\r\n $('.carousel').forEach(createCarousel);\r\n};\r\n\r\nexport default initSliders;\r\n","document.addEventListener(\"DOMContentLoaded\", function() {\r\n const listaMenu = document.querySelectorAll('.rotuloNoticias')\r\n const listaConteudo = document.querySelectorAll('#listaNoticias li')\r\n\r\n var cont = 0;\r\n\r\n if(listaMenu && listaConteudo){\r\n const ativaLink = (item) => {\r\n mostraItens(item.dataset.item)\r\n let elemendoDoMeio = document.querySelectorAll(\"#listaNoticias li.ativo .DestaqueNoticias-lista-item-img img\")[1]\r\n elemendoDoMeio.style.height = \"310px\"\r\n elemendoDoMeio.style.width = \"100%\"\r\n elemendoDoMeio.style.objectFit = \"cover\"\r\n }\r\n \r\n listaMenu.forEach((item) =>{\r\n listaMenu[0].classList.add('ativo')\r\n item.addEventListener(\"click\", (event) => {\r\n listaMenu.forEach(removeClasse => {\r\n removeClasse.classList.remove('ativo')\r\n })\r\n item.classList.add(\"ativo\")\r\n })\r\n })\r\n \r\n const mostraItens = (rotulo) => {\r\n listaConteudo.forEach(link => link.classList.remove('ativo'))\r\n cont = 0;\r\n listaConteudo.forEach(item => {\r\n if (item.dataset.item === rotulo && cont < 3) {\r\n item.classList.add('ativo')\r\n cont ++\r\n }\r\n })\r\n }\r\n listaMenu.forEach((link, index) => {\r\n link.addEventListener('click', () => {\r\n ativaLink(link)\r\n })\r\n })\r\n \r\n listaConteudo.forEach(link => link.classList.remove('ativo'))\r\n \r\n listaConteudo.forEach(item => {\r\n if (item.dataset.item === 'Geral' && cont < 3) {\r\n item.classList.add('ativo')\r\n cont ++\r\n }\r\n })\r\n }\r\n\r\n\r\n\r\n const activeItems = document.querySelectorAll(\"#listaNoticias li.ativo .DestaqueNoticias-lista-item-img img\");\r\n \r\n if (activeItems.length > 1) {\r\n let elementoDoMeio = activeItems[1];\r\n \r\n elementoDoMeio.style.height = \"310px\";\r\n elementoDoMeio.style.width = \"100%\";\r\n elementoDoMeio.style.objectFit = \"cover\";\r\n }\r\n});","import * as masks from './src/masks';\r\n\r\nexport const bindInputMask = (\r\n input, maskName, eventName = 'input'\r\n) => {\r\n const applyMask = masks[maskName];\r\n\r\n if (!(applyMask instanceof Function)) {\r\n console.error(`${maskName} is not a valid mask.`);\r\n return;\r\n }\r\n\r\n input.addEventListener(eventName, () => {\r\n const { value } = input;\r\n input.value = applyMask(value);\r\n });\r\n};\r\n\r\nexport const bindMasksByAttribute = (attrName = 'data-mask', context = document) => {\r\n const inputs = context.querySelectorAll(`[${attrName}]`);\r\n Array.prototype.forEach.call(inputs, (input) => {\r\n const maskName = input.getAttribute(attrName);\r\n\r\n if (!maskName) {\r\n console.error('No mask defined for input', input);\r\n return;\r\n }\r\n\r\n bindInputMask(input, maskName);\r\n });\r\n}\r\n\r\nexport { masks };\r\n","import { bindMasksByAttribute } from 'br-input-masks';\r\nimport initA11y from './main/initA11y';\r\nimport initFormValidation from './main/initFormValidation';\r\nimport initGallery from './main/initGallery';\r\nimport initVideos from './main/initVideos';\r\nimport initMenuFX from './main/initMenuFX';\r\nimport initMenuButtons from './main/initMenuButtons';\r\nimport initModals from './main/initModals';\r\nimport initModalClick from './main/initModalClick';\r\nimport initScrollFX from './main/initScrollFX';\r\nimport initSliders from './main/initSliders';\r\nimport menuNoticias from './components/menuNoticias';\r\n\r\nbindMasksByAttribute();\r\n\r\ninitA11y();\r\n\r\ninitMenuFX();\r\n\r\ninitMenuButtons();\r\n\r\ninitSliders();\r\n\r\ninitGallery();\r\n\r\ninitVideos();\r\n\r\ninitModalClick();\r\n\r\ninitModals();\r\n\r\ninitScrollFX();\r\n\r\ninitFormValidation();\r\n\r\nmenuNoticias();\r\n"],"sourceRoot":""}