capibara 1.3.6 → 1.3.8

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/index.js CHANGED
@@ -255,7 +255,7 @@ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _uti
255
255
  /***/ (function(module, __webpack_exports__, __webpack_require__) {
256
256
 
257
257
  "use strict";
258
- eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _util_domUtils__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../util/domUtils */ \"./src/util/domUtils.js\");\n/* harmony import */ var _util_utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../util/utils */ \"./src/util/utils.js\");\n/* harmony import */ var _util_dateUtils__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../util/dateUtils */ \"./src/util/dateUtils.js\");\n/* harmony import */ var _util_icons__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../util/icons */ \"./src/util/icons.js\");\n\n\n\n\n\n/* harmony default export */ __webpack_exports__[\"default\"] = ({\n /**\n * Crea elemento Table\n * Contendrá los elementos que apareceran dentro de la tabla de planilla\n * Se Usa para :\n * - Agregar background con patron estilo tabla\n * - Agregar dayMouseOver, div que indica posicion de mouse\n * - Agregar DetailDay, para detalles de datos en tabla\n * - Agregar SelectedContainer, para dias seleccionados\n * - Agregar FloatBoxContainer, para visualizacion de datos en tabla\n *\n * @param {Object} config - Configuracion capibara\n * @return {Object} Elemento Dom creado\n */\n createAgTable(config) {\n let e = _util_domUtils__WEBPACK_IMPORTED_MODULE_0__[\"default\"].createElement(\"div\", {\n className: \"capibara\"\n });\n\n if (config.timeline.dark) {\n e.classList.add(\"dark-theme\");\n }\n\n if (config.timeline.header.extend.isShow) {\n e.classList.add(\"header-extended\");\n }\n\n return e;\n },\n\n /**\n * Recrea Background, que es el fondo grid, como tabla\n *\n * @param {Object} config - Configuracion capibara\n * @param {Object} $elem - Elemento relacionado, donde se cre el background\n * @return {Object} Elemento Dom Corner Footer\n */\n redrawBackground(config, $elem) {\n return this.createBackground(config, $elem);\n },\n\n /**\n * Crea y posiciona fondo de tabla\n * Este fondo contiene un patron de CSS que le da la apariencia de tabla\n * por lo cual se debe reposicionar segun la fecha de inicio, para hacer\n * calzar los fines de semana\n *\n * @param {Object} config - Configuracion capibara\n * @param {Object} [$elem = null] - Elemento background, si es null, lo crea\n * @return {Object} elemento Dom Background\n */\n createBackground(config, $elem = null) {\n let {\n height,\n width,\n dayWidth\n } = _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getTableDimensions(config);\n let start = new Date(config.timeline.start);\n let end = new Date(config.timeline.end);\n end.setTime(end.getTime() + _util_dateUtils__WEBPACK_IMPORTED_MODULE_2__[\"default\"].dayInMilliseconds); // add 24 hours\n\n let dCorrected = new Date(start.valueOf() + start.getTimezoneOffset() * 60000);\n let weekDay = dCorrected.getDay();\n let diffWeekDays = (weekDay - 1) * dayWidth * -1;\n $elem = $elem || _util_domUtils__WEBPACK_IMPORTED_MODULE_0__[\"default\"].createElement(\"div\", {\n className: \"background-grid\"\n });\n $elem.style[\"background-position\"] = diffWeekDays + \"px 0, 0 0, \" + diffWeekDays + \"px 0\";\n $elem.style.width = width + \"px\";\n $elem.style.height = height + 1 + \"px\";\n return $elem;\n },\n\n /**\n * Crea Plot Container Vertical\n * Los plots son elementos que agregan secciones de fondo en la planilla\n *\n * @param {Object} config - Configuracion capibara\n * @return {Object} Elemento Dom plotVerticalContainer\n */\n createPlotVerticalContainer(config) {\n let $elem = _util_domUtils__WEBPACK_IMPORTED_MODULE_0__[\"default\"].createElement(\"div\", {\n className: \"plot-vertical-container\"\n });\n return this.redrawPlotVerticalContainer(config, $elem);\n },\n\n createPlotHorizontalContainer(config) {\n let $elem = _util_domUtils__WEBPACK_IMPORTED_MODULE_0__[\"default\"].createElement(\"div\", {\n className: \"plot-horizontal-container\"\n });\n return this.redrawPlotHorizontalContainer(config, $elem);\n },\n\n /**\n * Recrea plotVerticalContainer, usando elemento existente\n * usa un elemento existente para usar la funcion para redibujar el elemento\n *\n * Los Plots se insertan como divs, con posicion especificada,\n * con ancho de dia\n *\n * @param {Object} config - Configuracion capibara\n * @param {Object} $elem - Elemento Dom donde crea plotVerticalContainer\n * @return {Object} Elemento Dom plotVerticalContainer\n */\n redrawPlotVerticalContainer(config, $elem) {\n $elem.innerHTML = \"\";\n\n if (config.timeline.plots && config.timeline.plots.vertical) {\n let {\n height,\n dayWidth\n } = _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getTableDimensions(config);\n config.timeline.plots.vertical.forEach(p => {\n let diffDays = Math.floor(_util_dateUtils__WEBPACK_IMPORTED_MODULE_2__[\"default\"].diffDays(config.timeline.start, p.date));\n let left = diffDays * dayWidth;\n let plot = _util_domUtils__WEBPACK_IMPORTED_MODULE_0__[\"default\"].createElement(\"div\", {\n classNames: [\"plot-vertical\", p.className || \"\"],\n style: {\n \"margin-left\": left + \"px\",\n height: height + \"px\"\n }\n });\n $elem.appendChild(plot);\n });\n }\n\n return $elem;\n },\n\n redrawPlotHorizontalContainer(config, $elem) {\n $elem.innerHTML = \"\";\n\n if (config.timeline.plots && config.timeline.plots.horizontal) {\n let {\n width,\n itemHeight\n } = _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getTableDimensions(config);\n config.timeline.plots.horizontal.forEach(p => {\n let item = _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getItemById(config, p.idNode, p.typeNode);\n let topPosition = _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getPositionByItem(config, item, \"parent\");\n let plot = _util_domUtils__WEBPACK_IMPORTED_MODULE_0__[\"default\"].createElement(\"div\", {\n classNames: [\"plot-horizontal\", p.className || \"\"],\n style: {\n \"margin-top\": topPosition * itemHeight + \"px\",\n width: width + \"px\"\n }\n });\n $elem.appendChild(plot);\n });\n }\n\n return $elem;\n },\n\n /**\n * Crea Corner Izquierdo\n * Se usa para :\n * - titulos relacionados con los datos del sidebar izquierdo\n * - titulos para inputs de header, absolute a la derecha\n * - boton para mostrar/ocultar sidebar izquierdo\n * - promedios\n *\n * @param {Object} config - Configuracion capibara\n * @return {Object} Elemento Dom Corner\n */\n createCorner(config, tab = null) {\n let $elem = _util_domUtils__WEBPACK_IMPORTED_MODULE_0__[\"default\"].createElement(\"div\", {\n className: \"corner\"\n });\n return this.redrawCorner($elem, config, tab);\n },\n\n redrawCorner($elem, config, tab = null) {\n let labelsInitialCorner = config.timeline.nav.left.initial.vars.filter(v => v.onlyTab == undefined || v.onlyTab && tab && v.onlyTab == tab.key).map(d => `<span class=\"item-col\">${d.label}</span>`).join(\"\");\n let labelsExtendCorner = config.timeline.nav.left.extend.vars.filter(v => v.onlyTab == undefined || v.onlyTab && tab && v.onlyTab == tab.key).map(d => `<span class=\"item-col\">${d.label}</span>`).join(\"\");\n let labelsHeaderExtend = config.timeline.header.extend.data.map(d => {\n if (d.isHidden) return \"\";\n let avg = \"\";\n let tooltip = \"\";\n let className = \"\";\n let isAccent = d.isAccent;\n\n if (d.average) {\n avg = ` <span class=\"average \"> ( <span> <span class=\"symbol\">x̄</span> ${d.average} </span>) </span> `;\n tooltip = `cap-tooltip=\"Promedio ${d.label} : ${d.average} ${d.suffix || \"\"}\"`;\n }\n\n if (d.color) {\n if (isAccent) {\n className = d.color ? \"c-\" + d.color + \"--background\" : \"\";\n } else {\n className = d.color ? \"c-\" + d.color + \"--text \" : \"\";\n }\n }\n\n return `<div class=\"input-title-container ${isAccent ? \"input-title--accent\" : \"\"} ${d.isPersistent ? \"persistent\" : \"\"}\">\n <span ${tooltip} class=\"input-title ${className}\">\n ${avg}\n ${d.label}\n </span>\n\n </div>`;\n }).join(\"\");\n let toggleSidebarBtnString = `\n <button toggle-sidebar class=\"cap-btn-icon cap-btn-icon-raised cap-btn-toggle-sidebar \">\n ${_util_icons__WEBPACK_IMPORTED_MODULE_3__[\"default\"].chevronRight}\n </button> `;\n\n if (config.timeline.nav.left.hideToggleSidebarButton) {\n toggleSidebarBtnString = \"\";\n }\n\n let template = `<div>\n\n ${toggleSidebarBtnString}\n <div class=\"corner-title\">\n <span class=\"bottom-text\">\n ${config.timeline.corner.left.label}\n </span>\n </div>\n\n <div class=\"initial-corner\">\n <div class=\"initial-corner-title\">\n <span class=\"bottom-container hide\">\n ${config.timeline.corner.initial.label}\n </span>\n\n <div class=\"bottom-container\">\n ${labelsInitialCorner}\n </div>\n\n </div>\n </div>\n\n\n <div class=\"extend-corner\">\n <div class=\"ex-corner-title\">\n <span class=\"bottom-container hide\">\n ${config.timeline.corner.extend.label}\n </span>\n\n <div class=\"bottom-container\">\n ${labelsExtendCorner}\n </div>\n\n </div>\n </div>\n\n\n <div class=\"cap-btn-nav-corner\">\n <div class=\"input-titles\">\n ${labelsHeaderExtend}\n </div>\n </div>\n\n <div class=\"progress-bar progress-bar-left hide-progress\"></div>\n\n </div>`;\n let r = _util_domUtils__WEBPACK_IMPORTED_MODULE_0__[\"default\"].createElementFromHTML(template);\n $elem.innerHTML = \"\";\n $elem.append(r);\n let toggleSidebar = $elem.querySelector(\"[toggle-sidebar]\");\n\n if (toggleSidebar) {\n toggleSidebar.addEventListener(\"click\", e => {\n r.dispatchEvent(new CustomEvent(\"toggleSidebar\", {\n bubbles: true,\n cancelable: false\n }));\n });\n }\n\n return $elem;\n },\n\n /**\n * Crea Corner Derecho\n * Se usa para :\n * - titulos relacionados con los datos del sidebar Derecho\n *\n * @param {Object} config - Configuracion capibara\n * @return {Object} Elemento Dom corner\n */\n createCornerRight(config, tab = null) {\n let $elem = _util_domUtils__WEBPACK_IMPORTED_MODULE_0__[\"default\"].createElement(\"div\", {\n classNames: [\"corner\", \"right\"]\n });\n return this.redrawCornerRight($elem, config, tab);\n },\n\n redrawCornerRight($el, config, tab = null) {\n let label = \"\";\n\n if (config.timeline.corner.right.label) {\n ` <span>\n ${config.timeline.corner.right.label}\n </span>`;\n }\n\n let str = `\n <div class=\"corner-title\">\n ${label}\n <div class=\"btn-container\"></div>\n </div>\n <div class=\"progress-bar progress-bar-right hide-progress\"></div>\n `;\n $el.innerHTML = str.trim();\n let $btnContainer = $el.querySelector(\".btn-container\");\n\n if (config.timeline.corner.right.buttons) {\n config.timeline.corner.right.buttons.forEach(btn => {\n let isEnabled = btn.getIsEnabled ? btn.getIsEnabled() : true;\n\n if (isEnabled) {\n let $btn = _util_domUtils__WEBPACK_IMPORTED_MODULE_0__[\"default\"].createElementFromHTML(`\n <button class=\"corner-btn cap-btn-raised\">\n ${btn.label || \"\"}\n </button> `);\n\n if (btn.onClick) {\n $btn.addEventListener(\"click\", btn.onClick);\n }\n\n $btnContainer.appendChild($btn);\n }\n });\n }\n\n if (config.timeline.corner.right.inputs) {\n config.timeline.corner.right.inputs.forEach(input => {\n let $input = this.createCornerRightInput({\n inputConfig: input\n });\n $btnContainer.appendChild($btn);\n });\n }\n\n return $el;\n },\n\n createCornerRightInput({\n inputConfig,\n dataDay = null,\n daySelected = null\n }) {\n let r = null;\n\n switch (inputConfig.type) {\n case \"autocomplete-crud\":\n r = this.createCornerRightInputAutocompleteCrud({\n inputConfig,\n dataDay,\n daySelected\n });\n break;\n }\n\n return r;\n },\n\n createCornerRightInputAutocompleteCrud({\n inputConfig,\n dataDay,\n daySelected\n }) {\n let elem = \"test\";\n return elem;\n },\n\n /**\n * Crea Header Top\n * Se usa para :\n * - Manejo de tabs\n * - Botones de navegación y selección de fecha\n * - Boton toggle Dark mode\n * - Boton toggle Header extended\n *\n * @param {Object} config - Configuracion capibara\n * @return {Object} Elemento Dom\n */\n createHeaderTop(config, tabSelected = null) {\n return this.redrawHeaderTop(config, tabSelected, _util_domUtils__WEBPACK_IMPORTED_MODULE_0__[\"default\"].createElement(\"div\"));\n },\n\n redrawHeaderTop(config, tabSelected = null, $elem) {\n let str = `\n <div class=\"header-top\">`;\n\n if (config.timeline.tabs) {\n let showTabs = true;\n\n if (config.timeline.tabs.filter(t => !t.isHidden).length == 0) {\n showTabs = false;\n }\n\n if (showTabs) {\n str += ` <div class=\"tab-select-container c-d-desktop-none c-d-mobile-flex\">\n <select class=\"tabs-select\" >`;\n config.timeline.tabs.forEach(tab => {\n if (!tab.isHidden) {\n str += ` <option ${tab == tabSelected ? 'selected=\"selected\"' : \"\"} value=\"${tab.id}\"> ${tab.label} </option>`;\n }\n });\n str += `</select> </div>`;\n str += ` <div class=\"tabs-container c-d-desktop-flex c-d-mobile-none\">`;\n config.timeline.tabs.forEach(tab => {\n if (!tab.isHidden) {\n str += ` <button\n class=\"tab ${tab.disabled ? \"disabled\" : \"\"} ${tab == tabSelected ? \"active\" : \"\"} ${tab.color}\"\n color=\"${tab.color}\"\n input-key=\"${tab.id}\"\n ${tab.tooltip ? 'cap-tooltip=\"' + tab.tooltip + '\"' : \"\"} >\n <span>${tab.label}</span>\n ${tab.icon || \"\"}\n </button>\n `;\n }\n });\n str += `</div>`;\n }\n }\n\n if (tabSelected) {\n if (tabSelected.legends) {\n str += ` \n <button toggle-legends class=\"cap-btn-icon cap-btn-icon-raised \">\n ${_util_icons__WEBPACK_IMPORTED_MODULE_3__[\"default\"].toggleLegends}\n </button> \n\n <div class=\"legends-container force-mobile-style hide\"> `;\n tabSelected.legends.forEach(legend => {\n let colorClass = \"\";\n let colorBg = \"\";\n\n if (_util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].isHexColor(legend.color)) {\n colorBg = \"background:\" + legend.color;\n } else {\n colorClass = legend.color ? legend.color + \"--background\" : \"\";\n }\n\n str += ` <div\n class=\"legend ${legend.active ? \"active\" : \"\"}\"\n input-key=\"${legend.key}\"\n ${legend.tooltip ? `cap-tooltip=\"${legend.tooltip}\"` : \"\"} >\n <div class=\"icon-legend ${colorClass} ${legend.shape}\" style=\"${colorBg}\"></div>\n <span>${legend.label}</span>\n </div>`;\n });\n str += `</div>`;\n }\n }\n\n str += `\n\n <div class=\"spacer\"></div>\n\n\n\n <button cap-btn-prev class=\"cap-btn-icon cap-btn-icon-raised\">\n ${_util_icons__WEBPACK_IMPORTED_MODULE_3__[\"default\"].arrowLeft}\n ${_util_icons__WEBPACK_IMPORTED_MODULE_3__[\"default\"].loadingIcon} \n </button>\n\n\n <button cap-btn-calendar class=\"cap-btn-icon cap-btn-icon-raised\">\n ${_util_icons__WEBPACK_IMPORTED_MODULE_3__[\"default\"].calendar}\n ${_util_icons__WEBPACK_IMPORTED_MODULE_3__[\"default\"].loadingIcon}\n </button>\n\n <button cap-btn-next class=\"cap-btn-icon cap-btn-icon-raised\">\n ${_util_icons__WEBPACK_IMPORTED_MODULE_3__[\"default\"].arrowRight}\n ${_util_icons__WEBPACK_IMPORTED_MODULE_3__[\"default\"].loadingIcon}\n </button>\n\n <div class=\"spacer\"></div>\n\n <button toggle-dark class=\"cap-btn-icon cap-btn-header c-d-mobile-none ${config.timeline.withDarkToggle == false ? \"hide\" : \"\"}\">\n ${_util_icons__WEBPACK_IMPORTED_MODULE_3__[\"default\"].dark}\n ${_util_icons__WEBPACK_IMPORTED_MODULE_3__[\"default\"].light}\n </button>`;\n\n if (config.timeline.header.extend.enabled !== false) {\n str += `<button toggle-header class=\"cap-btn-icon cap-btn-icon-raised\">\n ${_util_icons__WEBPACK_IMPORTED_MODULE_3__[\"default\"].chevronDown}\n </button>`;\n }\n\n str += ` <div class=\"button-right-container\"></div>\n </div>`;\n /*\n `\n <button toggle-sidebar-right class=\"cap-btn-icon cap-btn-icon-raised\">\n <span>\n <svg style=\"width:24px;height:24px\" viewBox=\"0 0 24 24\">\n <path fill=\"currentColor\" d=\"M15.41,16.58L10.83,12L15.41,7.41L14,6L8,12L14,18L15.41,16.58Z\" />\n </svg>\n </span>\n </button>\n </div>\n `;\n */\n\n let $r = _util_domUtils__WEBPACK_IMPORTED_MODULE_0__[\"default\"].createElementFromHTML(str);\n $elem.replaceWith($r);\n\n if (config.timeline.header.rightButtons) {\n let $buttonContainer = $r.querySelector(\".button-right-container\");\n config.timeline.header.rightButtons.forEach(button => {\n let hasBadge = false;\n\n if (button.hasBadge) {\n hasBadge = button.hasBadge();\n }\n\n let str = `<button class=\"cap-btn-icon cap-btn-icon-raised ${hasBadge ? \"cap-btn-has-badge\" : \"\"}\">\n <span>\n <svg style=\"width:24px;height:24px\" viewBox=\"0 0 24 24\">\n <path fill=\"currentColor\" d=\"${button.icon}\" />\n </svg>\n </span>\n </button>`;\n let $button = _util_domUtils__WEBPACK_IMPORTED_MODULE_0__[\"default\"].createElementFromHTML(str);\n $button.addEventListener(\"click\", evt => button.onClick({\n evt\n }));\n $buttonContainer.append($button);\n });\n }\n\n let $toggleDark = $r.querySelector(\"[toggle-dark]\");\n\n if ($toggleDark) {\n $toggleDark.addEventListener(\"click\", e => {\n $r.dispatchEvent(new CustomEvent(\"toggleDark\", {\n bubbles: true,\n cancelable: false\n }));\n });\n }\n\n let $btnCalendar = $r.querySelector(\"[cap-btn-calendar]\");\n\n if ($btnCalendar) {\n $btnCalendar.addEventListener(\"click\", e => {\n let x = e.x;\n let y = e.y;\n $r.dispatchEvent(new CustomEvent(\"clickCalendarIcon\", {\n bubbles: true,\n cancelable: false,\n detail: {\n x,\n y\n }\n }));\n });\n }\n\n let $btnToggleHeader = $r.querySelector(\"[toggle-header]\");\n\n if ($btnToggleHeader) {\n $btnToggleHeader.addEventListener(\"click\", e => {\n $r.dispatchEvent(new CustomEvent(\"toggleHeader\", {\n bubbles: true,\n cancelable: false\n }));\n });\n }\n /*\n $r.querySelector(\"[toggle-sidebar-right]\").addEventListener(\"click\", e => {\n $r.dispatchEvent(new CustomEvent(\"toggleSidebarRight\", {\n bubbles: true,\n cancelable: false,\n }));\n });\n */\n\n\n $r.querySelector(\"[cap-btn-prev]\").addEventListener(\"click\", e => {\n $r.dispatchEvent(new CustomEvent(\"headerPrev\", {\n bubbles: true,\n cancelable: false,\n detail: {\n originalEvt: e\n }\n }));\n });\n $r.querySelector(\"[cap-btn-calendar]\").addEventListener(\"click\", e => {\n $r.dispatchEvent(new CustomEvent(\"headerCalendar\", {\n bubbles: true,\n cancelable: false,\n detail: {\n originalEvt: e\n }\n }));\n });\n $r.querySelector(\"[cap-btn-next]\").addEventListener(\"click\", e => {\n $r.dispatchEvent(new CustomEvent(\"headerNext\", {\n bubbles: true,\n cancelable: false,\n detail: {\n originalEvt: e\n }\n }));\n });\n let $toggleLegendsBtn = $r.querySelector(\"[toggle-legends]\");\n\n if ($toggleLegendsBtn) {\n $toggleLegendsBtn.addEventListener(\"click\", e => {\n let $legendContainer = $r.querySelector(\".legends-container\");\n\n if ($legendContainer) {\n $legendContainer.classList.toggle(\"hide\");\n }\n });\n }\n\n $r.querySelectorAll(\".legend\").forEach($legend => {\n $legend.addEventListener(\"click\", e => {\n let key = e.currentTarget.getAttribute(\"input-key\");\n\n if (key) {\n let legendSelected = tabSelected.legends.find(tab => tab.key === key);\n\n if (legendSelected) {\n $r.dispatchEvent(new CustomEvent(\"selectLegendHeader\", {\n bubbles: true,\n cancelable: false,\n detail: {\n legend: legendSelected,\n $legend\n }\n }));\n }\n }\n });\n });\n $r.querySelectorAll(\".tab:not(.disabled)\").forEach($tab => {\n $tab.addEventListener(\"click\", e => {\n let key = e.currentTarget.getAttribute(\"input-key\");\n\n if (key) {\n let tabSelected = config.timeline.tabs.find(tab => tab.id == key);\n\n if (tabSelected) {\n $r.dispatchEvent(new CustomEvent(\"selectTabHeader\", {\n bubbles: true,\n cancelable: false,\n detail: {\n tab: tabSelected\n }\n }));\n }\n }\n });\n });\n $r.querySelectorAll(\".tabs-select:not(.disabled)\").forEach($tab => {\n $tab.addEventListener(\"change\", e => {\n let key = parseFloat(e.currentTarget.value);\n\n if (key) {\n let tabSelected = config.timeline.tabs.find(tab => tab.id == key);\n\n if (tabSelected) {\n $r.dispatchEvent(new CustomEvent(\"selectTabHeader\", {\n bubbles: true,\n cancelable: false,\n detail: {\n tab: tabSelected\n }\n }));\n }\n }\n });\n });\n return $r;\n },\n\n /**\n * Crea Header\n * Se usa para :\n * - Mostrar fechas en header\n *\n * @param {Object} config - Configuracion capibara\n * @return {Object} Elemento Dom\n */\n createHeader(config) {\n let $elem = _util_domUtils__WEBPACK_IMPORTED_MODULE_0__[\"default\"].createElement(\"header\");\n return this.redrawHeader(config, $elem);\n },\n\n /**\n * Recrea Header, usado para redibujar\n * utiliza $elem como elemento dom donde recrearlo\n *\n * @param {Object} config - Configuracion capibara\n * @param {Object} $elem - Elemento Dom donde crea Header\n * @return {Object} Elemento Dom\n */\n redrawHeader(config, $elem) {\n let datesTree = _util_dateUtils__WEBPACK_IMPORTED_MODULE_2__[\"default\"].getDateTreeRange(new Date(config.timeline.start), new Date(config.timeline.end));\n let str = `<div class=\"header-container\"> `;\n Object.keys(datesTree).forEach(keyY => {\n let year = datesTree[keyY];\n str += `<div class=\"agno-calendario\">\n <span class=\"agno hide\">${keyY}</span>\n <div class=\"meses\">`;\n Object.keys(year).forEach(keyM => {\n let month = datesTree[keyY][keyM];\n str += ` <div class=\"mes-calendario\">\n <div class=\"mes ${Object.keys(month).length < 4 ? \"mes-reduced mes-reduced-\" + Object.keys(month).length : \"\"}\">\n <div class=\"mes-label\">\n ${_util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getMonthByPosition(keyM)} ${keyY}\n </div>\n </div>\n <div class=\"dias\">`;\n Object.keys(month).forEach(keyD => {\n let day = datesTree[keyY][keyM][keyD];\n let isWeekend = day.isWeekend;\n let isToday = day.isToday;\n let date = _util_dateUtils__WEBPACK_IMPORTED_MODULE_2__[\"default\"].formatDate(day.Date);\n str += `<div class=\"dia-calendario ${isToday ? \"today\" : \"\"} ${isWeekend ? \"weekend\" : \"\"} ${config.timeline.dateSelectable ? \"is-clickeable\" : \"\"}\" date=\"${date}\">${keyD}</div>`;\n });\n str += `</div></div>`;\n });\n str += `</div> </div>`;\n });\n str += `</div>`;\n $elem.innerHTML = \"\";\n $elem.append(_util_domUtils__WEBPACK_IMPORTED_MODULE_0__[\"default\"].createElementFromHTML(str));\n\n if (config.timeline.dateSelectable) {\n $elem.querySelectorAll(\".dia-calendario[date]\").forEach($dia => {\n $dia.addEventListener(\"contextmenu\", evt => {\n $elem.dispatchEvent(new CustomEvent(\"contextMenuDate\", {\n bubbles: true,\n cancelable: false,\n detail: {\n $elem: $dia,\n date: $dia.getAttribute(\"date\"),\n clientX: evt.clientX,\n clientY: evt.clientY\n }\n }));\n });\n $dia.addEventListener(\"click\", evt => {\n $elem.dispatchEvent(new CustomEvent(\"clickDate\", {\n bubbles: true,\n cancelable: false,\n detail: {\n $elem: $dia,\n date: $dia.getAttribute(\"date\")\n }\n }));\n });\n });\n }\n\n return $elem;\n },\n\n /**\n * Crea Header extended\n * Se usa para :\n * -Mostrar inputs y datos para fechas en header\n *\n * @param {Object} config - Configuracion capibara\n * @return {Object} Elemento Dom headerExtended\n */\n createHeaderExtended(config) {\n if (config.timeline.header.extend.enabled == false) return null;\n let dates = _util_dateUtils__WEBPACK_IMPORTED_MODULE_2__[\"default\"].getDateRange(new Date(config.timeline.start), new Date(config.timeline.end));\n let str = `<div class=\"header-container-extended\">`;\n config.timeline.header.extend.data.forEach((d, d_index) => {\n if (d.isHidden) return \"\";\n let isPersistent = d.isPersistent;\n str += `<div class=\"input-list ${isPersistent ? \"persistent\" : \"\"}\">`;\n str += dates.map(date => {\n let value = \"\";\n let isFuture = _util_dateUtils__WEBPACK_IMPORTED_MODULE_2__[\"default\"].isFuture(date);\n let isToday = _util_dateUtils__WEBPACK_IMPORTED_MODULE_2__[\"default\"].isToday(date);\n\n if (d.data) {\n let dataFounded = d.data.find(dataInput => {\n return _util_dateUtils__WEBPACK_IMPORTED_MODULE_2__[\"default\"].isSameDate(new Date(dataInput.date), date);\n });\n\n if (dataFounded) {\n value = dataFounded.value || \"\";\n }\n }\n\n if (d.editable === false || isFuture && d.editableFuture == false || isToday && d.editableToday == false) {\n return `<div>\n <span date=\"${date}\" \n index=\"${d_index}\" \n class=\"${date.varName} ${d.color ? \"c-\" + d.color + \"--text\" : \"\"}\" > \n ${value} \n </span>\n </div>`;\n }\n\n let isDisabled = false;\n\n if (config.timeline.editable === false) {\n isDisabled = true;\n }\n\n return `<div class=\"dia-input\">\n <input \n date=\"${date}\" \n index=\"${d_index}\" \n class=\"header-input \n ${date.varName} ${d.color ? \"c-\" + d.color + \"--text\" : \"\"}\" \n type=\"number\"\n ${isDisabled ? \"disabled\" : \"\"} \n value=\"${value}\">\n </div>`;\n }).join(\"\");\n str += `</div>`;\n });\n str += `</div>`;\n let r = _util_domUtils__WEBPACK_IMPORTED_MODULE_0__[\"default\"].createElementFromHTML(str);\n r.querySelectorAll(\"input.header-input\").forEach(input => {\n input.addEventListener(\"input\", e => {\n let date = e.currentTarget.getAttribute(\"date\");\n let index = e.currentTarget.getAttribute(\"index\");\n let value = e.currentTarget.value;\n let typeData = config.timeline.header.extend.data[index]; //refresh config value\n\n let data = typeData.data.find(d => _util_dateUtils__WEBPACK_IMPORTED_MODULE_2__[\"default\"].isSameDate(new Date(d.date), new Date(date)));\n data.value = value;\n r.dispatchEvent(new CustomEvent(\"changeInputHeader\", {\n bubbles: true,\n cancelable: false,\n detail: {\n date: date,\n typeData: typeData,\n value: value\n }\n }));\n });\n });\n return r;\n },\n\n /**\n * Crear Sidebar Izquierdo\n * - Maneja items como arbol de 2 niveles (parent, children)\n * - El sidebar se divide en navList - InitialNav - extendedNav - BtnNav\n * - Se agrega itemDetail, para detalles de items\n *\n *\n * TODO: para evitar incrustar las ids en los inputs, se deben crear\n * los nodos uno por uno como elemento DOM, y agregarles los eventos directamente\n * ahora se hace seleccionando todos los inputs con querySelectorAll\n *\n * @param {Object} config - Configuracion capibara\n * @return {Object} Elemento Dom Sidebar Izquierdo\n */\n createNavLeft(config, tab = null) {\n let $elem = _util_domUtils__WEBPACK_IMPORTED_MODULE_0__[\"default\"].createElement(\"nav\", {\n className: \"left\"\n });\n return this.redrawNavLeft($elem, config, tab);\n },\n\n /**\n * Recrea Sidebar izquierdo, usado para redibujar\n * Utiliza $elem como elemento dom donde recrearlo\n *\n *\n * @param {Object} $elem - Elemento Dom donde crea el sidebar izquierdo\n * @param {Object} config - Configuracion capibara\n * @return {Object} Elemento Dom navLeft\n */\n redrawNavLeft($elem, config, tab = null) {\n let navList = \"\";\n let initialNavList = \"\";\n let exNavList = \"\";\n let btnNavList = \"\";\n let isDisabled = false;\n\n if (config.timeline.editable === false) {\n isDisabled = true;\n }\n\n config.data.forEach(d => {\n if (d.isHidden) return;\n navList += `\n <div class=\"nav-item\">\n\n\n <div class=\"nav-item-container parent\">`;\n\n if (d.children) {\n navList += `<button class=\"tree-icon ${d.isClosed ? \"\" : \"cap-rotate\"}\" item-id=\"${d.id || -1}\" type-node=\"${d.type || \"\"}\" >\n ${_util_icons__WEBPACK_IMPORTED_MODULE_3__[\"default\"].chevronDown}\n </button>`;\n }\n\n navList += `\n <div class=\"item-title truncate full-width ${d.clickeable ? \"clickeable\" : \"\"}\n ${d.navOver ? \"hoverable\" : \"\"} \" item-id=\"${d.id || -1}\" type-node=\"${d.type || \"\"}\" >\n ${d.label}\n </div>\n </div>`;\n\n if (d.children) {\n navList += `\n <div class=\"children-items ${d.isClosed ? \"hide\" : \"\"} \" child-list=\"${d.id || -1}\">`;\n d.children.forEach(c => {\n if (c.isHidden) return;\n navList += `\n <div class=\"child-nav-item\">\n <div class=\"nav-item-container\">\n `;\n /*\n <span class=\"nav-item-icon\">\n <svg style=\"width:24px;height:24px\" viewBox=\"0 0 24 24\">\n <path fill=\"currentColor\" d=\"M19,15L13,21L11.58,19.58L15.17,16H4V4H6V14H15.17L11.58,10.42L13,9L19,15Z\" />\n </svg>\n </span>\n */\n\n navList += `\n ${c.light ? '<span class=\"light ' + (c.light ? c.light + \"-light\" : \"\") + '\"></span>' : \"\"}\n\n <div class=\"item-title ${c.clickeable ? \"clickeable\" : \"\"}\n ${c.navOver ? \"hoverable\" : \"\"}\" item-id=\"${c.id || -1}\" type-node=\"${c.type || \"\"}\">\n <div class=\"truncate\">\n ${c.label}\n </div>\n </div>\n </div>\n </div>`;\n });\n navList += `\n </div>`;\n }\n\n navList += `</div>`; //initial\n\n initialNavList += `<div class=\"initial-nav-item parent\">`;\n\n if (d.withNav) {\n config.timeline.nav.left.initial.vars.forEach(v => {\n let value = _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getVarByPath(d.values, v.varName);\n\n if (v.round && !isNaN(value)) {\n value = _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].round(value, v.round);\n }\n\n if (v.input) {\n switch (v.input) {\n case \"hour\":\n value = value.split(\":\");\n let hhValue = value[0];\n let mmValue = value[1];\n initialNavList += `\n <div class=\"item-col has-input\">\n <div class=\"hour-input\">\n <input type=\"number\"\n input-type=\"time\"\n max=\"23\"\n min=\"00\"\n input-key=\"${v.key || \"\"}\"\n item-id=\"${d.id || -1}\"\n type-node=\"${d.type || \"\"}\"\n value=\"${hhValue}\"\n ${isDisabled ? \"disabled\" : \"\"}\n class=\"hh\">\n <span>:</span>\n <input type=\"number\"\n input-type=\"time\"\n max=\"59\"\n min=\"00\"\n input-key=\"${v.key || \"\"}\"\n item-id=\"${d.id || -1}\"\n type-node=\"${d.type || \"\"}\"\n value=\"${mmValue}\"\n ${isDisabled ? \"disabled\" : \"\"}\n class=\"mm\">\n </div>\n </div>`;\n break;\n\n case \"text\":\n case \"number\":\n default:\n initialNavList += `\n <div class=\"item-col has-input\">\n <input \n type=\"${v.input || \"text\"}\"\n input-type=\"${v.input || \"text\"}\"\n input-key=\"${v.key || \"\"}\"\n item-id=\"${d.id || -1}\"\n type-node=\"${d.type || \"\"}\"\n ${isDisabled ? \"disabled\" : \"\"}\n value=\"${value}\"/>\n </div>`;\n }\n } else {\n initialNavList += `\n <div class=\"item-col\">\n ${value}\n </div>`;\n }\n });\n }\n\n initialNavList += `\n </div>`;\n\n if (d.children) {\n d.children.forEach(c => {\n if (c.isHidden) return;\n initialNavList += `<div class=\"child-initial-nav-item ${d.isClosed ? \"hide\" : \"\"}\" child=\"${d.id || -1}\">`;\n\n if (c.withNav !== false) {\n config.timeline.nav.left.initial.vars.forEach(v => {\n if (v.onlyTab && tab && v.onlyTab !== tab.key) return;\n let value = _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getVarByPath(c.values, v.varName);\n\n if (v.round && !isNaN(value)) {\n value = _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].round(value, v.round);\n }\n\n if (v.input) {\n switch (v.input) {\n case \"hour\":\n value = value.split(\":\");\n let hhValue = value[0];\n let mmValue = value[1];\n initialNavList += `\n <div class=\"item-col has-input\">\n <div class=\"hour-input\">\n <input type=\"number\"\n input-type=\"time\"\n max=\"23\"\n min=\"00\"\n input-key=\"${v.key || \"\"}\"\n item-id=\"${c.id || -1}\"\n type-node=\"${c.type || \"\"}\"\n value=\"${hhValue}\"\n ${isDisabled ? \"disabled\" : \"\"}\n class=\"hh\">\n <span>:</span>\n <input type=\"number\"\n input-type=\"time\"\n max=\"59\"\n min=\"00\"\n input-key=\"${v.key || \"\"}\"\n item-id=\"${c.id || -1}\"\n type-node=\"${c.type || \"\"}\"\n value=\"${mmValue}\"\n ${isDisabled ? \"disabled\" : \"\"}\n class=\"mm\">\n </div>\n </div>`;\n break;\n\n case \"text\":\n case \"number\":\n default:\n initialNavList += `\n <div class=\"item-col has-input\">\n <input\n type=\"${v.input || \"text\"}\"\n input-type=\"${v.input || \"text\"}\"\n input-key=\"${v.key || \"\"}\"\n item-id=\"${c.id || -1}\"\n type-node=\"${c.type || \"\"}\"\n ${isDisabled ? \"disabled\" : \"\"}\n value=\"${value}\"/>\n </div>`;\n }\n } else {\n initialNavList += `\n <div class=\"item-col\">\n ${value}\n </div>`;\n }\n });\n }\n\n initialNavList += `\n </div>`;\n });\n } //Ext\n\n\n exNavList += `<div class=\"ex-nav-item parent\">`;\n\n if (d.withExNav) {\n config.timeline.nav.left.extend.vars.forEach(v => {\n let value = _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getVarByPath(d.values, v.varName);\n\n if (v.round && !isNaN(value)) {\n value = _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].round(value, v.round);\n }\n\n if (v.input) {\n switch (v.input) {\n case \"hour\":\n value = value.split(\":\");\n let hhValue = value[0];\n let mmValue = value[1];\n exNavList += `\n <div class=\"item-col has-input\">\n <div class=\"hour-input\">\n <input type=\"number\"\n input-type=\"time\"\n max=\"23\"\n min=\"0\"\n input-key=\"${v.key || \"\"}\"\n item-id=\"${d.id || -1}\"\n type-node=\"${d.type || \"\"}\"\n value=\"${hhValue}\"\n ${isDisabled ? \"disabled\" : \"\"}\n class=\"hh\">\n <span>:</span>\n <input type=\"number\"\n input-type=\"time\"\n max=\"59\"\n min=\"0\"\n input-key=\"${v.key || \"\"}\"\n item-id=\"${d.id || -1}\"\n type-node=\"${d.type || \"\"}\"\n value=\"${mmValue}\"\n ${isDisabled ? \"disabled\" : \"\"}\n class=\"mm\">\n </div>\n </div>`;\n break;\n\n case \"text\":\n case \"number\":\n default:\n exNavList += `\n <div class=\"item-col has-input\">\n <input\n type=\"${v.input || \"text\"}\"\n input-type=\"${v.input || \"text\"}\"\n input-key=\"${v.key || \"\"}\"\n item-id=\"${d.id || -1}\"\n type-node=\"${d.type || \"\"}\"\n ${isDisabled ? \"disabled\" : \"\"}\n value=\"${value}\"/>\n </div>`;\n }\n } else {\n exNavList += `\n <div class=\"item-col\">\n ${value}\n </div>`;\n }\n });\n }\n\n exNavList += `\n </div>`;\n\n if (d.children) {\n d.children.forEach(c => {\n if (c.isHidden) return;\n exNavList += `<div class=\"child-ex-nav-item ${d.isClosed ? \"hide\" : \"\"}\" child=\"${d.id || -1}\">`;\n\n if (c.withNav !== false) {\n config.timeline.nav.left.extend.vars.forEach(v => {\n if (v.onlyTab && tab && v.onlyTab !== tab.key) return;\n let value = _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getVarByPath(c.values, v.varName);\n\n if (v.round && !isNaN(value)) {\n value = _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].round(value, v.round);\n }\n\n if (v.input) {\n switch (v.input) {\n case \"hour\":\n value = value ? value.split(\":\") : [0, 0];\n let hhValue = value[0];\n let mmValue = value[1];\n exNavList += `\n <div class=\"item-col has-input\">\n <div class=\"hour-input\">\n <input type=\"number\"\n input-type=\"time\"\n max=\"23\"\n min=\"0\"\n input-key=\"${v.key || \"\"}\"\n item-id=\"${c.id || -1}\"\n type-node=\"${c.type || \"\"}\"\n value=\"${hhValue}\"\n ${isDisabled ? \"disabled\" : \"\"}\n class=\"hh\">\n <span>:</span>\n <input type=\"number\"\n input-type=\"time\"\n max=\"59\"\n min=\"0\"\n input-key=\"${v.key || \"\"}\"\n item-id=\"${c.id || -1}\"\n type-node=\"${c.type || \"\"}\"\n value=\"${mmValue}\"\n ${isDisabled ? \"disabled\" : \"\"}\n class=\"mm\">\n </div>\n </div>`;\n break;\n\n case \"text\":\n case \"number\":\n default:\n exNavList += `\n <div class=\"item-col has-input\">\n <input \n type=\"${v.input || \"text\"}\"\n input-type=\"${v.input || \"text\"}\"\n input-key=\"${v.key || \"\"}\"\n item-id=\"${c.id || -1}\"\n type-node=\"${c.type || \"\"}\"\n ${isDisabled ? \"disabled\" : \"\"}\n value=\"${value}\"/>\n </div>`;\n }\n } else {\n exNavList += `\n <div class=\"item-col\">\n ${value}\n </div>`;\n }\n });\n }\n\n exNavList += `\n </div>`;\n });\n } //buttons\n\n\n btnNavList += `<div class=\"cap-btn-nav-item parent\">\n <div class=\"cap-btn-nav-item-content\">`;\n\n if (config.timeline.nav.left.buttons && config.timeline.nav.left.buttons.vars) {\n config.timeline.nav.left.buttons.vars.forEach(btn => {\n if (d.withBtnNav) {\n let btnContent = \"\";\n let className = btn.className || \"\";\n\n if (btn.icon) {\n btnContent = btn.icon ? btn.icon : \"\";\n }\n\n if (btn.iconFormatter) {\n btnContent = btn.iconFormatter ? btn.iconFormatter(d, btn) : \"\";\n }\n\n if (btn.shape) {\n className += \" cap-btn-\" + btn.shape;\n btnContent += `<span> ${btn.formatter ? btn.formatter(d, btn) : \"\"} </span> `;\n }\n\n if (btn.btnClassNameFormatter) {\n let newClassName = btn.btnClassNameFormatter(d, btn);\n\n if (newClassName) {\n className += \" \" + newClassName;\n }\n }\n\n btnNavList += `\n <button class=\"cap-btn-shape ${className}\"\n input-key=\"${btn.key || \"\"}\"\n item-id=\"${d.id || -1}\"\n ${isDisabled ? \"disabled\" : \"\"}\n type-node=\"${d.type || \"\"}\">\n ${btnContent}\n </button>`;\n }\n });\n }\n\n btnNavList += `\n </div>\n </div>`;\n\n if (d.children) {\n d.children.forEach(c => {\n if (c.isHidden) return; //buttons\n\n btnNavList += `<div class=\"cap-btn-child-nav-item parent ${d.isClosed ? \"hide\" : \"\"}\" child=\"${d.id || -1}\">\n <div class=\"cap-btn-nav-item-content\">`;\n\n if (config.timeline.nav.left.buttons && config.timeline.nav.left.buttons.vars) {\n config.timeline.nav.left.buttons.vars.forEach(btn => {\n if (c.withNav !== false) {\n let btnContent = \"\";\n let className = btn.className || \"\";\n\n if (btn.icon) {\n btnContent = btn.icon ? btn.icon : \"\";\n }\n\n if (btn.iconFormatter) {\n btnContent = btn.iconFormatter ? btn.iconFormatter(c, btn) : \"\";\n }\n\n if (btn.shape) {\n className += \" cap-btn-\" + btn.shape;\n btnContent += `<span> ${btn.formatter ? btn.formatter(c, btn) : \"\"} </span> `;\n }\n\n if (btn.btnClassNameFormatter) {\n let newClassName = btn.btnClassNameFormatter(c, btn);\n\n if (newClassName) {\n className += \" \" + newClassName;\n }\n }\n\n btnNavList += `\n <button class=\"cap-btn-shape ${className}\"\n input-key=\"${btn.key || \"\"}\"\n item-id=\"${c.id || -1}\"\n ${isDisabled ? \"disabled\" : \"\"}\n type-node=\"${c.type || \"\"}\">\n ${btnContent}\n </button>`;\n }\n });\n }\n\n btnNavList += `\n </div>\n </div>`;\n });\n }\n });\n let itemDetail = ` <div class=\"detail-nav-item hide\">\n ${this.getDetailNavItemContent()}\n </div>`;\n let str = `<div class=\"nav-container\">\n ${itemDetail}\n <div class=\"nav-item-list\">\n ${navList}\n </div>\n <div class=\"initial-nav-list\">\n ${initialNavList}\n </div>\n <div class=\"extend-nav-list\">\n ${exNavList}\n </div>\n <div class=\"cap-btn-nav-list\">\n ${btnNavList}\n </div>\n </div>`;\n let navContainer = _util_domUtils__WEBPACK_IMPORTED_MODULE_0__[\"default\"].createElementFromHTML(str);\n $elem.innerHTML = \"\";\n $elem.append(navContainer); //detalle de nav-item\n\n $elem.querySelectorAll(\".item-title.hoverable\").forEach(i => {\n i.addEventListener(\"mouseover\", e => {\n let pos = _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].eventToPositionNavLeft(config, e, $elem);\n let itemId = i.getAttribute(\"item-id\");\n let item = _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getItemById(config, itemId);\n let typeNode = i.getAttribute(\"type-node\");\n i.dispatchEvent(new CustomEvent(\"overNavItem\", {\n bubbles: true,\n cancelable: false,\n detail: {\n originalEvt: e,\n item: item,\n type: typeNode,\n pos: pos\n }\n }));\n });\n }); //oculta detalle de nav-item, al salir del nav-item-list\n\n $elem.querySelectorAll(\".nav-item-list\").forEach(i => {\n i.addEventListener(\"mouseleave\", e => {\n i.dispatchEvent(new CustomEvent(\"leaveNavItem\", {\n bubbles: true,\n cancelable: false\n }));\n });\n }); //oculta detalle de nav-item-list, al salir de nav-item\n\n $elem.querySelectorAll(\".item-title:not(.hoverable)\").forEach(i => {\n i.addEventListener(\"mousemove\", e => {\n i.dispatchEvent(new CustomEvent(\"leaveNavItem\", {\n bubbles: true,\n cancelable: false\n }));\n });\n });\n $elem.querySelectorAll(\".item-title.clickeable\").forEach(i => {\n i.addEventListener(\"click\", e => {\n let itemId = i.getAttribute(\"item-id\");\n let typeNode = i.getAttribute(\"type-node\");\n let value = i.value;\n i.dispatchEvent(new CustomEvent(\"clickNavLeftItem\", {\n bubbles: true,\n cancelable: false,\n detail: {\n itemId: itemId,\n type: typeNode,\n value: value\n }\n }));\n });\n });\n $elem.querySelectorAll(\"input\").forEach(i => {\n i.addEventListener(\"change\", e => {\n let inputType = i.getAttribute(\"input-type\");\n let key = i.getAttribute(\"input-key\");\n let itemId = i.getAttribute(\"item-id\");\n let typeNode = i.getAttribute(\"type-node\");\n let item = _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getItemById(config, itemId);\n let value = i.value;\n\n if (inputType == \"time\") {\n let hh_input = i.parentElement.querySelector(\"input.hh\").value;\n let mm_input = i.parentElement.querySelector(\"input.mm\").value;\n mm_input = mm_input < 10 ? \"0\" + parseFloat(mm_input) : mm_input;\n i.parentElement.querySelector(\"input.mm\").value = mm_input;\n value = hh_input + \":\" + mm_input;\n }\n\n i.dispatchEvent(new CustomEvent(\"saveNavLeftInput\", {\n bubbles: true,\n cancelable: false,\n detail: {\n key: key,\n itemId: itemId,\n item: item,\n type: typeNode,\n value: value,\n tabSelected: tab\n }\n }));\n });\n });\n $elem.querySelectorAll(\"button.cap-btn-shape\").forEach(i => {\n i.addEventListener(\"click\", e => {\n let key = i.getAttribute(\"input-key\");\n let itemId = i.getAttribute(\"item-id\");\n let typeNode = i.getAttribute(\"type-node\");\n i.dispatchEvent(new CustomEvent(\"clickNavLeftButton\", {\n bubbles: true,\n cancelable: false,\n detail: {\n key: key,\n itemId: itemId,\n type: typeNode\n }\n }));\n });\n });\n $elem.querySelectorAll(\"button.tree-icon\").forEach(i => {\n i.addEventListener(\"click\", e => {\n let itemId = i.getAttribute(\"item-id\");\n let typeNode = i.getAttribute(\"type-node\");\n let dataConfig = config.data.find(d => d.id == itemId);\n let $navItem = e.currentTarget.closest(\".nav-item\");\n let $children = $navItem.querySelector(\".children-items\");\n let itemsToHide = e.currentTarget.closest(\"nav.left\").querySelectorAll(\"[child='\" + itemId + \"'], [child-list='\" + itemId + \"']\");\n\n if ($children) {\n if ($children.classList.contains(\"hide\")) {\n e.currentTarget.classList.add(\"cap-rotate\");\n itemsToHide.forEach(i => i.classList.remove(\"hide\"));\n dataConfig.isClosed = false;\n } else {\n e.currentTarget.classList.remove(\"cap-rotate\");\n itemsToHide.forEach(i => i.classList.add(\"hide\"));\n dataConfig.isClosed = true;\n }\n }\n\n i.dispatchEvent(new CustomEvent(\"clickNavLeftTreeIcon\", {\n bubbles: true,\n cancelable: false,\n detail: {\n itemId: itemId,\n type: typeNode\n }\n })); //e.currentTarget.parent\n });\n });\n return $elem;\n },\n\n /**\n * Crea Html como String, para el detalle de items en el Sidebar Izquierdo\n *\n * @param {Object} [item={}] - Configuracion de item\n * @return {String} Html de ventana de detalle\n */\n getDetailNavItemContent(item = {}) {\n if (item.navOver == undefined) item.navOver = {};\n return `\n <div class=\"header-detail\">\n <div class=\"detail-title truncate\">\n ${item.label || \"\"}\n </div>\n <div class=\"detail-subtitle\">\n ${item.navOver.subtitle || \"\"}\n </div>\n <div class=\"header-chip ${item.light ? item.light + \"-light\" : \"\"} ${item.navOver.chip ? \"\" : \"hide\"}\">\n ${item.navOver.chip || \"\"}\n </div>\n </div>\n\n <div class=\"detail-container\">\n ${item.navOver.content || \"\"}\n </div>`;\n },\n\n /**\n * Crea Sidebar Derecho\n * Usado principalmente para formulario de ingreso de datos para los dias\n * seleccionados\n *\n * @param {Object} config - Configuracion capibara\n * @param {Object} tab - Tab de referencia, para la creacion del formulario\n * @return {Object} {element, inputs}, element es el elemento Dom del sidebar,\n * inputs es un array de elementos Dom de cada input creado\n * (no son elementos html de tipo input)\n */\n createNavRight(config, tab = null) {\n var $elem = _util_domUtils__WEBPACK_IMPORTED_MODULE_0__[\"default\"].createElement(\"nav\", {\n className: \"right\"\n });\n return this.redrawNavRight(config, $elem, tab, []);\n },\n\n /**\n * Recrea Sidebar Derecho\n * Utiliza $elem como elemento dom donde recrearlo\n *\n * @param {Object} config - Configuracion capibara\n * @param {Object} $elem - Elemento Dom donde crea el sidebar derecho\n * @param {Object} tab - Tab de referencia, para la creacion del formulario\n * @param {Object} dataDay - datos del dia seleccionando, para autorrelleno de formulario\n * @param {Object} daySelected - datos del dia seleccionado\n * @param {String} daySelected.date - fecha del dia seleccionado\n * @param {Object} daySelected.item - Item de Sidebar relacionado al dia seleccionado\n * @param {Object} daySelected.pos - posicion de dia seleccionado\n * @return {Object} Elemento Dom Sidebar Derecho\n */\n redrawNavRight(config, $elem, selected = null, tab = null, dataDay = null, daySelected = null) {\n let $navRight = $elem; //dom.createElement(\"nav\",{className:\"right\"});\n\n let $divContainer = _util_domUtils__WEBPACK_IMPORTED_MODULE_0__[\"default\"].createElement(\"div\", {\n className: \"nav-input-container\"\n });\n let $inputs = [];\n let checkboxInputs = [];\n let inputsWithReload = [];\n let tabSelected = tab;\n selected = selected || [daySelected];\n\n if (tabSelected && tabSelected.inputs) {\n tabSelected.inputs.forEach(i => {\n if (i.disabled) return;\n let $input = this.createInput(i, dataDay, daySelected, selected);\n\n if ($input) {\n $divContainer.appendChild($input);\n $inputs.push($input);\n\n if (i.type == \"checkbox\") {\n checkboxInputs.push($input);\n }\n\n if (i.reloadOnSelect != null) {\n inputsWithReload.push({\n $input,\n config: i\n });\n }\n }\n });\n } //manejo de eventos para inputs con showIf\n\n\n if (checkboxInputs) {\n checkboxInputs.forEach($c => {\n //obtiene key de checkbox\n let key = $c.getAttribute(\"input-key\");\n let props = tabSelected.inputs.find(i => {\n return i.key == key;\n });\n let isChecked = false;\n\n if (dataDay) {\n isChecked = _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getVarByPath(dataDay, props.varName);\n } //obtiene inputs relacionados desde config para mostrar/ocultar\n\n\n let inputsToHide = tabSelected.inputs.filter(i => {\n return i.showIf && i.showIf == key;\n });\n let inputsToHideKeys = inputsToHide.map(i => i.key); //obtiene inputs del dom, filtrando con inputsToHide\n\n let $inputsHidden = $inputs.filter($i => {\n let inputKey = $i.getAttribute(\"input-key\");\n return inputsToHideKeys.indexOf(inputKey) > -1;\n }); //si hay inputs,\n\n if ($inputsHidden) {\n if (!isChecked) {\n $inputsHidden.forEach($i => {\n $i.classList.add(\"hide\");\n });\n }\n\n $c.addEventListener(\"input\", e => {\n $inputsHidden.forEach($i => {\n let fn = $c.querySelector(\"input[type='checkbox']\").checked ? \"remove\" : \"add\";\n $i.classList[fn](\"hide\");\n });\n });\n }\n });\n }\n\n let saveCancelBtns = this.createNavRightbuttons();\n $divContainer.appendChild(saveCancelBtns);\n $navRight.innerHTML = \"\";\n $navRight.appendChild($divContainer);\n return {\n element: $navRight,\n inputs: $inputs,\n inputsWithReload,\n saveCancelBtns\n };\n },\n\n /**\n * Crea Corner inferior izquierdo, como titulo para footer\n *\n * @param {Object} config - Configuracion capibara\n * @return {Object} Elemento Dom Corner Footer\n */\n createCornerFooter(config) {\n if (config.timeline.footer === undefined || config.timeline.footer.enabled == false) return null;\n let str = \"\";\n\n if (config.timeline.footer) {\n str += `<div class=\"corner-footer\">\n <div class=\"corner-title\">\n <span>\n ${config.timeline.footer.label}\n </span>\n </div>\n </div>`;\n }\n\n return _util_domUtils__WEBPACK_IMPORTED_MODULE_0__[\"default\"].createElementFromHTML(str);\n },\n\n /**\n * Crea Footer para planilla\n * Inicialmente creado para totales\n *\n * @param {Object} config - Configuracion capibara\n * @return {Object} Elemento Dom Corner Footer\n */\n createFooter(config) {\n if (config.timeline.footer === undefined || config.timeline.footer.enabled == false) return null;\n let str = `\n <footer>\n <div class=\"footer-container\">\n `;\n config.timeline.footer.data.forEach(d => {\n str += `\n <div class=\"footer-item\">${d.value}</div>\n `;\n });\n str += `\n </div>\n </footer>\n `;\n return _util_domUtils__WEBPACK_IMPORTED_MODULE_0__[\"default\"].createElementFromHTML(str);\n },\n\n /**\n * Crea Footer para planilla\n * Inicialmente creado para totales\n *\n * @param {Object} config - Configuracion capibara\n * @param {Object[]} selected - array de objetos, de dias seleccionados\n * @return {Object} Elemento Dom Corner Footer\n */\n createSelectBoard(config, selected) {\n let $elem = _util_domUtils__WEBPACK_IMPORTED_MODULE_0__[\"default\"].createElement(\"div\", {\n className: \"select-container\"\n });\n return this.redrawSelectBoard($elem, selected);\n },\n\n /**\n * Crea linea vertical para fecha Actual\n *\n * @param {Object} config - Configuracion capibara\n * @return {Object} Elemento Dom Corner Footer\n */\n createTodayLine(config) {\n return this.redrawTodayLine(config, _util_domUtils__WEBPACK_IMPORTED_MODULE_0__[\"default\"].createElement(\"div\", {\n className: \"today-line\"\n }));\n },\n\n /**\n * Recrea linea vertical para fecha Actual\n * si el elemento $elem no es enviado, se crea un nuevo elemento\n *\n * Si el dia actual no esta dentro del rango de fechas del config,\n * deshabilita la linea con la clase css .disable-line\n *\n * @param {Object} config - Configuracion capibara\n * @param {Object} [$elem=null] - Elemento Dom donde recrea la linea, si es null, la crea\n * @return {Object} Elemento Dom Corner Footer\n */\n redrawTodayLine(config, $elem = null) {\n let endTime = new Date(config.timeline.end).getTime();\n let todayTime = new Date().getTime();\n let {\n height,\n dayWidth\n } = _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getTableDimensions(config);\n if ($elem == null) $elem = _util_domUtils__WEBPACK_IMPORTED_MODULE_0__[\"default\"].createElement(\"div\", {\n className: \"today-line\"\n });\n\n if (endTime < todayTime) {\n $elem.classList.add(\"disable-line\");\n } else {\n $elem.classList.remove(\"disable-line\");\n }\n\n let diffDays = Math.floor(_util_dateUtils__WEBPACK_IMPORTED_MODULE_2__[\"default\"].diffDays(config.timeline.start, _util_dateUtils__WEBPACK_IMPORTED_MODULE_2__[\"default\"].formatDate(new Date())));\n let diff = diffDays * dayWidth;\n diff += dayWidth / 2 - 2; // para centrar linea\n\n Object.assign($elem.style, {\n \"margin-left\": diff + \"px\",\n height: height + \"px\"\n });\n return $elem;\n },\n\n /**\n * Crea elemento FloatBox, que contiene los datos que se muestra en la tabla\n *\n * @param {Object} config - Configuracion capibara\n * @param {Object} tab - Tab de referencia, para mostrar datos configurados por tab\n * @return {Object} Elemento Dom Corner Footer\n */\n createFloatBox(config, tab) {\n let $container = _util_domUtils__WEBPACK_IMPORTED_MODULE_0__[\"default\"].createElement(\"div\", {\n className: \"float-box-container\"\n });\n return this.redrawFloatBox(config, tab, $container);\n },\n\n /**\n * Recrea elemento FloatBox, que contiene los datos que se muestra en la tabla\n * Se usa principalmente para mostrar datos en la tabla de la planilla\n * los muestra de manera flotante, calculando el Top y el Left segun la poscion\n *\n * Se consideran los elementos padres ocultos, para ocultar los datos\n *\n * Se insertan los elementos FloatBox, como elemento con datos de un item y dia especifico\n *\n *\n * @param {Object} config - Configuracion capibara\n * @param {Object} tab - Tab de referencia, para mostrar datos configurados por tab\n * @return {Object} Elemento Dom Corner Footer\n */\n redrawFloatBox(config, tab, $container) {\n $container.innerHTML = \"\"; //let tabSelected = tab || null;\n\n config.data.forEach(de => {\n if (de.isHidden) return;\n de.children.forEach(ds => {\n if (ds.isHidden) return;\n ds.data.forEach(data => {\n if ((!data.message || data.message.value == null) && (data.values == null || data.values == undefined || Object.entries(data.values).length === 0)) {\n return null;\n } //children Data\n\n\n let position = this.getPositionFloatBox(config, data, ds);\n let className = \"\";\n\n if (data.errors && data.errors.length > 0) {\n className += \"has-errors \";\n }\n\n if (de.isClosed) {\n className += \"hide \";\n }\n\n let msg = null;\n\n if (tab.floaBox && tab.floatBox.messagePath) {\n msg = _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getVarByPath(data, tab.floatBox.messagePath);\n }\n\n if (msg || data.message && data.message.value) {\n className += \"has-message \";\n }\n\n let str = `\n <div class=\"float-box ${className} ${de.isClosed ? \"hide\" : \"\"}\"\n style=\"${position ? position : \"\"}\"\n item-id=\"${ds.id || -1}\"\n type-node=\"${ds.type || \"\"}\"> `;\n let strExt = `\n <div class=\"float-box-ext ${de.isClosed ? \"hide\" : \"\"}\"\n style=\"${position ? position : \"\"}\"\n item-id=\"${ds.id || -1}-ext\"\n type-node=\"${ds.type || \"\"}\">\n <div class=\"long-bar-container\">`;\n\n if (tab && tab.floatBox) {\n if (tab.floatBox.plots) {\n str += `<div class=\"plot-floatbox-container\">`;\n tab.floatBox.plots.forEach(n => {\n let cssVars = \"\";\n let className = \"\";\n\n if (_util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getVarByPath(data.values, n.varName) !== null) {\n if (n.color) {\n cssVars = `--local-color:${n.color};`;\n }\n\n className = n.className || \"\";\n str += `<div class=\"plot-floatbox ${className} ${n.style || \"\"}\" style=\"${cssVars} \"></div>`;\n }\n });\n str += `\n </div>`;\n } //numeros en el floatBox\n\n\n if (tab.floatBox.nums) {\n tab.floatBox.nums.forEach(n => {\n if (tab.legends && n.tabKey) {\n let legend = tab.legends.find(l => l.key == n.tabKey);\n if (legend && !legend.active) return;\n }\n\n let dataFloatBox = null;\n let className = \"\";\n let showIf = true;\n let hideIf = false;\n let colorClass = \"\";\n let colorStyle = \"\";\n let classNamesExt = \"\";\n let colorStyleExt = \"\";\n let cssVars = \"\";\n\n if (n.varName) {\n dataFloatBox = _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getVarByPath(data.values, n.varName);\n }\n\n if (n.varShow) {\n showIf = Boolean(_util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getVarByPath(data.values, n.varShow));\n dataFloatBox = dataFloatBox || \"\";\n }\n\n if (n.varHide) {\n hideIf = Boolean(_util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getVarByPath(data.values, n.varHide));\n }\n\n if (n.shape) {\n className += \"shape-\" + n.shape;\n }\n\n if (n.color) {\n if (_util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].isHexColor(n.color)) {\n colorStyle = `--local-color: ${n.color};`;\n } else {\n colorClass = n.color;\n }\n }\n\n if (n.longBar) {\n if (n.longBarColor) {\n let longBarColor = _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getVarByPath(data.values, n.longBarColor);\n let longBarOpacity = _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getVarByPath(data.values, n.longBarOpacity) || null;\n\n if (longBarColor) {\n if (_util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].isHexColor(longBarColor)) {\n colorStyleExt = `--local-color: ${longBarColor}; ${longBarOpacity ? \"--local-opacity: \" + longBarOpacity : \"\"}; `;\n } else {\n classNamesExt = longBarColor;\n }\n } else if (colorClass && colorClass != \"\") {\n classNamesExt = colorClass;\n } else if (colorStyle && colorStyle != \"\") {\n colorStyleExt = colorStyle;\n }\n }\n\n if (n.longBarClassName) {\n classNamesExt += \" \" + n.longBarClassName;\n }\n\n let longBar = _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getVarByPath(data.values, n.longBar);\n\n if (longBar) {\n cssVars = `--long:${longBar};`;\n }\n }\n\n if (dataFloatBox !== null && showIf && !hideIf) {\n str += `<span class=\"data ${colorClass} ${className}\" style=\"${colorStyle}\">\n ${typeof dataFloatBox == \"string\" ? dataFloatBox : \"\"}\n ${typeof dataFloatBox == \"number\" ? _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].round(dataFloatBox, n.round) : \"\"}\n </span>`;\n\n if (n.longBar && cssVars) {\n strExt += `<div class=\"long-bar ${classNamesExt}\" style=\"${colorStyleExt} ${cssVars} \"></div> `;\n }\n }\n });\n } //puntos en el floatBox\n\n\n if (tab.floatBox.dots) {\n str += `<div class=\"dot-container-middle\">`;\n tab.floatBox.dots.forEach(dot => {\n if (_util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getVarByPath(data.values, dot.varName) !== null) {\n let className = \"\";\n let colorClass = \"\";\n let colorStyle = \"\";\n\n if (dot.shape) {\n className += dot.shape;\n }\n\n if (dot.color) {\n if (_util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].isHexColor(dot.color)) {\n colorStyle = `--local-color: ${dot.color}`;\n } else {\n colorClass = dot.color;\n }\n }\n\n str += `\n <div class=\"dot ${colorClass} ${className}\" style=\"${colorStyle}\" ></div>`;\n }\n });\n str += `\n </div>`;\n } //fila de puntos en floatBox\n\n\n if (tab.floatBox.rowDots) {\n tab.floatBox.rowDots.forEach(row => {\n let freeColumns = 4;\n str += `<span class=\"rowdot--row \">`;\n row.forEach(dot => {\n if (tab.legends && dot.tabKey) {\n let legend = tab.legends.find(l => l.key == dot.tabKey);\n if (legend && !legend.active) return;\n }\n\n let dataFloatBox = null;\n let className = \"\";\n let showIf = true;\n let hideIf = false;\n let colorClass = \"\";\n let colorStyle = \"\";\n\n if (dot.varName) {\n dataFloatBox = _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getVarByPath(data.values, dot.varName);\n dataFloatBox = parseInt(dataFloatBox);\n }\n\n if (dot.varShow) {\n showIf = Boolean(_util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getVarByPath(data.values, dot.varShow));\n dataFloatBox = dataFloatBox || \"\";\n }\n\n if (dot.varHide) {\n hideIf = Boolean(_util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getVarByPath(data.values, dot.varHide));\n }\n\n if (dot.shape) {\n className += \" shape-\" + dot.shape;\n }\n\n if (dot.color) {\n if (_util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].isHexColor(dot.color)) {\n colorStyle = `--local-color: ${dot.color}`;\n } else {\n colorClass = dot.color;\n }\n }\n\n if (dataFloatBox !== null && dataFloatBox > 0 && showIf && !hideIf && freeColumns > 0) {\n let n = dataFloatBox > freeColumns ? freeColumns : dataFloatBox;\n freeColumns -= n;\n\n for (let index = 0; index < n; index++) {\n str += `<div class=\"rowdot--dot ${colorClass} ${className}\" style=\"${colorStyle}\"></div>`;\n }\n }\n });\n str += `</span>`;\n });\n }\n }\n\n str += `\n </div>`;\n strExt += `\n </div>\n </div>`;\n let $elem = _util_domUtils__WEBPACK_IMPORTED_MODULE_0__[\"default\"].createElementFromHTML(str);\n let $elemExt = _util_domUtils__WEBPACK_IMPORTED_MODULE_0__[\"default\"].createElementFromHTML(strExt);\n $elem.addEventListener(\"mouseover\", e => {\n $elem.dispatchEvent(new CustomEvent(\"mouseOverFloatBox\", {\n bubbles: true,\n cancelable: false,\n detail: {\n item: ds,\n data: data,\n originalEvt: e\n }\n }));\n });\n $elem.addEventListener(\"click\", e => {\n $elem.dispatchEvent(new CustomEvent(\"clickFloatBox\", {\n bubbles: true,\n cancelable: false,\n detail: {\n item: ds,\n data: data,\n originalEvt: e\n }\n }));\n });\n $container.appendChild($elem);\n $container.appendChild($elemExt);\n });\n });\n });\n return $container;\n },\n\n /**\n * Crea DetailDay, detalle de valores de item y Dia\n * se usa para:\n * - Muestra nombre de item y detalles\n * - Muestra capsulas de datos\n * - Muestra Pills, pildoras de datos resumidos\n * - Muestra alertas\n * - Muestra Mensaje\n *\n * @param {Object} config - Configuracion capibara\n * @param {Object} item - Item relacionado\n * @param {Object} dataDay - valores de item y Dia\n * @param {Boolean} [onlyStringContent = false] - para escoger si devuelve String o DomElement\n * @return {String|Object} Elemento como String o DomElement\n */\n createDetailDay(config, item = {}, dataDay, tabSelected, onlyStringContent = false) {\n let str = `\n <div class=\"header-detail\">\n <div class=\"title truncate\">\n ${item.label || \"\"}\n </div>\n <div class=\"subtitle\">\n ${dataDay ? _util_dateUtils__WEBPACK_IMPORTED_MODULE_2__[\"default\"].formatDateReadeable(dataDay.date) : \"\"}\n </div>\n </div>\n\n <div class=\"list-detail list\">`; //CAPSULES\n\n if (dataDay) {\n config.timeline.detailDay.capsules.forEach(cap => {\n //para comprobar si tiene datos, se obtiene el primer valor\n //de la lista de values de una capsula\n let hasValues = cap.values.filter(v => _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getVarByPath(dataDay.values, v.varName) !== null).length > 0;\n let hideIf = false;\n\n if (cap.hideIf) {\n hideIf = Boolean(_util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getVarByPath(dataDay.values, cap.hideIf));\n }\n\n let colorClass = \"\";\n let colorStyle = \"\";\n\n if (cap.color) {\n if (_util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].isHexColor(cap.color)) {\n colorStyle = `--local-color: ${cap.color};`;\n colorStyle += `--local-color-font: ${cap.color};`;\n } else {\n colorClass = cap.color;\n }\n }\n\n if (hasValues && !hideIf) {\n str += `\n <div class=\"item-detail ${colorClass}\" style=\"${colorStyle}\">\n\n <div class=\"left-icon ${cap.shape || \"\"} \"></div>\n\n <div class=\"name\">\n <span>\n ${cap.title || \"\"}\n </span>\n </div>`;\n str += `\n <div class=\"item-description\"> `;\n cap.values.forEach(v => {\n let value = v.varName ? _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getVarByPath(dataDay.values, v.varName) : null;\n\n if (cap.isLabeledArray) {\n value.forEach(valueLabeled => {\n let outputValue = null;\n let valueName = v.valueName ? v.valueName : \"value\";\n let tempValue = _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getVarByPath(valueLabeled, valueName);\n\n if (tempValue) {\n outputValue = v.round ? _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].round(tempValue, v.round) : tempValue;\n }\n\n if (v.formatter) {\n outputValue = v.formatter(valueLabeled);\n }\n\n if (typeof outputValue == \"number\") {\n outputValue = _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].formatNumber(outputValue);\n }\n\n str += outputValue == null ? \"\" : `\n <div class=\"desc ${v.showColumn ? \"desc-column\" : \"\"}\">\n <div class=\"label\">\n ${v.hideLabel ? \"\" : valueLabeled.label}\n </div >\n <div class=\"val\">\n <span class=\"prefix\">\n ${v.prefix || \"\"}\n </span>\n <span class=\"value\">\n ${outputValue}\n </span>\n <span class=\"suffix\">\n ${valueLabeled.suffix || v.suffix || \"\"}\n </span>\n </div>\n </div>`;\n });\n } else {\n let outputValue = v.round ? _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].round(value, v.round) : value;\n\n if (v.formatter) {\n outputValue = v.formatter({\n options: v,\n dataDay,\n outputValue\n });\n }\n\n if (typeof outputValue == \"number\") {\n outputValue = _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].formatNumber(outputValue);\n }\n\n str += outputValue == null ? \"\" : `\n <div class=\"desc\">\n <span class=\"prefix\">\n ${v.prefix || \"\"}\n </span>\n <span class=\"value\">\n ${outputValue}\n </span>\n <span class=\"suffix\">\n ${v.suffix || \"\"}\n </span>\n </div>`;\n }\n });\n str += `\n </div>`;\n str += `\n </div>`; // end .item-detail\n }\n });\n }\n\n str += `\n </div>`; // list-detail\n //PILLS\n\n if (config.timeline.detailDay.pillsVarName && dataDay && dataDay.values[config.timeline.detailDay.pillsVarName]) {\n str += `\n <div class=\"elements-detail\">\n <div class=\"name\"> ${config.timeline.detailDay.pillsTitle} </div>\n <div class=\"elements-list\">`;\n dataDay.values[config.timeline.detailDay.pillsVarName].forEach(e => {\n let value = e.value;\n\n if (typeof outputValue == \"number\") {\n value = _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].formatNumber(value);\n }\n\n str += `\n <div class=\"element-detail\">\n <b>${e.label}</b>\n ${value}\n </div>`;\n });\n str += `\n </div>\n </div>`; //end .element-detail > .element-list\n } //str += `</div>`;\n\n\n if (dataDay && dataDay.errors && dataDay.errors.length > 0) {\n dataDay.errors.forEach(err => {\n str += `\n <div class=\"alert\">\n ${_util_icons__WEBPACK_IMPORTED_MODULE_3__[\"default\"].alert}\n ${err.label}\n </div>`;\n });\n }\n\n let msg = null;\n let author = null;\n let dateMsg = null;\n\n if (dataDay && tabSelected.floatBox && tabSelected.floatBox.messagePath) {\n msg = _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getVarByPath(dataDay, tabSelected.floatBox.messagePath);\n\n if (!msg && dataDay.message && dataDay.message.value) {\n msg = dataDay.message.value;\n author = dataDay.message.author;\n dateMsg = _util_dateUtils__WEBPACK_IMPORTED_MODULE_2__[\"default\"].formatDateReadeable(new Date(dataDay.message.date));\n }\n }\n\n if (msg) {\n //msg = msg.replace(/(\\r\\n|\\r|\\n)/g, '<br>');\n str += `\n <div class=\"msj-container\">\n <div class=\"msj\">\n <pre>${msg || \"\"}</pre>\n </div>\n <div class=\"msj-detail\">\n <span class=\"email\"> ${author || \"\"} </span>\n <span class=\"date\"> ${dateMsg || \"\"} </span>\n </div>\n </div>`;\n }\n\n let strContainer = `<div class=\"detail-day dd-hide\"> ${str} </div>`;\n if (onlyStringContent) return str;\n return _util_domUtils__WEBPACK_IMPORTED_MODULE_0__[\"default\"].createElementFromHTML(strContainer);\n },\n\n /**\n * Recrea HTML de detailDay\n *\n * @param {Object} config - Configuracion capibara\n * @param {Object} item - Item relacionado\n * @param {Object} dataDay - valores de item y Dia\n * @return {String} Elemento como String, de detailDay\n */\n redrawDetailDay(config, item, dataDay, tabSelected) {\n return this.createDetailDay(config, item, dataDay, tabSelected, true);\n },\n\n /**\n * Reposiciona FloatBox\n * verifica si el parent esta desplegado, para ocultar los datos\n *\n * Solo actualiza las alturas de los floatbox\n * no recrea los floatbox, es mas optimo\n *\n * @param {Object} config - Configuracion capibara\n * @param {Object} item - Item relacionado\n */\n repositionFloatBox(config, $floatBoxContainer) {\n $floatBoxContainer.querySelectorAll(\".float-box\").forEach($f => {\n let itemId = $f.getAttribute(\"item-id\");\n let itemHeight = parseFloat(_util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getCSSVariable(config, \"--item-height\"));\n let item, parent;\n ({\n item,\n parent\n } = _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getItemById(config, itemId, \"child\", true));\n\n if (item) {\n let top = _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getPositionByItem(config, item);\n $f.style.top = top * itemHeight + \"px\";\n\n if (parent && parent.isClosed) {\n $f.classList.add(\"hide\");\n } else if ($f.classList.contains(\"hide\")) {\n $f.classList.remove(\"hide\");\n }\n }\n });\n },\n\n /**\n * Recrea indicadores de dias seleccionados\n *\n * @param {Object} $elem - Elemento Dom donde crea los elementos seleccionados\n * @param {Object[]} selected - Array con los dias seleccionados\n * @return {Object} Elemento Dom que contiene los indicadores de dias seleccionados\n */\n redrawSelectBoard($elem, selected) {\n $elem.innerHTML = \"\";\n let hasNumber = true;\n\n if (selected) {\n if (selected.length == 1) hasNumber = false;\n selected.forEach(s => {\n let attributes = [];\n\n if (hasNumber) {\n attributes.push({\n name: \"cap-badge\",\n value: s.index\n });\n }\n\n let $s = _util_domUtils__WEBPACK_IMPORTED_MODULE_0__[\"default\"].createElement(\"div\", {\n className: \"selected-day\",\n attributes\n });\n $s.style.left = s.pos.left + \"px\";\n $s.style.top = s.pos.top + \"px\";\n $elem.append($s);\n });\n }\n\n return $elem;\n },\n\n /**\n * Obtiene String con estilos CSS de la posicion de un floatBox\n * calculado segun item y fecha de los valores\n *\n * @param {Object} config - Configuracion capibara, para ver fecha de inicio\n * @param {Object} data - Datos del dia indicado\n * @param {Object} item - Item relacionado\n * @return {String} String CSS top y left , para posicionar floatBox en table\n */\n getPositionFloatBox(config, data, item) {\n let left = _util_dateUtils__WEBPACK_IMPORTED_MODULE_2__[\"default\"].diffDays(config.timeline.start, data.date);\n let top = _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getPositionByItem(config, item);\n let dayWidth = parseFloat(_util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getCSSVariable(config, \"--day-width\"));\n let itemHeight = parseFloat(_util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getCSSVariable(config, \"--item-height\"));\n left *= dayWidth;\n top *= itemHeight;\n return \"top: \" + top + \".5px; left:\" + left + \".5px;\";\n },\n\n /**\n * Crea Boton como elemento Dom\n *\n * @param {Object} props - propiedades para boton\n * @param {String} props.className - classes css para boton\n * @param {*} props.key - key para identificar a boton\n * @param {String} props.label - Texto boton\n * @return {Object} Elemento Dom del boton creado\n */\n createButton(props) {\n return _util_domUtils__WEBPACK_IMPORTED_MODULE_0__[\"default\"].createElementFromHTML(`\n <button class=\"${props.className || \"\"}\" input-key=\"${props.key || \"\"}\">\n ${props.label || \"\"}\n </button>`);\n },\n\n /**\n * Crea Botones de guardar y cancelar los datos de formulario del sidebar derecho\n *\n * @return {Object} Elemento Dom del botones creados\n */\n createNavRightbuttons() {\n let saveBtn = this.createButton({\n label: \"Guardar\",\n className: \"cap-btn-raised\"\n });\n let cancelBtn = this.createButton({\n label: \"Cancelar\",\n className: \"cap-btn-outline\"\n });\n let btnSection = _util_domUtils__WEBPACK_IMPORTED_MODULE_0__[\"default\"].createElementFromHTML(`<div class=\"button-section\"></div>`);\n btnSection.appendChild(saveBtn);\n btnSection.appendChild(cancelBtn);\n saveBtn.addEventListener(\"click\", e => {\n saveBtn.dispatchEvent(new CustomEvent(\"saveMultiInput\", {\n bubbles: true,\n cancelable: false\n }));\n });\n cancelBtn.addEventListener(\"click\", e => {\n cancelBtn.dispatchEvent(new CustomEvent(\"cancelMultiInput\", {\n bubbles: true,\n cancelable: false\n }));\n });\n return btnSection;\n },\n\n /**\n * Crea Input como elemento Dom\n *\n * @param {Object} props - config para Input\n * @param {Object} [dataDay = null] - valores de item y Dia, opcional\n * @param {Object} [daySelected = null] - datos del dia seleccionado\n * @param {Object[]} [selected = []] - array de objetos, de dias seleccionados\n * @return {Object} Elemento Dom del input creado\n */\n createInput(props, dataDay = null, daySelected = null, selected = []) {\n let r = null;\n if (props.ignoreRender == true) return r;\n\n switch (props.type) {\n case \"custom\":\n r = props.render ? props.render({\n props,\n dataDay,\n daySelected,\n selected\n }) : null;\n r.setAttribute(\"input-key\", props.key);\n break;\n\n case \"select\":\n r = this.createInputSelect(props, dataDay, daySelected);\n break;\n\n case \"file\":\n r = this.createInputFile(props, dataDay);\n break;\n\n case \"fileLink\":\n r = this.createFileLink(props, dataDay);\n break;\n\n case \"text\":\n r = this.createText(props, selected);\n break;\n\n case \"title\":\n r = this.createTitle(props);\n break;\n\n case \"number\":\n r = this.createInputNumber(props, dataDay);\n break;\n\n case \"float\":\n r = this.createInputFloat(props, dataDay);\n break;\n\n case \"message\":\n r = this.createInputMessage(props, dataDay);\n break;\n\n case \"textarea\":\n r = this.createInputTextArea(props, dataDay);\n break;\n\n case \"checkbox\":\n r = this.createInputCheckbox(props, dataDay);\n break;\n\n case \"inputList\":\n r = this.createInputList(props, dataDay, daySelected);\n break;\n\n case \"input-box\":\n r = this.createInputBox(props, dataDay);\n break;\n\n case \"list\":\n r = this.createList(props, dataDay);\n break;\n\n case \"data-list\":\n r = this.createDataList(props, dataDay, daySelected, selected);\n break;\n\n case \"button\":\n r = this.createInputButton(props, dataDay);\n break;\n\n case \"buttons-group\":\n r = this.createInputButtonsGroup(props, dataDay);\n break;\n\n case \"time\":\n r = this.createInputTime(props, dataDay);\n break;\n\n case \"text\":\n default:\n r = this.createInputText(props, dataDay);\n }\n\n return r;\n },\n\n /**\n * Crea Input con formato Hora, como elemento Dom\n *\n * Usa 2 inputs, hora y minutos\n *\n * el value que interpreta es String HH:MM\n *\n * @param {Object} props - config para Input\n * @param {Object} [dataDay = null] - valores de item y Dia, opcional\n * @return {Object} Elemento Dom del input creado\n */\n createInputTime(props, dataDay) {\n let hhValue = \"\";\n let mmValue = \"\";\n\n if (dataDay && dataDay.values) {\n let value = _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getVarByPath(dataDay, props.varName);\n\n if (value) {\n value = value.split(\":\");\n hhValue = value[0];\n mmValue = value[1];\n }\n }\n\n let $elem = _util_domUtils__WEBPACK_IMPORTED_MODULE_0__[\"default\"].createElementFromHTML(`\n <div class=\"input-section ${props.isHidden ? 'hide' : ''} \" input-key=\"${props.key || \"\"}\">\n <span class=\"text-subtitle d-block\">\n ${props.label || \"\"}\n </span>\n <div class=\"d-flex\">\n <div class=\"time\">\n <input type=\"number\"\n class=\"hour\"\n id=\"test\"\n placeholder=\"00\"\n min=\"0\"\n max=\"24\"\n value=\"${hhValue}\">\n <span class=\"symbol\">:</span>\n <input type=\"number\"\n class=\"minutes\"\n placeholder=\"00\"\n min=\"0\"\n max=\"59\"\n value=\"${mmValue}\">\n </div>\n <span class=\"text-hint\">\n ${props.textHint || \"\"}\n </span>\n </div>\n </div>`);\n let $hhInput = $elem.querySelector(\".hour\");\n let $mmInput = $elem.querySelector(\".minutes\");\n $hhInput.addEventListener(\"input\", e => {\n $hhInput.dispatchEvent(new CustomEvent(\"changeTimeInputHH\", {\n bubbles: true,\n cancelable: false,\n detail: {\n key: props.key,\n value: e.srcElement.value\n }\n }));\n });\n $mmInput.addEventListener(\"input\", e => {\n $mmInput.dispatchEvent(new CustomEvent(\"changeTimeInputMM\", {\n bubbles: true,\n cancelable: false,\n detail: {\n key: props.key,\n value: e.srcElement.value\n }\n }));\n });\n this.addKeyDownInputEvents($hhInput, $elem, props);\n this.addKeyDownInputEvents($mmInput, $elem, props);\n return $elem;\n },\n\n /**\n * Crea Text como elemento Dom\n * Se configura como input, pero no devuelve datos, es un texto\n *\n * @param {Object} props - config para Input\n * @return {Object} Elemento Dom del input creado\n */\n createText(props, selected) {\n let label = props.label;\n\n if (props.formatter) {\n label = props.formatter({\n selected\n });\n }\n\n let $elem = _util_domUtils__WEBPACK_IMPORTED_MODULE_0__[\"default\"].createElementFromHTML(`\n <div class=\"input-section ${props.isHidden ? 'hide' : ''} \" input-key=\"${props.key || \"\"}\">\n <span class=\"${props.classNames || \"\"}\">\n ${label}\n </span>\n </div>`);\n return $elem;\n },\n\n /**\n * Crea Title como elemento Dom\n * Se configura como input, pero no devuelve datos, es un texto\n *\n * @param {Object} props - config para Input\n * @return {Object} Elemento Dom del input creado\n */\n createTitle(props) {\n let classNames = \"text-title\";\n\n if (props.isSubtitle) {\n classNames = \"text-subtitle\";\n }\n\n return _util_domUtils__WEBPACK_IMPORTED_MODULE_0__[\"default\"].createElementFromHTML(`\n <div class=\"input-section ${props.isHidden ? 'hide' : ''} \" input-key=\"${props.key || \"\"}\">\n <span class=\"${classNames}\">\n ${props.label}\n </span>\n </div>`);\n },\n\n /**\n * Crea Input tipo Numerico como elemento Dom\n *\n * @param {Object} props - config para Input\n * @param {Object} dataDay - valores de item y Dia, opcional\n * @return {Object} Elemento Dom del input creado\n */\n createInputNumber(props, dataDay) {\n let value = \"\";\n\n if (dataDay && dataDay.values) {\n value = _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getVarByPath(dataDay, props.varName);\n }\n\n value = value || \"\";\n let elem = _util_domUtils__WEBPACK_IMPORTED_MODULE_0__[\"default\"].createElementFromHTML(`\n <div class=\"input-section ${props.classNames || \"\"} ${props.isHidden ? 'hide' : ''} \" input-key=\"${props.key || \"\"}\">\n <div class=\"input-section-title\">\n <span class=\"text-subtitle\">\n ${props.label}\n </span>\n <span class=\"text-subtitle-2 \">\n ${props.suffix ? \"(\" + props.suffix + \")\" : \"\"}\n </span>\n </div>\n <div class=\"d-flex\">\n <input type=\"number\"\n class=\"nav-input\"\n value=\"${value}\">\n\n <span class=\"text-hint\">\n ${props.textHint || \"\"}\n </span>\n </div>\n </div>`);\n let inputElem = elem.querySelector(\"input\");\n this.addKeyDownInputEvents(inputElem, elem, props);\n return elem;\n },\n\n /**\n * Crea Input tipo FIlepicker como elemento Dom\n *\n * @param {Object} props - config para Input\n * @param {Object} dataDay - valores de item y Dia, opcional\n * @return {Object} Elemento Dom del input creado\n */\n createInputFile(props, dataDay) {\n let value = \"\";\n let fileName = \"\";\n let filePath = \"\";\n\n if (dataDay && dataDay.values) {\n value = _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getVarByPath(dataDay, props.varName);\n fileName = _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getVarByPath(dataDay, props.fileNameValue);\n filePath = _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getVarByPath(dataDay, props.filePathValue);\n }\n\n value = value || \"\";\n fileName = fileName || \"\";\n filePath = filePath || \"\";\n let elem = _util_domUtils__WEBPACK_IMPORTED_MODULE_0__[\"default\"].createElementFromHTML(`\n <div class=\"input-section ${props.classNames || \"\"} ${props.isHidden ? 'hide' : ''} \" input-key=\"${props.key || \"\"}\">\n\n <div class=\"input-section-title\">\n <span class=\"text-subtitle\">\n ${props.label}\n </span>\n </div>\n\n <div class=\"nav-input-file\" >\n <button class=\"small-close clear-file-input\">x</button>\n <label >\n <span class=\"nav-input-file-label\">\n ${props.pickerLabel || \"Seleccionar Archivo\"}\n </span>\n <input type=\"file\" value=\"${value}\">\n </label>\n </div>\n\n <div class=\"input-section-link\">\n <a href=\"${filePath}\" target=\"_blank\" >\n ${fileName}\n </a>\n </div>\n\n </div>`);\n let $inputElem = elem.querySelector(\"input\");\n let $clearBtn = elem.querySelector(\".clear-file-input\");\n let $fileInputLabel = elem.querySelector(\".nav-input-file-label\");\n $inputElem.addEventListener(\"change\", evt => {\n let fileName = $inputElem.files[0].name;\n $fileInputLabel.textContent = fileName;\n });\n $clearBtn.addEventListener(\"click\", evt => {\n $inputElem.value = \"\";\n $fileInputLabel.textContent = props.pickerLabel || \"Seleccionar Archivo\";\n evt.stopPropagation();\n });\n return elem;\n },\n\n createFileLink(props, dataDay) {\n let fileName = \"\";\n let filePath = \"\";\n\n if (dataDay && dataDay.values) {\n //value = utils.getVarByPath(dataDay, props.varName);\n fileName = _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getVarByPath(dataDay, props.fileNameValue);\n filePath = _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getVarByPath(dataDay, props.filePathValue);\n }\n\n if (fileName == \"\") return null;\n fileName = fileName || \"\";\n filePath = filePath || \"\";\n let elem = _util_domUtils__WEBPACK_IMPORTED_MODULE_0__[\"default\"].createElementFromHTML(`\n <div class=\"input-section ${props.classNames || \"\"} ${props.isHidden ? 'hide' : ''} \" input-key=\"${props.key || \"\"}\">\n\n <div class=\"input-section-title\">\n <span class=\"text-subtitle\">\n ${props.label}\n </span>\n </div>\n\n <div class=\"input-section-link\">\n <a href=\"${filePath}\" target=\"_blank\" >\n ${fileName}\n </a>\n </div>\n\n </div>`);\n return elem;\n },\n\n /**\n * Crea lista de Inputs, con array de valores, como elemento Dom\n *\n * @param {Object} props - config para Input\n * @param {Object} dataDay - valores de item y Dia, opcional\n * @param {Object} [daySelected = null] - datos del dia seleccionado\n * @return {Object} Elemento Dom del input creado\n */\n createInputList(props, dataDay, daySelected = null) {\n let inputList = []; //obtiene inputs default, para crearlos, sin valores\n\n if (daySelected && Array.isArray(daySelected.item.values[props.inputList])) {\n inputList = daySelected.item.values[props.inputList].map(inputRow => {\n //limpia inputList inputs\n inputRow.inputs.map(input => {\n input.value = null;\n return input;\n }); //obtiene valores del dia\n\n if (dataDay && dataDay.values) {\n let inputValues = _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getVarByPath(dataDay, props.valuesPath); //autorrellena\n\n if (inputValues) {\n inputRow.inputs.forEach(input => {\n let values = inputValues.find(v => v.id == inputRow.id);\n input.value = values ? values[input.varName] : null;\n });\n }\n }\n\n return inputRow;\n });\n }\n\n let str = `<div input-key=\"${props.key || \"\"}\" class=\"input-section-list ${props.isHidden ? 'hide' : ''} \">\n <div class=\"input-section-title\">\n <span class=\"text-title\">\n ${props.label}\n </span> \n </div>`;\n inputList.forEach(inputRow => {\n str += `\n <div class=\"input-section ${props.toRight ? \"to-right\" : \"\"}\" >\n <span class=\"text-subtitle\">\n ${inputRow.label}\n </span>`;\n inputRow.inputs.forEach(input => {\n str += ` \n <div class=\"input-section-col\" >\n <span class=\"text-subtitle \">\n ${input.label}\n </span>\n <input type=\"number\"\n input-id=\"${inputRow.id}\"\n input-label=\"${input.label}\"\n class=\"nav-input small\"\n value=\"${input.value}\">\n </div>`;\n });\n str += `\n </div>`;\n });\n str += `</div>`;\n let elem = _util_domUtils__WEBPACK_IMPORTED_MODULE_0__[\"default\"].createElementFromHTML(str);\n let inputsElem = elem.querySelectorAll(\"input\");\n inputsElem.forEach(inputElem => this.addKeyDownInputEvents(inputElem, elem, props));\n return elem;\n },\n\n createInputSelect(props, dataDay, daySelected = null) {\n let value = null;\n let options = props.options;\n\n if (dataDay && dataDay.values) {\n let val = _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getVarByPath(dataDay, props.varName);\n value = val ? val.value : null;\n }\n\n let str = `<div input-key=\"${props.key || \"\"}\" class=\"${props.isHidden ? 'hide' : ''}\" >\n <div class=\"input-section \" >\n <span class=\"text-subtitle\">\n ${props.label}\n </span>\n\n <select class=\"input-select\">\n\n <option value=\"\" ${value == null ? \"selected\" : \"\"}>\n ${props.noDataLabel || \"-- sin asignar --\"}\n </option>\n\n `;\n options.forEach(option => {\n str += `\n <option value=\"${option.id}\" ${option.id == value ? \"selected\" : \"\"}>\n ${option.label}\n </option>\n `;\n });\n str += `\n\n </select>\n </div>\n\n </div>`;\n let elem = _util_domUtils__WEBPACK_IMPORTED_MODULE_0__[\"default\"].createElementFromHTML(str);\n return elem;\n },\n\n /**\n * Crea Input de texto TextArea como elemento Dom\n *\n * @param {Object} props - config para Input\n * @param {Object} dataDay - valores de item y Dia, opcional\n * @return {Object} Elemento Dom del input creado\n */\n createInputTextArea(props, dataDay) {\n let value = \"\";\n\n if (dataDay && dataDay.values) {\n value = _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getVarByPath(dataDay, props.varName);\n }\n\n let elem = _util_domUtils__WEBPACK_IMPORTED_MODULE_0__[\"default\"].createElementFromHTML(`\n <div class=\"input-section ${props.isHidden ? 'hide' : ''} \" input-key=\"${props.key || \"\"}\">\n <span class=\"text-subtitle d-block\">\n ${props.label}\n </span>\n <textarea class=\"\" value=\"${value}\"></textarea>\n </div>`);\n let inputElem = elem.querySelector(\"textarea\");\n this.addKeyDownInputEvents(inputElem, elem, props);\n return elem;\n },\n\n /**\n * Crea Input de Mensaje como elemento Dom\n * utiliza TextArea\n *\n * @param {Object} props - config para Input\n * @param {Object} dataDay - valores de item y Dia, opcional\n * @return {Object} Elemento Dom del input creado\n */\n createInputMessage(props, dataDay) {\n let value = dataDay ? _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getVarByPath(dataDay, props.varName) : null;\n let elem = _util_domUtils__WEBPACK_IMPORTED_MODULE_0__[\"default\"].createElementFromHTML(`\n <div class=\"input-section msj-input-container ${props.isHidden ? 'hide' : ''} \"\n input-key=\"${props.key || \"\"}\">\n <span class=\"text-subtitle d-block\">\n Mensaje\n </span>\n <textarea class=\"msj\">${value || \"\"}</textarea>\n </div>`);\n let inputElem = elem.querySelector(\"textarea\"); //this.addKeyDownInputEvents(inputElem);\n\n return elem;\n },\n\n /**\n * Crea Input de texto como elemento Dom\n *\n * @param {Object} props - config para Input\n * @param {Object} dataDay - valores de item y Dia, opcional\n * @return {Object} Elemento Dom del input creado\n */\n createInputText(props, dataDay) {\n let value = \"\";\n\n if (dataDay && dataDay.values) {\n value = _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getVarByPath(dataDay, props.varName);\n }\n\n let elem = _util_domUtils__WEBPACK_IMPORTED_MODULE_0__[\"default\"].createElementFromHTML(`\n <div class=\"input-section ${props.isHidden ? 'hide' : ''} \" input-key=\"${props.key || \"\"}\">\n <span class=\"text-subtitle d-block\">\n ${props.label}\n </span>\n <input type=\"text\" class=\"nav-input\" value=\"${value}\">\n </div>`);\n let inputElem = elem.querySelector(\"input\");\n this.addKeyDownInputEvents(inputElem, elem, props);\n return elem;\n },\n\n /**\n * Crea Input Numero Flotante, como elemento Dom\n *\n * @param {Object} props - config para Input\n * @param {Object} dataDay - valores de item y Dia, opcional\n * @return {Object} Elemento Dom del input creado\n */\n createInputFloat(props, dataDay) {\n let value = \"\";\n\n if (dataDay && dataDay.values) {\n value = _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getVarByPath(dataDay, props.varName);\n }\n\n let elem = _util_domUtils__WEBPACK_IMPORTED_MODULE_0__[\"default\"].createElementFromHTML(`\n <div class=\"input-section ${props.isHidden ? 'hide' : ''} \" input-key=\"${props.key || \"\"}\">\n <span class=\"text-subtitle d-block\">\n ${props.label}\n </span>\n <input type=\"number\" class=\"nav-input\" value=\"${value}\">\n </div>`);\n let inputElem = elem.querySelector(\"input\");\n this.addKeyDownInputEvents(inputElem, elem, props);\n return elem;\n },\n\n createDataList(props, dataDay, daySelected, selected) {\n let list = [];\n\n if (dataDay && dataDay.values) {\n list = _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getVarByPath(dataDay, props.varName) || [];\n }\n\n let searchInput = ` <div class=\"search-input-container\">\n <input id=\"\" type=\"text\" name=\"\" class=\"search-input\" placeholder=\"buscar\">\n <button class=\"search-input-clear\">\n ${_util_icons__WEBPACK_IMPORTED_MODULE_3__[\"default\"].closeIcon}\n </button>\n </div>`;\n let editBtn = \"\";\n\n if (props.editButton) {\n editBtn = `<button class=\"cap-btn-outline cap-btn-sm edit-btn\" input-key=\"${props.editButton.key}\">\n ${props.editButton.label} \n </button> `;\n }\n\n let str = `\n <div class=\"input-section ${props.isHidden ? 'hide' : ''} \" input-key=\"${props.key || \"\"}\">\n <div class=\"input-section-title\">\n <span class=\"text-subtitle d-block\">\n ${props.label}\n </span>\n ${editBtn}\t\n </div>\n <div class=\"input-box \" input-key=\"${props.key || \"\"}\">\n ${searchInput}\n </div>\n </div> `;\n let $el = _util_domUtils__WEBPACK_IMPORTED_MODULE_0__[\"default\"].createElementFromHTML(str);\n let $searchInput = $el.querySelector(\".search-input\");\n let $searchInputClear = $el.querySelector(\".search-input-clear\");\n let $inputBox = $el.querySelector(\".input-box\");\n list.map((item, j) => {\n let label = _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getVarByPath(item, props.varNameLabel) || dataDay.label || \"__\";\n let $elItem = this.createDataListItem({\n label,\n valueText: _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getVarByPath(item, props.varNameValueText) || \"\",\n subText: _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getVarByPath(item, props.varNameSubText) || \"\",\n id: \"list-item-\" + (dataDay.id || j),\n key: \"list-item-\" + (dataDay.id || j),\n tooltip: _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getVarByPath(item, props.varNameTooltip) || label,\n //colorIcon: \"c-red\",\n link: _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getVarByPath(item, props.varNameLink) || null,\n suffix: _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getVarByPath(item, props.varNameSuffix) || null //value: JSON.stringify(utils.getVarByPath(item, props.varNameInput)) || {}\n\n });\n $inputBox.appendChild($elItem);\n });\n $searchInputClear.addEventListener(\"click\", e => {\n $searchInput.value = \"\";\n $searchInput.dispatchEvent(new Event(\"input\", {\n bubbles: true\n }));\n });\n $searchInput.addEventListener(\"keydown\", e => {\n if (e.key === \"Escape\") {\n $searchInput.value = \"\";\n $searchInput.dispatchEvent(new Event(\"input\", {\n bubbles: true\n }));\n }\n });\n $searchInput.addEventListener(\"input\", e => {\n let $inputs = [];\n $inputs = $el.querySelectorAll(\".mini-input-section\") || [];\n $inputs.forEach($i => {\n let label = $i.getAttribute(\"label\");\n let search = $searchInput.value;\n\n if (label.toLowerCase().includes(search.toLowerCase())) {\n $i.classList.remove(\"hide\");\n } else {\n $i.classList.add(\"hide\");\n }\n });\n });\n let button = $el.querySelector(\"button.edit-btn\");\n\n if (button && props.editButton && props.editButton.onClick) {\n button.addEventListener(\"click\", e => props.editButton.onClick({\n event: e,\n props,\n dataDay,\n daySelected,\n selected,\n $element: $el\n }));\n }\n\n return $el;\n },\n\n createDataListItem({\n label = \"\",\n valueText = \"\",\n subText = \"\",\n id = \"\",\n key = \"\",\n tooltip = \"\",\n colorIcon = \"\",\n link = null,\n suffix = null,\n value = \"\"\n }) {\n let tooltipStr = \"\";\n let iconStr = null;\n let linkStr = \"\";\n let str = \"\";\n\n if (tooltip) {\n tooltipStr = `\n <div class=\"mini-input-section--tooltip\">\n ${tooltip}\n </div>`;\n }\n\n if (colorIcon) {\n if (_util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].isHexColor(itemFormated.colorIcon)) {\n iconStr = `<div class=\"mini-input-section--icon\" style=\"background:${colorIcon}\"> </div>`;\n } else {\n iconStr = `<div class=\"mini-input-section--icon ${colorIcon}\"> </div>`;\n }\n }\n\n if (link) {\n linkStr = `<a class=\"mini-input-section--link\" target=\"_blank\" href=\"${link}\">${_util_icons__WEBPACK_IMPORTED_MODULE_3__[\"default\"].linkIcon}</a> `;\n }\n\n str += `\n <div class=\"mini-input-section ${iconStr ? \"has-icon\" : \"\"} \" label=\"${label}\" data-id=\"${id}\" data-key=\"${key}\" data-value=\"${value || ''}\">\n <label>\n ${iconStr || \"\"}\n\n <div class=\"mini-input-section--titles\">\n <div class=\"mini-input-section--title truncate\">\n ${label}\n </div>\n <div class=\"mini-input-section--subtitle truncate\">\n ${subText}\n </div>\n </div>\n\n <div class=\"mini-input-section--content\" >\n ${valueText}\n </div>\n <div class=\"mini-input-section--suffix\" >\n ${suffix}\n </div>\n\n ${linkStr}\n\n </label>\n ${tooltipStr}\n </div>`;\n return _util_domUtils__WEBPACK_IMPORTED_MODULE_0__[\"default\"].createElementFromHTML(str);\n },\n\n createList(props, dataDay) {\n let tabsContainer = \"\";\n\n if (props.tabs) {\n let tabs = \"\";\n props.tabs.forEach(tab => {\n tabs += `\n <div class=\"input-box-tab\" tab-key=\"${tab.key}\">\n ${tab.name}\n </div>`;\n });\n tabsContainer = `\n <div class=\"input-box-tab-container\">\n ${tabs}\n </div>\n `;\n }\n\n let searchInput = `\n <div class=\"search-input-container\">\n <input id=\"\" type=\"text\" name=\"\" class=\"search-input\" placeholder=\"buscar\">\n <button class=\"search-input-clear\">\n ${_util_icons__WEBPACK_IMPORTED_MODULE_3__[\"default\"].closeIcon}\n </button>\n </div>\n `;\n let str = `\n <div class=\"input-section ${props.isHidden ? 'hide' : ''} \" input-key=\"${props.key || \"\"}\">\n <span class=\"text-subtitle d-block\">\n ${props.label}\n </span>\n\n ${tabsContainer}\n <div class=\"input-box \" input-key=\"${props.key || \"\"}\">\n\n ${searchInput}\n `; //TODO obtener input segun fila\n\n if (props.inputs) {\n props.inputs.forEach(i => {\n if (i.isTitle) {\n let tooltip = \"\";\n let icon = null;\n\n if (i.tooltip) {\n tooltip = `\n <div class=\"mini-input-section--tooltip\">\n ${i.tooltip}\n ${i.suffix ? \"(\" + i.suffix + \")\" : \"\"}\n </div>`;\n }\n\n if (i.colorIcon) {\n if (_util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].isHexColor(i.colorIcon)) {\n icon = `<div class=\"mini-input-section--icon\" style=\"background:${i.colorIcon}\"> </div>`;\n } else {\n icon = `<div class=\"mini-input-section--icon ${i.colorIcon}\"> </div>`;\n }\n }\n\n str += `\n <div class=\"mini-input-section is-title ${icon ? \"has-icon\" : \"\"}\" input-tab-key=\"${i.tabKey || \"\"}\" label=\"${i.label}\">\n <label>\n ${icon || \"\"}\n <div class=\"mini-input-section--title truncate\">\n ${i.label}\n </div>\n </label>\n ${tooltip}\n </div>`;\n } else {\n let tooltip = \"\";\n let icon = null;\n let link = \"\";\n\n if (i.tooltip) {\n tooltip = `\n <div class=\"mini-input-section--tooltip\">\n ${i.tooltip}\n </div>`;\n }\n\n if (i.colorIcon) {\n if (_util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].isHexColor(i.colorIcon)) {\n icon = `<div class=\"mini-input-section--icon\" style=\"background:${i.colorIcon}\"> </div>`;\n } else {\n icon = `<div class=\"mini-input-section--icon ${i.colorIcon}\"> </div>`;\n }\n }\n\n if (i.link) {\n link = `<a class=\"mini-input-section--link\" target=\"_blank\" href=\"${i.link}\">\n ${_util_icons__WEBPACK_IMPORTED_MODULE_3__[\"default\"].linkIcon}\n </a> `;\n }\n\n str += `\n <div class=\"mini-input-section ${icon ? \"has-icon\" : \"\"}\" input-tab-key=\"${i.tabKey || \"\"}\" label=\"${i.label}\">\n <label>\n\n ${icon}\n\n <div class=\"mini-input-section--title truncate\">\n ${i.label}\n </div>\n\n <div class=\"mini-input-section--suffix\" >${i.suffix ? \"(\" + i.suffix + \")\" : \"\"}</div>\n\n ${link}\n\n </label>\n <div class=\"mini-input-section--footer\">\n <span class=\"start\"> start</span>\n <span class=\"end\"> end </span>\n </div>\n ${tooltip}\n </div>`;\n }\n });\n }\n\n str += `\n </div>\n </div> `;\n let $el = _util_domUtils__WEBPACK_IMPORTED_MODULE_0__[\"default\"].createElementFromHTML(str);\n let $tabs = $el.querySelectorAll(\".input-box-tab[tab-key]\") || [];\n let $searchInput = $el.querySelector(\".search-input\") || null;\n let $searchInputClear = $el.querySelector(\".search-input-clear\") || null;\n $tabs.forEach(t => {\n t.addEventListener(\"click\", e => {\n this.selectInputBoxTab(t, $el);\n $searchInput.value = \"\";\n $searchInput.dispatchEvent(new Event(\"input\", {\n bubbles: true\n }));\n });\n });\n\n if ($searchInputClear) {\n $searchInputClear.addEventListener(\"click\", e => {\n $searchInput.value = \"\";\n $searchInput.dispatchEvent(new Event(\"input\", {\n bubbles: true\n }));\n });\n }\n\n if ($searchInput) {\n $searchInput.addEventListener(\"keydown\", e => {\n if (e.key === \"Escape\") {\n $searchInput.value = \"\";\n $searchInput.dispatchEvent(new Event(\"input\", {\n bubbles: true\n }));\n }\n });\n $searchInput.addEventListener(\"input\", e => {\n let $tabSelected = $el.querySelector(\".input-box-tab[tab-key].active\") || null;\n let $inputs = [];\n\n if ($tabSelected) {\n let tabKey = $tabSelected.getAttribute(\"tab-key\");\n $inputs = $el.querySelectorAll(\".mini-input-section[input-tab-key='\" + tabKey + \"']\") || [];\n } else {\n $inputs = $el.querySelectorAll(\".mini-input-section\") || [];\n }\n\n $inputs.forEach($i => {\n let label = $i.getAttribute(\"label\");\n let search = $searchInput.value;\n\n if (label.toLowerCase().includes(search.toLowerCase())) {\n $i.classList.remove(\"hide\");\n } else {\n $i.classList.add(\"hide\");\n }\n });\n });\n }\n\n this.selectInputBoxTab(_.first($tabs), $el);\n return $el;\n },\n\n /**\n * Crea InputBox, como elemento Dom\n * un InputBox es un contenedor con una lista de inputs\n *\n * @param {Object} props - config para Input\n * @param {Object} dataDay - valores de item y Dia, opcional\n * @return {Object} Elemento Dom del input creado\n */\n createInputBox(props, dataDay) {\n let value = [];\n\n if (dataDay && dataDay.values) {\n value = _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getVarByPath(dataDay, props.varName);\n }\n\n let tabsContainer = \"\";\n\n if (props.tabs) {\n let tabs = \"\";\n props.tabs.forEach(tab => {\n tabs += `\n <div class=\"input-box-tab\" tab-key=\"${tab.key}\">\n ${tab.name}\n </div>`;\n });\n tabsContainer = `\n <div class=\"input-box-tab-container\">\n ${tabs}\n </div>\n `;\n }\n\n let searchInput = `\n <div class=\"search-input-container\">\n <input id=\"\" type=\"text\" name=\"\" class=\"search-input\" placeholder=\"buscar\">\n <button class=\"search-input-clear\">\n ${_util_icons__WEBPACK_IMPORTED_MODULE_3__[\"default\"].closeIcon}\n </button>\n </div>\n `;\n let str = `\n <div class=\"input-section ${props.isHidden ? 'hide' : ''} \" input-key=\"${props.key || \"\"}\">\n <span class=\"text-subtitle d-block\">\n ${props.label}\n </span>\n\n ${tabsContainer}\n\n <div class=\"input-box \" input-key=\"${props.key || \"\"}\">\n\n ${searchInput}\n `;\n\n if (props.inputs) {\n props.inputs.forEach(i => {\n if (i.isTitle) {\n let tooltip = \"\";\n let icon = \"\";\n\n if (i.tooltip) {\n tooltip = `\n <div class=\"mini-input-section--tooltip\">\n ${i.tooltip}\n ${i.suffix ? \"(\" + i.suffix + \")\" : \"\"}\n </div>`;\n }\n\n if (i.colorIcon) {\n if (_util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].isHexColor(i.colorIcon)) {\n icon = `<div class=\"mini-input-section--icon\" style=\"background:${i.colorIcon}\"> </div>`;\n } else {\n icon = `<div class=\"mini-input-section--icon ${i.colorIcon}\"> </div>`;\n }\n }\n\n str += `\n <div class=\"mini-input-section is-title\" input-tab-key=\"${i.tabKey || \"\"}\" label=\"${i.label}\">\n <label>\n ${icon}\n <div class=\"mini-input-section--title truncate\">\n ${i.label}\n </div>\n </label>\n ${tooltip}\n </div>`;\n } else {\n let value_found = value ? value.find(val => val.id == i.id) : null;\n let v = value_found || \"\";\n let inputValue = props.varNameInput && v[props.varNameInput] ? v[props.varNameInput] : v.value;\n let tooltip = \"\";\n let icon = \"\";\n let link = \"\";\n\n if (i.tooltip) {\n tooltip = `\n <div class=\"mini-input-section--tooltip\">\n ${i.tooltip}\n </div>`;\n }\n\n if (i.colorIcon) {\n if (_util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].isHexColor(i.colorIcon)) {\n icon = `<div class=\"mini-input-section--icon\" style=\"background:${i.colorIcon}\"> </div>`;\n } else {\n icon = `<div class=\"mini-input-section--icon ${i.colorIcon}\"> </div>`;\n }\n }\n\n if (i.link) {\n link = `<a class=\"mini-input-section--link\" target=\"_blank\" href=\"${i.link}\">\n ${_util_icons__WEBPACK_IMPORTED_MODULE_3__[\"default\"].linkIcon}\n </a> `;\n }\n\n str += `\n <div class=\"mini-input-section ${icon ? \"has-icon\" : \"\"}\" input-tab-key=\"${i.tabKey || \"\"}\" label=\"${i.label}\">\n <label>\n <input type=\"number\"\n class=\"mini-input\"\n input-id=\"${i.id || \"\"}\"\n input-key=\"${i.key || i.label}\"\n value=\"${inputValue || \"\"}\">\n\n ${icon || \"\"}\n\n <div class=\"mini-input-section--title truncate\">\n ${i.label}\n </div>\n\n <div class=\"mini-input-section--suffix\" >${i.suffix ? \"(\" + i.suffix + \")\" : \"\"}</div>\n\n ${link}\n\n </label>\n ${tooltip}\n </div>`;\n }\n });\n }\n\n str += `\n </div>\n </div> `;\n let $el = _util_domUtils__WEBPACK_IMPORTED_MODULE_0__[\"default\"].createElementFromHTML(str);\n let $tabs = $el.querySelectorAll(\".input-box-tab[tab-key]\") || [];\n let $inputs = $el.querySelectorAll(\"input.mini-input\") || [];\n let $searchInput = $el.querySelector(\".search-input\") || null;\n let $searchInputClear = $el.querySelector(\".search-input-clear\") || null;\n $tabs.forEach(t => {\n t.addEventListener(\"click\", e => {\n this.selectInputBoxTab(t, $el);\n $searchInput.value = \"\";\n $searchInput.dispatchEvent(new Event(\"input\", {\n bubbles: true\n }));\n });\n });\n\n if ($searchInputClear) {\n $searchInputClear.addEventListener(\"click\", e => {\n $searchInput.value = \"\";\n $searchInput.dispatchEvent(new Event(\"input\", {\n bubbles: true\n }));\n });\n }\n\n if ($searchInput) {\n $searchInput.addEventListener(\"keydown\", e => {\n if (e.key === \"Escape\") {\n $searchInput.value = \"\";\n $searchInput.dispatchEvent(new Event(\"input\", {\n bubbles: true\n }));\n }\n });\n $searchInput.addEventListener(\"input\", e => {\n let $tabSelected = $el.querySelector(\".input-box-tab[tab-key].active\") || null;\n let $inputs = [];\n\n if ($tabSelected) {\n let tabKey = $tabSelected.getAttribute(\"tab-key\");\n $inputs = $el.querySelectorAll(\".mini-input-section[input-tab-key='\" + tabKey + \"']\") || [];\n } else {\n $inputs = $el.querySelectorAll(\".mini-input-section\") || [];\n }\n\n $inputs.forEach($i => {\n let label = $i.getAttribute(\"label\");\n let search = $searchInput.value;\n\n if (label.toLowerCase().includes(search.toLowerCase())) {\n $i.classList.remove(\"hide\");\n } else {\n $i.classList.add(\"hide\");\n }\n });\n });\n }\n\n this.selectInputBoxTab(_.first($tabs), $el);\n $inputs.forEach(i => this.addKeyDownInputEvents(i, $el, props));\n return $el;\n },\n\n selectInputBoxTab($tab, $el) {\n let $tabs = $el.querySelectorAll(\".input-box-tab[tab-key]\") || [];\n let $inputSections = $el.querySelectorAll(\".mini-input-section\") || [];\n $tabs.forEach(t => {\n t.classList.remove(\"active\");\n });\n\n if ($tab) {\n $tab.classList.add(\"active\");\n $inputSections.forEach(i => {\n let key = i.getAttribute(\"input-tab-key\");\n\n if (key == $tab.getAttribute(\"tab-key\")) {\n i.classList.remove(\"hide\");\n } else {\n i.classList.add(\"hide\");\n }\n });\n }\n },\n\n /**\n * Crea Checkbox, como elemento Dom\n *\n * @param {Object} props - config para Input\n * @param {Object} dataDay - valores de item y Dia, opcional\n * @return {Object} Elemento Dom del input creado\n */\n createInputCheckbox(props, dataDay) {\n let value = \"\";\n\n if (dataDay && dataDay.values) {\n value = _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getVarByPath(dataDay, props.varName);\n }\n\n let r = _util_domUtils__WEBPACK_IMPORTED_MODULE_0__[\"default\"].createElementFromHTML(`\n <div class=\"input-section ${props.isHidden ? 'hide' : ''} \" input-key=\"${props.key || \"\"}\">\n <label>\n <input type=\"checkbox\" name=\"${props.key || \"\"}\" input-key=\"${props.key || \"\"}\" ${value ? \"checked\" : \"\"}>\n ${props.label}\n </label>\n </div>`);\n return r;\n },\n\n createInputButtonsGroup(props) {\n let $container = _util_domUtils__WEBPACK_IMPORTED_MODULE_0__[\"default\"].createElementFromHTML(`\n <div class=\"input-section ${props.isHidden ? 'hide' : ''} \" input-key=\"${props.key || \"\"}\">\n <div class=\"buttons-group\"> </div>\n </div>`);\n let $containerButtonGroup = $container.querySelector(\".buttons-group\");\n let $buttons = [];\n $buttons = props.buttons.map(buttonProp => {\n let buttonStr = `\n <button \n name=\"${buttonProp.key || \"\"}\" \n input-key=\"${buttonProp.key || \"\"}\"\n class=\"cap-btn-outline cap-btn-sm ${buttonProp.isSelected ? 'selected' : ''} \">\n ${buttonProp.label}\n </button>`;\n let $button = _util_domUtils__WEBPACK_IMPORTED_MODULE_0__[\"default\"].createElementFromHTML(buttonStr);\n $containerButtonGroup.append($button);\n $button.addEventListener(\"click\", e => {\n if (props.isSelectable) {\n $buttons.forEach($b => $b.classList.remove(\"selected\"));\n $button.classList.add(\"selected\");\n }\n\n buttonProp.onClick({\n props,\n event: e,\n buttonsElements: $buttons\n });\n });\n return $button;\n });\n return $container;\n },\n\n createInputButton(props) {\n let r = _util_domUtils__WEBPACK_IMPORTED_MODULE_0__[\"default\"].createElementFromHTML(`\n <div class=\"input-section ${props.isHidden ? 'hide' : ''} \" input-key=\"${props.key || \"\"}\">\n <button \n name=\"${props.key || \"\"}\"\n input-key=\"${props.key || \"\"}\"\n class=\"cap-btn-outline\">\n ${props.label}\n </button>\n </div>`);\n let button = r.querySelector(\"button\");\n button.addEventListener(\"click\", e => props.onClick({\n props,\n event: e\n }));\n return r;\n },\n\n addKeyDownInputEvents($input, $inputContainer, props) {\n $input.addEventListener(\"keydown\", function (event) {\n if (event.keyCode === 13) {\n //ENTER\n $input.dispatchEvent(new CustomEvent(\"saveMultiInput\", {\n bubbles: true,\n cancelable: false\n }));\n }\n\n if (event.keyCode === 27) {\n //ESC\n $input.dispatchEvent(new CustomEvent(\"cancelMultiInput\", {\n bubbles: true,\n cancelable: false\n }));\n }\n });\n $input.addEventListener(\"input\", e => {\n if (props.onInput) {\n props.onInput({\n event: e,\n value: e.srcElement.value,\n props,\n $element: $inputContainer\n });\n }\n });\n },\n\n createContextMenu({\n config,\n $capibaraElem = null,\n evt = null,\n date = null,\n item = null,\n selected = [],\n tabSelected = null,\n left = null,\n top = null,\n name = \"\"\n }) {\n if (config.timeline.contextMenu === undefined) return {\n elem: null,\n isVisible: false\n };\n let className = \"\";\n let style = \"\";\n let strHtml = \"\";\n let leftPosition = null;\n let topPosition = null;\n let isVisible = true;\n let boundRectCapibara = null;\n let gap = 15; //px\n\n if ($capibaraElem) {\n boundRectCapibara = $capibaraElem.getBoundingClientRect();\n }\n\n if (evt && boundRectCapibara) {\n left = evt.clientX;\n top = evt.clientY - boundRectCapibara.top;\n }\n\n if (left) {\n leftPosition = left;\n }\n\n if (top) {\n topPosition = top;\n }\n\n if (leftPosition !== null & topPosition !== null) {\n if (boundRectCapibara) {\n let transformStyle = \"\";\n\n if (topPosition > boundRectCapibara.height * 2 / 6 && topPosition <= boundRectCapibara.height * 4 / 6) {\n transformStyle += `translateY(-50%)`;\n }\n\n if (topPosition > boundRectCapibara.height * 4 / 6) {\n transformStyle += `translateY(-100%)`;\n }\n\n if (leftPosition > boundRectCapibara.width * 4 / 6) {\n transformStyle += `translateX(-100%)`;\n leftPosition -= gap;\n } else {\n leftPosition += gap;\n }\n\n if (transformStyle != \"\") {\n style += ` transform: ${transformStyle};`;\n }\n }\n\n style += `top: ${topPosition}px; left: ${leftPosition}px;`;\n } else {\n className += \"cm-hide\";\n isVisible = false;\n }\n\n strHtml += ` <div class=\"cap-context-menu-container ${className}\">\n <div class=\"cap-context-menu\" style=\"${style}\">\n </div>\n </div>`;\n let $contextMenuContainer = _util_domUtils__WEBPACK_IMPORTED_MODULE_0__[\"default\"].createElementFromHTML(strHtml);\n let $contextMenu = $contextMenuContainer.querySelector(\".cap-context-menu\");\n config.timeline.contextMenu.options.forEach(option => {\n if (option.showIf) {\n let show = option.showIf({\n item,\n date,\n selected,\n name,\n tabSelected\n });\n if (!show) return;\n }\n\n let isEnabled = true;\n let isClickeable = true;\n\n if (option.enableIf) {\n isEnabled = option.enableIf({\n item,\n date,\n selected,\n name,\n tabSelected\n });\n }\n\n let optionClassName = \"\";\n let strIcon = \"\";\n let label = \"\";\n\n if (!isEnabled) {\n optionClassName += \"is-disabled \";\n }\n\n if (option.isDivider) {\n isClickeable = false;\n optionClassName += \"is-divider \";\n }\n\n if (option.label) {\n label = `<span>${option.label}</span>`;\n }\n\n if (option.icon) {\n strIcon = `<div class=\"cap-context-menu_item_icon\">\n <svg viewBox=\"0 0 24 24\">\n <path d=\"${option.icon}\" />\n </svg>\n </div>`;\n }\n\n let optionStrHtml = `\n <div class=\"cap-context-menu_item ${optionClassName}\">\n ${strIcon}\n ${label}\n </div>`;\n let $option = _util_domUtils__WEBPACK_IMPORTED_MODULE_0__[\"default\"].createElementFromHTML(optionStrHtml);\n\n if (isEnabled && isClickeable) {\n $option.addEventListener(\"click\", evtClick => option.onClick({\n config,\n evt: evtClick,\n date,\n item,\n selected,\n tabSelected\n }));\n } else {\n $option.addEventListener(\"click\", evtClick => {\n evtClick.preventDefault();\n evtClick.stopPropagation();\n });\n }\n\n $contextMenu.append($option);\n });\n return {\n elem: $contextMenuContainer,\n isVisible\n };\n }\n\n});//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"./src/util/tableElements.js.js","sources":["webpack://Capibara/./src/util/tableElements.js?1d86"],"sourcesContent":["import dom from \"../util/domUtils\";\nimport utils from \"../util/utils\";\nimport dateUtils from \"../util/dateUtils\";\nimport icons from \"../util/icons\";\nimport domUtils from \"../util/domUtils\";\n\nexport default {\n  /**\n   * Crea elemento Table\n   * Contendrá los elementos que apareceran dentro de la tabla de planilla\n   * Se Usa para :\n   *    - Agregar background con patron estilo tabla\n   *    - Agregar dayMouseOver, div que indica posicion de mouse\n   *    - Agregar DetailDay, para detalles de datos en tabla\n   *    - Agregar SelectedContainer, para dias seleccionados\n   *    - Agregar FloatBoxContainer, para visualizacion de datos en tabla\n   *\n   * @param {Object} config - Configuracion capibara\n   * @return {Object} Elemento Dom creado\n   */\n  createAgTable(config) {\n    let e = dom.createElement(\"div\", { className: \"capibara\" });\n    if (config.timeline.dark) {\n      e.classList.add(\"dark-theme\");\n    }\n    if (config.timeline.header.extend.isShow) {\n      e.classList.add(\"header-extended\");\n    }\n    return e;\n  },\n\n  /**\n   * Recrea Background, que es el fondo grid, como tabla\n   *\n   * @param {Object} config - Configuracion capibara\n   * @param {Object} $elem - Elemento relacionado, donde se cre el background\n   * @return {Object} Elemento Dom Corner Footer\n   */\n  redrawBackground(config, $elem) {\n    return this.createBackground(config, $elem);\n  },\n\n  /**\n   * Crea y posiciona fondo de tabla\n   * Este fondo contiene un patron de CSS que le da la apariencia de tabla\n   * por lo cual se debe reposicionar segun la fecha de inicio, para hacer\n   * calzar los fines de semana\n   *\n   * @param {Object} config - Configuracion capibara\n   * @param {Object} [$elem = null] - Elemento background, si es null, lo crea\n   * @return {Object} elemento Dom Background\n   */\n  createBackground(config, $elem = null) {\n    let { height, width, dayWidth } = utils.getTableDimensions(config);\n\n    let start = new Date(config.timeline.start);\n    let end = new Date(config.timeline.end);\n\n    end.setTime(end.getTime() + dateUtils.dayInMilliseconds); // add 24 hours\n\n    let dCorrected = new Date(\n      start.valueOf() + start.getTimezoneOffset() * 60000\n    );\n    let weekDay = dCorrected.getDay();\n    let diffWeekDays = (weekDay - 1) * dayWidth * -1;\n\n    $elem = $elem || dom.createElement(\"div\", { className: \"background-grid\" });\n    $elem.style[\"background-position\"] =\n      diffWeekDays + \"px 0, 0 0, \" + diffWeekDays + \"px 0\";\n    $elem.style.width = width + \"px\";\n    $elem.style.height = height + 1 + \"px\";\n    return $elem;\n  },\n\n  /**\n   * Crea Plot Container Vertical\n   * Los plots son elementos que agregan secciones de fondo en la planilla\n   *\n   * @param {Object} config - Configuracion capibara\n   * @return {Object} Elemento Dom plotVerticalContainer\n   */\n  createPlotVerticalContainer(config) {\n    let $elem = dom.createElement(\"div\", {\n      className: \"plot-vertical-container\"\n    });\n    return this.redrawPlotVerticalContainer(config, $elem);\n  },\n\n  createPlotHorizontalContainer(config) {\n    let $elem = dom.createElement(\"div\", {\n      className: \"plot-horizontal-container\"\n    });\n    return this.redrawPlotHorizontalContainer(config, $elem);\n  },\n\n  /**\n   * Recrea plotVerticalContainer, usando elemento existente\n   * usa un elemento existente para usar la funcion para redibujar el elemento\n   *\n   * Los Plots se insertan como divs, con posicion especificada,\n   * con ancho de dia\n   *\n   * @param {Object} config - Configuracion capibara\n   * @param {Object} $elem - Elemento Dom donde crea plotVerticalContainer\n   * @return {Object} Elemento Dom plotVerticalContainer\n   */\n  redrawPlotVerticalContainer(config, $elem) {\n    $elem.innerHTML = \"\";\n    if (config.timeline.plots && config.timeline.plots.vertical) {\n      let { height, dayWidth } = utils.getTableDimensions(config);\n\n      config.timeline.plots.vertical.forEach((p) => {\n        let diffDays = Math.floor(\n          dateUtils.diffDays(config.timeline.start, p.date)\n        );\n        let left = diffDays * dayWidth;\n        let plot = dom.createElement(\"div\", {\n          classNames: [\"plot-vertical\", p.className || \"\"],\n          style: {\n            \"margin-left\": left + \"px\",\n            height: height + \"px\"\n          }\n        });\n        $elem.appendChild(plot);\n      });\n    }\n    return $elem;\n  },\n\n  redrawPlotHorizontalContainer(config, $elem) {\n    $elem.innerHTML = \"\";\n    if (config.timeline.plots && config.timeline.plots.horizontal) {\n      let { width, itemHeight } = utils.getTableDimensions(config);\n      config.timeline.plots.horizontal.forEach((p) => {\n        let item = utils.getItemById(config, p.idNode, p.typeNode);\n        let topPosition = utils.getPositionByItem(config, item, \"parent\");\n        let plot = dom.createElement(\"div\", {\n          classNames: [\"plot-horizontal\", p.className || \"\"],\n          style: {\n            \"margin-top\": topPosition * itemHeight + \"px\",\n            width: width + \"px\"\n          }\n        });\n        $elem.appendChild(plot);\n      });\n    }\n    return $elem;\n  },\n\n  /**\n   * Crea Corner Izquierdo\n   * Se usa para :\n   *    - titulos relacionados con los datos del sidebar izquierdo\n   *    - titulos para inputs de header, absolute a la derecha\n   *    - boton para mostrar/ocultar sidebar izquierdo\n   *    - promedios\n   *\n   * @param {Object} config - Configuracion capibara\n   * @return {Object} Elemento Dom Corner\n   */\n  createCorner(config, tab = null) {\n    let $elem = dom.createElement(\"div\", { className: \"corner\" });\n    return this.redrawCorner($elem, config, tab);\n  },\n\n  redrawCorner($elem, config, tab = null) {\n    let labelsInitialCorner = config.timeline.nav.left.initial.vars\n      .filter(\n        (v) =>\n          v.onlyTab == undefined || (v.onlyTab && tab && v.onlyTab == tab.key)\n      )\n      .map((d) => `<span class=\"item-col\">${d.label}</span>`)\n      .join(\"\");\n\n    let labelsExtendCorner = config.timeline.nav.left.extend.vars\n      .filter(\n        (v) =>\n          v.onlyTab == undefined || (v.onlyTab && tab && v.onlyTab == tab.key)\n      )\n      .map((d) => `<span class=\"item-col\">${d.label}</span>`)\n      .join(\"\");\n\n    let labelsHeaderExtend = config.timeline.header.extend.data\n      .map((d) => {\n        if (d.isHidden) return \"\";\n\n        let avg = \"\";\n        let tooltip = \"\";\n        let className = \"\";\n        let isAccent = d.isAccent;\n\n        if (d.average) {\n          avg = ` <span class=\"average \"> ( <span> <span class=\"symbol\">x̄</span> ${d.average} </span>)  </span>   `;\n\n          tooltip = `cap-tooltip=\"Promedio ${d.label} : ${d.average} ${\n            d.suffix || \"\"\n          }\"`;\n        }\n\n        if (d.color) {\n          if (isAccent) {\n            className = d.color ? \"c-\" + d.color + \"--background\" : \"\";\n          } else {\n            className = d.color ? \"c-\" + d.color + \"--text \" : \"\";\n          }\n        }\n\n        return `<div class=\"input-title-container ${\n          isAccent ? \"input-title--accent\" : \"\"\n        } ${d.isPersistent ? \"persistent\" : \"\"}\">\n                                  <span ${tooltip} class=\"input-title ${className}\">\n                                    ${avg}\n                                    ${d.label}\n                                  </span>\n\n                                </div>`;\n      })\n      .join(\"\");\n\n    let toggleSidebarBtnString = `\n          <button toggle-sidebar class=\"cap-btn-icon cap-btn-icon-raised cap-btn-toggle-sidebar \">\n          ${icons.chevronRight}\n          </button> `;\n\n    if (config.timeline.nav.left.hideToggleSidebarButton) {\n      toggleSidebarBtnString = \"\";\n    }\n\n    let template = `<div>\n\n          ${toggleSidebarBtnString}\n        <div class=\"corner-title\">\n          <span class=\"bottom-text\">\n            ${config.timeline.corner.left.label}\n          </span>\n        </div>\n\n        <div class=\"initial-corner\">\n          <div class=\"initial-corner-title\">\n            <span class=\"bottom-container hide\">\n              ${config.timeline.corner.initial.label}\n            </span>\n\n            <div class=\"bottom-container\">\n              ${labelsInitialCorner}\n            </div>\n\n          </div>\n        </div>\n\n\n        <div class=\"extend-corner\">\n          <div class=\"ex-corner-title\">\n            <span class=\"bottom-container hide\">\n              ${config.timeline.corner.extend.label}\n            </span>\n\n            <div class=\"bottom-container\">\n              ${labelsExtendCorner}\n            </div>\n\n          </div>\n        </div>\n\n\n        <div class=\"cap-btn-nav-corner\">\n          <div class=\"input-titles\">\n              ${labelsHeaderExtend}\n          </div>\n        </div>\n\n        <div class=\"progress-bar progress-bar-left hide-progress\"></div>\n\n      </div>`;\n\n    let r = dom.createElementFromHTML(template);\n\n    $elem.innerHTML = \"\";\n    $elem.append(r);\n\n    let toggleSidebar = $elem.querySelector(\"[toggle-sidebar]\");\n    if (toggleSidebar) {\n      toggleSidebar.addEventListener(\"click\", (e) => {\n        r.dispatchEvent(\n          new CustomEvent(\"toggleSidebar\", {\n            bubbles: true,\n            cancelable: false\n          })\n        );\n      });\n    }\n\n    return $elem;\n  },\n\n  /**\n   * Crea Corner Derecho\n   * Se usa para :\n   *    - titulos relacionados con los datos del sidebar Derecho\n   *\n   * @param {Object} config - Configuracion capibara\n   * @return {Object} Elemento Dom corner\n   */\n  createCornerRight(config, tab = null) {\n    let $elem = dom.createElement(\"div\", { classNames: [\"corner\", \"right\"] });\n    return this.redrawCornerRight($elem, config, tab);\n  },\n\n  redrawCornerRight($el, config, tab = null) {\n    let label = \"\";\n\n    if (config.timeline.corner.right.label) {\n      ` <span>\n            ${config.timeline.corner.right.label}\n          </span>`;\n    }\n\n    let str = `\n        <div class=\"corner-title\">\n        ${label}\n        <div class=\"btn-container\"></div>\n        </div>\n        <div class=\"progress-bar progress-bar-right hide-progress\"></div>\n    `;\n    $el.innerHTML = str.trim();\n    let $btnContainer = $el.querySelector(\".btn-container\");\n\n    if (config.timeline.corner.right.buttons) {\n      config.timeline.corner.right.buttons.forEach((btn) => {\n        let isEnabled = btn.getIsEnabled ? btn.getIsEnabled() : true;\n        if (isEnabled) {\n          let $btn = dom.createElementFromHTML(`\n                        <button class=\"corner-btn cap-btn-raised\">\n                          ${btn.label || \"\"}\n                        </button> `);\n\n          if (btn.onClick) {\n            $btn.addEventListener(\"click\", btn.onClick);\n          }\n\n          $btnContainer.appendChild($btn);\n        }\n      });\n    }\n    if (config.timeline.corner.right.inputs) {\n      config.timeline.corner.right.inputs.forEach((input) => {\n        let $input = this.createCornerRightInput({ inputConfig: input });\n        $btnContainer.appendChild($btn);\n      });\n    }\n    return $el;\n  },\n\n  createCornerRightInput({ inputConfig, dataDay = null, daySelected = null }) {\n    let r = null;\n    switch (inputConfig.type) {\n      case \"autocomplete-crud\":\n        r = this.createCornerRightInputAutocompleteCrud({\n          inputConfig,\n          dataDay,\n          daySelected\n        });\n        break;\n    }\n    return r;\n  },\n\n  createCornerRightInputAutocompleteCrud({\n    inputConfig,\n    dataDay,\n    daySelected\n  }) {\n    let elem = \"test\";\n    return elem;\n  },\n\n  /**\n   * Crea Header Top\n   * Se usa para :\n   *    - Manejo de tabs\n   *    - Botones de navegación y selección de fecha\n   *    - Boton toggle Dark mode\n   *    - Boton toggle Header extended\n   *\n   * @param {Object} config - Configuracion capibara\n   * @return {Object} Elemento Dom\n   */\n\n  createHeaderTop(config, tabSelected = null) {\n    return this.redrawHeaderTop(config, tabSelected, dom.createElement(\"div\"));\n  },\n\n  redrawHeaderTop(config, tabSelected = null, $elem) {\n    let str = `\n      <div class=\"header-top\">`;\n\n    if (config.timeline.tabs) {\n      let showTabs = true;\n\n      if (config.timeline.tabs.filter((t) => !t.isHidden).length == 0) {\n        showTabs = false;\n      }\n\n      if (showTabs) {\n        str += ` <div class=\"tab-select-container c-d-desktop-none c-d-mobile-flex\">\n                  <select class=\"tabs-select\" >`;\n\n        config.timeline.tabs.forEach((tab) => {\n          if (!tab.isHidden) {\n            str += ` <option ${\n              tab == tabSelected ? 'selected=\"selected\"' : \"\"\n            } value=\"${tab.id}\"> ${tab.label} </option>`;\n          }\n        });\n\n        str += `</select> </div>`;\n\n        str += ` <div class=\"tabs-container c-d-desktop-flex c-d-mobile-none\">`;\n\n        config.timeline.tabs.forEach((tab) => {\n          if (!tab.isHidden) {\n            str += ` <button\n                        class=\"tab ${tab.disabled ? \"disabled\" : \"\"}  ${\n                          tab == tabSelected ? \"active\" : \"\"\n                        }  ${tab.color}\"\n                        color=\"${tab.color}\"\n                        input-key=\"${tab.id}\"\n                        ${\n                          tab.tooltip ? 'cap-tooltip=\"' + tab.tooltip + '\"' : \"\"\n                        } >\n                    <span>${tab.label}</span>\n                    ${tab.icon || \"\"}\n                  </button>\n                  `;\n          }\n        });\n\n        str += `</div>`;\n      }\n    }\n\n    if (tabSelected) {\n      if (tabSelected.legends) {\n        str += ` \n        <button toggle-legends class=\"cap-btn-icon cap-btn-icon-raised \">\n          ${icons.toggleLegends}\n        </button> \n\n        <div class=\"legends-container force-mobile-style hide\"> `;\n\n        tabSelected.legends.forEach((legend) => {\n          let colorClass = \"\";\n          let colorBg = \"\";\n\n          if (utils.isHexColor(legend.color)) {\n            colorBg = \"background:\" + legend.color;\n          } else {\n            colorClass = legend.color ? legend.color + \"--background\" : \"\";\n          }\n\n          str += ` <div\n                      class=\"legend ${legend.active ? \"active\" : \"\"}\"\n                      input-key=\"${legend.key}\"\n                      ${\n                        legend.tooltip ? `cap-tooltip=\"${legend.tooltip}\"` : \"\"\n                      } >\n                  <div class=\"icon-legend ${colorClass} ${\n                    legend.shape\n                  }\" style=\"${colorBg}\"></div>\n                  <span>${legend.label}</span>\n                </div>`;\n        });\n\n        str += `</div>`;\n      }\n    }\n\n    str += `\n\n          <div class=\"spacer\"></div>\n\n\n\n          <button cap-btn-prev class=\"cap-btn-icon cap-btn-icon-raised\">\n             ${icons.arrowLeft}\n             ${icons.loadingIcon} \n          </button>\n\n\n          <button cap-btn-calendar class=\"cap-btn-icon cap-btn-icon-raised\">\n            ${icons.calendar}\n            ${icons.loadingIcon}\n          </button>\n\n          <button cap-btn-next class=\"cap-btn-icon cap-btn-icon-raised\">\n            ${icons.arrowRight}\n            ${icons.loadingIcon}\n          </button>\n\n          <div class=\"spacer\"></div>\n\n          <button toggle-dark class=\"cap-btn-icon cap-btn-header c-d-mobile-none ${\n            config.timeline.withDarkToggle == false ? \"hide\" : \"\"\n          }\">\n            ${icons.dark}\n            ${icons.light}\n          </button>`;\n\n    if (config.timeline.header.extend.enabled !== false) {\n      str += `<button toggle-header class=\"cap-btn-icon cap-btn-icon-raised\">\n          ${icons.chevronDown}\n          </button>`;\n    }\n\n    str += ` <div class=\"button-right-container\"></div>\n        </div>`;\n    /*\n          `\n          <button toggle-sidebar-right class=\"cap-btn-icon cap-btn-icon-raised\">\n            <span>\n              <svg style=\"width:24px;height:24px\" viewBox=\"0 0 24 24\">\n                  <path fill=\"currentColor\" d=\"M15.41,16.58L10.83,12L15.41,7.41L14,6L8,12L14,18L15.41,16.58Z\" />\n              </svg>\n            </span>\n          </button>\n\n      </div>\n    `;\n    */\n\n    let $r = dom.createElementFromHTML(str);\n    $elem.replaceWith($r);\n\n    if (config.timeline.header.rightButtons) {\n      let $buttonContainer = $r.querySelector(\".button-right-container\");\n      config.timeline.header.rightButtons.forEach((button) => {\n        let hasBadge = false;\n        if (button.hasBadge) {\n          hasBadge = button.hasBadge();\n        }\n        let str = `<button class=\"cap-btn-icon cap-btn-icon-raised ${\n          hasBadge ? \"cap-btn-has-badge\" : \"\"\n        }\">\n            <span>\n              <svg style=\"width:24px;height:24px\" viewBox=\"0 0 24 24\">\n                  <path fill=\"currentColor\" d=\"${button.icon}\" />\n              </svg>\n            </span>\n          </button>`;\n        let $button = dom.createElementFromHTML(str);\n        $button.addEventListener(\"click\", (evt) => button.onClick({ evt }));\n        $buttonContainer.append($button);\n      });\n    }\n\n    let $toggleDark = $r.querySelector(\"[toggle-dark]\");\n    if ($toggleDark) {\n      $toggleDark.addEventListener(\"click\", (e) => {\n        $r.dispatchEvent(\n          new CustomEvent(\"toggleDark\", {\n            bubbles: true,\n            cancelable: false\n          })\n        );\n      });\n    }\n\n    let $btnCalendar = $r.querySelector(\"[cap-btn-calendar]\");\n    if ($btnCalendar) {\n      $btnCalendar.addEventListener(\"click\", (e) => {\n        let x = e.x;\n        let y = e.y;\n        $r.dispatchEvent(\n          new CustomEvent(\"clickCalendarIcon\", {\n            bubbles: true,\n            cancelable: false,\n            detail: { x, y }\n          })\n        );\n      });\n    }\n\n    let $btnToggleHeader = $r.querySelector(\"[toggle-header]\");\n    if ($btnToggleHeader) {\n      $btnToggleHeader.addEventListener(\"click\", (e) => {\n        $r.dispatchEvent(\n          new CustomEvent(\"toggleHeader\", {\n            bubbles: true,\n            cancelable: false\n          })\n        );\n      });\n    }\n\n    /*\n    $r.querySelector(\"[toggle-sidebar-right]\").addEventListener(\"click\", e => {\n      $r.dispatchEvent(new CustomEvent(\"toggleSidebarRight\", {\n        bubbles: true,\n        cancelable: false,\n      }));\n    });\n    */\n\n    $r.querySelector(\"[cap-btn-prev]\").addEventListener(\"click\", (e) => {\n      $r.dispatchEvent(\n        new CustomEvent(\"headerPrev\", {\n          bubbles: true,\n          cancelable: false,\n          detail: {\n            originalEvt: e\n          }\n        })\n      );\n    });\n\n    $r.querySelector(\"[cap-btn-calendar]\").addEventListener(\"click\", (e) => {\n      $r.dispatchEvent(\n        new CustomEvent(\"headerCalendar\", {\n          bubbles: true,\n          cancelable: false,\n          detail: {\n            originalEvt: e\n          }\n        })\n      );\n    });\n\n    $r.querySelector(\"[cap-btn-next]\").addEventListener(\"click\", (e) => {\n      $r.dispatchEvent(\n        new CustomEvent(\"headerNext\", {\n          bubbles: true,\n          cancelable: false,\n          detail: {\n            originalEvt: e\n          }\n        })\n      );\n    });\n\n    let $toggleLegendsBtn = $r.querySelector(\"[toggle-legends]\");\n    if ($toggleLegendsBtn) {\n      $toggleLegendsBtn.addEventListener(\"click\", (e) => {\n        let $legendContainer = $r.querySelector(\".legends-container\");\n        if ($legendContainer) {\n          $legendContainer.classList.toggle(\"hide\");\n        }\n      });\n    }\n\n    $r.querySelectorAll(\".legend\").forEach(($legend) => {\n      $legend.addEventListener(\"click\", (e) => {\n        let key = e.currentTarget.getAttribute(\"input-key\");\n\n        if (key) {\n          let legendSelected = tabSelected.legends.find(\n            (tab) => tab.key === key\n          );\n          if (legendSelected) {\n            $r.dispatchEvent(\n              new CustomEvent(\"selectLegendHeader\", {\n                bubbles: true,\n                cancelable: false,\n                detail: {\n                  legend: legendSelected,\n                  $legend\n                }\n              })\n            );\n          }\n        }\n      });\n    });\n\n    $r.querySelectorAll(\".tab:not(.disabled)\").forEach(($tab) => {\n      $tab.addEventListener(\"click\", (e) => {\n        let key = e.currentTarget.getAttribute(\"input-key\");\n\n        if (key) {\n          let tabSelected = config.timeline.tabs.find((tab) => tab.id == key);\n          if (tabSelected) {\n            $r.dispatchEvent(\n              new CustomEvent(\"selectTabHeader\", {\n                bubbles: true,\n                cancelable: false,\n                detail: {\n                  tab: tabSelected\n                }\n              })\n            );\n          }\n        }\n      });\n    });\n\n    $r.querySelectorAll(\".tabs-select:not(.disabled)\").forEach(($tab) => {\n      $tab.addEventListener(\"change\", (e) => {\n        let key = parseFloat(e.currentTarget.value);\n\n        if (key) {\n          let tabSelected = config.timeline.tabs.find((tab) => tab.id == key);\n          if (tabSelected) {\n            $r.dispatchEvent(\n              new CustomEvent(\"selectTabHeader\", {\n                bubbles: true,\n                cancelable: false,\n                detail: {\n                  tab: tabSelected\n                }\n              })\n            );\n          }\n        }\n      });\n    });\n\n    return $r;\n  },\n\n  /**\n   * Crea Header\n   * Se usa para :\n   *    - Mostrar fechas en header\n   *\n   * @param {Object} config - Configuracion capibara\n   * @return {Object} Elemento Dom\n   */\n  createHeader(config) {\n    let $elem = dom.createElement(\"header\");\n    return this.redrawHeader(config, $elem);\n  },\n\n  /**\n   * Recrea Header, usado para redibujar\n   * utiliza $elem como elemento dom donde recrearlo\n   *\n   * @param {Object} config - Configuracion capibara\n   * @param {Object} $elem - Elemento Dom donde crea Header\n   * @return {Object} Elemento Dom\n   */\n  redrawHeader(config, $elem) {\n    let datesTree = dateUtils.getDateTreeRange(\n      new Date(config.timeline.start),\n      new Date(config.timeline.end)\n    );\n\n    let str = `<div class=\"header-container\"> `;\n\n    Object.keys(datesTree).forEach((keyY) => {\n      let year = datesTree[keyY];\n      str += `<div class=\"agno-calendario\">\n              <span class=\"agno hide\">${keyY}</span>\n              <div class=\"meses\">`;\n\n      Object.keys(year).forEach((keyM) => {\n        let month = datesTree[keyY][keyM];\n        str += ` <div class=\"mes-calendario\">\n                    <div class=\"mes ${\n                      Object.keys(month).length < 4\n                        ? \"mes-reduced mes-reduced-\" + Object.keys(month).length\n                        : \"\"\n                    }\">\n                      <div class=\"mes-label\">\n                        ${utils.getMonthByPosition(keyM)} ${keyY}\n                      </div>\n                    </div>\n                    <div class=\"dias\">`;\n        Object.keys(month).forEach((keyD) => {\n          let day = datesTree[keyY][keyM][keyD];\n          let isWeekend = day.isWeekend;\n          let isToday = day.isToday;\n          let date = dateUtils.formatDate(day.Date);\n          str += `<div class=\"dia-calendario ${isToday ? \"today\" : \"\"}  ${\n            isWeekend ? \"weekend\" : \"\"\n          } ${\n            config.timeline.dateSelectable ? \"is-clickeable\" : \"\"\n          }\" date=\"${date}\">${keyD}</div>`;\n        });\n        str += `</div></div>`;\n      });\n      str += `</div> </div>`;\n    });\n\n    str += `</div>`;\n    $elem.innerHTML = \"\";\n    $elem.append(dom.createElementFromHTML(str));\n\n    if (config.timeline.dateSelectable) {\n      $elem.querySelectorAll(\".dia-calendario[date]\").forEach(($dia) => {\n        $dia.addEventListener(\"contextmenu\", (evt) => {\n          $elem.dispatchEvent(\n            new CustomEvent(\"contextMenuDate\", {\n              bubbles: true,\n              cancelable: false,\n              detail: {\n                $elem: $dia,\n                date: $dia.getAttribute(\"date\"),\n                clientX: evt.clientX,\n                clientY: evt.clientY\n              }\n            })\n          );\n        });\n\n        $dia.addEventListener(\"click\", (evt) => {\n          $elem.dispatchEvent(\n            new CustomEvent(\"clickDate\", {\n              bubbles: true,\n              cancelable: false,\n              detail: {\n                $elem: $dia,\n                date: $dia.getAttribute(\"date\")\n              }\n            })\n          );\n        });\n      });\n    }\n\n    return $elem;\n  },\n\n  /**\n   * Crea Header extended\n   * Se usa para :\n   *    -Mostrar inputs y datos para fechas en header\n   *\n   * @param {Object} config - Configuracion capibara\n   * @return {Object} Elemento Dom headerExtended\n   */\n  createHeaderExtended(config) {\n    if (config.timeline.header.extend.enabled == false) return null;\n\n    let dates = dateUtils.getDateRange(\n      new Date(config.timeline.start),\n      new Date(config.timeline.end)\n    );\n    let str = `<div class=\"header-container-extended\">`;\n\n    config.timeline.header.extend.data.forEach((d, d_index) => {\n      if (d.isHidden) return \"\";\n\n      let isPersistent = d.isPersistent;\n      str += `<div class=\"input-list ${isPersistent ? \"persistent\" : \"\"}\">`;\n      str += dates\n        .map((date) => {\n          let value = \"\";\n          let isFuture = dateUtils.isFuture(date);\n          let isToday = dateUtils.isToday(date);\n\n          if (d.data) {\n            let dataFounded = d.data.find((dataInput) => {\n              return dateUtils.isSameDate(new Date(dataInput.date), date);\n            });\n            if (dataFounded) {\n              value = dataFounded.value || \"\";\n            }\n          }\n\n          if (\n            d.editable === false ||\n            (isFuture && d.editableFuture == false) ||\n            (isToday && d.editableToday == false)\n          ) {\n            return `<div>\n                      <span date=\"${date}\" \n                            index=\"${d_index}\" \n                            class=\"${date.varName} ${\n                              d.color ? \"c-\" + d.color + \"--text\" : \"\"\n                            }\" > \n                            ${value} \n                            </span>\n                    </div>`;\n          }\n\n          let isDisabled = false;\n          if (config.timeline.editable === false) {\n            isDisabled = true;\n          }\n\n          return `<div class=\"dia-input\">\n                  <input \n                  date=\"${date}\" \n                  index=\"${d_index}\" \n                  class=\"header-input \n                  ${date.varName} ${d.color ? \"c-\" + d.color + \"--text\" : \"\"}\" \n                  type=\"number\"\n                  ${isDisabled ? \"disabled\" : \"\"} \n                  value=\"${value}\">\n                </div>`;\n        })\n        .join(\"\");\n      str += `</div>`;\n    });\n\n    str += `</div>`;\n\n    let r = dom.createElementFromHTML(str);\n\n    r.querySelectorAll(\"input.header-input\").forEach((input) => {\n      input.addEventListener(\"input\", (e) => {\n        let date = e.currentTarget.getAttribute(\"date\");\n        let index = e.currentTarget.getAttribute(\"index\");\n        let value = e.currentTarget.value;\n        let typeData = config.timeline.header.extend.data[index];\n\n        //refresh config value\n        let data = typeData.data.find((d) =>\n          dateUtils.isSameDate(new Date(d.date), new Date(date))\n        );\n        data.value = value;\n\n        r.dispatchEvent(\n          new CustomEvent(\"changeInputHeader\", {\n            bubbles: true,\n            cancelable: false,\n            detail: {\n              date: date,\n              typeData: typeData,\n              value: value\n            }\n          })\n        );\n      });\n    });\n\n    return r;\n  },\n\n  /**\n   * Crear Sidebar Izquierdo\n   *    - Maneja items como arbol de 2 niveles (parent, children)\n   *    - El sidebar se divide en navList - InitialNav - extendedNav - BtnNav\n   *    - Se agrega itemDetail, para detalles de items\n   *\n   *\n   * TODO: para evitar incrustar las ids en los inputs, se deben crear\n   * los nodos uno por uno como elemento DOM, y agregarles los eventos directamente\n   * ahora se hace seleccionando todos los inputs con querySelectorAll\n   *\n   * @param {Object} config - Configuracion capibara\n   * @return {Object} Elemento Dom Sidebar Izquierdo\n   */\n  createNavLeft(config, tab = null) {\n    let $elem = dom.createElement(\"nav\", { className: \"left\" });\n    return this.redrawNavLeft($elem, config, tab);\n  },\n\n  /**\n   * Recrea Sidebar izquierdo, usado para redibujar\n   * Utiliza $elem como elemento dom donde recrearlo\n   *\n   *\n   * @param {Object} $elem - Elemento Dom donde crea el sidebar izquierdo\n   * @param {Object} config - Configuracion capibara\n   * @return {Object} Elemento Dom navLeft\n   */\n\n  redrawNavLeft($elem, config, tab = null) {\n    let navList = \"\";\n    let initialNavList = \"\";\n    let exNavList = \"\";\n    let btnNavList = \"\";\n    let isDisabled = false;\n    if (config.timeline.editable === false) {\n      isDisabled = true;\n    }\n\n    config.data.forEach((d) => {\n      if (d.isHidden) return;\n\n      navList += `\n       <div class=\"nav-item\">\n\n\n        <div class=\"nav-item-container parent\">`;\n\n      if (d.children) {\n        navList += `<button class=\"tree-icon ${\n          d.isClosed ? \"\" : \"cap-rotate\"\n        }\" item-id=\"${d.id || -1}\" type-node=\"${d.type || \"\"}\" >\n        ${icons.chevronDown}\n                       </button>`;\n      }\n\n      navList += `\n          <div class=\"item-title truncate full-width ${\n            d.clickeable ? \"clickeable\" : \"\"\n          }\n                      ${d.navOver ? \"hoverable\" : \"\"} \" item-id=\"${\n                        d.id || -1\n                      }\" type-node=\"${d.type || \"\"}\" >\n            ${d.label}\n          </div>\n        </div>`;\n\n      if (d.children) {\n        navList += `\n              <div class=\"children-items ${\n                d.isClosed ? \"hide\" : \"\"\n              } \" child-list=\"${d.id || -1}\">`;\n\n        d.children.forEach((c) => {\n          if (c.isHidden) return;\n\n          navList += `\n                <div class=\"child-nav-item\">\n                  <div class=\"nav-item-container\">\n                    `;\n\n          /*\n                    <span class=\"nav-item-icon\">\n                      <svg style=\"width:24px;height:24px\" viewBox=\"0 0 24 24\">\n                          <path fill=\"currentColor\" d=\"M19,15L13,21L11.58,19.58L15.17,16H4V4H6V14H15.17L11.58,10.42L13,9L19,15Z\" />\n                      </svg>\n                    </span>\n                      */\n\n          navList += `\n                    ${\n                      c.light\n                        ? '<span class=\"light ' +\n                          (c.light ? c.light + \"-light\" : \"\") +\n                          '\"></span>'\n                        : \"\"\n                    }\n\n                    <div class=\"item-title ${c.clickeable ? \"clickeable\" : \"\"}\n                      ${c.navOver ? \"hoverable\" : \"\"}\" item-id=\"${\n                        c.id || -1\n                      }\" type-node=\"${c.type || \"\"}\">\n                      <div class=\"truncate\">\n                        ${c.label}\n                      </div>\n                    </div>\n                  </div>\n                </div>`;\n        });\n\n        navList += `\n              </div>`;\n      }\n\n      navList += `</div>`;\n\n      //initial\n      initialNavList += `<div class=\"initial-nav-item parent\">`;\n      if (d.withNav) {\n        config.timeline.nav.left.initial.vars.forEach((v) => {\n          let value = utils.getVarByPath(d.values, v.varName);\n\n          if (v.round && !isNaN(value)) {\n            value = utils.round(value, v.round);\n          }\n          if (v.input) {\n            switch (v.input) {\n              case \"hour\":\n                value = value.split(\":\");\n                let hhValue = value[0];\n                let mmValue = value[1];\n                initialNavList += `\n                            <div class=\"item-col has-input\">\n                              <div class=\"hour-input\">\n                                <input type=\"number\"\n                                      input-type=\"time\"\n                                      max=\"23\"\n                                      min=\"00\"\n                                      input-key=\"${v.key || \"\"}\"\n                                      item-id=\"${d.id || -1}\"\n                                      type-node=\"${d.type || \"\"}\"\n                                      value=\"${hhValue}\"\n                                      ${isDisabled ? \"disabled\" : \"\"}\n                                      class=\"hh\">\n                                <span>:</span>\n                                <input type=\"number\"\n                                      input-type=\"time\"\n                                      max=\"59\"\n                                      min=\"00\"\n                                      input-key=\"${v.key || \"\"}\"\n                                      item-id=\"${d.id || -1}\"\n                                      type-node=\"${d.type || \"\"}\"\n                                      value=\"${mmValue}\"\n                                      ${isDisabled ? \"disabled\" : \"\"}\n                                      class=\"mm\">\n                              </div>\n                            </div>`;\n                break;\n              case \"text\":\n              case \"number\":\n              default:\n                initialNavList += `\n                            <div class=\"item-col has-input\">\n                              <input  \n                                      type=\"${v.input || \"text\"}\"\n                                      input-type=\"${v.input || \"text\"}\"\n                                      input-key=\"${v.key || \"\"}\"\n                                      item-id=\"${d.id || -1}\"\n                                      type-node=\"${d.type || \"\"}\"\n                                      ${isDisabled ? \"disabled\" : \"\"}\n                                      value=\"${value}\"/>\n                            </div>`;\n            }\n          } else {\n            initialNavList += `\n                          <div class=\"item-col\">\n                            ${value}\n                          </div>`;\n          }\n        });\n      }\n\n      initialNavList += `\n                  </div>`;\n\n      if (d.children) {\n        d.children.forEach((c) => {\n          if (c.isHidden) return;\n          initialNavList += `<div class=\"child-initial-nav-item ${\n            d.isClosed ? \"hide\" : \"\"\n          }\" child=\"${d.id || -1}\">`;\n\n          if (c.withNav !== false) {\n            config.timeline.nav.left.initial.vars.forEach((v) => {\n              if (v.onlyTab && tab && v.onlyTab !== tab.key) return;\n\n              let value = utils.getVarByPath(c.values, v.varName);\n              if (v.round && !isNaN(value)) {\n                value = utils.round(value, v.round);\n              }\n              if (v.input) {\n                switch (v.input) {\n                  case \"hour\":\n                    value = value.split(\":\");\n                    let hhValue = value[0];\n                    let mmValue = value[1];\n                    initialNavList += `\n                                  <div class=\"item-col has-input\">\n                                    <div class=\"hour-input\">\n                                      <input type=\"number\"\n                                            input-type=\"time\"\n                                            max=\"23\"\n                                            min=\"00\"\n                                            input-key=\"${v.key || \"\"}\"\n                                            item-id=\"${c.id || -1}\"\n                                            type-node=\"${c.type || \"\"}\"\n                                            value=\"${hhValue}\"\n                                            ${isDisabled ? \"disabled\" : \"\"}\n                                            class=\"hh\">\n                                      <span>:</span>\n                                      <input type=\"number\"\n                                            input-type=\"time\"\n                                            max=\"59\"\n                                            min=\"00\"\n                                            input-key=\"${v.key || \"\"}\"\n                                            item-id=\"${c.id || -1}\"\n                                            type-node=\"${c.type || \"\"}\"\n                                            value=\"${mmValue}\"\n                                            ${isDisabled ? \"disabled\" : \"\"}\n                                            class=\"mm\">\n                                    </div>\n                                  </div>`;\n                    break;\n                  case \"text\":\n                  case \"number\":\n                  default:\n                    initialNavList += `\n                                  <div class=\"item-col has-input\">\n                                    <input\n                                            type=\"${v.input || \"text\"}\"\n                                            input-type=\"${v.input || \"text\"}\"\n                                            input-key=\"${v.key || \"\"}\"\n                                            item-id=\"${c.id || -1}\"\n                                            type-node=\"${c.type || \"\"}\"\n                                            ${isDisabled ? \"disabled\" : \"\"}\n                                            value=\"${value}\"/>\n                                  </div>`;\n                }\n              } else {\n                initialNavList += `\n                                <div class=\"item-col\">\n                                  ${value}\n                                </div>`;\n              }\n            });\n          }\n          initialNavList += `\n                      </div>`;\n        });\n      }\n\n      //Ext\n      exNavList += `<div class=\"ex-nav-item parent\">`;\n      if (d.withExNav) {\n        config.timeline.nav.left.extend.vars.forEach((v) => {\n          let value = utils.getVarByPath(d.values, v.varName);\n          if (v.round && !isNaN(value)) {\n            value = utils.round(value, v.round);\n          }\n          if (v.input) {\n            switch (v.input) {\n              case \"hour\":\n                value = value.split(\":\");\n                let hhValue = value[0];\n                let mmValue = value[1];\n                exNavList += `\n                            <div class=\"item-col has-input\">\n                              <div class=\"hour-input\">\n                                <input type=\"number\"\n                                      input-type=\"time\"\n                                      max=\"23\"\n                                      min=\"0\"\n                                      input-key=\"${v.key || \"\"}\"\n                                      item-id=\"${d.id || -1}\"\n                                      type-node=\"${d.type || \"\"}\"\n                                      value=\"${hhValue}\"\n                                      ${isDisabled ? \"disabled\" : \"\"}\n                                      class=\"hh\">\n                                <span>:</span>\n                                <input type=\"number\"\n                                      input-type=\"time\"\n                                      max=\"59\"\n                                      min=\"0\"\n                                      input-key=\"${v.key || \"\"}\"\n                                      item-id=\"${d.id || -1}\"\n                                      type-node=\"${d.type || \"\"}\"\n                                      value=\"${mmValue}\"\n                                      ${isDisabled ? \"disabled\" : \"\"}\n                                      class=\"mm\">\n                              </div>\n                            </div>`;\n                break;\n              case \"text\":\n              case \"number\":\n              default:\n                exNavList += `\n                            <div class=\"item-col has-input\">\n                              <input\n                                      type=\"${v.input || \"text\"}\"\n                                      input-type=\"${v.input || \"text\"}\"\n                                      input-key=\"${v.key || \"\"}\"\n                                      item-id=\"${d.id || -1}\"\n                                      type-node=\"${d.type || \"\"}\"\n                                      ${isDisabled ? \"disabled\" : \"\"}\n                                      value=\"${value}\"/>\n                            </div>`;\n            }\n          } else {\n            exNavList += `\n                          <div class=\"item-col\">\n                            ${value}\n                          </div>`;\n          }\n        });\n      }\n\n      exNavList += `\n                  </div>`;\n\n      if (d.children) {\n        d.children.forEach((c) => {\n          if (c.isHidden) return;\n          exNavList += `<div class=\"child-ex-nav-item ${\n            d.isClosed ? \"hide\" : \"\"\n          }\" child=\"${d.id || -1}\">`;\n\n          if (c.withNav !== false) {\n            config.timeline.nav.left.extend.vars.forEach((v) => {\n              if (v.onlyTab && tab && v.onlyTab !== tab.key) return;\n\n              let value = utils.getVarByPath(c.values, v.varName);\n              if (v.round && !isNaN(value)) {\n                value = utils.round(value, v.round);\n              }\n\n              if (v.input) {\n                switch (v.input) {\n                  case \"hour\":\n                    value = value ? value.split(\":\") : [0, 0];\n                    let hhValue = value[0];\n                    let mmValue = value[1];\n                    exNavList += `\n                                  <div class=\"item-col has-input\">\n                                    <div class=\"hour-input\">\n                                      <input type=\"number\"\n                                            input-type=\"time\"\n                                            max=\"23\"\n                                            min=\"0\"\n                                            input-key=\"${v.key || \"\"}\"\n                                            item-id=\"${c.id || -1}\"\n                                            type-node=\"${c.type || \"\"}\"\n                                            value=\"${hhValue}\"\n                                            ${isDisabled ? \"disabled\" : \"\"}\n                                            class=\"hh\">\n                                      <span>:</span>\n                                      <input type=\"number\"\n                                            input-type=\"time\"\n                                            max=\"59\"\n                                            min=\"0\"\n                                            input-key=\"${v.key || \"\"}\"\n                                            item-id=\"${c.id || -1}\"\n                                            type-node=\"${c.type || \"\"}\"\n                                            value=\"${mmValue}\"\n                                            ${isDisabled ? \"disabled\" : \"\"}\n                                            class=\"mm\">\n                                    </div>\n                                  </div>`;\n                    break;\n                  case \"text\":\n                  case \"number\":\n                  default:\n                    exNavList += `\n                                  <div class=\"item-col has-input\">\n                                    <input  \n                                            type=\"${v.input || \"text\"}\"\n                                            input-type=\"${v.input || \"text\"}\"\n                                            input-key=\"${v.key || \"\"}\"\n                                            item-id=\"${c.id || -1}\"\n                                            type-node=\"${c.type || \"\"}\"\n                                            ${isDisabled ? \"disabled\" : \"\"}\n                                            value=\"${value}\"/>\n                                  </div>`;\n                }\n              } else {\n                exNavList += `\n                                <div class=\"item-col\">\n                                  ${value}\n                                </div>`;\n              }\n            });\n          }\n          exNavList += `\n                      </div>`;\n        });\n      }\n\n      //buttons\n      btnNavList += `<div class=\"cap-btn-nav-item parent\">\n                        <div class=\"cap-btn-nav-item-content\">`;\n      if (\n        config.timeline.nav.left.buttons &&\n        config.timeline.nav.left.buttons.vars\n      ) {\n        config.timeline.nav.left.buttons.vars.forEach((btn) => {\n          if (d.withBtnNav) {\n            let btnContent = \"\";\n            let className = btn.className || \"\";\n\n            if (btn.icon) {\n              btnContent = btn.icon ? btn.icon : \"\";\n            }\n\n            if (btn.iconFormatter) {\n              btnContent = btn.iconFormatter ? btn.iconFormatter(d, btn) : \"\";\n            }\n\n            if (btn.shape) {\n              className += \" cap-btn-\" + btn.shape;\n              btnContent += `<span> ${\n                btn.formatter ? btn.formatter(d, btn) : \"\"\n              } </span> `;\n            }\n            if (btn.btnClassNameFormatter) {\n              let newClassName = btn.btnClassNameFormatter(d, btn);\n              if (newClassName) {\n                className += \" \" + newClassName;\n              }\n            }\n\n            btnNavList += `\n                    <button class=\"cap-btn-shape ${className}\"\n                            input-key=\"${btn.key || \"\"}\"\n                            item-id=\"${d.id || -1}\"\n                            ${isDisabled ? \"disabled\" : \"\"}\n                            type-node=\"${d.type || \"\"}\">\n                            ${btnContent}\n                    </button>`;\n          }\n        });\n      }\n      btnNavList += `\n                      </div>\n                    </div>`;\n\n      if (d.children) {\n        d.children.forEach((c) => {\n          if (c.isHidden) return;\n\n          //buttons\n          btnNavList += `<div class=\"cap-btn-child-nav-item parent ${\n            d.isClosed ? \"hide\" : \"\"\n          }\" child=\"${d.id || -1}\">\n                            <div class=\"cap-btn-nav-item-content\">`;\n\n          if (\n            config.timeline.nav.left.buttons &&\n            config.timeline.nav.left.buttons.vars\n          ) {\n            config.timeline.nav.left.buttons.vars.forEach((btn) => {\n              if (c.withNav !== false) {\n                let btnContent = \"\";\n                let className = btn.className || \"\";\n\n                if (btn.icon) {\n                  btnContent = btn.icon ? btn.icon : \"\";\n                }\n\n                if (btn.iconFormatter) {\n                  btnContent = btn.iconFormatter\n                    ? btn.iconFormatter(c, btn)\n                    : \"\";\n                }\n\n                if (btn.shape) {\n                  className += \" cap-btn-\" + btn.shape;\n                  btnContent += `<span> ${\n                    btn.formatter ? btn.formatter(c, btn) : \"\"\n                  } </span> `;\n                }\n                if (btn.btnClassNameFormatter) {\n                  let newClassName = btn.btnClassNameFormatter(c, btn);\n                  if (newClassName) {\n                    className += \" \" + newClassName;\n                  }\n                }\n\n                btnNavList += `\n                      <button class=\"cap-btn-shape ${className}\"\n                              input-key=\"${btn.key || \"\"}\"\n                              item-id=\"${c.id || -1}\"\n                              ${isDisabled ? \"disabled\" : \"\"}\n                              type-node=\"${c.type || \"\"}\">\n                              ${btnContent}\n                      </button>`;\n              }\n            });\n          }\n\n          btnNavList += `\n                          </div>\n                        </div>`;\n        });\n      }\n    });\n\n    let itemDetail = ` <div class=\"detail-nav-item hide\">\n                          ${this.getDetailNavItemContent()}\n                        </div>`;\n\n    let str = `<div class=\"nav-container\">\n                      ${itemDetail}\n                    <div class=\"nav-item-list\">\n                      ${navList}\n                    </div>\n                    <div class=\"initial-nav-list\">\n                      ${initialNavList}\n                    </div>\n                    <div class=\"extend-nav-list\">\n                      ${exNavList}\n                    </div>\n                    <div class=\"cap-btn-nav-list\">\n                      ${btnNavList}\n                    </div>\n                  </div>`;\n\n    let navContainer = dom.createElementFromHTML(str);\n    $elem.innerHTML = \"\";\n    $elem.append(navContainer);\n\n    //detalle de nav-item\n    $elem.querySelectorAll(\".item-title.hoverable\").forEach((i) => {\n      i.addEventListener(\"mouseover\", (e) => {\n        let pos = utils.eventToPositionNavLeft(config, e, $elem);\n        let itemId = i.getAttribute(\"item-id\");\n        let item = utils.getItemById(config, itemId);\n        let typeNode = i.getAttribute(\"type-node\");\n        i.dispatchEvent(\n          new CustomEvent(\"overNavItem\", {\n            bubbles: true,\n            cancelable: false,\n            detail: {\n              originalEvt: e,\n              item: item,\n              type: typeNode,\n              pos: pos\n            }\n          })\n        );\n      });\n    });\n\n    //oculta detalle de nav-item, al salir del nav-item-list\n    $elem.querySelectorAll(\".nav-item-list\").forEach((i) => {\n      i.addEventListener(\"mouseleave\", (e) => {\n        i.dispatchEvent(\n          new CustomEvent(\"leaveNavItem\", {\n            bubbles: true,\n            cancelable: false\n          })\n        );\n      });\n    });\n\n    //oculta detalle de nav-item-list, al salir de nav-item\n    $elem.querySelectorAll(\".item-title:not(.hoverable)\").forEach((i) => {\n      i.addEventListener(\"mousemove\", (e) => {\n        i.dispatchEvent(\n          new CustomEvent(\"leaveNavItem\", {\n            bubbles: true,\n            cancelable: false\n          })\n        );\n      });\n    });\n\n    $elem.querySelectorAll(\".item-title.clickeable\").forEach((i) => {\n      i.addEventListener(\"click\", (e) => {\n        let itemId = i.getAttribute(\"item-id\");\n        let typeNode = i.getAttribute(\"type-node\");\n        let value = i.value;\n        i.dispatchEvent(\n          new CustomEvent(\"clickNavLeftItem\", {\n            bubbles: true,\n            cancelable: false,\n            detail: {\n              itemId: itemId,\n              type: typeNode,\n              value: value\n            }\n          })\n        );\n      });\n    });\n\n    $elem.querySelectorAll(\"input\").forEach((i) => {\n      i.addEventListener(\"change\", (e) => {\n        let inputType = i.getAttribute(\"input-type\");\n        let key = i.getAttribute(\"input-key\");\n        let itemId = i.getAttribute(\"item-id\");\n        let typeNode = i.getAttribute(\"type-node\");\n        let item = utils.getItemById(config, itemId);\n        let value = i.value;\n        if (inputType == \"time\") {\n          let hh_input = i.parentElement.querySelector(\"input.hh\").value;\n          let mm_input = i.parentElement.querySelector(\"input.mm\").value;\n          mm_input = mm_input < 10 ? \"0\" + parseFloat(mm_input) : mm_input;\n          i.parentElement.querySelector(\"input.mm\").value = mm_input;\n          value = hh_input + \":\" + mm_input;\n        }\n        i.dispatchEvent(\n          new CustomEvent(\"saveNavLeftInput\", {\n            bubbles: true,\n            cancelable: false,\n            detail: {\n              key: key,\n              itemId: itemId,\n              item: item,\n              type: typeNode,\n              value: value,\n              tabSelected: tab\n            }\n          })\n        );\n      });\n    });\n\n    $elem.querySelectorAll(\"button.cap-btn-shape\").forEach((i) => {\n      i.addEventListener(\"click\", (e) => {\n        let key = i.getAttribute(\"input-key\");\n        let itemId = i.getAttribute(\"item-id\");\n        let typeNode = i.getAttribute(\"type-node\");\n        i.dispatchEvent(\n          new CustomEvent(\"clickNavLeftButton\", {\n            bubbles: true,\n            cancelable: false,\n            detail: {\n              key: key,\n              itemId: itemId,\n              type: typeNode\n            }\n          })\n        );\n      });\n    });\n\n    $elem.querySelectorAll(\"button.tree-icon\").forEach((i) => {\n      i.addEventListener(\"click\", (e) => {\n        let itemId = i.getAttribute(\"item-id\");\n        let typeNode = i.getAttribute(\"type-node\");\n        let dataConfig = config.data.find((d) => d.id == itemId);\n\n        let $navItem = e.currentTarget.closest(\".nav-item\");\n        let $children = $navItem.querySelector(\".children-items\");\n        let itemsToHide = e.currentTarget\n          .closest(\"nav.left\")\n          .querySelectorAll(\n            \"[child='\" + itemId + \"'], [child-list='\" + itemId + \"']\"\n          );\n\n        if ($children) {\n          if ($children.classList.contains(\"hide\")) {\n            e.currentTarget.classList.add(\"cap-rotate\");\n            itemsToHide.forEach((i) => i.classList.remove(\"hide\"));\n            dataConfig.isClosed = false;\n          } else {\n            e.currentTarget.classList.remove(\"cap-rotate\");\n            itemsToHide.forEach((i) => i.classList.add(\"hide\"));\n            dataConfig.isClosed = true;\n          }\n        }\n\n        i.dispatchEvent(\n          new CustomEvent(\"clickNavLeftTreeIcon\", {\n            bubbles: true,\n            cancelable: false,\n            detail: {\n              itemId: itemId,\n              type: typeNode\n            }\n          })\n        );\n\n        //e.currentTarget.parent\n      });\n    });\n\n    return $elem;\n  },\n\n  /**\n   * Crea Html como String, para el detalle de items en el Sidebar Izquierdo\n   *\n   * @param {Object} [item={}] - Configuracion de item\n   * @return {String} Html de ventana de detalle\n   */\n  getDetailNavItemContent(item = {}) {\n    if (item.navOver == undefined) item.navOver = {};\n\n    return `\n                    <div class=\"header-detail\">\n                      <div class=\"detail-title truncate\">\n                        ${item.label || \"\"}\n                      </div>\n                      <div class=\"detail-subtitle\">\n                        ${item.navOver.subtitle || \"\"}\n                      </div>\n                      <div class=\"header-chip ${\n                        item.light ? item.light + \"-light\" : \"\"\n                      }  ${item.navOver.chip ? \"\" : \"hide\"}\">\n                        ${item.navOver.chip || \"\"}\n                      </div>\n                    </div>\n\n                    <div class=\"detail-container\">\n                      ${item.navOver.content || \"\"}\n                    </div>`;\n  },\n\n  /**\n   * Crea Sidebar Derecho\n   * Usado principalmente para formulario de ingreso de datos para los dias\n   * seleccionados\n   *\n   * @param {Object} config - Configuracion capibara\n   * @param {Object} tab - Tab de referencia, para la creacion del formulario\n   * @return {Object} {element, inputs}, element es el elemento Dom del sidebar,\n   *                  inputs es un array de elementos Dom de cada input creado\n   *                  (no son elementos html de tipo input)\n   */\n  createNavRight(config, tab = null) {\n    var $elem = dom.createElement(\"nav\", { className: \"right\" });\n    return this.redrawNavRight(config, $elem, tab, []);\n  },\n\n  /**\n   * Recrea Sidebar Derecho\n   * Utiliza $elem como elemento dom donde recrearlo\n   *\n   * @param {Object} config - Configuracion capibara\n   * @param {Object} $elem - Elemento Dom donde crea el sidebar derecho\n   * @param {Object} tab - Tab de referencia, para la creacion del formulario\n   * @param {Object} dataDay - datos del dia seleccionando, para autorrelleno de formulario\n   * @param {Object} daySelected - datos del dia seleccionado\n   * @param {String} daySelected.date - fecha del dia seleccionado\n   * @param {Object} daySelected.item - Item de Sidebar relacionado al dia seleccionado\n   * @param {Object} daySelected.pos - posicion de dia seleccionado\n   * @return {Object} Elemento Dom Sidebar Derecho\n   */\n  redrawNavRight(\n    config,\n    $elem,\n    selected = null,\n    tab = null,\n    dataDay = null,\n    daySelected = null\n  ) {\n    let $navRight = $elem; //dom.createElement(\"nav\",{className:\"right\"});\n    let $divContainer = dom.createElement(\"div\", {\n      className: \"nav-input-container\"\n    });\n    let $inputs = [];\n    let checkboxInputs = [];\n    let inputsWithReload = [];\n    let tabSelected = tab;\n    selected = selected || [daySelected];\n\n    if (tabSelected && tabSelected.inputs) {\n      tabSelected.inputs.forEach((i) => {\n        if (i.disabled) return;\n\n        let $input = this.createInput(i, dataDay, daySelected, selected);\n        if ($input) {\n          $divContainer.appendChild($input);\n          $inputs.push($input);\n\n          if (i.type == \"checkbox\") {\n            checkboxInputs.push($input);\n          }\n\n          if (i.reloadOnSelect != null) {\n            inputsWithReload.push({ $input, config: i });\n          }\n        }\n      });\n    }\n\n    //manejo de eventos para inputs con showIf\n    if (checkboxInputs) {\n      checkboxInputs.forEach(($c) => {\n        //obtiene key de checkbox\n        let key = $c.getAttribute(\"input-key\");\n        let props = tabSelected.inputs.find((i) => {\n          return i.key == key;\n        });\n\n        let isChecked = false;\n        if (dataDay) {\n          isChecked = utils.getVarByPath(dataDay, props.varName);\n        }\n\n        //obtiene inputs relacionados desde config para mostrar/ocultar\n        let inputsToHide = tabSelected.inputs.filter((i) => {\n          return i.showIf && i.showIf == key;\n        });\n        let inputsToHideKeys = inputsToHide.map((i) => i.key);\n\n        //obtiene inputs del dom, filtrando con inputsToHide\n        let $inputsHidden = $inputs.filter(($i) => {\n          let inputKey = $i.getAttribute(\"input-key\");\n          return inputsToHideKeys.indexOf(inputKey) > -1;\n        });\n\n        //si hay inputs,\n        if ($inputsHidden) {\n          if (!isChecked) {\n            $inputsHidden.forEach(($i) => {\n              $i.classList.add(\"hide\");\n            });\n          }\n          $c.addEventListener(\"input\", (e) => {\n            $inputsHidden.forEach(($i) => {\n              let fn = $c.querySelector(\"input[type='checkbox']\").checked\n                ? \"remove\"\n                : \"add\";\n              $i.classList[fn](\"hide\");\n            });\n          });\n        }\n      });\n    }\n\n    let saveCancelBtns = this.createNavRightbuttons();\n    $divContainer.appendChild(saveCancelBtns);\n    $navRight.innerHTML = \"\";\n    $navRight.appendChild($divContainer);\n\n    return {\n      element: $navRight,\n      inputs: $inputs,\n      inputsWithReload,\n      saveCancelBtns\n    };\n  },\n\n  /**\n   * Crea Corner inferior izquierdo, como titulo para footer\n   *\n   * @param {Object} config - Configuracion capibara\n   * @return {Object} Elemento Dom Corner Footer\n   */\n  createCornerFooter(config) {\n    if (\n      config.timeline.footer === undefined ||\n      config.timeline.footer.enabled == false\n    )\n      return null;\n    let str = \"\";\n\n    if (config.timeline.footer) {\n      str += `<div class=\"corner-footer\">\n          <div class=\"corner-title\">\n            <span>\n              ${config.timeline.footer.label}\n            </span>\n          </div>\n        </div>`;\n    }\n    return dom.createElementFromHTML(str);\n  },\n\n  /**\n   * Crea Footer para planilla\n   * Inicialmente creado para totales\n   *\n   * @param {Object} config - Configuracion capibara\n   * @return {Object} Elemento Dom Corner Footer\n   */\n  createFooter(config) {\n    if (\n      config.timeline.footer === undefined ||\n      config.timeline.footer.enabled == false\n    )\n      return null;\n\n    let str = `\n        <footer>\n          <div class=\"footer-container\">\n          `;\n    config.timeline.footer.data.forEach((d) => {\n      str += `\n              <div class=\"footer-item\">${d.value}</div>\n            `;\n    });\n    str += `\n          </div>\n        </footer>\n        `;\n\n    return dom.createElementFromHTML(str);\n  },\n\n  /**\n   * Crea Footer para planilla\n   * Inicialmente creado para totales\n   *\n   * @param {Object} config - Configuracion capibara\n   * @param {Object[]} selected - array de objetos, de dias seleccionados\n   * @return {Object} Elemento Dom Corner Footer\n   */\n  createSelectBoard(config, selected) {\n    let $elem = dom.createElement(\"div\", { className: \"select-container\" });\n    return this.redrawSelectBoard($elem, selected);\n  },\n\n  /**\n   * Crea linea vertical para fecha Actual\n   *\n   * @param {Object} config - Configuracion capibara\n   * @return {Object} Elemento Dom Corner Footer\n   */\n  createTodayLine(config) {\n    return this.redrawTodayLine(\n      config,\n      dom.createElement(\"div\", { className: \"today-line\" })\n    );\n  },\n\n  /**\n   * Recrea linea vertical para fecha Actual\n   * si el elemento $elem no es enviado, se crea un nuevo elemento\n   *\n   * Si el dia actual no esta dentro del rango de fechas del config,\n   * deshabilita la linea con la clase css .disable-line\n   *\n   * @param {Object} config - Configuracion capibara\n   * @param {Object} [$elem=null] - Elemento Dom donde recrea la linea, si es null, la crea\n   * @return {Object} Elemento Dom Corner Footer\n   */\n  redrawTodayLine(config, $elem = null) {\n    let endTime = new Date(config.timeline.end).getTime();\n    let todayTime = new Date().getTime();\n    let { height, dayWidth } = utils.getTableDimensions(config);\n\n    if ($elem == null)\n      $elem = dom.createElement(\"div\", { className: \"today-line\" });\n\n    if (endTime < todayTime) {\n      $elem.classList.add(\"disable-line\");\n    } else {\n      $elem.classList.remove(\"disable-line\");\n    }\n\n    let diffDays = Math.floor(\n      dateUtils.diffDays(\n        config.timeline.start,\n        dateUtils.formatDate(new Date())\n      )\n    );\n    let diff = diffDays * dayWidth;\n    diff += dayWidth / 2 - 2; // para centrar linea\n    Object.assign($elem.style, {\n      \"margin-left\": diff + \"px\",\n      height: height + \"px\"\n    });\n    return $elem;\n  },\n\n  /**\n   * Crea elemento FloatBox, que contiene los datos que se muestra en la tabla\n   *\n   * @param {Object} config - Configuracion capibara\n   * @param {Object} tab - Tab de referencia, para mostrar datos configurados por tab\n   * @return {Object} Elemento Dom Corner Footer\n   */\n  createFloatBox(config, tab) {\n    let $container = dom.createElement(\"div\", {\n      className: \"float-box-container\"\n    });\n    return this.redrawFloatBox(config, tab, $container);\n  },\n\n  /**\n   * Recrea elemento FloatBox, que contiene los datos que se muestra en la tabla\n   * Se usa principalmente para mostrar datos en la tabla de la planilla\n   * los muestra de manera flotante, calculando el Top y el Left segun la poscion\n   *\n   * Se consideran los elementos padres ocultos, para ocultar los datos\n   *\n   * Se insertan los elementos FloatBox, como elemento con datos de un item y dia especifico\n   *\n   *\n   * @param {Object} config - Configuracion capibara\n   * @param {Object} tab - Tab de referencia, para mostrar datos configurados por tab\n   * @return {Object} Elemento Dom Corner Footer\n   */\n  redrawFloatBox(config, tab, $container) {\n    $container.innerHTML = \"\";\n    //let tabSelected = tab || null;\n\n    config.data.forEach((de) => {\n      if (de.isHidden) return;\n      de.children.forEach((ds) => {\n        if (ds.isHidden) return;\n\n        ds.data.forEach((data) => {\n          if (\n            (!data.message || data.message.value == null) &&\n            (data.values == null ||\n              data.values == undefined ||\n              Object.entries(data.values).length === 0)\n          ) {\n            return null;\n          }\n\n          //children Data\n          let position = this.getPositionFloatBox(config, data, ds);\n\n          let className = \"\";\n\n          if (data.errors && data.errors.length > 0) {\n            className += \"has-errors \";\n          }\n\n          if (de.isClosed) {\n            className += \"hide \";\n          }\n\n          let msg = null;\n          if (tab.floaBox && tab.floatBox.messagePath) {\n            msg = utils.getVarByPath(data, tab.floatBox.messagePath);\n          }\n\n          if (msg || (data.message && data.message.value)) {\n            className += \"has-message \";\n          }\n\n          let str = `\n                <div class=\"float-box ${className} ${de.isClosed ? \"hide\" : \"\"}\"\n                     style=\"${position ? position : \"\"}\"\n                     item-id=\"${ds.id || -1}\"\n                     type-node=\"${ds.type || \"\"}\"> `;\n\n          let strExt = `\n                <div class=\"float-box-ext ${de.isClosed ? \"hide\" : \"\"}\"\n                      style=\"${position ? position : \"\"}\"\n                      item-id=\"${ds.id || -1}-ext\"\n                      type-node=\"${ds.type || \"\"}\">\n                  <div class=\"long-bar-container\">`;\n\n          if (tab && tab.floatBox) {\n            if (tab.floatBox.plots) {\n              str += `<div class=\"plot-floatbox-container\">`;\n              tab.floatBox.plots.forEach((n) => {\n                let cssVars = \"\";\n                let className = \"\";\n                if (utils.getVarByPath(data.values, n.varName) !== null) {\n                  if (n.color) {\n                    cssVars = `--local-color:${n.color};`;\n                  }\n\n                  className = n.className || \"\";\n\n                  str += `<div class=\"plot-floatbox ${className} ${\n                    n.style || \"\"\n                  }\" style=\"${cssVars} \"></div>`;\n                }\n              });\n              str += `\n                        </div>`;\n            }\n\n            //numeros en el floatBox\n            if (tab.floatBox.nums) {\n              tab.floatBox.nums.forEach((n) => {\n                if (tab.legends && n.tabKey) {\n                  let legend = tab.legends.find((l) => l.key == n.tabKey);\n                  if (legend && !legend.active) return;\n                }\n\n                let dataFloatBox = null;\n                let className = \"\";\n                let showIf = true;\n                let hideIf = false;\n                let colorClass = \"\";\n                let colorStyle = \"\";\n                let classNamesExt = \"\";\n                let colorStyleExt = \"\";\n                let cssVars = \"\";\n\n                if (n.varName) {\n                  dataFloatBox = utils.getVarByPath(data.values, n.varName);\n                }\n\n                if (n.varShow) {\n                  showIf = Boolean(utils.getVarByPath(data.values, n.varShow));\n                  dataFloatBox = dataFloatBox || \"\";\n                }\n\n                if (n.varHide) {\n                  hideIf = Boolean(utils.getVarByPath(data.values, n.varHide));\n                }\n\n                if (n.shape) {\n                  className += \"shape-\" + n.shape;\n                }\n\n                if (n.color) {\n                  if (utils.isHexColor(n.color)) {\n                    colorStyle = `--local-color: ${n.color};`;\n                  } else {\n                    colorClass = n.color;\n                  }\n                }\n\n                if (n.longBar) {\n                  if (n.longBarColor) {\n                    let longBarColor = utils.getVarByPath(\n                      data.values,\n                      n.longBarColor\n                    );\n                    let longBarOpacity =\n                      utils.getVarByPath(data.values, n.longBarOpacity) || null;\n                    if (longBarColor) {\n                      if (utils.isHexColor(longBarColor)) {\n                        colorStyleExt = `--local-color: ${longBarColor}; ${\n                          longBarOpacity\n                            ? \"--local-opacity: \" + longBarOpacity\n                            : \"\"\n                        }; `;\n                      } else {\n                        classNamesExt = longBarColor;\n                      }\n                    } else if (colorClass && colorClass != \"\") {\n                      classNamesExt = colorClass;\n                    } else if (colorStyle && colorStyle != \"\") {\n                      colorStyleExt = colorStyle;\n                    }\n                  }\n\n                  if(n.longBarClassName){\n                    classNamesExt += \" \" + n.longBarClassName;\n                  }\n\n                  let longBar = utils.getVarByPath(data.values, n.longBar);\n                  if (longBar) {\n                    cssVars = `--long:${longBar};`;\n                  }\n                }\n\n                if (dataFloatBox !== null && showIf && !hideIf) {\n                  str += `<span class=\"data ${colorClass} ${className}\" style=\"${colorStyle}\">\n                                ${\n                                  typeof dataFloatBox == \"string\"\n                                    ? dataFloatBox\n                                    : \"\"\n                                }\n                                ${\n                                  typeof dataFloatBox == \"number\"\n                                    ? utils.round(dataFloatBox, n.round)\n                                    : \"\"\n                                }\n                              </span>`;\n\n                  if (n.longBar && cssVars) {\n                    strExt += `<div class=\"long-bar ${classNamesExt}\" style=\"${colorStyleExt} ${cssVars} \"></div> `;\n                  }\n                }\n              });\n            }\n\n            //puntos en el floatBox\n            if (tab.floatBox.dots) {\n              str += `<div class=\"dot-container-middle\">`;\n              tab.floatBox.dots.forEach((dot) => {\n                if (utils.getVarByPath(data.values, dot.varName) !== null) {\n\n                  let className = \"\";\n                  let colorClass = \"\";\n                  let colorStyle = \"\";\n\n                  if (dot.shape) {\n                    className +=  dot.shape;\n                  }\n\n                  if (dot.color) {\n                    if (utils.isHexColor(dot.color)) {\n                      colorStyle = `--local-color: ${dot.color}`;\n                    } else {\n                      colorClass = dot.color;\n                    }\n                  }\n\n                  str += `\n                       <div class=\"dot ${colorClass} ${className}\" style=\"${colorStyle}\" ></div>`;\n\n                }\n              });\n              str += `\n                        </div>`;\n            }\n\n            //fila de puntos en floatBox\n            if (tab.floatBox.rowDots) {\n              tab.floatBox.rowDots.forEach((row) => {\n                let freeColumns = 4;\n                str += `<span class=\"rowdot--row \">`;\n\n                row.forEach((dot) => {\n                  if (tab.legends && dot.tabKey) {\n                    let legend = tab.legends.find((l) => l.key == dot.tabKey);\n                    if (legend && !legend.active) return;\n                  }\n\n                  let dataFloatBox = null;\n                  let className = \"\";\n                  let showIf = true;\n                  let hideIf = false;\n                  let colorClass = \"\";\n                  let colorStyle = \"\";\n\n                  if (dot.varName) {\n                    dataFloatBox = utils.getVarByPath(data.values, dot.varName);\n                    dataFloatBox = parseInt(dataFloatBox);\n                  }\n\n                  if (dot.varShow) {\n                    showIf = Boolean(\n                      utils.getVarByPath(data.values, dot.varShow)\n                    );\n                    dataFloatBox = dataFloatBox || \"\";\n                  }\n\n                  if (dot.varHide) {\n                    hideIf = Boolean(\n                      utils.getVarByPath(data.values, dot.varHide)\n                    );\n                  }\n\n                  if (dot.shape) {\n                    className += \" shape-\" + dot.shape;\n                  }\n\n                  if (dot.color) {\n                    if (utils.isHexColor(dot.color)) {\n                      colorStyle = `--local-color: ${dot.color}`;\n                    } else {\n                      colorClass = dot.color;\n                    }\n                  }\n\n                  if (\n                    dataFloatBox !== null &&\n                    dataFloatBox > 0 &&\n                    showIf &&\n                    !hideIf &&\n                    freeColumns > 0\n                  ) {\n                    let n =\n                      dataFloatBox > freeColumns ? freeColumns : dataFloatBox;\n                    freeColumns -= n;\n                    for (let index = 0; index < n; index++) {\n                      str += `<div class=\"rowdot--dot ${colorClass} ${className}\" style=\"${colorStyle}\"></div>`;\n                    }\n                  }\n                });\n\n                str += `</span>`;\n              });\n            }\n          }\n\n          str += `\n                </div>`;\n          strExt += `\n              </div>\n                </div>`;\n\n          let $elem = dom.createElementFromHTML(str);\n\n          let $elemExt = dom.createElementFromHTML(strExt);\n\n          $elem.addEventListener(\"mouseover\", (e) => {\n            $elem.dispatchEvent(\n              new CustomEvent(\"mouseOverFloatBox\", {\n                bubbles: true,\n                cancelable: false,\n                detail: {\n                  item: ds,\n                  data: data,\n                  originalEvt: e\n                }\n              })\n            );\n          });\n\n          $elem.addEventListener(\"click\", (e) => {\n            $elem.dispatchEvent(\n              new CustomEvent(\"clickFloatBox\", {\n                bubbles: true,\n                cancelable: false,\n                detail: {\n                  item: ds,\n                  data: data,\n                  originalEvt: e\n                }\n              })\n            );\n          });\n\n          $container.appendChild($elem);\n          $container.appendChild($elemExt);\n        });\n      });\n    });\n\n    return $container;\n  },\n\n  /**\n   * Crea DetailDay, detalle de valores de item y Dia\n   * se usa para:\n   *    - Muestra nombre de item y detalles\n   *    - Muestra capsulas de datos\n   *    - Muestra Pills, pildoras de datos resumidos\n   *    - Muestra alertas\n   *    - Muestra Mensaje\n   *\n   * @param {Object} config - Configuracion capibara\n   * @param {Object} item - Item relacionado\n   * @param {Object} dataDay - valores de item y Dia\n   * @param {Boolean} [onlyStringContent = false] - para escoger si devuelve String o DomElement\n   * @return {String|Object} Elemento como String o DomElement\n   */\n  createDetailDay(\n    config,\n    item = {},\n    dataDay,\n    tabSelected,\n    onlyStringContent = false\n  ) {\n    let str = `\n          <div class=\"header-detail\">\n            <div class=\"title truncate\">\n              ${item.label || \"\"}\n            </div>\n            <div class=\"subtitle\">\n              ${dataDay ? dateUtils.formatDateReadeable(dataDay.date) : \"\"}\n            </div>\n          </div>\n\n          <div class=\"list-detail list\">`;\n\n    //CAPSULES\n    if (dataDay) {\n      config.timeline.detailDay.capsules.forEach((cap) => {\n        //para comprobar si tiene datos, se obtiene el primer valor\n        //de la lista de values de una capsula\n        let hasValues =\n          cap.values.filter(\n            (v) => utils.getVarByPath(dataDay.values, v.varName) !== null\n          ).length > 0;\n        let hideIf = false;\n\n        if (cap.hideIf) {\n          hideIf = Boolean(utils.getVarByPath(dataDay.values, cap.hideIf));\n        }\n\n        let colorClass = \"\";\n        let colorStyle = \"\";\n\n        if (cap.color) {\n          if (utils.isHexColor(cap.color)) {\n            colorStyle = `--local-color: ${cap.color};`;\n            colorStyle += `--local-color-font: ${cap.color};`;\n          } else {\n            colorClass = cap.color;\n          }\n        }\n        if (hasValues && !hideIf) {\n          str += `\n              <div class=\"item-detail ${colorClass}\" style=\"${colorStyle}\">\n\n                <div class=\"left-icon ${cap.shape || \"\"} \"></div>\n\n                <div class=\"name\">\n                  <span>\n                    ${cap.title || \"\"}\n                  </span>\n                </div>`;\n\n          str += `\n          <div class=\"item-description\"> `;\n\n          cap.values.forEach((v) => {\n            let value = v.varName\n              ? utils.getVarByPath(dataDay.values, v.varName)\n              : null;\n\n            if (cap.isLabeledArray) {\n              value.forEach((valueLabeled) => {\n                let outputValue = null;\n                let valueName = v.valueName ? v.valueName : \"value\";\n\n                let tempValue = utils.getVarByPath(valueLabeled, valueName);\n\n                if (tempValue) {\n                  outputValue = v.round\n                    ? utils.round(tempValue, v.round)\n                    : tempValue;\n                }\n\n                if (v.formatter) {\n                  outputValue = v.formatter(valueLabeled);\n                }\n\n                if (typeof outputValue == \"number\") {\n                  outputValue = utils.formatNumber(outputValue);\n                }\n\n                str +=\n                  outputValue == null\n                    ? \"\"\n                    : `\n                      <div class=\"desc ${v.showColumn ? \"desc-column\" : \"\"}\">\n                        <div class=\"label\">\n                          ${v.hideLabel ? \"\" : valueLabeled.label}\n                        </div >\n                        <div class=\"val\">\n                          <span class=\"prefix\">\n                            ${v.prefix || \"\"}\n                          </span>\n                          <span class=\"value\">\n                            ${outputValue}\n                          </span>\n                          <span class=\"suffix\">\n                            ${valueLabeled.suffix || v.suffix || \"\"}\n                          </span>\n                        </div>\n                      </div>`;\n              });\n            } else {\n              let outputValue = v.round ? utils.round(value, v.round) : value;\n\n              if (v.formatter) {\n                outputValue = v.formatter({ options: v, dataDay, outputValue });\n              }\n\n              if (typeof outputValue == \"number\") {\n                outputValue = utils.formatNumber(outputValue);\n              }\n\n              str +=\n                outputValue == null\n                  ? \"\"\n                  : `\n                    <div class=\"desc\">\n                          <span class=\"prefix\">\n                            ${v.prefix || \"\"}\n                          </span>\n                          <span class=\"value\">\n                            ${outputValue}\n                          </span>\n                          <span class=\"suffix\">\n                            ${v.suffix || \"\"}\n                          </span>\n                    </div>`;\n            }\n          });\n\n          str += `\n                </div>`;\n\n          str += `\n              </div>`; // end .item-detail\n        }\n      });\n    }\n\n    str += `\n        </div>`; // list-detail\n\n    //PILLS\n    if (\n      config.timeline.detailDay.pillsVarName &&\n      dataDay &&\n      dataDay.values[config.timeline.detailDay.pillsVarName]\n    ) {\n      str += `\n          <div class=\"elements-detail\">\n            <div class=\"name\"> ${config.timeline.detailDay.pillsTitle} </div>\n            <div class=\"elements-list\">`;\n\n      dataDay.values[config.timeline.detailDay.pillsVarName].forEach((e) => {\n        let value = e.value;\n\n        if (typeof outputValue == \"number\") {\n          value = utils.formatNumber(value);\n        }\n\n        str += `\n            <div class=\"element-detail\">\n              <b>${e.label}</b>\n              ${value}\n            </div>`;\n      });\n\n      str += `\n            </div>\n            </div>`; //end .element-detail > .element-list\n    }\n\n    //str += `</div>`;\n\n    if (dataDay && dataDay.errors && dataDay.errors.length > 0) {\n      dataDay.errors.forEach((err) => {\n        str += `\n          <div class=\"alert\">\n            ${icons.alert}\n            ${err.label}\n          </div>`;\n      });\n    }\n\n    let msg = null;\n    let author = null;\n    let dateMsg = null;\n    if (dataDay && tabSelected.floatBox && tabSelected.floatBox.messagePath) {\n      msg = utils.getVarByPath(dataDay, tabSelected.floatBox.messagePath);\n\n      if (!msg && dataDay.message && dataDay.message.value) {\n        msg = dataDay.message.value;\n        author = dataDay.message.author;\n        dateMsg = dateUtils.formatDateReadeable(new Date(dataDay.message.date));\n      }\n    }\n    if (msg) {\n      //msg = msg.replace(/(\\r\\n|\\r|\\n)/g, '<br>');\n      str += `\n          <div class=\"msj-container\">\n            <div class=\"msj\">\n            <pre>${msg || \"\"}</pre>\n            </div>\n            <div class=\"msj-detail\">\n              <span class=\"email\"> ${author || \"\"} </span>\n              <span class=\"date\"> ${dateMsg || \"\"} </span>\n            </div>\n        </div>`;\n    }\n\n    let strContainer = `<div class=\"detail-day dd-hide\"> ${str} </div>`;\n\n    if (onlyStringContent) return str;\n\n    return dom.createElementFromHTML(strContainer);\n  },\n\n  /**\n   * Recrea HTML de detailDay\n   *\n   * @param {Object} config - Configuracion capibara\n   * @param {Object} item - Item relacionado\n   * @param {Object} dataDay - valores de item y Dia\n   * @return {String} Elemento como String, de detailDay\n   */\n  redrawDetailDay(config, item, dataDay, tabSelected) {\n    return this.createDetailDay(config, item, dataDay, tabSelected, true);\n  },\n\n  /**\n   * Reposiciona FloatBox\n   * verifica si el parent esta desplegado, para ocultar los datos\n   *\n   * Solo actualiza las alturas de los floatbox\n   * no recrea los floatbox, es mas optimo\n   *\n   * @param {Object} config - Configuracion capibara\n   * @param {Object} item - Item relacionado\n   */\n  repositionFloatBox(config, $floatBoxContainer) {\n    $floatBoxContainer.querySelectorAll(\".float-box\").forEach(($f) => {\n      let itemId = $f.getAttribute(\"item-id\");\n      let itemHeight = parseFloat(\n        utils.getCSSVariable(config, \"--item-height\")\n      );\n      let item, parent;\n      ({ item, parent } = utils.getItemById(config, itemId, \"child\", true));\n      if (item) {\n        let top = utils.getPositionByItem(config, item);\n        $f.style.top = top * itemHeight + \"px\";\n        if (parent && parent.isClosed) {\n          $f.classList.add(\"hide\");\n        } else if ($f.classList.contains(\"hide\")) {\n          $f.classList.remove(\"hide\");\n        }\n      }\n    });\n  },\n\n  /**\n   * Recrea indicadores de dias seleccionados\n   *\n   * @param {Object} $elem - Elemento Dom donde crea los elementos seleccionados\n   * @param {Object[]} selected - Array con los dias seleccionados\n   * @return {Object} Elemento Dom que contiene los indicadores de dias seleccionados\n   */\n  redrawSelectBoard($elem, selected) {\n    $elem.innerHTML = \"\";\n    let hasNumber = true;\n\n    if (selected) {\n      if (selected.length == 1) hasNumber = false;\n\n      selected.forEach((s) => {\n        let attributes = [];\n\n        if (hasNumber) {\n          attributes.push({ name: \"cap-badge\", value: s.index });\n        }\n        let $s = dom.createElement(\"div\", {\n          className: \"selected-day\",\n          attributes\n        });\n        $s.style.left = s.pos.left + \"px\";\n        $s.style.top = s.pos.top + \"px\";\n        $elem.append($s);\n      });\n    }\n    return $elem;\n  },\n\n  /**\n   * Obtiene String con estilos CSS de la posicion de un floatBox\n   * calculado segun item y fecha de los valores\n   *\n   * @param {Object} config - Configuracion capibara, para ver fecha de inicio\n   * @param {Object} data - Datos del dia indicado\n   * @param {Object} item - Item relacionado\n   * @return {String} String CSS top y left , para posicionar floatBox en table\n   */\n  getPositionFloatBox(config, data, item) {\n    let left = dateUtils.diffDays(config.timeline.start, data.date);\n    let top = utils.getPositionByItem(config, item);\n    let dayWidth = parseFloat(utils.getCSSVariable(config, \"--day-width\"));\n    let itemHeight = parseFloat(utils.getCSSVariable(config, \"--item-height\"));\n    left *= dayWidth;\n    top *= itemHeight;\n    return \"top: \" + top + \".5px; left:\" + left + \".5px;\";\n  },\n\n  /**\n   * Crea Boton como elemento Dom\n   *\n   * @param {Object} props - propiedades para boton\n   * @param {String} props.className - classes css para boton\n   * @param {*} props.key - key para identificar a boton\n   * @param {String} props.label - Texto boton\n   * @return {Object} Elemento Dom del boton creado\n   */\n  createButton(props) {\n    return dom.createElementFromHTML(`\n            <button class=\"${props.className || \"\"}\" input-key=\"${\n              props.key || \"\"\n            }\">\n              ${props.label || \"\"}\n            </button>`);\n  },\n\n  /**\n   * Crea Botones de guardar y cancelar los datos de formulario del sidebar derecho\n   *\n   * @return {Object} Elemento Dom del botones creados\n   */\n  createNavRightbuttons() {\n    let saveBtn = this.createButton({\n      label: \"Guardar\",\n      className: \"cap-btn-raised\"\n    });\n    let cancelBtn = this.createButton({\n      label: \"Cancelar\",\n      className: \"cap-btn-outline\"\n    });\n    let btnSection = dom.createElementFromHTML(\n      `<div class=\"button-section\"></div>`\n    );\n    btnSection.appendChild(saveBtn);\n    btnSection.appendChild(cancelBtn);\n\n    saveBtn.addEventListener(\"click\", (e) => {\n      saveBtn.dispatchEvent(\n        new CustomEvent(\"saveMultiInput\", {\n          bubbles: true,\n          cancelable: false\n        })\n      );\n    });\n\n    cancelBtn.addEventListener(\"click\", (e) => {\n      cancelBtn.dispatchEvent(\n        new CustomEvent(\"cancelMultiInput\", {\n          bubbles: true,\n          cancelable: false\n        })\n      );\n    });\n\n    return btnSection;\n  },\n\n  /**\n   * Crea Input como elemento Dom\n   *\n   * @param {Object} props - config para Input\n   * @param {Object} [dataDay = null] - valores de item y Dia, opcional\n   * @param {Object} [daySelected = null] - datos del dia seleccionado\n   * @param {Object[]} [selected = []] - array de objetos, de dias seleccionados\n   * @return {Object} Elemento Dom del input creado\n   */\n  createInput(props, dataDay = null, daySelected = null, selected = []) {\n    let r = null;\n\n    if (props.ignoreRender == true) return r;\n\n    switch (props.type) {\n      case \"custom\":\n        r = props.render ? props.render({props, dataDay, daySelected, selected}) : null;\n        r.setAttribute(\"input-key\", props.key);\n        break;\n      case \"select\":\n        r = this.createInputSelect(props, dataDay, daySelected);\n        break;\n      case \"file\":\n        r = this.createInputFile(props, dataDay);\n        break;\n      case \"fileLink\":\n        r = this.createFileLink(props, dataDay);\n        break;\n      case \"text\":\n        r = this.createText(props, selected);\n        break;\n      case \"title\":\n        r = this.createTitle(props);\n        break;\n      case \"number\":\n        r = this.createInputNumber(props, dataDay);\n        break;\n      case \"float\":\n        r = this.createInputFloat(props, dataDay);\n        break;\n      case \"message\":\n        r = this.createInputMessage(props, dataDay);\n        break;\n      case \"textarea\":\n        r = this.createInputTextArea(props, dataDay);\n        break;\n      case \"checkbox\":\n        r = this.createInputCheckbox(props, dataDay);\n        break;\n      case \"inputList\":\n        r = this.createInputList(props, dataDay, daySelected);\n        break;\n      case \"input-box\":\n        r = this.createInputBox(props, dataDay);\n        break;\n      case \"list\":\n        r = this.createList(props, dataDay);\n        break;\n      case \"data-list\":\n        r = this.createDataList(props, dataDay, daySelected, selected);\n        break;\n      case \"button\":\n        r = this.createInputButton(props, dataDay);\n        break;\n      case \"buttons-group\":\n        r = this.createInputButtonsGroup(props, dataDay);\n        break;\n      case \"time\":\n        r = this.createInputTime(props, dataDay);\n        break;\n      case \"text\":\n      default:\n        r = this.createInputText(props, dataDay);\n    }\n\n    return r;\n  },\n\n  /**\n   * Crea Input con formato Hora, como elemento Dom\n   *\n   * Usa 2 inputs, hora y minutos\n   *\n   * el value que interpreta es String HH:MM\n   *\n   * @param {Object} props - config para Input\n   * @param {Object} [dataDay = null] - valores de item y Dia, opcional\n   * @return {Object} Elemento Dom del input creado\n   */\n  createInputTime(props, dataDay) {\n    let hhValue = \"\";\n    let mmValue = \"\";\n\n    if (dataDay && dataDay.values) {\n      let value = utils.getVarByPath(dataDay, props.varName);\n\n      if (value) {\n        value = value.split(\":\");\n        hhValue = value[0];\n        mmValue = value[1];\n      }\n    }\n\n    let $elem = dom.createElementFromHTML(`\n          <div class=\"input-section ${props.isHidden ? 'hide':''} \" input-key=\"${props.key || \"\"}\">\n            <span class=\"text-subtitle d-block\">\n              ${props.label || \"\"}\n            </span>\n            <div class=\"d-flex\">\n              <div class=\"time\">\n                <input type=\"number\"\n                      class=\"hour\"\n                      id=\"test\"\n                      placeholder=\"00\"\n                      min=\"0\"\n                      max=\"24\"\n                      value=\"${hhValue}\">\n                <span class=\"symbol\">:</span>\n                <input type=\"number\"\n                      class=\"minutes\"\n                      placeholder=\"00\"\n                      min=\"0\"\n                      max=\"59\"\n                      value=\"${mmValue}\">\n              </div>\n              <span class=\"text-hint\">\n                ${props.textHint || \"\"}\n              </span>\n            </div>\n          </div>`);\n\n    let $hhInput = $elem.querySelector(\".hour\");\n    let $mmInput = $elem.querySelector(\".minutes\");\n\n    $hhInput.addEventListener(\"input\", (e) => {\n      $hhInput.dispatchEvent(\n        new CustomEvent(\"changeTimeInputHH\", {\n          bubbles: true,\n          cancelable: false,\n          detail: {\n            key: props.key,\n            value: e.srcElement.value\n          }\n        })\n      );\n    });\n\n    $mmInput.addEventListener(\"input\", (e) => {\n      $mmInput.dispatchEvent(\n        new CustomEvent(\"changeTimeInputMM\", {\n          bubbles: true,\n          cancelable: false,\n          detail: {\n            key: props.key,\n            value: e.srcElement.value\n          }\n        })\n      );\n    });\n\n    this.addKeyDownInputEvents($hhInput, $elem, props);\n    this.addKeyDownInputEvents($mmInput, $elem, props);\n\n    return $elem;\n  },\n\n  /**\n   * Crea Text como elemento Dom\n   * Se configura como input, pero no devuelve datos, es un texto\n   *\n   * @param {Object} props - config para Input\n   * @return {Object} Elemento Dom del input creado\n   */\n  createText(props, selected) {\n    let label = props.label;\n    if (props.formatter) {\n      label = props.formatter({ selected });\n    }\n    let $elem = dom.createElementFromHTML(`\n          <div class=\"input-section ${props.isHidden ? 'hide':''} \" input-key=\"${props.key || \"\"}\">\n            <span class=\"${props.classNames || \"\"}\">\n            ${label}\n            </span>\n          </div>`);\n    return $elem;\n  },\n\n  /**\n   * Crea Title como elemento Dom\n   * Se configura como input, pero no devuelve datos, es un texto\n   *\n   * @param {Object} props - config para Input\n   * @return {Object} Elemento Dom del input creado\n   */\n  createTitle(props) {\n    let classNames = \"text-title\";\n    if (props.isSubtitle) {\n      classNames = \"text-subtitle\";\n    }\n    return dom.createElementFromHTML(`\n          <div class=\"input-section ${props.isHidden ? 'hide': ''} \" input-key=\"${props.key || \"\"}\">\n            <span class=\"${classNames}\">\n              ${props.label}\n            </span>\n          </div>`);\n  },\n\n  /**\n   * Crea Input tipo Numerico como elemento Dom\n   *\n   * @param {Object} props - config para Input\n   * @param {Object} dataDay - valores de item y Dia, opcional\n   * @return {Object} Elemento Dom del input creado\n   */\n  createInputNumber(props, dataDay) {\n    let value = \"\";\n    if (dataDay && dataDay.values) {\n      value = utils.getVarByPath(dataDay, props.varName);\n    }\n    value = value || \"\";\n\n    let elem = dom.createElementFromHTML(`\n          <div class=\"input-section ${props.classNames || \"\"} ${props.isHidden ? 'hide':''} \" input-key=\"${\n            props.key || \"\"\n          }\">\n            <div class=\"input-section-title\">\n              <span class=\"text-subtitle\">\n                ${props.label}\n              </span>\n              <span class=\"text-subtitle-2 \">\n                ${props.suffix ? \"(\" + props.suffix + \")\" : \"\"}\n              </span>\n            </div>\n            <div class=\"d-flex\">\n              <input type=\"number\"\n                    class=\"nav-input\"\n                    value=\"${value}\">\n\n              <span class=\"text-hint\">\n                  ${props.textHint || \"\"}\n              </span>\n            </div>\n          </div>`);\n\n    let inputElem = elem.querySelector(\"input\");\n\n    this.addKeyDownInputEvents(inputElem, elem, props);\n\n    return elem;\n  },\n\n  /**\n   * Crea Input tipo FIlepicker como elemento Dom\n   *\n   * @param {Object} props - config para Input\n   * @param {Object} dataDay - valores de item y Dia, opcional\n   * @return {Object} Elemento Dom del input creado\n   */\n  createInputFile(props, dataDay) {\n    let value = \"\";\n    let fileName = \"\";\n    let filePath = \"\";\n\n    if (dataDay && dataDay.values) {\n      value = utils.getVarByPath(dataDay, props.varName);\n      fileName = utils.getVarByPath(dataDay, props.fileNameValue);\n      filePath = utils.getVarByPath(dataDay, props.filePathValue);\n    }\n\n    value = value || \"\";\n    fileName = fileName || \"\";\n    filePath = filePath || \"\";\n\n    let elem = dom.createElementFromHTML(`\n          <div class=\"input-section ${props.classNames || \"\"} ${props.isHidden ? 'hide':''} \" input-key=\"${\n            props.key || \"\"\n          }\">\n\n            <div class=\"input-section-title\">\n              <span class=\"text-subtitle\">\n                ${props.label}\n              </span>\n            </div>\n\n            <div class=\"nav-input-file\" >\n              <button class=\"small-close clear-file-input\">x</button>\n              <label >\n                <span class=\"nav-input-file-label\">\n                  ${props.pickerLabel || \"Seleccionar Archivo\"}\n                </span>\n                <input type=\"file\" value=\"${value}\">\n              </label>\n            </div>\n\n            <div class=\"input-section-link\">\n              <a href=\"${filePath}\" target=\"_blank\" >\n                ${fileName}\n              </a>\n            </div>\n\n          </div>`);\n\n    let $inputElem = elem.querySelector(\"input\");\n    let $clearBtn = elem.querySelector(\".clear-file-input\");\n    let $fileInputLabel = elem.querySelector(\".nav-input-file-label\");\n\n    $inputElem.addEventListener(\"change\", (evt) => {\n      let fileName = $inputElem.files[0].name;\n      $fileInputLabel.textContent = fileName;\n    });\n\n    $clearBtn.addEventListener(\"click\", (evt) => {\n      $inputElem.value = \"\";\n      $fileInputLabel.textContent = props.pickerLabel || \"Seleccionar Archivo\";\n      evt.stopPropagation();\n    });\n\n    return elem;\n  },\n\n  createFileLink(props, dataDay) {\n    let fileName = \"\";\n    let filePath = \"\";\n\n    if (dataDay && dataDay.values) {\n      //value = utils.getVarByPath(dataDay, props.varName);\n      fileName = utils.getVarByPath(dataDay, props.fileNameValue);\n      filePath = utils.getVarByPath(dataDay, props.filePathValue);\n    }\n\n    if (fileName == \"\") return null;\n\n    fileName = fileName || \"\";\n    filePath = filePath || \"\";\n\n    let elem = dom.createElementFromHTML(`\n          <div class=\"input-section ${props.classNames || \"\"} ${props.isHidden ? 'hide':''} \" input-key=\"${\n            props.key || \"\"\n          }\">\n\n            <div class=\"input-section-title\">\n              <span class=\"text-subtitle\">\n                ${props.label}\n              </span>\n            </div>\n\n            <div class=\"input-section-link\">\n              <a href=\"${filePath}\" target=\"_blank\" >\n                ${fileName}\n              </a>\n            </div>\n\n          </div>`);\n\n    return elem;\n  },\n\n  /**\n   * Crea lista de Inputs, con array de valores, como elemento Dom\n   *\n   * @param {Object} props - config para Input\n   * @param {Object} dataDay - valores de item y Dia, opcional\n   * @param {Object} [daySelected = null] - datos del dia seleccionado\n   * @return {Object} Elemento Dom del input creado\n   */\n  createInputList(props, dataDay, daySelected = null) {\n    let inputList = [];\n\n    //obtiene inputs default, para crearlos, sin valores\n    if (\n      daySelected &&\n      Array.isArray(daySelected.item.values[props.inputList])\n    ) {\n      inputList = daySelected.item.values[props.inputList].map((inputRow) => {\n        //limpia inputList inputs\n        inputRow.inputs.map((input) => {\n          input.value = null;\n          return input;\n        });\n\n        //obtiene valores del dia\n        if (dataDay && dataDay.values) {\n          let inputValues = utils.getVarByPath(dataDay, props.valuesPath);\n\n          //autorrellena\n          if (inputValues) {\n            inputRow.inputs.forEach((input) => {\n              let values = inputValues.find((v) => v.id == inputRow.id);\n              input.value = values ? values[input.varName] : null;\n            });\n          }\n        }\n\n        return inputRow;\n      });\n    }\n\n    let str = `<div input-key=\"${props.key || \"\"}\" class=\"input-section-list ${props.isHidden ? 'hide': ''} \">\n            <div class=\"input-section-title\">\n              <span class=\"text-title\">\n                ${props.label}\n              </span> \n            </div>`;\n    inputList.forEach((inputRow) => {\n      str += `\n                  <div class=\"input-section ${\n                    props.toRight ? \"to-right\" : \"\"\n                  }\" >\n                      <span class=\"text-subtitle\">\n                        ${inputRow.label}\n                      </span>`;\n\n      inputRow.inputs.forEach((input) => {\n        str += ` \n                    <div class=\"input-section-col\" >\n                      <span class=\"text-subtitle \">\n                        ${input.label}\n                      </span>\n                      <input type=\"number\"\n                            input-id=\"${inputRow.id}\"\n                            input-label=\"${input.label}\"\n                            class=\"nav-input small\"\n                            value=\"${input.value}\">\n                    </div>`;\n      });\n      str += `\n                  </div>`;\n    });\n    str += `</div>`;\n\n    let elem = dom.createElementFromHTML(str);\n\n    let inputsElem = elem.querySelectorAll(\"input\");\n    inputsElem.forEach((inputElem) => this.addKeyDownInputEvents(inputElem, elem, props));\n    return elem;\n  },\n\n  createInputSelect(props, dataDay, daySelected = null) {\n    let value = null;\n    let options = props.options;\n\n    if (dataDay && dataDay.values) {\n      let val = utils.getVarByPath(dataDay, props.varName);\n      value = val ? val.value : null;\n    }\n\n    let str = `<div input-key=\"${props.key || \"\"}\" class=\"${props.isHidden ? 'hide': ''}\" >\n                  <div class=\"input-section \" >\n                      <span class=\"text-subtitle\">\n                        ${props.label}\n                      </span>\n\n                      <select class=\"input-select\">\n\n                 <option value=\"\" ${value == null ? \"selected\" : \"\"}>\n                  ${props.noDataLabel || \"-- sin asignar --\"}\n                 </option>\n\n        `;\n\n    options.forEach((option) => {\n      str += `\n                 <option value=\"${option.id}\" ${\n                   option.id == value ? \"selected\" : \"\"\n                 }>\n                 ${option.label}\n                 </option>\n                `;\n    });\n    str += `\n\n                      </select>\n                  </div>\n\n      </div>`;\n\n    let elem = dom.createElementFromHTML(str);\n\n    return elem;\n  },\n\n  /**\n   * Crea Input de texto TextArea como elemento Dom\n   *\n   * @param {Object} props - config para Input\n   * @param {Object} dataDay - valores de item y Dia, opcional\n   * @return {Object} Elemento Dom del input creado\n   */\n  createInputTextArea(props, dataDay) {\n    let value = \"\";\n    if (dataDay && dataDay.values) {\n      value = utils.getVarByPath(dataDay, props.varName);\n    }\n    let elem = dom.createElementFromHTML(`\n          <div class=\"input-section ${props.isHidden ? 'hide':''} \" input-key=\"${props.key || \"\"}\">\n            <span class=\"text-subtitle d-block\">\n              ${props.label}\n            </span>\n            <textarea class=\"\" value=\"${value}\"></textarea>\n          </div>`);\n\n    let inputElem = elem.querySelector(\"textarea\");\n    this.addKeyDownInputEvents(inputElem, elem, props);\n    return elem;\n  },\n\n  /**\n   * Crea Input de Mensaje como elemento Dom\n   * utiliza TextArea\n   *\n   * @param {Object} props - config para Input\n   * @param {Object} dataDay - valores de item y Dia, opcional\n   * @return {Object} Elemento Dom del input creado\n   */\n  createInputMessage(props, dataDay) {\n    let value = dataDay ? utils.getVarByPath(dataDay, props.varName) : null;\n    let elem = dom.createElementFromHTML(`\n          <div class=\"input-section msj-input-container ${props.isHidden ? 'hide':''} \"\n              input-key=\"${props.key || \"\"}\">\n            <span class=\"text-subtitle d-block\">\n              Mensaje\n            </span>\n            <textarea class=\"msj\">${value || \"\"}</textarea>\n          </div>`);\n\n    let inputElem = elem.querySelector(\"textarea\");\n    //this.addKeyDownInputEvents(inputElem);\n    return elem;\n  },\n\n  /**\n   * Crea Input de texto como elemento Dom\n   *\n   * @param {Object} props - config para Input\n   * @param {Object} dataDay - valores de item y Dia, opcional\n   * @return {Object} Elemento Dom del input creado\n   */\n  createInputText(props, dataDay) {\n    let value = \"\";\n    if (dataDay && dataDay.values) {\n      value = utils.getVarByPath(dataDay, props.varName);\n    }\n    let elem = dom.createElementFromHTML(`\n          <div class=\"input-section ${props.isHidden ? 'hide':''} \" input-key=\"${props.key || \"\"}\">\n            <span class=\"text-subtitle d-block\">\n              ${props.label}\n            </span>\n            <input type=\"text\" class=\"nav-input\" value=\"${value}\">\n          </div>`);\n\n    let inputElem = elem.querySelector(\"input\");\n    this.addKeyDownInputEvents(inputElem, elem, props);\n    return elem;\n  },\n\n  /**\n   * Crea Input Numero Flotante, como elemento Dom\n   *\n   * @param {Object} props - config para Input\n   * @param {Object} dataDay - valores de item y Dia, opcional\n   * @return {Object} Elemento Dom del input creado\n   */\n  createInputFloat(props, dataDay) {\n    let value = \"\";\n    if (dataDay && dataDay.values) {\n      value = utils.getVarByPath(dataDay, props.varName);\n    }\n    let elem = dom.createElementFromHTML(`\n          <div class=\"input-section ${props.isHidden ? 'hide':''} \" input-key=\"${props.key || \"\"}\">\n            <span class=\"text-subtitle d-block\">\n              ${props.label}\n            </span>\n            <input type=\"number\" class=\"nav-input\" value=\"${value}\">\n          </div>`);\n\n    let inputElem = elem.querySelector(\"input\");\n    this.addKeyDownInputEvents(inputElem, elem, props);\n    return elem;\n  },\n\n  createDataList(props, dataDay, daySelected, selected) {\n    let list = [];\n    if (dataDay && dataDay.values) {\n      list = utils.getVarByPath(dataDay, props.varName) || [];\n    }\n\n    let searchInput = ` <div class=\"search-input-container\">\n                          <input id=\"\" type=\"text\" name=\"\" class=\"search-input\" placeholder=\"buscar\">\n                          <button class=\"search-input-clear\">\n                          ${icons.closeIcon}\n                          </button>\n                        </div>`;\n\n    let editBtn = \"\";\n\n    if (props.editButton) {\n      editBtn = `<button class=\"cap-btn-outline cap-btn-sm edit-btn\" input-key=\"${props.editButton.key}\">\n                    ${props.editButton.label} \n                  </button> `;\n    }\n\n    let str = `\n      <div class=\"input-section ${props.isHidden ? 'hide':''} \" input-key=\"${props.key || \"\"}\">\n        <div class=\"input-section-title\">\n            <span class=\"text-subtitle d-block\">\n                ${props.label}\n              </span>\n              ${editBtn}\t\n        </div>\n        <div class=\"input-box \" input-key=\"${props.key || \"\"}\">\n            ${searchInput}\n        </div>\n      </div> `;\n\n    let $el = dom.createElementFromHTML(str);\n    let $searchInput = $el.querySelector(\".search-input\");\n    let $searchInputClear = $el.querySelector(\".search-input-clear\");\n    let $inputBox = $el.querySelector(\".input-box\");\n\n    list.map((item, j) => {\n      let label =\n        utils.getVarByPath(item, props.varNameLabel) || dataDay.label || \"__\";\n\n      let $elItem = this.createDataListItem({\n        label,\n        valueText: utils.getVarByPath(item, props.varNameValueText) || \"\",\n        subText: utils.getVarByPath(item, props.varNameSubText) || \"\",\n        id: \"list-item-\" + (dataDay.id || j),\n        key: \"list-item-\" + (dataDay.id || j),\n        tooltip: utils.getVarByPath(item, props.varNameTooltip) || label,\n        //colorIcon: \"c-red\",\n        link: utils.getVarByPath(item, props.varNameLink) || null,\n        suffix: utils.getVarByPath(item, props.varNameSuffix) || null,\n        //value: JSON.stringify(utils.getVarByPath(item, props.varNameInput)) || {}\n      });\n      $inputBox.appendChild($elItem);\n    });\n\n    $searchInputClear.addEventListener(\"click\", (e) => {\n      $searchInput.value = \"\";\n      $searchInput.dispatchEvent(new Event(\"input\", { bubbles: true }));\n    });\n\n    $searchInput.addEventListener(\"keydown\", (e) => {\n      if (e.key === \"Escape\") {\n        $searchInput.value = \"\";\n        $searchInput.dispatchEvent(new Event(\"input\", { bubbles: true }));\n      }\n    });\n\n    $searchInput.addEventListener(\"input\", (e) => {\n      let $inputs = [];\n      $inputs = $el.querySelectorAll(\".mini-input-section\") || [];\n      $inputs.forEach(($i) => {\n        let label = $i.getAttribute(\"label\");\n        let search = $searchInput.value;\n        if (label.toLowerCase().includes(search.toLowerCase())) {\n          $i.classList.remove(\"hide\");\n        } else {\n          $i.classList.add(\"hide\");\n        }\n      });\n    });\n\n    let button = $el.querySelector(\"button.edit-btn\");\n    if (button && props.editButton && props.editButton.onClick) {\n      button.addEventListener(\"click\", (e) =>\n        props.editButton.onClick({\n          event: e,\n          props,\n          dataDay,\n          daySelected,\n          selected,\n          $element: $el\n        })\n      );\n    }\n\n    return $el;\n  },\n\n  createDataListItem({\n    label = \"\",\n    valueText = \"\",\n    subText = \"\",\n    id = \"\",\n    key = \"\",\n    tooltip = \"\",\n    colorIcon = \"\",\n    link = null,\n    suffix = null,\n    value = \"\"\n  }) {\n    let tooltipStr = \"\";\n    let iconStr = null;\n    let linkStr = \"\";\n    let str = \"\";\n\n    if (tooltip) {\n      tooltipStr = `\n                  <div class=\"mini-input-section--tooltip\">\n                    ${tooltip}\n                  </div>`;\n    }\n\n    if (colorIcon) {\n      if (utils.isHexColor(itemFormated.colorIcon)) {\n        iconStr = `<div class=\"mini-input-section--icon\" style=\"background:${colorIcon}\"> </div>`;\n      } else {\n        iconStr = `<div class=\"mini-input-section--icon ${colorIcon}\"> </div>`;\n      }\n    }\n\n    if (link) {\n      linkStr = `<a class=\"mini-input-section--link\" target=\"_blank\" href=\"${link}\">${icons.linkIcon}</a> `;\n    }\n\n    str += `\n            <div class=\"mini-input-section ${\n              iconStr ? \"has-icon\" : \"\"\n            } \" label=\"${label}\" data-id=\"${id}\" data-key=\"${key}\" data-value=\"${value || ''}\">\n              <label>\n                ${iconStr || \"\"}\n\n                <div class=\"mini-input-section--titles\">\n                  <div class=\"mini-input-section--title truncate\">\n                    ${label}\n                  </div>\n                  <div class=\"mini-input-section--subtitle truncate\">\n                    ${subText}\n                  </div>\n                </div>\n\n                <div class=\"mini-input-section--content\" >\n                  ${valueText}\n                </div>\n                <div class=\"mini-input-section--suffix\" >\n                  ${suffix}\n                </div>\n\n                ${linkStr}\n\n              </label>\n              ${tooltipStr}\n            </div>`;\n    return dom.createElementFromHTML(str);\n  },\n\n  createList(props, dataDay) {\n    let tabsContainer = \"\";\n\n    if (props.tabs) {\n      let tabs = \"\";\n      props.tabs.forEach((tab) => {\n        tabs += `\n        <div class=\"input-box-tab\" tab-key=\"${tab.key}\">\n          ${tab.name}\n        </div>`;\n      });\n\n      tabsContainer = `\n        <div class=\"input-box-tab-container\">\n        ${tabs}\n        </div>\n      `;\n    }\n\n    let searchInput = `\n      <div class=\"search-input-container\">\n        <input id=\"\" type=\"text\" name=\"\" class=\"search-input\" placeholder=\"buscar\">\n        <button class=\"search-input-clear\">\n         ${icons.closeIcon}\n        </button>\n      </div>\n    `;\n\n    let str = `\n      <div class=\"input-section ${props.isHidden ? 'hide':''} \" input-key=\"${props.key || \"\"}\">\n           <span class=\"text-subtitle d-block\">\n              ${props.label}\n            </span>\n\n            ${tabsContainer}\n        <div class=\"input-box \" input-key=\"${props.key || \"\"}\">\n\n            ${searchInput}\n      `;\n\n    //TODO obtener input segun fila\n    if (props.inputs) {\n      props.inputs.forEach((i) => {\n        if (i.isTitle) {\n          let tooltip = \"\";\n          let icon = null;\n\n          if (i.tooltip) {\n            tooltip = `\n                  <div class=\"mini-input-section--tooltip\">\n                    ${i.tooltip}\n                    ${i.suffix ? \"(\" + i.suffix + \")\" : \"\"}\n                  </div>`;\n          }\n\n          if (i.colorIcon) {\n            if (utils.isHexColor(i.colorIcon)) {\n              icon = `<div class=\"mini-input-section--icon\" style=\"background:${i.colorIcon}\"> </div>`;\n            } else {\n              icon = `<div class=\"mini-input-section--icon ${i.colorIcon}\"> </div>`;\n            }\n          }\n\n          str += `\n            <div class=\"mini-input-section is-title  ${\n              icon ? \"has-icon\" : \"\"\n            }\" input-tab-key=\"${i.tabKey || \"\"}\" label=\"${i.label}\">\n              <label>\n                ${icon || \"\"}\n                <div class=\"mini-input-section--title truncate\">\n                  ${i.label}\n                </div>\n              </label>\n              ${tooltip}\n            </div>`;\n        } else {\n          let tooltip = \"\";\n          let icon = null;\n          let link = \"\";\n\n          if (i.tooltip) {\n            tooltip = `\n                  <div class=\"mini-input-section--tooltip\">\n                    ${i.tooltip}\n                  </div>`;\n          }\n\n          if (i.colorIcon) {\n            if (utils.isHexColor(i.colorIcon)) {\n              icon = `<div class=\"mini-input-section--icon\" style=\"background:${i.colorIcon}\"> </div>`;\n            } else {\n              icon = `<div class=\"mini-input-section--icon ${i.colorIcon}\"> </div>`;\n            }\n          }\n\n          if (i.link) {\n            link = `<a class=\"mini-input-section--link\" target=\"_blank\" href=\"${i.link}\">\n                ${icons.linkIcon}\n                </a> `;\n          }\n\n          str += `\n            <div class=\"mini-input-section  ${\n              icon ? \"has-icon\" : \"\"\n            }\" input-tab-key=\"${i.tabKey || \"\"}\" label=\"${i.label}\">\n              <label>\n\n                ${icon}\n\n                <div class=\"mini-input-section--title truncate\">\n                  ${i.label}\n                </div>\n\n                <div class=\"mini-input-section--suffix\" >${\n                  i.suffix ? \"(\" + i.suffix + \")\" : \"\"\n                }</div>\n\n                ${link}\n\n              </label>\n              <div class=\"mini-input-section--footer\">\n                <span class=\"start\"> start</span>\n                <span class=\"end\"> end </span>\n              </div>\n              ${tooltip}\n            </div>`;\n        }\n      });\n    }\n\n    str += `\n        </div>\n      </div> `;\n\n    let $el = dom.createElementFromHTML(str);\n    let $tabs = $el.querySelectorAll(\".input-box-tab[tab-key]\") || [];\n    let $searchInput = $el.querySelector(\".search-input\") || null;\n    let $searchInputClear = $el.querySelector(\".search-input-clear\") || null;\n\n    $tabs.forEach((t) => {\n      t.addEventListener(\"click\", (e) => {\n        this.selectInputBoxTab(t, $el);\n        $searchInput.value = \"\";\n        $searchInput.dispatchEvent(new Event(\"input\", { bubbles: true }));\n      });\n    });\n\n    if ($searchInputClear) {\n      $searchInputClear.addEventListener(\"click\", (e) => {\n        $searchInput.value = \"\";\n        $searchInput.dispatchEvent(new Event(\"input\", { bubbles: true }));\n      });\n    }\n\n    if ($searchInput) {\n      $searchInput.addEventListener(\"keydown\", (e) => {\n        if (e.key === \"Escape\") {\n          $searchInput.value = \"\";\n          $searchInput.dispatchEvent(new Event(\"input\", { bubbles: true }));\n        }\n      });\n\n      $searchInput.addEventListener(\"input\", (e) => {\n        let $tabSelected =\n          $el.querySelector(\".input-box-tab[tab-key].active\") || null;\n        let $inputs = [];\n        if ($tabSelected) {\n          let tabKey = $tabSelected.getAttribute(\"tab-key\");\n          $inputs =\n            $el.querySelectorAll(\n              \".mini-input-section[input-tab-key='\" + tabKey + \"']\"\n            ) || [];\n        } else {\n          $inputs = $el.querySelectorAll(\".mini-input-section\") || [];\n        }\n        $inputs.forEach(($i) => {\n          let label = $i.getAttribute(\"label\");\n          let search = $searchInput.value;\n          if (label.toLowerCase().includes(search.toLowerCase())) {\n            $i.classList.remove(\"hide\");\n          } else {\n            $i.classList.add(\"hide\");\n          }\n        });\n      });\n    }\n\n    this.selectInputBoxTab(_.first($tabs), $el);\n\n    return $el;\n  },\n\n  /**\n   * Crea InputBox, como elemento Dom\n   * un InputBox es un contenedor con una lista de inputs\n   *\n   * @param {Object} props - config para Input\n   * @param {Object} dataDay - valores de item y Dia, opcional\n   * @return {Object} Elemento Dom del input creado\n   */\n  createInputBox(props, dataDay) {\n    let value = [];\n    if (dataDay && dataDay.values) {\n      value = utils.getVarByPath(dataDay, props.varName);\n    }\n\n    let tabsContainer = \"\";\n\n    if (props.tabs) {\n      let tabs = \"\";\n      props.tabs.forEach((tab) => {\n        tabs += `\n        <div class=\"input-box-tab\" tab-key=\"${tab.key}\">\n          ${tab.name}\n        </div>`;\n      });\n\n      tabsContainer = `\n        <div class=\"input-box-tab-container\">\n        ${tabs}\n        </div>\n      `;\n    }\n\n    let searchInput = `\n      <div class=\"search-input-container\">\n        <input id=\"\" type=\"text\" name=\"\" class=\"search-input\" placeholder=\"buscar\">\n        <button class=\"search-input-clear\">\n         ${icons.closeIcon}\n        </button>\n      </div>\n    `;\n\n    let str = `\n      <div class=\"input-section ${props.isHidden ? 'hide':''} \" input-key=\"${props.key || \"\"}\">\n           <span class=\"text-subtitle d-block\">\n              ${props.label}\n            </span>\n\n            ${tabsContainer}\n\n            <div class=\"input-box \" input-key=\"${props.key || \"\"}\">\n\n            ${searchInput}\n      `;\n\n    if (props.inputs) {\n      props.inputs.forEach((i) => {\n        if (i.isTitle) {\n          let tooltip = \"\";\n          let icon = \"\";\n\n          if (i.tooltip) {\n            tooltip = `\n                  <div class=\"mini-input-section--tooltip\">\n                    ${i.tooltip}\n                    ${i.suffix ? \"(\" + i.suffix + \")\" : \"\"}\n                  </div>`;\n          }\n\n          if (i.colorIcon) {\n            if (utils.isHexColor(i.colorIcon)) {\n              icon = `<div class=\"mini-input-section--icon\" style=\"background:${i.colorIcon}\"> </div>`;\n            } else {\n              icon = `<div class=\"mini-input-section--icon ${i.colorIcon}\"> </div>`;\n            }\n          }\n\n          str += `\n            <div class=\"mini-input-section is-title\" input-tab-key=\"${\n              i.tabKey || \"\"\n            }\" label=\"${i.label}\">\n              <label>\n                ${icon}\n                <div class=\"mini-input-section--title truncate\">\n                  ${i.label}\n                </div>\n              </label>\n              ${tooltip}\n            </div>`;\n        } else {\n          let value_found = value ? value.find((val) => val.id == i.id) : null;\n          let v = value_found || \"\";\n          let inputValue =\n            props.varNameInput && v[props.varNameInput]\n              ? v[props.varNameInput]\n              : v.value;\n          let tooltip = \"\";\n          let icon = \"\";\n          let link = \"\";\n\n          if (i.tooltip) {\n            tooltip = `\n                  <div class=\"mini-input-section--tooltip\">\n                    ${i.tooltip}\n                  </div>`;\n          }\n\n          if (i.colorIcon) {\n            if (utils.isHexColor(i.colorIcon)) {\n              icon = `<div class=\"mini-input-section--icon\" style=\"background:${i.colorIcon}\"> </div>`;\n            } else {\n              icon = `<div class=\"mini-input-section--icon ${i.colorIcon}\"> </div>`;\n            }\n          }\n\n          if (i.link) {\n            link = `<a class=\"mini-input-section--link\" target=\"_blank\" href=\"${i.link}\">\n                ${icons.linkIcon}\n                </a> `;\n          }\n\n          str += `\n            <div class=\"mini-input-section ${\n              icon ? \"has-icon\" : \"\"\n            }\" input-tab-key=\"${i.tabKey || \"\"}\" label=\"${i.label}\">\n              <label>\n                <input type=\"number\"\n                      class=\"mini-input\"\n                      input-id=\"${i.id || \"\"}\"\n                      input-key=\"${i.key || i.label}\"\n                      value=\"${inputValue || \"\"}\">\n\n                ${icon || \"\"}\n\n                <div class=\"mini-input-section--title truncate\">\n                  ${i.label}\n                </div>\n\n                <div class=\"mini-input-section--suffix\" >${\n                  i.suffix ? \"(\" + i.suffix + \")\" : \"\"\n                }</div>\n\n                ${link}\n\n              </label>\n              ${tooltip}\n            </div>`;\n        }\n      });\n    }\n\n    str += `\n        </div>\n      </div> `;\n\n    let $el = dom.createElementFromHTML(str);\n    let $tabs = $el.querySelectorAll(\".input-box-tab[tab-key]\") || [];\n    let $inputs = $el.querySelectorAll(\"input.mini-input\") || [];\n    let $searchInput = $el.querySelector(\".search-input\") || null;\n    let $searchInputClear = $el.querySelector(\".search-input-clear\") || null;\n\n    $tabs.forEach((t) => {\n      t.addEventListener(\"click\", (e) => {\n        this.selectInputBoxTab(t, $el);\n        $searchInput.value = \"\";\n        $searchInput.dispatchEvent(new Event(\"input\", { bubbles: true }));\n      });\n    });\n\n    if ($searchInputClear) {\n      $searchInputClear.addEventListener(\"click\", (e) => {\n        $searchInput.value = \"\";\n        $searchInput.dispatchEvent(new Event(\"input\", { bubbles: true }));\n      });\n    }\n\n    if ($searchInput) {\n      $searchInput.addEventListener(\"keydown\", (e) => {\n        if (e.key === \"Escape\") {\n          $searchInput.value = \"\";\n          $searchInput.dispatchEvent(new Event(\"input\", { bubbles: true }));\n        }\n      });\n\n      $searchInput.addEventListener(\"input\", (e) => {\n        let $tabSelected =\n          $el.querySelector(\".input-box-tab[tab-key].active\") || null;\n        let $inputs = [];\n        if ($tabSelected) {\n          let tabKey = $tabSelected.getAttribute(\"tab-key\");\n          $inputs =\n            $el.querySelectorAll(\n              \".mini-input-section[input-tab-key='\" + tabKey + \"']\"\n            ) || [];\n        } else {\n          $inputs = $el.querySelectorAll(\".mini-input-section\") || [];\n        }\n        $inputs.forEach(($i) => {\n          let label = $i.getAttribute(\"label\");\n          let search = $searchInput.value;\n          if (label.toLowerCase().includes(search.toLowerCase())) {\n            $i.classList.remove(\"hide\");\n          } else {\n            $i.classList.add(\"hide\");\n          }\n        });\n      });\n    }\n\n    this.selectInputBoxTab(_.first($tabs), $el);\n\n    $inputs.forEach((i) => this.addKeyDownInputEvents(i, $el, props));\n\n    return $el;\n  },\n\n  selectInputBoxTab($tab, $el) {\n    let $tabs = $el.querySelectorAll(\".input-box-tab[tab-key]\") || [];\n    let $inputSections = $el.querySelectorAll(\".mini-input-section\") || [];\n\n    $tabs.forEach((t) => {\n      t.classList.remove(\"active\");\n    });\n\n    if ($tab) {\n      $tab.classList.add(\"active\");\n\n      $inputSections.forEach((i) => {\n        let key = i.getAttribute(\"input-tab-key\");\n        if (key == $tab.getAttribute(\"tab-key\")) {\n          i.classList.remove(\"hide\");\n        } else {\n          i.classList.add(\"hide\");\n        }\n      });\n    }\n  },\n\n  /**\n   * Crea Checkbox, como elemento Dom\n   *\n   * @param {Object} props - config para Input\n   * @param {Object} dataDay - valores de item y Dia, opcional\n   * @return {Object} Elemento Dom del input creado\n   */\n  createInputCheckbox(props, dataDay) {\n    let value = \"\";\n    if (dataDay && dataDay.values) {\n      value = utils.getVarByPath(dataDay, props.varName);\n    }\n    let r = dom.createElementFromHTML(`\n      <div class=\"input-section ${props.isHidden ? 'hide':''} \" input-key=\"${props.key || \"\"}\">\n        <label>\n          <input type=\"checkbox\" name=\"${props.key || \"\"}\" input-key=\"${\n            props.key || \"\"\n          }\" ${value ? \"checked\" : \"\"}>\n          ${props.label}\n        </label>\n      </div>`);\n\n    return r;\n  },\n\n  createInputButtonsGroup(props) {\n    let $container = dom.createElementFromHTML(`\n      <div class=\"input-section ${props.isHidden ? 'hide':''} \" input-key=\"${props.key || \"\"}\">\n        <div class=\"buttons-group\"> </div>\n      </div>`);\n\n    let $containerButtonGroup = $container.querySelector(\".buttons-group\");\n\n    let $buttons = [];\n    $buttons = props.buttons.map((buttonProp) => {\n      let buttonStr = `\n        <button \n          name=\"${buttonProp.key || \"\"}\" \n          input-key=\"${buttonProp.key || \"\"}\"\n          class=\"cap-btn-outline cap-btn-sm ${buttonProp.isSelected ? 'selected' : ''} \">\n          ${buttonProp.label}\n        </button>`;\n\n      let $button = domUtils.createElementFromHTML(buttonStr);\n      $containerButtonGroup.append($button);\n\n      $button.addEventListener(\"click\", (e) => {\n        if (props.isSelectable) {\n          $buttons.forEach(($b) => $b.classList.remove(\"selected\"));\n          $button.classList.add(\"selected\");\n        }\n        buttonProp.onClick({ props, event: e, buttonsElements: $buttons });\n      });\n      return $button;\n    });\n\n    return $container;\n  },\n\n  createInputButton(props) {\n    let r = dom.createElementFromHTML(`\n      <div class=\"input-section ${props.isHidden ? 'hide':''} \" input-key=\"${props.key || \"\"}\">\n          <button \n            name=\"${props.key || \"\"}\"\n            input-key=\"${props.key || \"\"}\"\n            class=\"cap-btn-outline\">\n            ${props.label}\n          </button>\n      </div>`);\n\n    let button = r.querySelector(\"button\");\n    button.addEventListener(\"click\", (e) => props.onClick({ props, event: e }));\n\n    return r;\n  },\n\n  addKeyDownInputEvents($input, $inputContainer, props) {\n    $input.addEventListener(\"keydown\", function (event) {\n      if (event.keyCode === 13) {\n        //ENTER\n        $input.dispatchEvent(\n          new CustomEvent(\"saveMultiInput\", {\n            bubbles: true,\n            cancelable: false\n          })\n        );\n      }\n      if (event.keyCode === 27) {\n        //ESC\n        $input.dispatchEvent(\n          new CustomEvent(\"cancelMultiInput\", {\n            bubbles: true,\n            cancelable: false\n          })\n        );\n      }\n    });\n    $input.addEventListener(\"input\", (e) => {\n      if(props.onInput){\n        props.onInput({\n          event:e,\n          value: e.srcElement.value,\n          props,\n          $element: $inputContainer\n        });\n      }\n    });\n  },\n\n  createContextMenu({\n    config,\n    $capibaraElem = null,\n    evt = null,\n    date = null,\n    item = null,\n    selected = [],\n    tabSelected = null,\n    left = null,\n    top = null,\n    name = \"\"\n  }) {\n    if (config.timeline.contextMenu === undefined)\n      return { elem: null, isVisible: false };\n\n    let className = \"\";\n    let style = \"\";\n    let strHtml = \"\";\n    let leftPosition = null;\n    let topPosition = null;\n    let isVisible = true;\n    let boundRectCapibara = null;\n    let gap = 15; //px\n\n    if ($capibaraElem) {\n      boundRectCapibara = $capibaraElem.getBoundingClientRect();\n    }\n\n    if (evt && boundRectCapibara) {\n      left = evt.clientX;\n      top = evt.clientY - boundRectCapibara.top;\n    }\n\n    if (left) {\n      leftPosition = left;\n    }\n\n    if (top) {\n      topPosition = top;\n    }\n\n    if ((leftPosition !== null) & (topPosition !== null)) {\n      if (boundRectCapibara) {\n        let transformStyle = \"\";\n        if (\n          topPosition > (boundRectCapibara.height * 2) / 6 &&\n          topPosition <= (boundRectCapibara.height * 4) / 6\n        ) {\n          transformStyle += `translateY(-50%)`;\n        }\n        if (topPosition > (boundRectCapibara.height * 4) / 6) {\n          transformStyle += `translateY(-100%)`;\n        }\n\n        if (leftPosition > (boundRectCapibara.width * 4) / 6) {\n          transformStyle += `translateX(-100%)`;\n          leftPosition -= gap;\n        } else {\n          leftPosition += gap;\n        }\n        if (transformStyle != \"\") {\n          style += ` transform: ${transformStyle};`;\n        }\n      }\n\n      style += `top: ${topPosition}px; left: ${leftPosition}px;`;\n    } else {\n      className += \"cm-hide\";\n      isVisible = false;\n    }\n\n    strHtml += ` <div class=\"cap-context-menu-container ${className}\">\n                    <div class=\"cap-context-menu\" style=\"${style}\">\n                    </div>\n                 </div>`;\n\n    let $contextMenuContainer = dom.createElementFromHTML(strHtml);\n    let $contextMenu = $contextMenuContainer.querySelector(\".cap-context-menu\");\n\n    config.timeline.contextMenu.options.forEach((option) => {\n      if (option.showIf) {\n        let show = option.showIf({ item, date, selected, name, tabSelected });\n        if (!show) return;\n      }\n\n      let isEnabled = true;\n      let isClickeable = true;\n      if (option.enableIf) {\n        isEnabled = option.enableIf({\n          item,\n          date,\n          selected,\n          name,\n          tabSelected\n        });\n      }\n\n      let optionClassName = \"\";\n      let strIcon = \"\";\n      let label = \"\";\n\n      if (!isEnabled) {\n        optionClassName += \"is-disabled \";\n      }\n\n      if (option.isDivider) {\n        isClickeable = false;\n        optionClassName += \"is-divider \";\n      }\n\n      if (option.label) {\n        label = `<span>${option.label}</span>`;\n      }\n\n      if (option.icon) {\n        strIcon = `<div class=\"cap-context-menu_item_icon\">\n                      <svg viewBox=\"0 0 24 24\">\n                        <path d=\"${option.icon}\" />\n                      </svg>\n                  </div>`;\n      }\n\n      let optionStrHtml = `\n        <div class=\"cap-context-menu_item ${optionClassName}\">\n          ${strIcon}\n          ${label}\n        </div>`;\n\n      let $option = dom.createElementFromHTML(optionStrHtml);\n\n      if (isEnabled && isClickeable) {\n        $option.addEventListener(\"click\", (evtClick) =>\n          option.onClick({\n            config,\n            evt: evtClick,\n            date,\n            item,\n            selected,\n            tabSelected\n          })\n        );\n      } else {\n        $option.addEventListener(\"click\", (evtClick) => {\n          evtClick.preventDefault();\n          evtClick.stopPropagation();\n        });\n      }\n\n      $contextMenu.append($option);\n    });\n\n    return {\n      elem: $contextMenuContainer,\n      isVisible\n    };\n  }\n};\n"],"mappings":"AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AAAA;AACA;AAAA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AAAA;AAAA;AAAA;AAEA;AACA;AAEA;AACA;AACA;AAGA;AACA;AAEA;AAAA;AAAA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AADA;AAGA;AACA;AACA;AACA;AACA;AACA;AADA;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AAAA;AAAA;AAAA;AAEA;AACA;AAGA;AACA;AACA;AACA;AACA;AACA;AAFA;AAFA;AAOA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAFA;AAFA;AAOA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AAQA;AAQA;AAEA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AAEA;AACA;AAEA;AACA;AAAA;AACA;AACA;AAEA;AACA;AAFA;AAKA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AAAA;AAAA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AAAA;AAAA;AAAA;AAAA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AAHA;AAKA;AAPA;AACA;AAQA;AACA;AACA;AACA;AACA;AACA;AACA;AAHA;AAKA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AAGA;AACA;AAEA;AAEA;AAEA;AACA;AACA;AACA;AAGA;AACA;AACA;AAGA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAGA;AAGA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AAAA;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AAEA;AACA;AAFA;AAKA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AAAA;AAAA;AAAA;AAHA;AAMA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AAEA;AACA;AAFA;AAKA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AAEA;AACA;AACA;AACA;AADA;AAHA;AAQA;AAEA;AACA;AAEA;AACA;AACA;AACA;AADA;AAHA;AAQA;AAEA;AACA;AAEA;AACA;AACA;AACA;AADA;AAHA;AAQA;AAEA;AACA;AAAA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AAEA;AACA;AACA;AACA;AACA;AAFA;AAHA;AASA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AAEA;AACA;AACA;AACA;AADA;AAHA;AAQA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AAEA;AACA;AACA;AACA;AADA;AAHA;AAQA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAKA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AAKA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAKA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AAJA;AAHA;AAWA;AAEA;AACA;AAEA;AACA;AACA;AACA;AACA;AAFA;AAHA;AASA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AAIA;AAEA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AAKA;AACA;AACA;AACA;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AAEA;AAEA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AAGA;AAEA;AAEA;AACA;AACA;AACA;AACA;AACA;AAHA;AAHA;AAUA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAGA;AACA;AACA;AACA;AACA;AACA;AAGA;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AAIA;AACA;AAEA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAOA;AACA;AACA;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AA7CA;AA+CA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAGA;AACA;AACA;AAEA;AACA;AAAA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AA7CA;AA+CA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AA7CA;AA+CA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAGA;AACA;AACA;AAEA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AA7CA;AA+CA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AAIA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAGA;AACA;AAAA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AAGA;AACA;AACA;AAIA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAGA;AACA;AACA;AACA;AACA;AAGA;AACA;AAAA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AAJA;AAHA;AAWA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AAFA;AAKA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AAFA;AAKA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AAHA;AAHA;AAUA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AANA;AAHA;AAaA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AAHA;AAHA;AAUA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AAKA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAFA;AAHA;AAWA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAQA;AACA;AAAA;AACA;AADA;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAJA;AAMA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAKA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAMA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AAAA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AAAA;AAAA;AAEA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAMA;AACA;AACA;AAAA;AACA;AACA;AAFA;AAIA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AADA;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AAEA;AACA;AAMA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AAEA;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAIA;AACA;AACA;AACA;AACA;AAKA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAKA;AAKA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAGA;AACA;AACA;AACA;AACA;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAOA;AAEA;AACA;AAAA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AAEA;AAEA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AAHA;AAHA;AAUA;AAEA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AAHA;AAHA;AAUA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAOA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAIA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AAEA;AACA;AACA;AAGA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAIA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAIA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AAAA;AAKA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAGA;AACA;AAAA;AAAA;AAAA;AACA;AAAA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAAA;AAAA;AAAA;AACA;AACA;AAAA;AACA;AACA;AAFA;AAIA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAFA;AAIA;AACA;AACA;AAFA;AAIA;AAGA;AACA;AAEA;AACA;AAEA;AACA;AAFA;AAKA;AAEA;AACA;AAEA;AACA;AAFA;AAKA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AAAA;AACA;AACA;AA1DA;AACA;AA4DA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AAEA;AACA;AAEA;AACA;AACA;AACA;AACA;AAFA;AAHA;AASA;AAEA;AACA;AAEA;AACA;AACA;AACA;AACA;AAFA;AAHA;AASA;AAEA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AAAA;AAAA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AAAA;AAEA;AACA;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AAEA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AAEA;AACA;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AAIA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAGA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AAEA;AACA;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAVA;AAYA;AACA;AAEA;AACA;AACA;AAAA;AAAA;AACA;AAEA;AACA;AACA;AACA;AAAA;AAAA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AAAA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AANA;AASA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAVA;AAYA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AAAA;AACA;AACA;AAEA;AACA;AAEA;AACA;AAAA;AACA;AACA;AAIA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAIA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AAAA;AACA;AACA;AAEA;AACA;AAEA;AACA;AAAA;AACA;AACA;AAIA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AAEA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AAGA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AAAA;AAAA;AAAA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AAFA;AAKA;AACA;AAAA;AACA;AACA;AAEA;AACA;AAFA;AAKA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAJA;AAMA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAVA;AAYA;AACA;AAAA;AAAA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AAIA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AAEA;AACA;AACA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AALA;AAOA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AANA;AASA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AAFA;AAIA;AACA;AAl/HA","sourceRoot":""}\n//# sourceURL=webpack-internal:///./src/util/tableElements.js\n");
258
+ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _util_domUtils__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../util/domUtils */ \"./src/util/domUtils.js\");\n/* harmony import */ var _util_utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../util/utils */ \"./src/util/utils.js\");\n/* harmony import */ var _util_dateUtils__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../util/dateUtils */ \"./src/util/dateUtils.js\");\n/* harmony import */ var _util_icons__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../util/icons */ \"./src/util/icons.js\");\n\n\n\n\n\n/* harmony default export */ __webpack_exports__[\"default\"] = ({\n /**\n * Crea elemento Table\n * Contendrá los elementos que apareceran dentro de la tabla de planilla\n * Se Usa para :\n * - Agregar background con patron estilo tabla\n * - Agregar dayMouseOver, div que indica posicion de mouse\n * - Agregar DetailDay, para detalles de datos en tabla\n * - Agregar SelectedContainer, para dias seleccionados\n * - Agregar FloatBoxContainer, para visualizacion de datos en tabla\n *\n * @param {Object} config - Configuracion capibara\n * @return {Object} Elemento Dom creado\n */\n createAgTable(config) {\n let e = _util_domUtils__WEBPACK_IMPORTED_MODULE_0__[\"default\"].createElement(\"div\", {\n className: \"capibara\"\n });\n\n if (config.timeline.dark) {\n e.classList.add(\"dark-theme\");\n }\n\n if (config.timeline.header.extend.isShow) {\n e.classList.add(\"header-extended\");\n }\n\n return e;\n },\n\n /**\n * Recrea Background, que es el fondo grid, como tabla\n *\n * @param {Object} config - Configuracion capibara\n * @param {Object} $elem - Elemento relacionado, donde se cre el background\n * @return {Object} Elemento Dom Corner Footer\n */\n redrawBackground(config, $elem) {\n return this.createBackground(config, $elem);\n },\n\n /**\n * Crea y posiciona fondo de tabla\n * Este fondo contiene un patron de CSS que le da la apariencia de tabla\n * por lo cual se debe reposicionar segun la fecha de inicio, para hacer\n * calzar los fines de semana\n *\n * @param {Object} config - Configuracion capibara\n * @param {Object} [$elem = null] - Elemento background, si es null, lo crea\n * @return {Object} elemento Dom Background\n */\n createBackground(config, $elem = null) {\n let {\n height,\n width,\n dayWidth\n } = _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getTableDimensions(config);\n let start = new Date(config.timeline.start);\n let end = new Date(config.timeline.end);\n end.setTime(end.getTime() + _util_dateUtils__WEBPACK_IMPORTED_MODULE_2__[\"default\"].dayInMilliseconds); // add 24 hours\n\n let dCorrected = new Date(start.valueOf() + start.getTimezoneOffset() * 60000);\n let weekDay = dCorrected.getDay();\n let diffWeekDays = (weekDay - 1) * dayWidth * -1;\n $elem = $elem || _util_domUtils__WEBPACK_IMPORTED_MODULE_0__[\"default\"].createElement(\"div\", {\n className: \"background-grid\"\n });\n $elem.style[\"background-position\"] = diffWeekDays + \"px 0, 0 0, \" + diffWeekDays + \"px 0\";\n $elem.style.width = width + \"px\";\n $elem.style.height = height + 1 + \"px\";\n return $elem;\n },\n\n /**\n * Crea Plot Container Vertical\n * Los plots son elementos que agregan secciones de fondo en la planilla\n *\n * @param {Object} config - Configuracion capibara\n * @return {Object} Elemento Dom plotVerticalContainer\n */\n createPlotVerticalContainer(config) {\n let $elem = _util_domUtils__WEBPACK_IMPORTED_MODULE_0__[\"default\"].createElement(\"div\", {\n className: \"plot-vertical-container\"\n });\n return this.redrawPlotVerticalContainer(config, $elem);\n },\n\n createPlotHorizontalContainer(config) {\n let $elem = _util_domUtils__WEBPACK_IMPORTED_MODULE_0__[\"default\"].createElement(\"div\", {\n className: \"plot-horizontal-container\"\n });\n return this.redrawPlotHorizontalContainer(config, $elem);\n },\n\n /**\n * Recrea plotVerticalContainer, usando elemento existente\n * usa un elemento existente para usar la funcion para redibujar el elemento\n *\n * Los Plots se insertan como divs, con posicion especificada,\n * con ancho de dia\n *\n * @param {Object} config - Configuracion capibara\n * @param {Object} $elem - Elemento Dom donde crea plotVerticalContainer\n * @return {Object} Elemento Dom plotVerticalContainer\n */\n redrawPlotVerticalContainer(config, $elem) {\n $elem.innerHTML = \"\";\n\n if (config.timeline.plots && config.timeline.plots.vertical) {\n let {\n height,\n dayWidth\n } = _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getTableDimensions(config);\n config.timeline.plots.vertical.forEach(p => {\n let diffDays = Math.floor(_util_dateUtils__WEBPACK_IMPORTED_MODULE_2__[\"default\"].diffDays(config.timeline.start, p.date));\n let left = diffDays * dayWidth;\n let plot = _util_domUtils__WEBPACK_IMPORTED_MODULE_0__[\"default\"].createElement(\"div\", {\n classNames: [\"plot-vertical\", p.className || \"\"],\n style: {\n \"margin-left\": left + \"px\",\n height: height + \"px\"\n }\n });\n $elem.appendChild(plot);\n });\n }\n\n return $elem;\n },\n\n redrawPlotHorizontalContainer(config, $elem) {\n $elem.innerHTML = \"\";\n\n if (config.timeline.plots && config.timeline.plots.horizontal) {\n let {\n width,\n itemHeight\n } = _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getTableDimensions(config);\n config.timeline.plots.horizontal.forEach(p => {\n let item = _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getItemById(config, p.idNode, p.typeNode);\n let topPosition = _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getPositionByItem(config, item, \"parent\");\n let plot = _util_domUtils__WEBPACK_IMPORTED_MODULE_0__[\"default\"].createElement(\"div\", {\n classNames: [\"plot-horizontal\", p.className || \"\"],\n style: {\n \"margin-top\": topPosition * itemHeight + \"px\",\n width: width + \"px\"\n }\n });\n $elem.appendChild(plot);\n });\n }\n\n return $elem;\n },\n\n /**\n * Crea Corner Izquierdo\n * Se usa para :\n * - titulos relacionados con los datos del sidebar izquierdo\n * - titulos para inputs de header, absolute a la derecha\n * - boton para mostrar/ocultar sidebar izquierdo\n * - promedios\n *\n * @param {Object} config - Configuracion capibara\n * @return {Object} Elemento Dom Corner\n */\n createCorner(config, tab = null) {\n let $elem = _util_domUtils__WEBPACK_IMPORTED_MODULE_0__[\"default\"].createElement(\"div\", {\n className: \"corner\"\n });\n return this.redrawCorner($elem, config, tab);\n },\n\n redrawCorner($elem, config, tab = null) {\n let labelsInitialCorner = config.timeline.nav.left.initial.vars.filter(v => v.onlyTab == undefined || v.onlyTab && tab && v.onlyTab == tab.key).map(d => `<span class=\"item-col\">${d.label}</span>`).join(\"\");\n let labelsExtendCorner = config.timeline.nav.left.extend.vars.filter(v => v.onlyTab == undefined || v.onlyTab && tab && v.onlyTab == tab.key).map(d => `<span class=\"item-col\">${d.label}</span>`).join(\"\");\n let labelsHeaderExtend = config.timeline.header.extend.data.map(d => {\n if (d.isHidden) return \"\";\n let avg = \"\";\n let tooltip = \"\";\n let className = \"\";\n let isAccent = d.isAccent;\n\n if (d.average) {\n avg = ` <span class=\"average \"> ( <span> <span class=\"symbol\">x̄</span> ${d.average} </span>) </span> `;\n tooltip = `cap-tooltip=\"Promedio ${d.label} : ${d.average} ${d.suffix || \"\"}\"`;\n }\n\n if (d.color) {\n if (isAccent) {\n className = d.color ? \"c-\" + d.color + \"--background\" : \"\";\n } else {\n className = d.color ? \"c-\" + d.color + \"--text \" : \"\";\n }\n }\n\n return `<div class=\"input-title-container ${isAccent ? \"input-title--accent\" : \"\"} ${d.isPersistent ? \"persistent\" : \"\"}\">\n <span ${tooltip} class=\"input-title ${className}\">\n ${avg}\n ${d.label}\n </span>\n\n </div>`;\n }).join(\"\");\n let toggleSidebarBtnString = `\n <button toggle-sidebar class=\"cap-btn-icon cap-btn-icon-raised cap-btn-toggle-sidebar \">\n ${_util_icons__WEBPACK_IMPORTED_MODULE_3__[\"default\"].chevronRight}\n </button> `;\n\n if (config.timeline.nav.left.hideToggleSidebarButton) {\n toggleSidebarBtnString = \"\";\n }\n\n let template = `<div>\n\n ${toggleSidebarBtnString}\n <div class=\"corner-title\">\n <span class=\"bottom-text\">\n ${config.timeline.corner.left.label}\n </span>\n </div>\n\n <div class=\"initial-corner\">\n <div class=\"initial-corner-title\">\n <span class=\"bottom-container hide\">\n ${config.timeline.corner.initial.label}\n </span>\n\n <div class=\"bottom-container\">\n ${labelsInitialCorner}\n </div>\n\n </div>\n </div>\n\n\n <div class=\"extend-corner\">\n <div class=\"ex-corner-title\">\n <span class=\"bottom-container hide\">\n ${config.timeline.corner.extend.label}\n </span>\n\n <div class=\"bottom-container\">\n ${labelsExtendCorner}\n </div>\n\n </div>\n </div>\n\n\n <div class=\"cap-btn-nav-corner\">\n <div class=\"input-titles\">\n ${labelsHeaderExtend}\n </div>\n </div>\n\n <div class=\"progress-bar progress-bar-left hide-progress\"></div>\n\n </div>`;\n let r = _util_domUtils__WEBPACK_IMPORTED_MODULE_0__[\"default\"].createElementFromHTML(template);\n $elem.innerHTML = \"\";\n $elem.append(r);\n let toggleSidebar = $elem.querySelector(\"[toggle-sidebar]\");\n\n if (toggleSidebar) {\n toggleSidebar.addEventListener(\"click\", e => {\n r.dispatchEvent(new CustomEvent(\"toggleSidebar\", {\n bubbles: true,\n cancelable: false\n }));\n });\n }\n\n return $elem;\n },\n\n /**\n * Crea Corner Derecho\n * Se usa para :\n * - titulos relacionados con los datos del sidebar Derecho\n *\n * @param {Object} config - Configuracion capibara\n * @return {Object} Elemento Dom corner\n */\n createCornerRight(config, tab = null) {\n let $elem = _util_domUtils__WEBPACK_IMPORTED_MODULE_0__[\"default\"].createElement(\"div\", {\n classNames: [\"corner\", \"right\"]\n });\n return this.redrawCornerRight($elem, config, tab);\n },\n\n redrawCornerRight($el, config, tab = null) {\n let label = \"\";\n\n if (config.timeline.corner.right.label) {\n ` <span>\n ${config.timeline.corner.right.label}\n </span>`;\n }\n\n let str = `\n <div class=\"corner-title\">\n ${label}\n <div class=\"btn-container\"></div>\n </div>\n <div class=\"progress-bar progress-bar-right hide-progress\"></div>\n `;\n $el.innerHTML = str.trim();\n let $btnContainer = $el.querySelector(\".btn-container\");\n\n if (config.timeline.corner.right.buttons) {\n config.timeline.corner.right.buttons.forEach(btn => {\n let isEnabled = btn.getIsEnabled ? btn.getIsEnabled() : true;\n\n if (isEnabled) {\n let $btn = _util_domUtils__WEBPACK_IMPORTED_MODULE_0__[\"default\"].createElementFromHTML(`\n <button class=\"corner-btn cap-btn-raised\">\n ${btn.label || \"\"}\n </button> `);\n\n if (btn.onClick) {\n $btn.addEventListener(\"click\", btn.onClick);\n }\n\n $btnContainer.appendChild($btn);\n }\n });\n }\n\n if (config.timeline.corner.right.inputs) {\n config.timeline.corner.right.inputs.forEach(input => {\n let $input = this.createCornerRightInput({\n inputConfig: input\n });\n $btnContainer.appendChild($btn);\n });\n }\n\n return $el;\n },\n\n createCornerRightInput({\n inputConfig,\n dataDay = null,\n daySelected = null\n }) {\n let r = null;\n\n switch (inputConfig.type) {\n case \"autocomplete-crud\":\n r = this.createCornerRightInputAutocompleteCrud({\n inputConfig,\n dataDay,\n daySelected\n });\n break;\n }\n\n return r;\n },\n\n createCornerRightInputAutocompleteCrud({\n inputConfig,\n dataDay,\n daySelected\n }) {\n let elem = \"test\";\n return elem;\n },\n\n /**\n * Crea Header Top\n * Se usa para :\n * - Manejo de tabs\n * - Botones de navegación y selección de fecha\n * - Boton toggle Dark mode\n * - Boton toggle Header extended\n *\n * @param {Object} config - Configuracion capibara\n * @return {Object} Elemento Dom\n */\n createHeaderTop(config, tabSelected = null) {\n return this.redrawHeaderTop(config, tabSelected, _util_domUtils__WEBPACK_IMPORTED_MODULE_0__[\"default\"].createElement(\"div\"));\n },\n\n redrawHeaderTop(config, tabSelected = null, $elem) {\n let str = `\n <div class=\"header-top\">`;\n\n if (config.timeline.tabs) {\n let showTabs = true;\n\n if (config.timeline.tabs.filter(t => !t.isHidden).length == 0) {\n showTabs = false;\n }\n\n if (showTabs) {\n str += ` <div class=\"tab-select-container c-d-desktop-none c-d-mobile-flex\">\n <select class=\"tabs-select\" >`;\n config.timeline.tabs.forEach(tab => {\n if (!tab.isHidden) {\n str += ` <option ${tab == tabSelected ? 'selected=\"selected\"' : \"\"} value=\"${tab.id}\"> ${tab.label} </option>`;\n }\n });\n str += `</select> </div>`;\n str += ` <div class=\"tabs-container c-d-desktop-flex c-d-mobile-none\">`;\n config.timeline.tabs.forEach(tab => {\n if (!tab.isHidden) {\n str += ` <button\n class=\"tab ${tab.disabled ? \"disabled\" : \"\"} ${tab == tabSelected ? \"active\" : \"\"} ${tab.color}\"\n color=\"${tab.color}\"\n input-key=\"${tab.id}\"\n ${tab.tooltip ? 'cap-tooltip=\"' + tab.tooltip + '\"' : \"\"} >\n <span>${tab.label}</span>\n ${tab.icon || \"\"}\n </button>\n `;\n }\n });\n str += `</div>`;\n }\n }\n\n if (tabSelected) {\n if (tabSelected.legends) {\n str += ` \n <button toggle-legends class=\"cap-btn-icon cap-btn-icon-raised \">\n ${_util_icons__WEBPACK_IMPORTED_MODULE_3__[\"default\"].toggleLegends}\n </button> \n\n <div class=\"legends-container force-mobile-style hide\"> `;\n tabSelected.legends.forEach(legend => {\n let colorClass = \"\";\n let colorBg = \"\";\n\n if (_util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].isHexColor(legend.color)) {\n colorBg = \"background:\" + legend.color;\n } else {\n colorClass = legend.color ? legend.color + \"--background\" : \"\";\n }\n\n str += ` <div\n class=\"legend ${legend.active ? \"active\" : \"\"}\"\n input-key=\"${legend.key}\"\n ${legend.tooltip ? `cap-tooltip=\"${legend.tooltip}\"` : \"\"} >\n <div class=\"icon-legend ${colorClass} ${legend.shape}\" style=\"${colorBg}\"></div>\n <span>${legend.label}</span>\n </div>`;\n });\n str += `</div>`;\n }\n }\n\n str += `\n\n <div class=\"spacer\"></div>\n\n\n\n <button cap-btn-prev class=\"cap-btn-icon cap-btn-icon-raised\">\n ${_util_icons__WEBPACK_IMPORTED_MODULE_3__[\"default\"].arrowLeft}\n ${_util_icons__WEBPACK_IMPORTED_MODULE_3__[\"default\"].loadingIcon} \n </button>\n\n\n <button cap-btn-calendar class=\"cap-btn-icon cap-btn-icon-raised\">\n ${_util_icons__WEBPACK_IMPORTED_MODULE_3__[\"default\"].calendar}\n ${_util_icons__WEBPACK_IMPORTED_MODULE_3__[\"default\"].loadingIcon}\n </button>\n\n <button cap-btn-next class=\"cap-btn-icon cap-btn-icon-raised\">\n ${_util_icons__WEBPACK_IMPORTED_MODULE_3__[\"default\"].arrowRight}\n ${_util_icons__WEBPACK_IMPORTED_MODULE_3__[\"default\"].loadingIcon}\n </button>\n\n <div class=\"spacer\"></div>\n\n <button toggle-dark class=\"cap-btn-icon cap-btn-header c-d-mobile-none ${config.timeline.withDarkToggle == false ? \"hide\" : \"\"}\">\n ${_util_icons__WEBPACK_IMPORTED_MODULE_3__[\"default\"].dark}\n ${_util_icons__WEBPACK_IMPORTED_MODULE_3__[\"default\"].light}\n </button>`;\n\n if (config.timeline.header.extend.enabled !== false) {\n str += `<button toggle-header class=\"cap-btn-icon cap-btn-icon-raised\">\n ${_util_icons__WEBPACK_IMPORTED_MODULE_3__[\"default\"].chevronDown}\n </button>`;\n }\n\n str += ` <div class=\"button-right-container\"></div>\n </div>`;\n /*\n `\n <button toggle-sidebar-right class=\"cap-btn-icon cap-btn-icon-raised\">\n <span>\n <svg style=\"width:24px;height:24px\" viewBox=\"0 0 24 24\">\n <path fill=\"currentColor\" d=\"M15.41,16.58L10.83,12L15.41,7.41L14,6L8,12L14,18L15.41,16.58Z\" />\n </svg>\n </span>\n </button>\n </div>\n `;\n */\n\n let $r = _util_domUtils__WEBPACK_IMPORTED_MODULE_0__[\"default\"].createElementFromHTML(str);\n $elem.replaceWith($r);\n\n if (config.timeline.header.rightButtons) {\n let $buttonContainer = $r.querySelector(\".button-right-container\");\n config.timeline.header.rightButtons.forEach(button => {\n let hasBadge = false;\n\n if (button.hasBadge) {\n hasBadge = button.hasBadge();\n }\n\n let str = `<button class=\"cap-btn-icon cap-btn-icon-raised ${hasBadge ? \"cap-btn-has-badge\" : \"\"}\">\n <span>\n <svg style=\"width:24px;height:24px\" viewBox=\"0 0 24 24\">\n <path fill=\"currentColor\" d=\"${button.icon}\" />\n </svg>\n </span>\n </button>`;\n let $button = _util_domUtils__WEBPACK_IMPORTED_MODULE_0__[\"default\"].createElementFromHTML(str);\n $button.addEventListener(\"click\", evt => button.onClick({\n evt\n }));\n $buttonContainer.append($button);\n });\n }\n\n let $toggleDark = $r.querySelector(\"[toggle-dark]\");\n\n if ($toggleDark) {\n $toggleDark.addEventListener(\"click\", e => {\n $r.dispatchEvent(new CustomEvent(\"toggleDark\", {\n bubbles: true,\n cancelable: false\n }));\n });\n }\n\n let $btnCalendar = $r.querySelector(\"[cap-btn-calendar]\");\n\n if ($btnCalendar) {\n $btnCalendar.addEventListener(\"click\", e => {\n let x = e.x;\n let y = e.y;\n $r.dispatchEvent(new CustomEvent(\"clickCalendarIcon\", {\n bubbles: true,\n cancelable: false,\n detail: {\n x,\n y\n }\n }));\n });\n }\n\n let $btnToggleHeader = $r.querySelector(\"[toggle-header]\");\n\n if ($btnToggleHeader) {\n $btnToggleHeader.addEventListener(\"click\", e => {\n $r.dispatchEvent(new CustomEvent(\"toggleHeader\", {\n bubbles: true,\n cancelable: false\n }));\n });\n }\n /*\n $r.querySelector(\"[toggle-sidebar-right]\").addEventListener(\"click\", e => {\n $r.dispatchEvent(new CustomEvent(\"toggleSidebarRight\", {\n bubbles: true,\n cancelable: false,\n }));\n });\n */\n\n\n $r.querySelector(\"[cap-btn-prev]\").addEventListener(\"click\", e => {\n $r.dispatchEvent(new CustomEvent(\"headerPrev\", {\n bubbles: true,\n cancelable: false,\n detail: {\n originalEvt: e\n }\n }));\n });\n $r.querySelector(\"[cap-btn-calendar]\").addEventListener(\"click\", e => {\n $r.dispatchEvent(new CustomEvent(\"headerCalendar\", {\n bubbles: true,\n cancelable: false,\n detail: {\n originalEvt: e\n }\n }));\n });\n $r.querySelector(\"[cap-btn-next]\").addEventListener(\"click\", e => {\n $r.dispatchEvent(new CustomEvent(\"headerNext\", {\n bubbles: true,\n cancelable: false,\n detail: {\n originalEvt: e\n }\n }));\n });\n let $toggleLegendsBtn = $r.querySelector(\"[toggle-legends]\");\n\n if ($toggleLegendsBtn) {\n $toggleLegendsBtn.addEventListener(\"click\", e => {\n let $legendContainer = $r.querySelector(\".legends-container\");\n\n if ($legendContainer) {\n $legendContainer.classList.toggle(\"hide\");\n }\n });\n }\n\n $r.querySelectorAll(\".legend\").forEach($legend => {\n $legend.addEventListener(\"click\", e => {\n let key = e.currentTarget.getAttribute(\"input-key\");\n\n if (key) {\n let legendSelected = tabSelected.legends.find(tab => tab.key === key);\n\n if (legendSelected) {\n $r.dispatchEvent(new CustomEvent(\"selectLegendHeader\", {\n bubbles: true,\n cancelable: false,\n detail: {\n legend: legendSelected,\n $legend\n }\n }));\n }\n }\n });\n });\n $r.querySelectorAll(\".tab:not(.disabled)\").forEach($tab => {\n $tab.addEventListener(\"click\", e => {\n let key = e.currentTarget.getAttribute(\"input-key\");\n\n if (key) {\n let tabSelected = config.timeline.tabs.find(tab => tab.id == key);\n\n if (tabSelected) {\n $r.dispatchEvent(new CustomEvent(\"selectTabHeader\", {\n bubbles: true,\n cancelable: false,\n detail: {\n tab: tabSelected\n }\n }));\n }\n }\n });\n });\n $r.querySelectorAll(\".tabs-select:not(.disabled)\").forEach($tab => {\n $tab.addEventListener(\"change\", e => {\n let key = parseFloat(e.currentTarget.value);\n\n if (key) {\n let tabSelected = config.timeline.tabs.find(tab => tab.id == key);\n\n if (tabSelected) {\n $r.dispatchEvent(new CustomEvent(\"selectTabHeader\", {\n bubbles: true,\n cancelable: false,\n detail: {\n tab: tabSelected\n }\n }));\n }\n }\n });\n });\n return $r;\n },\n\n /**\n * Crea Header\n * Se usa para :\n * - Mostrar fechas en header\n *\n * @param {Object} config - Configuracion capibara\n * @return {Object} Elemento Dom\n */\n createHeader(config) {\n let $elem = _util_domUtils__WEBPACK_IMPORTED_MODULE_0__[\"default\"].createElement(\"header\");\n return this.redrawHeader(config, $elem);\n },\n\n /**\n * Recrea Header, usado para redibujar\n * utiliza $elem como elemento dom donde recrearlo\n *\n * @param {Object} config - Configuracion capibara\n * @param {Object} $elem - Elemento Dom donde crea Header\n * @return {Object} Elemento Dom\n */\n redrawHeader(config, $elem) {\n let datesTree = _util_dateUtils__WEBPACK_IMPORTED_MODULE_2__[\"default\"].getDateTreeRange(new Date(config.timeline.start), new Date(config.timeline.end));\n let str = `<div class=\"header-container\"> `;\n Object.keys(datesTree).forEach(keyY => {\n let year = datesTree[keyY];\n str += `<div class=\"agno-calendario\">\n <span class=\"agno hide\">${keyY}</span>\n <div class=\"meses\">`;\n Object.keys(year).forEach(keyM => {\n let month = datesTree[keyY][keyM];\n str += ` <div class=\"mes-calendario\">\n <div class=\"mes ${Object.keys(month).length < 4 ? \"mes-reduced mes-reduced-\" + Object.keys(month).length : \"\"}\">\n <div class=\"mes-label\">\n ${_util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getMonthByPosition(keyM)} ${keyY}\n </div>\n </div>\n <div class=\"dias\">`;\n Object.keys(month).forEach(keyD => {\n let day = datesTree[keyY][keyM][keyD];\n let isWeekend = day.isWeekend;\n let isToday = day.isToday;\n let date = _util_dateUtils__WEBPACK_IMPORTED_MODULE_2__[\"default\"].formatDate(day.Date);\n str += `<div class=\"dia-calendario ${isToday ? \"today\" : \"\"} ${isWeekend ? \"weekend\" : \"\"} ${config.timeline.dateSelectable ? \"is-clickeable\" : \"\"}\" date=\"${date}\">${keyD}</div>`;\n });\n str += `</div></div>`;\n });\n str += `</div> </div>`;\n });\n str += `</div>`;\n $elem.innerHTML = \"\";\n $elem.append(_util_domUtils__WEBPACK_IMPORTED_MODULE_0__[\"default\"].createElementFromHTML(str));\n\n if (config.timeline.dateSelectable) {\n $elem.querySelectorAll(\".dia-calendario[date]\").forEach($dia => {\n $dia.addEventListener(\"contextmenu\", evt => {\n $elem.dispatchEvent(new CustomEvent(\"contextMenuDate\", {\n bubbles: true,\n cancelable: false,\n detail: {\n $elem: $dia,\n date: $dia.getAttribute(\"date\"),\n clientX: evt.clientX,\n clientY: evt.clientY\n }\n }));\n });\n $dia.addEventListener(\"click\", evt => {\n $elem.dispatchEvent(new CustomEvent(\"clickDate\", {\n bubbles: true,\n cancelable: false,\n detail: {\n $elem: $dia,\n date: $dia.getAttribute(\"date\")\n }\n }));\n });\n });\n }\n\n return $elem;\n },\n\n /**\n * Crea Header extended\n * Se usa para :\n * -Mostrar inputs y datos para fechas en header\n *\n * @param {Object} config - Configuracion capibara\n * @return {Object} Elemento Dom headerExtended\n */\n createHeaderExtended(config) {\n if (config.timeline.header.extend.enabled == false) return null;\n let dates = _util_dateUtils__WEBPACK_IMPORTED_MODULE_2__[\"default\"].getDateRange(new Date(config.timeline.start), new Date(config.timeline.end));\n let str = `<div class=\"header-container-extended\">`;\n config.timeline.header.extend.data.forEach((d, d_index) => {\n if (d.isHidden) return \"\";\n let isPersistent = d.isPersistent;\n str += `<div class=\"input-list ${isPersistent ? \"persistent\" : \"\"}\">`;\n str += dates.map(date => {\n let value = \"\";\n let isFuture = _util_dateUtils__WEBPACK_IMPORTED_MODULE_2__[\"default\"].isFuture(date);\n let isToday = _util_dateUtils__WEBPACK_IMPORTED_MODULE_2__[\"default\"].isToday(date);\n\n if (d.data) {\n let dataFounded = d.data.find(dataInput => {\n return _util_dateUtils__WEBPACK_IMPORTED_MODULE_2__[\"default\"].isSameDate(new Date(dataInput.date), date);\n });\n\n if (dataFounded) {\n value = dataFounded.value || \"\";\n }\n }\n\n if (d.editable === false || isFuture && d.editableFuture == false || isToday && d.editableToday == false) {\n return `<div>\n <span date=\"${date}\" \n index=\"${d_index}\" \n class=\"${date.varName} ${d.color ? \"c-\" + d.color + \"--text\" : \"\"}\" > \n ${value} \n </span>\n </div>`;\n }\n\n let isDisabled = false;\n\n if (config.timeline.editable === false) {\n isDisabled = true;\n }\n\n return `<div class=\"dia-input\">\n <input \n date=\"${date}\" \n index=\"${d_index}\" \n class=\"header-input \n ${date.varName} ${d.color ? \"c-\" + d.color + \"--text\" : \"\"}\" \n type=\"number\"\n ${isDisabled ? \"disabled\" : \"\"} \n value=\"${value}\">\n </div>`;\n }).join(\"\");\n str += `</div>`;\n });\n str += `</div>`;\n let r = _util_domUtils__WEBPACK_IMPORTED_MODULE_0__[\"default\"].createElementFromHTML(str);\n r.querySelectorAll(\"input.header-input\").forEach(input => {\n input.addEventListener(\"input\", e => {\n let date = e.currentTarget.getAttribute(\"date\");\n let index = e.currentTarget.getAttribute(\"index\");\n let value = e.currentTarget.value;\n let typeData = config.timeline.header.extend.data[index]; //refresh config value\n\n let data = typeData.data.find(d => _util_dateUtils__WEBPACK_IMPORTED_MODULE_2__[\"default\"].isSameDate(new Date(d.date), new Date(date)));\n data.value = value;\n r.dispatchEvent(new CustomEvent(\"changeInputHeader\", {\n bubbles: true,\n cancelable: false,\n detail: {\n date: date,\n typeData: typeData,\n value: value\n }\n }));\n });\n });\n return r;\n },\n\n /**\n * Crear Sidebar Izquierdo\n * - Maneja items como arbol de 2 niveles (parent, children)\n * - El sidebar se divide en navList - InitialNav - extendedNav - BtnNav\n * - Se agrega itemDetail, para detalles de items\n *\n *\n * TODO: para evitar incrustar las ids en los inputs, se deben crear\n * los nodos uno por uno como elemento DOM, y agregarles los eventos directamente\n * ahora se hace seleccionando todos los inputs con querySelectorAll\n *\n * @param {Object} config - Configuracion capibara\n * @return {Object} Elemento Dom Sidebar Izquierdo\n */\n createNavLeft(config, tab = null) {\n let $elem = _util_domUtils__WEBPACK_IMPORTED_MODULE_0__[\"default\"].createElement(\"nav\", {\n className: \"left\"\n });\n return this.redrawNavLeft($elem, config, tab);\n },\n\n /**\n * Recrea Sidebar izquierdo, usado para redibujar\n * Utiliza $elem como elemento dom donde recrearlo\n *\n *\n * @param {Object} $elem - Elemento Dom donde crea el sidebar izquierdo\n * @param {Object} config - Configuracion capibara\n * @return {Object} Elemento Dom navLeft\n */\n redrawNavLeft($elem, config, tab = null) {\n let navList = \"\";\n let initialNavList = \"\";\n let exNavList = \"\";\n let btnNavList = \"\";\n let isDisabled = false;\n\n if (config.timeline.editable === false) {\n isDisabled = true;\n }\n\n config.data.forEach(d => {\n if (d.isHidden) return;\n navList += `\n <div class=\"nav-item\">\n\n\n <div class=\"nav-item-container parent\">`;\n\n if (d.children) {\n navList += `<button class=\"tree-icon ${d.isClosed ? \"\" : \"cap-rotate\"}\" item-id=\"${d.id || -1}\" type-node=\"${d.type || \"\"}\" >\n ${_util_icons__WEBPACK_IMPORTED_MODULE_3__[\"default\"].chevronDown}\n </button>`;\n }\n\n navList += `\n <div class=\"item-title truncate full-width ${d.clickeable ? \"clickeable\" : \"\"}\n ${d.navOver ? \"hoverable\" : \"\"} \" item-id=\"${d.id || -1}\" type-node=\"${d.type || \"\"}\" >\n ${d.label}\n </div>\n </div>`;\n\n if (d.children) {\n navList += `\n <div class=\"children-items ${d.isClosed ? \"hide\" : \"\"} \" child-list=\"${d.id || -1}\">`;\n d.children.forEach(c => {\n if (c.isHidden) return;\n navList += `\n <div class=\"child-nav-item\">\n <div class=\"nav-item-container\">\n `;\n /*\n <span class=\"nav-item-icon\">\n <svg style=\"width:24px;height:24px\" viewBox=\"0 0 24 24\">\n <path fill=\"currentColor\" d=\"M19,15L13,21L11.58,19.58L15.17,16H4V4H6V14H15.17L11.58,10.42L13,9L19,15Z\" />\n </svg>\n </span>\n */\n\n navList += `\n ${c.light ? '<span class=\"light ' + (c.light ? c.light + \"-light\" : \"\") + '\"></span>' : \"\"}\n\n <div class=\"item-title ${c.clickeable ? \"clickeable\" : \"\"}\n ${c.navOver ? \"hoverable\" : \"\"}\" item-id=\"${c.id || -1}\" type-node=\"${c.type || \"\"}\">\n <div class=\"truncate\">\n ${c.label}\n </div>\n </div>\n </div>\n </div>`;\n });\n navList += `\n </div>`;\n }\n\n navList += `</div>`; //initial\n\n initialNavList += `<div class=\"initial-nav-item parent\">`;\n\n if (d.withNav) {\n config.timeline.nav.left.initial.vars.forEach(v => {\n let value = _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getVarByPath(d.values, v.varName);\n\n if (v.round && !isNaN(value)) {\n value = _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].round(value, v.round);\n }\n\n if (v.input) {\n switch (v.input) {\n case \"hour\":\n value = value.split(\":\");\n let hhValue = value[0];\n let mmValue = value[1];\n initialNavList += `\n <div class=\"item-col has-input\">\n <div class=\"hour-input\">\n <input type=\"number\"\n input-type=\"time\"\n max=\"23\"\n min=\"00\"\n input-key=\"${v.key || \"\"}\"\n item-id=\"${d.id || -1}\"\n type-node=\"${d.type || \"\"}\"\n value=\"${hhValue}\"\n ${isDisabled ? \"disabled\" : \"\"}\n class=\"hh\">\n <span>:</span>\n <input type=\"number\"\n input-type=\"time\"\n max=\"59\"\n min=\"00\"\n input-key=\"${v.key || \"\"}\"\n item-id=\"${d.id || -1}\"\n type-node=\"${d.type || \"\"}\"\n value=\"${mmValue}\"\n ${isDisabled ? \"disabled\" : \"\"}\n class=\"mm\">\n </div>\n </div>`;\n break;\n\n case \"text\":\n case \"number\":\n default:\n initialNavList += `\n <div class=\"item-col has-input\">\n <input \n type=\"${v.input || \"text\"}\"\n input-type=\"${v.input || \"text\"}\"\n input-key=\"${v.key || \"\"}\"\n item-id=\"${d.id || -1}\"\n type-node=\"${d.type || \"\"}\"\n ${isDisabled ? \"disabled\" : \"\"}\n value=\"${value}\"/>\n </div>`;\n }\n } else {\n initialNavList += `\n <div class=\"item-col\">\n ${value}\n </div>`;\n }\n });\n }\n\n initialNavList += `\n </div>`;\n\n if (d.children) {\n d.children.forEach(c => {\n if (c.isHidden) return;\n initialNavList += `<div class=\"child-initial-nav-item ${d.isClosed ? \"hide\" : \"\"}\" child=\"${d.id || -1}\">`;\n\n if (c.withNav !== false) {\n config.timeline.nav.left.initial.vars.forEach(v => {\n if (v.onlyTab && tab && v.onlyTab !== tab.key) return;\n let value = _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getVarByPath(c.values, v.varName);\n\n if (v.round && !isNaN(value)) {\n value = _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].round(value, v.round);\n }\n\n if (v.input) {\n switch (v.input) {\n case \"hour\":\n value = value.split(\":\");\n let hhValue = value[0];\n let mmValue = value[1];\n initialNavList += `\n <div class=\"item-col has-input\">\n <div class=\"hour-input\">\n <input type=\"number\"\n input-type=\"time\"\n max=\"23\"\n min=\"00\"\n input-key=\"${v.key || \"\"}\"\n item-id=\"${c.id || -1}\"\n type-node=\"${c.type || \"\"}\"\n value=\"${hhValue}\"\n ${isDisabled ? \"disabled\" : \"\"}\n class=\"hh\">\n <span>:</span>\n <input type=\"number\"\n input-type=\"time\"\n max=\"59\"\n min=\"00\"\n input-key=\"${v.key || \"\"}\"\n item-id=\"${c.id || -1}\"\n type-node=\"${c.type || \"\"}\"\n value=\"${mmValue}\"\n ${isDisabled ? \"disabled\" : \"\"}\n class=\"mm\">\n </div>\n </div>`;\n break;\n\n case \"text\":\n case \"number\":\n default:\n initialNavList += `\n <div class=\"item-col has-input\">\n <input\n type=\"${v.input || \"text\"}\"\n input-type=\"${v.input || \"text\"}\"\n input-key=\"${v.key || \"\"}\"\n item-id=\"${c.id || -1}\"\n type-node=\"${c.type || \"\"}\"\n ${isDisabled ? \"disabled\" : \"\"}\n value=\"${value}\"/>\n </div>`;\n }\n } else {\n initialNavList += `\n <div class=\"item-col\">\n ${value}\n </div>`;\n }\n });\n }\n\n initialNavList += `\n </div>`;\n });\n } //Ext\n\n\n exNavList += `<div class=\"ex-nav-item parent\">`;\n\n if (d.withExNav) {\n config.timeline.nav.left.extend.vars.forEach(v => {\n let value = _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getVarByPath(d.values, v.varName);\n\n if (v.round && !isNaN(value)) {\n value = _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].round(value, v.round);\n }\n\n if (v.input) {\n switch (v.input) {\n case \"hour\":\n value = value.split(\":\");\n let hhValue = value[0];\n let mmValue = value[1];\n exNavList += `\n <div class=\"item-col has-input\">\n <div class=\"hour-input\">\n <input type=\"number\"\n input-type=\"time\"\n max=\"23\"\n min=\"0\"\n input-key=\"${v.key || \"\"}\"\n item-id=\"${d.id || -1}\"\n type-node=\"${d.type || \"\"}\"\n value=\"${hhValue}\"\n ${isDisabled ? \"disabled\" : \"\"}\n class=\"hh\">\n <span>:</span>\n <input type=\"number\"\n input-type=\"time\"\n max=\"59\"\n min=\"0\"\n input-key=\"${v.key || \"\"}\"\n item-id=\"${d.id || -1}\"\n type-node=\"${d.type || \"\"}\"\n value=\"${mmValue}\"\n ${isDisabled ? \"disabled\" : \"\"}\n class=\"mm\">\n </div>\n </div>`;\n break;\n\n case \"text\":\n case \"number\":\n default:\n exNavList += `\n <div class=\"item-col has-input\">\n <input\n type=\"${v.input || \"text\"}\"\n input-type=\"${v.input || \"text\"}\"\n input-key=\"${v.key || \"\"}\"\n item-id=\"${d.id || -1}\"\n type-node=\"${d.type || \"\"}\"\n ${isDisabled ? \"disabled\" : \"\"}\n value=\"${value}\"/>\n </div>`;\n }\n } else {\n exNavList += `\n <div class=\"item-col\">\n ${value}\n </div>`;\n }\n });\n }\n\n exNavList += `\n </div>`;\n\n if (d.children) {\n d.children.forEach(c => {\n if (c.isHidden) return;\n exNavList += `<div class=\"child-ex-nav-item ${d.isClosed ? \"hide\" : \"\"}\" child=\"${d.id || -1}\">`;\n\n if (c.withNav !== false) {\n config.timeline.nav.left.extend.vars.forEach(v => {\n if (v.onlyTab && tab && v.onlyTab !== tab.key) return;\n let value = _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getVarByPath(c.values, v.varName);\n\n if (v.round && !isNaN(value)) {\n value = _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].round(value, v.round);\n }\n\n if (v.input) {\n switch (v.input) {\n case \"hour\":\n value = value ? value.split(\":\") : [0, 0];\n let hhValue = value[0];\n let mmValue = value[1];\n exNavList += `\n <div class=\"item-col has-input\">\n <div class=\"hour-input\">\n <input type=\"number\"\n input-type=\"time\"\n max=\"23\"\n min=\"0\"\n input-key=\"${v.key || \"\"}\"\n item-id=\"${c.id || -1}\"\n type-node=\"${c.type || \"\"}\"\n value=\"${hhValue}\"\n ${isDisabled ? \"disabled\" : \"\"}\n class=\"hh\">\n <span>:</span>\n <input type=\"number\"\n input-type=\"time\"\n max=\"59\"\n min=\"0\"\n input-key=\"${v.key || \"\"}\"\n item-id=\"${c.id || -1}\"\n type-node=\"${c.type || \"\"}\"\n value=\"${mmValue}\"\n ${isDisabled ? \"disabled\" : \"\"}\n class=\"mm\">\n </div>\n </div>`;\n break;\n\n case \"text\":\n case \"number\":\n default:\n exNavList += `\n <div class=\"item-col has-input\">\n <input \n type=\"${v.input || \"text\"}\"\n input-type=\"${v.input || \"text\"}\"\n input-key=\"${v.key || \"\"}\"\n item-id=\"${c.id || -1}\"\n type-node=\"${c.type || \"\"}\"\n ${isDisabled ? \"disabled\" : \"\"}\n value=\"${value}\"/>\n </div>`;\n }\n } else {\n exNavList += `\n <div class=\"item-col\">\n ${value}\n </div>`;\n }\n });\n }\n\n exNavList += `\n </div>`;\n });\n } //buttons\n\n\n btnNavList += `<div class=\"cap-btn-nav-item parent\">\n <div class=\"cap-btn-nav-item-content\">`;\n\n if (config.timeline.nav.left.buttons && config.timeline.nav.left.buttons.vars) {\n config.timeline.nav.left.buttons.vars.forEach(btn => {\n if (d.withBtnNav) {\n let btnContent = \"\";\n let className = btn.className || \"\";\n\n if (btn.icon) {\n btnContent = btn.icon ? btn.icon : \"\";\n }\n\n if (btn.iconFormatter) {\n btnContent = btn.iconFormatter ? btn.iconFormatter(d, btn) : \"\";\n }\n\n if (btn.shape) {\n className += \" cap-btn-\" + btn.shape;\n btnContent += `<span> ${btn.formatter ? btn.formatter(d, btn) : \"\"} </span> `;\n }\n\n if (btn.btnClassNameFormatter) {\n let newClassName = btn.btnClassNameFormatter(d, btn);\n\n if (newClassName) {\n className += \" \" + newClassName;\n }\n }\n\n btnNavList += `\n <button class=\"cap-btn-shape ${className}\"\n input-key=\"${btn.key || \"\"}\"\n item-id=\"${d.id || -1}\"\n ${isDisabled ? \"disabled\" : \"\"}\n type-node=\"${d.type || \"\"}\">\n ${btnContent}\n </button>`;\n }\n });\n }\n\n btnNavList += `\n </div>\n </div>`;\n\n if (d.children) {\n d.children.forEach(c => {\n if (c.isHidden) return; //buttons\n\n btnNavList += `<div class=\"cap-btn-child-nav-item parent ${d.isClosed ? \"hide\" : \"\"}\" child=\"${d.id || -1}\">\n <div class=\"cap-btn-nav-item-content\">`;\n\n if (config.timeline.nav.left.buttons && config.timeline.nav.left.buttons.vars) {\n config.timeline.nav.left.buttons.vars.forEach(btn => {\n if (c.withNav !== false) {\n let btnContent = \"\";\n let className = btn.className || \"\";\n\n if (btn.icon) {\n btnContent = btn.icon ? btn.icon : \"\";\n }\n\n if (btn.iconFormatter) {\n btnContent = btn.iconFormatter ? btn.iconFormatter(c, btn) : \"\";\n }\n\n if (btn.shape) {\n className += \" cap-btn-\" + btn.shape;\n btnContent += `<span> ${btn.formatter ? btn.formatter(c, btn) : \"\"} </span> `;\n }\n\n if (btn.btnClassNameFormatter) {\n let newClassName = btn.btnClassNameFormatter(c, btn);\n\n if (newClassName) {\n className += \" \" + newClassName;\n }\n }\n\n btnNavList += `\n <button class=\"cap-btn-shape ${className}\"\n input-key=\"${btn.key || \"\"}\"\n item-id=\"${c.id || -1}\"\n ${isDisabled ? \"disabled\" : \"\"}\n type-node=\"${c.type || \"\"}\">\n ${btnContent}\n </button>`;\n }\n });\n }\n\n btnNavList += `\n </div>\n </div>`;\n });\n }\n });\n let itemDetail = ` <div class=\"detail-nav-item hide\">\n ${this.getDetailNavItemContent()}\n </div>`;\n let str = `<div class=\"nav-container\">\n ${itemDetail}\n <div class=\"nav-item-list\">\n ${navList}\n </div>\n <div class=\"initial-nav-list\">\n ${initialNavList}\n </div>\n <div class=\"extend-nav-list\">\n ${exNavList}\n </div>\n <div class=\"cap-btn-nav-list\">\n ${btnNavList}\n </div>\n </div>`;\n let navContainer = _util_domUtils__WEBPACK_IMPORTED_MODULE_0__[\"default\"].createElementFromHTML(str);\n $elem.innerHTML = \"\";\n $elem.append(navContainer); //detalle de nav-item\n\n $elem.querySelectorAll(\".item-title.hoverable\").forEach(i => {\n i.addEventListener(\"mouseover\", e => {\n let pos = _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].eventToPositionNavLeft(config, e, $elem);\n let itemId = i.getAttribute(\"item-id\");\n let item = _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getItemById(config, itemId);\n let typeNode = i.getAttribute(\"type-node\");\n i.dispatchEvent(new CustomEvent(\"overNavItem\", {\n bubbles: true,\n cancelable: false,\n detail: {\n originalEvt: e,\n item: item,\n type: typeNode,\n pos: pos\n }\n }));\n });\n }); //oculta detalle de nav-item, al salir del nav-item-list\n\n $elem.querySelectorAll(\".nav-item-list\").forEach(i => {\n i.addEventListener(\"mouseleave\", e => {\n i.dispatchEvent(new CustomEvent(\"leaveNavItem\", {\n bubbles: true,\n cancelable: false\n }));\n });\n }); //oculta detalle de nav-item-list, al salir de nav-item\n\n $elem.querySelectorAll(\".item-title:not(.hoverable)\").forEach(i => {\n i.addEventListener(\"mousemove\", e => {\n i.dispatchEvent(new CustomEvent(\"leaveNavItem\", {\n bubbles: true,\n cancelable: false\n }));\n });\n });\n $elem.querySelectorAll(\".item-title.clickeable\").forEach(i => {\n i.addEventListener(\"click\", e => {\n let itemId = i.getAttribute(\"item-id\");\n let typeNode = i.getAttribute(\"type-node\");\n let value = i.value;\n i.dispatchEvent(new CustomEvent(\"clickNavLeftItem\", {\n bubbles: true,\n cancelable: false,\n detail: {\n itemId: itemId,\n type: typeNode,\n value: value\n }\n }));\n });\n });\n $elem.querySelectorAll(\"input\").forEach(i => {\n i.addEventListener(\"change\", e => {\n let inputType = i.getAttribute(\"input-type\");\n let key = i.getAttribute(\"input-key\");\n let itemId = i.getAttribute(\"item-id\");\n let typeNode = i.getAttribute(\"type-node\");\n let item = _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getItemById(config, itemId);\n let value = i.value;\n\n if (inputType == \"time\") {\n let hh_input = i.parentElement.querySelector(\"input.hh\").value;\n let mm_input = i.parentElement.querySelector(\"input.mm\").value;\n mm_input = mm_input < 10 ? \"0\" + parseFloat(mm_input) : mm_input;\n i.parentElement.querySelector(\"input.mm\").value = mm_input;\n value = hh_input + \":\" + mm_input;\n }\n\n i.dispatchEvent(new CustomEvent(\"saveNavLeftInput\", {\n bubbles: true,\n cancelable: false,\n detail: {\n key: key,\n itemId: itemId,\n item: item,\n type: typeNode,\n value: value,\n tabSelected: tab\n }\n }));\n });\n });\n $elem.querySelectorAll(\"button.cap-btn-shape\").forEach(i => {\n i.addEventListener(\"click\", e => {\n let key = i.getAttribute(\"input-key\");\n let itemId = i.getAttribute(\"item-id\");\n let typeNode = i.getAttribute(\"type-node\");\n i.dispatchEvent(new CustomEvent(\"clickNavLeftButton\", {\n bubbles: true,\n cancelable: false,\n detail: {\n key: key,\n itemId: itemId,\n type: typeNode\n }\n }));\n });\n });\n $elem.querySelectorAll(\"button.tree-icon\").forEach(i => {\n i.addEventListener(\"click\", e => {\n let itemId = i.getAttribute(\"item-id\");\n let typeNode = i.getAttribute(\"type-node\");\n let dataConfig = config.data.find(d => d.id == itemId);\n let $navItem = e.currentTarget.closest(\".nav-item\");\n let $children = $navItem.querySelector(\".children-items\");\n let itemsToHide = e.currentTarget.closest(\"nav.left\").querySelectorAll(\"[child='\" + itemId + \"'], [child-list='\" + itemId + \"']\");\n\n if ($children) {\n if ($children.classList.contains(\"hide\")) {\n e.currentTarget.classList.add(\"cap-rotate\");\n itemsToHide.forEach(i => i.classList.remove(\"hide\"));\n dataConfig.isClosed = false;\n } else {\n e.currentTarget.classList.remove(\"cap-rotate\");\n itemsToHide.forEach(i => i.classList.add(\"hide\"));\n dataConfig.isClosed = true;\n }\n }\n\n i.dispatchEvent(new CustomEvent(\"clickNavLeftTreeIcon\", {\n bubbles: true,\n cancelable: false,\n detail: {\n itemId: itemId,\n type: typeNode\n }\n })); //e.currentTarget.parent\n });\n });\n return $elem;\n },\n\n /**\n * Crea Html como String, para el detalle de items en el Sidebar Izquierdo\n *\n * @param {Object} [item={}] - Configuracion de item\n * @return {String} Html de ventana de detalle\n */\n getDetailNavItemContent(item = {}) {\n if (item.navOver == undefined) item.navOver = {};\n return `\n <div class=\"header-detail\">\n <div class=\"detail-title truncate\">\n ${item.label || \"\"}\n </div>\n <div class=\"detail-subtitle\">\n ${item.navOver.subtitle || \"\"}\n </div>\n <div class=\"header-chip ${item.light ? item.light + \"-light\" : \"\"} ${item.navOver.chip ? \"\" : \"hide\"}\">\n ${item.navOver.chip || \"\"}\n </div>\n </div>\n\n <div class=\"detail-container\">\n ${item.navOver.content || \"\"}\n </div>`;\n },\n\n /**\n * Crea Sidebar Derecho\n * Usado principalmente para formulario de ingreso de datos para los dias\n * seleccionados\n *\n * @param {Object} config - Configuracion capibara\n * @param {Object} tab - Tab de referencia, para la creacion del formulario\n * @return {Object} {element, inputs}, element es el elemento Dom del sidebar,\n * inputs es un array de elementos Dom de cada input creado\n * (no son elementos html de tipo input)\n */\n createNavRight(config, tab = null) {\n var $elem = _util_domUtils__WEBPACK_IMPORTED_MODULE_0__[\"default\"].createElement(\"nav\", {\n className: \"right\"\n });\n return this.redrawNavRight(config, $elem, tab, []);\n },\n\n /**\n * Recrea Sidebar Derecho\n * Utiliza $elem como elemento dom donde recrearlo\n *\n * @param {Object} config - Configuracion capibara\n * @param {Object} $elem - Elemento Dom donde crea el sidebar derecho\n * @param {Object} tab - Tab de referencia, para la creacion del formulario\n * @param {Object} dataDay - datos del dia seleccionando, para autorrelleno de formulario\n * @param {Object} daySelected - datos del dia seleccionado\n * @param {String} daySelected.date - fecha del dia seleccionado\n * @param {Object} daySelected.item - Item de Sidebar relacionado al dia seleccionado\n * @param {Object} daySelected.pos - posicion de dia seleccionado\n * @return {Object} Elemento Dom Sidebar Derecho\n */\n redrawNavRight(config, $elem, selected = null, tab = null, dataDay = null, daySelected = null) {\n let $navRight = $elem; //dom.createElement(\"nav\",{className:\"right\"});\n\n let $divContainer = _util_domUtils__WEBPACK_IMPORTED_MODULE_0__[\"default\"].createElement(\"div\", {\n className: \"nav-input-container\"\n });\n let $inputs = [];\n let checkboxInputs = [];\n let inputsWithReload = [];\n let tabSelected = tab;\n selected = selected || [daySelected];\n\n if (tabSelected && tabSelected.inputs) {\n tabSelected.inputs.forEach(i => {\n if (i.disabled) return;\n let $input = this.createInput(i, dataDay, daySelected, selected);\n\n if ($input) {\n $divContainer.appendChild($input);\n $inputs.push($input);\n\n if (i.type == \"checkbox\") {\n checkboxInputs.push($input);\n }\n\n if (i.reloadOnSelect != null) {\n inputsWithReload.push({\n $input,\n config: i\n });\n }\n }\n });\n } //manejo de eventos para inputs con showIf\n\n\n if (checkboxInputs) {\n checkboxInputs.forEach($c => {\n //obtiene key de checkbox\n let key = $c.getAttribute(\"input-key\");\n let props = tabSelected.inputs.find(i => {\n return i.key == key;\n });\n let isChecked = false;\n\n if (dataDay) {\n isChecked = _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getVarByPath(dataDay, props.varName);\n } //obtiene inputs relacionados desde config para mostrar/ocultar\n\n\n let inputsToHide = tabSelected.inputs.filter(i => {\n return i.showIf && i.showIf == key;\n });\n let inputsToHideKeys = inputsToHide.map(i => i.key); //obtiene inputs del dom, filtrando con inputsToHide\n\n let $inputsHidden = $inputs.filter($i => {\n let inputKey = $i.getAttribute(\"input-key\");\n return inputsToHideKeys.indexOf(inputKey) > -1;\n }); //si hay inputs,\n\n if ($inputsHidden) {\n if (!isChecked) {\n $inputsHidden.forEach($i => {\n $i.classList.add(\"hide\");\n });\n }\n\n $c.addEventListener(\"input\", e => {\n $inputsHidden.forEach($i => {\n let fn = $c.querySelector(\"input[type='checkbox']\").checked ? \"remove\" : \"add\";\n $i.classList[fn](\"hide\");\n });\n });\n }\n });\n }\n\n let saveCancelBtns = this.createNavRightbuttons();\n $divContainer.appendChild(saveCancelBtns);\n $navRight.innerHTML = \"\";\n $navRight.appendChild($divContainer);\n return {\n element: $navRight,\n inputs: $inputs,\n inputsWithReload,\n saveCancelBtns\n };\n },\n\n /**\n * Crea Corner inferior izquierdo, como titulo para footer\n *\n * @param {Object} config - Configuracion capibara\n * @return {Object} Elemento Dom Corner Footer\n */\n createCornerFooter(config) {\n if (config.timeline.footer === undefined || config.timeline.footer.enabled == false) return null;\n let str = \"\";\n\n if (config.timeline.footer) {\n str += `<div class=\"corner-footer\">\n <div class=\"corner-title\">\n <span>\n ${config.timeline.footer.label}\n </span>\n </div>\n </div>`;\n }\n\n return _util_domUtils__WEBPACK_IMPORTED_MODULE_0__[\"default\"].createElementFromHTML(str);\n },\n\n /**\n * Crea Footer para planilla\n * Inicialmente creado para totales\n *\n * @param {Object} config - Configuracion capibara\n * @return {Object} Elemento Dom Corner Footer\n */\n createFooter(config) {\n if (config.timeline.footer === undefined || config.timeline.footer.enabled == false) return null;\n let str = `\n <footer>\n <div class=\"footer-container\">\n `;\n config.timeline.footer.data.forEach(d => {\n str += `\n <div class=\"footer-item\">${d.value}</div>\n `;\n });\n str += `\n </div>\n </footer>\n `;\n return _util_domUtils__WEBPACK_IMPORTED_MODULE_0__[\"default\"].createElementFromHTML(str);\n },\n\n /**\n * Crea Footer para planilla\n * Inicialmente creado para totales\n *\n * @param {Object} config - Configuracion capibara\n * @param {Object[]} selected - array de objetos, de dias seleccionados\n * @return {Object} Elemento Dom Corner Footer\n */\n createSelectBoard(config, selected) {\n let $elem = _util_domUtils__WEBPACK_IMPORTED_MODULE_0__[\"default\"].createElement(\"div\", {\n className: \"select-container\"\n });\n return this.redrawSelectBoard($elem, selected);\n },\n\n /**\n * Crea linea vertical para fecha Actual\n *\n * @param {Object} config - Configuracion capibara\n * @return {Object} Elemento Dom Corner Footer\n */\n createTodayLine(config) {\n return this.redrawTodayLine(config, _util_domUtils__WEBPACK_IMPORTED_MODULE_0__[\"default\"].createElement(\"div\", {\n className: \"today-line\"\n }));\n },\n\n /**\n * Recrea linea vertical para fecha Actual\n * si el elemento $elem no es enviado, se crea un nuevo elemento\n *\n * Si el dia actual no esta dentro del rango de fechas del config,\n * deshabilita la linea con la clase css .disable-line\n *\n * @param {Object} config - Configuracion capibara\n * @param {Object} [$elem=null] - Elemento Dom donde recrea la linea, si es null, la crea\n * @return {Object} Elemento Dom Corner Footer\n */\n redrawTodayLine(config, $elem = null) {\n let endTime = new Date(config.timeline.end).getTime();\n let todayTime = new Date().getTime();\n let {\n height,\n dayWidth\n } = _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getTableDimensions(config);\n if ($elem == null) $elem = _util_domUtils__WEBPACK_IMPORTED_MODULE_0__[\"default\"].createElement(\"div\", {\n className: \"today-line\"\n });\n\n if (endTime < todayTime) {\n $elem.classList.add(\"disable-line\");\n } else {\n $elem.classList.remove(\"disable-line\");\n }\n\n let diffDays = Math.floor(_util_dateUtils__WEBPACK_IMPORTED_MODULE_2__[\"default\"].diffDays(config.timeline.start, _util_dateUtils__WEBPACK_IMPORTED_MODULE_2__[\"default\"].formatDate(new Date())));\n let diff = diffDays * dayWidth;\n diff += dayWidth / 2 - 2; // para centrar linea\n\n Object.assign($elem.style, {\n \"margin-left\": diff + \"px\",\n height: height + \"px\"\n });\n return $elem;\n },\n\n /**\n * Crea elemento FloatBox, que contiene los datos que se muestra en la tabla\n *\n * @param {Object} config - Configuracion capibara\n * @param {Object} tab - Tab de referencia, para mostrar datos configurados por tab\n * @return {Object} Elemento Dom Corner Footer\n */\n createFloatBox(config, tab) {\n let $container = _util_domUtils__WEBPACK_IMPORTED_MODULE_0__[\"default\"].createElement(\"div\", {\n className: \"float-box-container\"\n });\n return this.redrawFloatBox(config, tab, $container);\n },\n\n /**\n * Recrea elemento FloatBox, que contiene los datos que se muestra en la tabla\n * Se usa principalmente para mostrar datos en la tabla de la planilla\n * los muestra de manera flotante, calculando el Top y el Left segun la poscion\n *\n * Se consideran los elementos padres ocultos, para ocultar los datos\n *\n * Se insertan los elementos FloatBox, como elemento con datos de un item y dia especifico\n *\n *\n * @param {Object} config - Configuracion capibara\n * @param {Object} tab - Tab de referencia, para mostrar datos configurados por tab\n * @return {Object} Elemento Dom Corner Footer\n */\n redrawFloatBox(config, tab, $container) {\n $container.innerHTML = \"\"; //let tabSelected = tab || null;\n\n config.data.forEach(de => {\n if (de.isHidden) return;\n de.children.forEach(ds => {\n if (ds.isHidden) return;\n ds.data.forEach(data => {\n if ((!data.message || data.message.value == null) && (data.values == null || data.values == undefined || Object.entries(data.values).length === 0)) {\n return null;\n } //children Data\n\n\n let position = this.getPositionFloatBox(config, data, ds);\n let className = \"\";\n\n if (data.errors && data.errors.length > 0) {\n className += \"has-errors \";\n }\n\n if (de.isClosed) {\n className += \"hide \";\n }\n\n let msg = null;\n\n if (tab.floaBox && tab.floatBox.messagePath) {\n msg = _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getVarByPath(data, tab.floatBox.messagePath);\n }\n\n if (msg || data.message && data.message.value) {\n className += \"has-message \";\n }\n\n let str = `\n <div class=\"float-box ${className} ${de.isClosed ? \"hide\" : \"\"}\"\n style=\"${position ? position : \"\"}\"\n item-id=\"${ds.id || -1}\"\n type-node=\"${ds.type || \"\"}\"> `;\n let strExt = `\n <div class=\"float-box-ext ${de.isClosed ? \"hide\" : \"\"}\"\n style=\"${position ? position : \"\"}\"\n item-id=\"${ds.id || -1}-ext\"\n type-node=\"${ds.type || \"\"}\">\n <div class=\"long-bar-container\">`;\n\n if (tab && tab.floatBox) {\n if (tab.floatBox.plots) {\n str += `<div class=\"plot-floatbox-container\">`;\n tab.floatBox.plots.forEach(n => {\n let cssVars = \"\";\n let className = \"\";\n\n if (_util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getVarByPath(data.values, n.varName) !== null) {\n if (n.color) {\n cssVars = `--local-color:${n.color};`;\n }\n\n className = n.className || \"\";\n str += `<div class=\"plot-floatbox ${className} ${n.style || \"\"}\" style=\"${cssVars} \"></div>`;\n }\n });\n str += `\n </div>`;\n } //numeros en el floatBox\n\n\n if (tab.floatBox.nums) {\n tab.floatBox.nums.forEach(n => {\n if (tab.legends && n.tabKey) {\n let legend = tab.legends.find(l => l.key == n.tabKey);\n if (legend && !legend.active) return;\n }\n\n let dataFloatBox = null;\n let className = \"\";\n let showIf = true;\n let hideIf = false;\n let colorClass = \"\";\n let colorStyle = \"\";\n let classNamesExt = \"\";\n let colorStyleExt = \"\";\n let cssVars = \"\";\n\n if (n.varName) {\n dataFloatBox = _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getVarByPath(data.values, n.varName);\n }\n\n if (n.varShow) {\n showIf = Boolean(_util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getVarByPath(data.values, n.varShow));\n dataFloatBox = dataFloatBox || \"\";\n }\n\n if (n.varHide) {\n hideIf = Boolean(_util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getVarByPath(data.values, n.varHide));\n }\n\n if (n.shape) {\n className += \"shape-\" + n.shape;\n }\n\n if (n.color) {\n if (_util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].isHexColor(n.color)) {\n colorStyle = `--local-color: ${n.color};`;\n } else {\n colorClass = n.color;\n }\n }\n\n if (n.longBar) {\n if (n.longBarColor) {\n let longBarColor = _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getVarByPath(data.values, n.longBarColor);\n let longBarOpacity = _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getVarByPath(data.values, n.longBarOpacity) || null;\n\n if (longBarColor) {\n if (_util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].isHexColor(longBarColor)) {\n colorStyleExt = `--local-color: ${longBarColor}; ${longBarOpacity ? \"--local-opacity: \" + longBarOpacity : \"\"}; `;\n } else {\n classNamesExt = longBarColor;\n }\n } else if (colorClass && colorClass != \"\") {\n classNamesExt = colorClass;\n } else if (colorStyle && colorStyle != \"\") {\n colorStyleExt = colorStyle;\n }\n }\n\n if (n.longBarClassName) {\n classNamesExt += \" \" + n.longBarClassName;\n }\n\n let longBar = _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getVarByPath(data.values, n.longBar);\n\n if (longBar) {\n cssVars = `--long:${longBar};`;\n }\n }\n\n if (dataFloatBox !== null && showIf && !hideIf) {\n str += `<span class=\"data ${colorClass} ${className}\" style=\"${colorStyle}\">\n ${typeof dataFloatBox == \"string\" ? dataFloatBox : \"\"}\n ${typeof dataFloatBox == \"number\" ? _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].round(dataFloatBox, n.round) : \"\"}\n </span>`;\n\n if (n.longBar && cssVars) {\n strExt += `<div class=\"long-bar ${classNamesExt}\" style=\"${colorStyleExt} ${cssVars} \"></div> `;\n }\n }\n });\n } //puntos en el floatBox\n\n\n if (tab.floatBox.dots) {\n str += `<div class=\"dot-container-middle\">`;\n tab.floatBox.dots.forEach(dot => {\n if (_util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getVarByPath(data.values, dot.varName) !== null) {\n let className = \"\";\n let colorClass = \"\";\n let colorStyle = \"\";\n\n if (dot.shape) {\n className += dot.shape;\n }\n\n if (dot.color) {\n if (_util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].isHexColor(dot.color)) {\n colorStyle = `--local-color: ${dot.color}`;\n } else {\n colorClass = dot.color;\n }\n }\n\n str += `\n <div class=\"dot ${colorClass} ${className}\" style=\"${colorStyle}\" ></div>`;\n }\n });\n str += `\n </div>`;\n } //fila de puntos en floatBox\n\n\n if (tab.floatBox.rowDots) {\n tab.floatBox.rowDots.forEach(row => {\n let freeColumns = 4;\n str += `<span class=\"rowdot--row \">`;\n row.forEach(dot => {\n if (tab.legends && dot.tabKey) {\n let legend = tab.legends.find(l => l.key == dot.tabKey);\n if (legend && !legend.active) return;\n }\n\n let dataFloatBox = null;\n let className = \"\";\n let showIf = true;\n let hideIf = false;\n let colorClass = \"\";\n let colorStyle = \"\";\n\n if (dot.varName) {\n dataFloatBox = _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getVarByPath(data.values, dot.varName);\n dataFloatBox = parseInt(dataFloatBox);\n }\n\n if (dot.varShow) {\n showIf = Boolean(_util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getVarByPath(data.values, dot.varShow));\n dataFloatBox = dataFloatBox || \"\";\n }\n\n if (dot.varHide) {\n hideIf = Boolean(_util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getVarByPath(data.values, dot.varHide));\n }\n\n if (dot.shape) {\n className += \" shape-\" + dot.shape;\n }\n\n if (dot.color) {\n if (_util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].isHexColor(dot.color)) {\n colorStyle = `--local-color: ${dot.color}`;\n } else {\n colorClass = dot.color;\n }\n }\n\n if (dataFloatBox !== null && dataFloatBox > 0 && showIf && !hideIf && freeColumns > 0) {\n let n = dataFloatBox > freeColumns ? freeColumns : dataFloatBox;\n freeColumns -= n;\n\n for (let index = 0; index < n; index++) {\n str += `<div class=\"rowdot--dot ${colorClass} ${className}\" style=\"${colorStyle}\"></div>`;\n }\n }\n });\n str += `</span>`;\n });\n }\n }\n\n str += `\n </div>`;\n strExt += `\n </div>\n </div>`;\n let $elem = _util_domUtils__WEBPACK_IMPORTED_MODULE_0__[\"default\"].createElementFromHTML(str);\n let $elemExt = _util_domUtils__WEBPACK_IMPORTED_MODULE_0__[\"default\"].createElementFromHTML(strExt);\n $elem.addEventListener(\"mouseover\", e => {\n $elem.dispatchEvent(new CustomEvent(\"mouseOverFloatBox\", {\n bubbles: true,\n cancelable: false,\n detail: {\n item: ds,\n data: data,\n originalEvt: e\n }\n }));\n });\n $elem.addEventListener(\"click\", e => {\n $elem.dispatchEvent(new CustomEvent(\"clickFloatBox\", {\n bubbles: true,\n cancelable: false,\n detail: {\n item: ds,\n data: data,\n originalEvt: e\n }\n }));\n });\n $container.appendChild($elem);\n $container.appendChild($elemExt);\n });\n });\n });\n return $container;\n },\n\n /**\n * Crea DetailDay, detalle de valores de item y Dia\n * se usa para:\n * - Muestra nombre de item y detalles\n * - Muestra capsulas de datos\n * - Muestra Pills, pildoras de datos resumidos\n * - Muestra alertas\n * - Muestra Mensaje\n *\n * @param {Object} config - Configuracion capibara\n * @param {Object} item - Item relacionado\n * @param {Object} dataDay - valores de item y Dia\n * @param {Boolean} [onlyStringContent = false] - para escoger si devuelve String o DomElement\n * @return {String|Object} Elemento como String o DomElement\n */\n createDetailDay(config, item = {}, dataDay, tabSelected, onlyStringContent = false) {\n let str = `\n <div class=\"header-detail\">\n <div class=\"title truncate\">\n ${item.label || \"\"}\n </div>\n <div class=\"subtitle\">\n ${dataDay ? _util_dateUtils__WEBPACK_IMPORTED_MODULE_2__[\"default\"].formatDateReadeable(dataDay.date) : \"\"}\n </div>\n </div>\n\n <div class=\"list-detail list\">`; //CAPSULES\n\n if (dataDay) {\n config.timeline.detailDay.capsules.forEach(cap => {\n //para comprobar si tiene datos, se obtiene el primer valor\n //de la lista de values de una capsula\n let hasValues = cap.values.filter(v => _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getVarByPath(dataDay.values, v.varName) !== null).length > 0;\n let hideIf = false;\n\n if (cap.hideIf) {\n hideIf = Boolean(_util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getVarByPath(dataDay.values, cap.hideIf));\n }\n\n let colorClass = \"\";\n let colorStyle = \"\";\n\n if (cap.color) {\n if (_util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].isHexColor(cap.color)) {\n colorStyle = `--local-color: ${cap.color};`;\n colorStyle += `--local-color-font: ${cap.color};`;\n } else {\n colorClass = cap.color;\n }\n }\n\n if (hasValues && !hideIf) {\n str += `\n <div class=\"item-detail ${colorClass}\" style=\"${colorStyle}\">\n\n <div class=\"left-icon ${cap.shape || \"\"} \"></div>\n\n <div class=\"name\">\n <span>\n ${cap.title || \"\"}\n </span>\n </div>`;\n str += `\n <div class=\"item-description\"> `;\n cap.values.forEach(v => {\n let value = v.varName ? _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getVarByPath(dataDay.values, v.varName) : null;\n\n if (cap.isLabeledArray) {\n value.forEach(valueLabeled => {\n let outputValue = null;\n let valueName = v.valueName ? v.valueName : \"value\";\n let tempValue = _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getVarByPath(valueLabeled, valueName);\n\n if (tempValue) {\n outputValue = v.round ? _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].round(tempValue, v.round) : tempValue;\n }\n\n if (v.formatter) {\n outputValue = v.formatter(valueLabeled);\n }\n\n if (typeof outputValue == \"number\") {\n outputValue = _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].formatNumber(outputValue);\n }\n\n str += outputValue == null ? \"\" : `\n <div class=\"desc ${v.showColumn ? \"desc-column\" : \"\"}\">\n <div class=\"label\">\n ${v.hideLabel ? \"\" : valueLabeled.label}\n </div >\n <div class=\"val\">\n <span class=\"prefix\">\n ${v.prefix || \"\"}\n </span>\n <span class=\"value\">\n ${outputValue}\n </span>\n <span class=\"suffix\">\n ${valueLabeled.suffix || v.suffix || \"\"}\n </span>\n </div>\n </div>`;\n });\n } else {\n let outputValue = v.round ? _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].round(value, v.round) : value;\n\n if (v.formatter) {\n outputValue = v.formatter({\n options: v,\n dataDay,\n outputValue\n });\n }\n\n if (typeof outputValue == \"number\") {\n outputValue = _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].formatNumber(outputValue);\n }\n\n str += outputValue == null ? \"\" : `\n <div class=\"desc\">\n <span class=\"prefix\">\n ${v.prefix || \"\"}\n </span>\n <span class=\"value\">\n ${outputValue}\n </span>\n <span class=\"suffix\">\n ${v.suffix || \"\"}\n </span>\n </div>`;\n }\n });\n str += `\n </div>`;\n str += `\n </div>`; // end .item-detail\n }\n });\n }\n\n str += `\n </div>`; // list-detail\n //PILLS\n\n if (config.timeline.detailDay.pillsVarName && dataDay && dataDay.values[config.timeline.detailDay.pillsVarName]) {\n str += `\n <div class=\"elements-detail\">\n <div class=\"name\"> ${config.timeline.detailDay.pillsTitle} </div>\n <div class=\"elements-list\">`;\n dataDay.values[config.timeline.detailDay.pillsVarName].forEach(e => {\n let value = e.value;\n\n if (typeof outputValue == \"number\") {\n value = _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].formatNumber(value);\n }\n\n str += `\n <div class=\"element-detail\">\n <b>${e.label}</b>\n ${value}\n </div>`;\n });\n str += `\n </div>\n </div>`; //end .element-detail > .element-list\n } //str += `</div>`;\n\n\n if (dataDay && dataDay.errors && dataDay.errors.length > 0) {\n dataDay.errors.forEach(err => {\n str += `\n <div class=\"alert\">\n ${_util_icons__WEBPACK_IMPORTED_MODULE_3__[\"default\"].alert}\n ${err.label}\n </div>`;\n });\n }\n\n let msg = null;\n let author = null;\n let dateMsg = null;\n\n if (dataDay && tabSelected.floatBox && tabSelected.floatBox.messagePath) {\n msg = _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getVarByPath(dataDay, tabSelected.floatBox.messagePath);\n }\n\n if (!msg && dataDay && dataDay.message && dataDay.message.value) {\n msg = dataDay.message.value;\n author = dataDay.message.author;\n dateMsg = _util_dateUtils__WEBPACK_IMPORTED_MODULE_2__[\"default\"].formatDateReadeable(new Date(dataDay.message.date));\n }\n\n if (msg) {\n //msg = msg.replace(/(\\r\\n|\\r|\\n)/g, '<br>');\n str += `\n <div class=\"msj-container\">\n <div class=\"msj\">\n <pre>${msg || \"\"}</pre>\n </div>\n <div class=\"msj-detail\">\n <span class=\"email\"> ${author || \"\"} </span>\n <span class=\"date\"> ${dateMsg || \"\"} </span>\n </div>\n </div>`;\n }\n\n let strContainer = `<div class=\"detail-day dd-hide\"> ${str} </div>`;\n if (onlyStringContent) return str;\n return _util_domUtils__WEBPACK_IMPORTED_MODULE_0__[\"default\"].createElementFromHTML(strContainer);\n },\n\n /**\n * Recrea HTML de detailDay\n *\n * @param {Object} config - Configuracion capibara\n * @param {Object} item - Item relacionado\n * @param {Object} dataDay - valores de item y Dia\n * @return {String} Elemento como String, de detailDay\n */\n redrawDetailDay(config, item, dataDay, tabSelected) {\n return this.createDetailDay(config, item, dataDay, tabSelected, true);\n },\n\n /**\n * Reposiciona FloatBox\n * verifica si el parent esta desplegado, para ocultar los datos\n *\n * Solo actualiza las alturas de los floatbox\n * no recrea los floatbox, es mas optimo\n *\n * @param {Object} config - Configuracion capibara\n * @param {Object} item - Item relacionado\n */\n repositionFloatBox(config, $floatBoxContainer) {\n $floatBoxContainer.querySelectorAll(\".float-box\").forEach($f => {\n let itemId = $f.getAttribute(\"item-id\");\n let itemHeight = parseFloat(_util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getCSSVariable(config, \"--item-height\"));\n let item, parent;\n ({\n item,\n parent\n } = _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getItemById(config, itemId, \"child\", true));\n\n if (item) {\n let top = _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getPositionByItem(config, item);\n $f.style.top = top * itemHeight + \"px\";\n\n if (parent && parent.isClosed) {\n $f.classList.add(\"hide\");\n } else if ($f.classList.contains(\"hide\")) {\n $f.classList.remove(\"hide\");\n }\n }\n });\n },\n\n /**\n * Recrea indicadores de dias seleccionados\n *\n * @param {Object} $elem - Elemento Dom donde crea los elementos seleccionados\n * @param {Object[]} selected - Array con los dias seleccionados\n * @return {Object} Elemento Dom que contiene los indicadores de dias seleccionados\n */\n redrawSelectBoard($elem, selected) {\n $elem.innerHTML = \"\";\n let hasNumber = true;\n\n if (selected) {\n if (selected.length == 1) hasNumber = false;\n selected.forEach(s => {\n let attributes = [];\n\n if (hasNumber) {\n attributes.push({\n name: \"cap-badge\",\n value: s.index\n });\n }\n\n let $s = _util_domUtils__WEBPACK_IMPORTED_MODULE_0__[\"default\"].createElement(\"div\", {\n className: \"selected-day\",\n attributes\n });\n $s.style.left = s.pos.left + \"px\";\n $s.style.top = s.pos.top + \"px\";\n $elem.append($s);\n });\n }\n\n return $elem;\n },\n\n /**\n * Obtiene String con estilos CSS de la posicion de un floatBox\n * calculado segun item y fecha de los valores\n *\n * @param {Object} config - Configuracion capibara, para ver fecha de inicio\n * @param {Object} data - Datos del dia indicado\n * @param {Object} item - Item relacionado\n * @return {String} String CSS top y left , para posicionar floatBox en table\n */\n getPositionFloatBox(config, data, item) {\n let left = _util_dateUtils__WEBPACK_IMPORTED_MODULE_2__[\"default\"].diffDays(config.timeline.start, data.date);\n let top = _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getPositionByItem(config, item);\n let dayWidth = parseFloat(_util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getCSSVariable(config, \"--day-width\"));\n let itemHeight = parseFloat(_util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getCSSVariable(config, \"--item-height\"));\n left *= dayWidth;\n top *= itemHeight;\n return \"top: \" + top + \".5px; left:\" + left + \".5px;\";\n },\n\n /**\n * Crea Boton como elemento Dom\n *\n * @param {Object} props - propiedades para boton\n * @param {String} props.className - classes css para boton\n * @param {*} props.key - key para identificar a boton\n * @param {String} props.label - Texto boton\n * @return {Object} Elemento Dom del boton creado\n */\n createButton(props) {\n return _util_domUtils__WEBPACK_IMPORTED_MODULE_0__[\"default\"].createElementFromHTML(`\n <button class=\"${props.className || \"\"}\" input-key=\"${props.key || \"\"}\">\n ${props.label || \"\"}\n </button>`);\n },\n\n /**\n * Crea Botones de guardar y cancelar los datos de formulario del sidebar derecho\n *\n * @return {Object} Elemento Dom del botones creados\n */\n createNavRightbuttons() {\n let saveBtn = this.createButton({\n label: \"Guardar\",\n className: \"cap-btn-raised\"\n });\n let cancelBtn = this.createButton({\n label: \"Cancelar\",\n className: \"cap-btn-outline\"\n });\n let btnSection = _util_domUtils__WEBPACK_IMPORTED_MODULE_0__[\"default\"].createElementFromHTML(`<div class=\"button-section\"></div>`);\n btnSection.appendChild(saveBtn);\n btnSection.appendChild(cancelBtn);\n saveBtn.addEventListener(\"click\", e => {\n saveBtn.dispatchEvent(new CustomEvent(\"saveMultiInput\", {\n bubbles: true,\n cancelable: false\n }));\n });\n cancelBtn.addEventListener(\"click\", e => {\n cancelBtn.dispatchEvent(new CustomEvent(\"cancelMultiInput\", {\n bubbles: true,\n cancelable: false\n }));\n });\n return btnSection;\n },\n\n /**\n * Crea Input como elemento Dom\n *\n * @param {Object} props - config para Input\n * @param {Object} [dataDay = null] - valores de item y Dia, opcional\n * @param {Object} [daySelected = null] - datos del dia seleccionado\n * @param {Object[]} [selected = []] - array de objetos, de dias seleccionados\n * @return {Object} Elemento Dom del input creado\n */\n createInput(props, dataDay = null, daySelected = null, selected = []) {\n let r = null;\n if (props.ignoreRender == true) return r;\n\n switch (props.type) {\n case \"custom\":\n r = props.render ? props.render({\n props,\n dataDay,\n daySelected,\n selected\n }) : null;\n r.setAttribute(\"input-key\", props.key);\n break;\n\n case \"select\":\n r = this.createInputSelect(props, dataDay, daySelected);\n break;\n\n case \"file\":\n r = this.createInputFile(props, dataDay);\n break;\n\n case \"fileLink\":\n r = this.createFileLink(props, dataDay);\n break;\n\n case \"text\":\n r = this.createText(props, selected);\n break;\n\n case \"title\":\n r = this.createTitle(props);\n break;\n\n case \"number\":\n r = this.createInputNumber(props, dataDay);\n break;\n\n case \"float\":\n r = this.createInputFloat(props, dataDay);\n break;\n\n case \"message\":\n r = this.createInputMessage(props, dataDay);\n break;\n\n case \"textarea\":\n r = this.createInputTextArea(props, dataDay);\n break;\n\n case \"checkbox\":\n r = this.createInputCheckbox(props, dataDay);\n break;\n\n case \"inputList\":\n r = this.createInputList(props, dataDay, daySelected);\n break;\n\n case \"input-box\":\n r = this.createInputBox(props, dataDay);\n break;\n\n case \"list\":\n r = this.createList(props, dataDay);\n break;\n\n case \"data-list\":\n r = this.createDataList(props, dataDay, daySelected, selected);\n break;\n\n case \"button\":\n r = this.createInputButton(props, dataDay);\n break;\n\n case \"buttons-group\":\n r = this.createInputButtonsGroup(props, dataDay);\n break;\n\n case \"time\":\n r = this.createInputTime(props, dataDay);\n break;\n\n case \"text\":\n default:\n r = this.createInputText(props, dataDay);\n }\n\n return r;\n },\n\n /**\n * Crea Input con formato Hora, como elemento Dom\n *\n * Usa 2 inputs, hora y minutos\n *\n * el value que interpreta es String HH:MM\n *\n * @param {Object} props - config para Input\n * @param {Object} [dataDay = null] - valores de item y Dia, opcional\n * @return {Object} Elemento Dom del input creado\n */\n createInputTime(props, dataDay) {\n let hhValue = \"\";\n let mmValue = \"\";\n\n if (dataDay && dataDay.values) {\n let value = _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getVarByPath(dataDay, props.varName);\n\n if (value) {\n value = value.split(\":\");\n hhValue = value[0];\n mmValue = value[1];\n }\n }\n\n let $elem = _util_domUtils__WEBPACK_IMPORTED_MODULE_0__[\"default\"].createElementFromHTML(`\n <div class=\"input-section ${props.isHidden ? 'hide' : ''} \" input-key=\"${props.key || \"\"}\">\n <span class=\"text-subtitle d-block\">\n ${props.label || \"\"}\n </span>\n <div class=\"d-flex\">\n <div class=\"time\">\n <input type=\"number\"\n class=\"hour\"\n id=\"test\"\n placeholder=\"00\"\n min=\"0\"\n max=\"24\"\n value=\"${hhValue}\">\n <span class=\"symbol\">:</span>\n <input type=\"number\"\n class=\"minutes\"\n placeholder=\"00\"\n min=\"0\"\n max=\"59\"\n value=\"${mmValue}\">\n </div>\n <span class=\"text-hint\">\n ${props.textHint || \"\"}\n </span>\n </div>\n </div>`);\n let $hhInput = $elem.querySelector(\".hour\");\n let $mmInput = $elem.querySelector(\".minutes\");\n $hhInput.addEventListener(\"input\", e => {\n $hhInput.dispatchEvent(new CustomEvent(\"changeTimeInputHH\", {\n bubbles: true,\n cancelable: false,\n detail: {\n key: props.key,\n value: e.srcElement.value\n }\n }));\n });\n $mmInput.addEventListener(\"input\", e => {\n $mmInput.dispatchEvent(new CustomEvent(\"changeTimeInputMM\", {\n bubbles: true,\n cancelable: false,\n detail: {\n key: props.key,\n value: e.srcElement.value\n }\n }));\n });\n this.addKeyDownInputEvents($hhInput, $elem, props);\n this.addKeyDownInputEvents($mmInput, $elem, props);\n return $elem;\n },\n\n /**\n * Crea Text como elemento Dom\n * Se configura como input, pero no devuelve datos, es un texto\n *\n * @param {Object} props - config para Input\n * @return {Object} Elemento Dom del input creado\n */\n createText(props, selected) {\n let label = props.label;\n\n if (props.formatter) {\n label = props.formatter({\n selected\n });\n }\n\n let $elem = _util_domUtils__WEBPACK_IMPORTED_MODULE_0__[\"default\"].createElementFromHTML(`\n <div class=\"input-section ${props.isHidden ? 'hide' : ''} \" input-key=\"${props.key || \"\"}\">\n <span class=\"${props.classNames || \"\"}\">\n ${label}\n </span>\n </div>`);\n return $elem;\n },\n\n /**\n * Crea Title como elemento Dom\n * Se configura como input, pero no devuelve datos, es un texto\n *\n * @param {Object} props - config para Input\n * @return {Object} Elemento Dom del input creado\n */\n createTitle(props) {\n let classNames = \"text-title\";\n\n if (props.isSubtitle) {\n classNames = \"text-subtitle\";\n }\n\n return _util_domUtils__WEBPACK_IMPORTED_MODULE_0__[\"default\"].createElementFromHTML(`\n <div class=\"input-section ${props.isHidden ? 'hide' : ''} \" input-key=\"${props.key || \"\"}\">\n <span class=\"${classNames}\">\n ${props.label}\n </span>\n </div>`);\n },\n\n /**\n * Crea Input tipo Numerico como elemento Dom\n *\n * @param {Object} props - config para Input\n * @param {Object} dataDay - valores de item y Dia, opcional\n * @return {Object} Elemento Dom del input creado\n */\n createInputNumber(props, dataDay) {\n let value = \"\";\n\n if (dataDay && dataDay.values) {\n value = _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getVarByPath(dataDay, props.varName);\n }\n\n value = value || \"\";\n let elem = _util_domUtils__WEBPACK_IMPORTED_MODULE_0__[\"default\"].createElementFromHTML(`\n <div class=\"input-section ${props.classNames || \"\"} ${props.isHidden ? 'hide' : ''} \" input-key=\"${props.key || \"\"}\">\n <div class=\"input-section-title\">\n <span class=\"text-subtitle\">\n ${props.label}\n </span>\n <span class=\"text-subtitle-2 \">\n ${props.suffix ? \"(\" + props.suffix + \")\" : \"\"}\n </span>\n </div>\n <div class=\"d-flex\">\n <input type=\"number\"\n class=\"nav-input\"\n value=\"${value}\">\n\n <span class=\"text-hint\">\n ${props.textHint || \"\"}\n </span>\n </div>\n </div>`);\n let inputElem = elem.querySelector(\"input\");\n this.addKeyDownInputEvents(inputElem, elem, props);\n return elem;\n },\n\n /**\n * Crea Input tipo FIlepicker como elemento Dom\n *\n * @param {Object} props - config para Input\n * @param {Object} dataDay - valores de item y Dia, opcional\n * @return {Object} Elemento Dom del input creado\n */\n createInputFile(props, dataDay) {\n let value = \"\";\n let fileName = \"\";\n let filePath = \"\";\n\n if (dataDay && dataDay.values) {\n value = _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getVarByPath(dataDay, props.varName);\n fileName = _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getVarByPath(dataDay, props.fileNameValue);\n filePath = _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getVarByPath(dataDay, props.filePathValue);\n }\n\n value = value || \"\";\n fileName = fileName || \"\";\n filePath = filePath || \"\";\n let elem = _util_domUtils__WEBPACK_IMPORTED_MODULE_0__[\"default\"].createElementFromHTML(`\n <div class=\"input-section ${props.classNames || \"\"} ${props.isHidden ? 'hide' : ''} \" input-key=\"${props.key || \"\"}\">\n\n <div class=\"input-section-title\">\n <span class=\"text-subtitle\">\n ${props.label}\n </span>\n </div>\n\n <div class=\"nav-input-file\" >\n <button class=\"small-close clear-file-input\">x</button>\n <label >\n <span class=\"nav-input-file-label\">\n ${props.pickerLabel || \"Seleccionar Archivo\"}\n </span>\n <input type=\"file\" value=\"${value}\">\n </label>\n </div>\n\n <div class=\"input-section-link\">\n <a href=\"${filePath}\" target=\"_blank\" >\n ${fileName}\n </a>\n </div>\n\n </div>`);\n let $inputElem = elem.querySelector(\"input\");\n let $clearBtn = elem.querySelector(\".clear-file-input\");\n let $fileInputLabel = elem.querySelector(\".nav-input-file-label\");\n $inputElem.addEventListener(\"change\", evt => {\n let fileName = $inputElem.files[0].name;\n $fileInputLabel.textContent = fileName;\n });\n $clearBtn.addEventListener(\"click\", evt => {\n $inputElem.value = \"\";\n $fileInputLabel.textContent = props.pickerLabel || \"Seleccionar Archivo\";\n evt.stopPropagation();\n });\n return elem;\n },\n\n createFileLink(props, dataDay) {\n let fileName = \"\";\n let filePath = \"\";\n\n if (dataDay && dataDay.values) {\n //value = utils.getVarByPath(dataDay, props.varName);\n fileName = _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getVarByPath(dataDay, props.fileNameValue);\n filePath = _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getVarByPath(dataDay, props.filePathValue);\n }\n\n if (fileName == \"\") return null;\n fileName = fileName || \"\";\n filePath = filePath || \"\";\n let elem = _util_domUtils__WEBPACK_IMPORTED_MODULE_0__[\"default\"].createElementFromHTML(`\n <div class=\"input-section ${props.classNames || \"\"} ${props.isHidden ? 'hide' : ''} \" input-key=\"${props.key || \"\"}\">\n\n <div class=\"input-section-title\">\n <span class=\"text-subtitle\">\n ${props.label}\n </span>\n </div>\n\n <div class=\"input-section-link\">\n <a href=\"${filePath}\" target=\"_blank\" >\n ${fileName}\n </a>\n </div>\n\n </div>`);\n return elem;\n },\n\n /**\n * Crea lista de Inputs, con array de valores, como elemento Dom\n *\n * @param {Object} props - config para Input\n * @param {Object} dataDay - valores de item y Dia, opcional\n * @param {Object} [daySelected = null] - datos del dia seleccionado\n * @return {Object} Elemento Dom del input creado\n */\n createInputList(props, dataDay, daySelected = null) {\n let inputList = []; //obtiene inputs default, para crearlos, sin valores\n\n if (daySelected && Array.isArray(daySelected.item.values[props.inputList])) {\n inputList = daySelected.item.values[props.inputList].map(inputRow => {\n //limpia inputList inputs\n inputRow.inputs.map(input => {\n input.value = null;\n return input;\n }); //obtiene valores del dia\n\n if (dataDay && dataDay.values) {\n let inputValues = _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getVarByPath(dataDay, props.valuesPath); //autorrellena\n\n if (inputValues) {\n inputRow.inputs.forEach(input => {\n let values = inputValues.find(v => v.id == inputRow.id);\n input.value = values ? values[input.varName] : null;\n });\n }\n }\n\n return inputRow;\n });\n }\n\n let str = `<div input-key=\"${props.key || \"\"}\" class=\"input-section-list ${props.isHidden ? 'hide' : ''} \">\n <div class=\"input-section-title\">\n <span class=\"text-title\">\n ${props.label}\n </span> \n </div>`;\n inputList.forEach(inputRow => {\n str += `\n <div class=\"input-section ${props.toRight ? \"to-right\" : \"\"}\" >\n <span class=\"text-subtitle\">\n ${inputRow.label}\n </span>`;\n inputRow.inputs.forEach(input => {\n str += ` \n <div class=\"input-section-col\" >\n <span class=\"text-subtitle \">\n ${input.label}\n </span>\n <input type=\"number\"\n input-id=\"${inputRow.id}\"\n input-label=\"${input.label}\"\n class=\"nav-input small\"\n value=\"${input.value}\">\n </div>`;\n });\n str += `\n </div>`;\n });\n str += `</div>`;\n let elem = _util_domUtils__WEBPACK_IMPORTED_MODULE_0__[\"default\"].createElementFromHTML(str);\n let inputsElem = elem.querySelectorAll(\"input\");\n inputsElem.forEach(inputElem => this.addKeyDownInputEvents(inputElem, elem, props));\n return elem;\n },\n\n createInputSelect(props, dataDay, daySelected = null) {\n let value = null;\n let options = props.options;\n\n if (dataDay && dataDay.values) {\n let val = _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getVarByPath(dataDay, props.varName);\n value = val ? val.value : null;\n }\n\n let str = `<div input-key=\"${props.key || \"\"}\" class=\"${props.isHidden ? 'hide' : ''}\" >\n <div class=\"input-section \" >\n <span class=\"text-subtitle\">\n ${props.label}\n </span>\n\n <select class=\"input-select\">\n\n <option value=\"\" ${value == null ? \"selected\" : \"\"}>\n ${props.noDataLabel || \"-- sin asignar --\"}\n </option>\n\n `;\n options.forEach(option => {\n str += `\n <option value=\"${option.id}\" ${option.id == value ? \"selected\" : \"\"}>\n ${option.label}\n </option>\n `;\n });\n str += `\n\n </select>\n </div>\n\n </div>`;\n let elem = _util_domUtils__WEBPACK_IMPORTED_MODULE_0__[\"default\"].createElementFromHTML(str);\n return elem;\n },\n\n /**\n * Crea Input de texto TextArea como elemento Dom\n *\n * @param {Object} props - config para Input\n * @param {Object} dataDay - valores de item y Dia, opcional\n * @return {Object} Elemento Dom del input creado\n */\n createInputTextArea(props, dataDay) {\n let value = \"\";\n\n if (dataDay && dataDay.values) {\n value = _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getVarByPath(dataDay, props.varName);\n }\n\n let elem = _util_domUtils__WEBPACK_IMPORTED_MODULE_0__[\"default\"].createElementFromHTML(`\n <div class=\"input-section ${props.isHidden ? 'hide' : ''} \" input-key=\"${props.key || \"\"}\">\n <span class=\"text-subtitle d-block\">\n ${props.label}\n </span>\n <textarea class=\"\" value=\"${value}\"></textarea>\n </div>`);\n let inputElem = elem.querySelector(\"textarea\");\n this.addKeyDownInputEvents(inputElem, elem, props);\n return elem;\n },\n\n /**\n * Crea Input de Mensaje como elemento Dom\n * utiliza TextArea\n *\n * @param {Object} props - config para Input\n * @param {Object} dataDay - valores de item y Dia, opcional\n * @return {Object} Elemento Dom del input creado\n */\n createInputMessage(props, dataDay) {\n let value = dataDay ? _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getVarByPath(dataDay, props.varName) : null;\n let elem = _util_domUtils__WEBPACK_IMPORTED_MODULE_0__[\"default\"].createElementFromHTML(`\n <div class=\"input-section msj-input-container ${props.isHidden ? 'hide' : ''} \"\n input-key=\"${props.key || \"\"}\">\n <span class=\"text-subtitle d-block\">\n Mensaje\n </span>\n <textarea class=\"msj\">${value || \"\"}</textarea>\n </div>`);\n let inputElem = elem.querySelector(\"textarea\"); //this.addKeyDownInputEvents(inputElem);\n\n return elem;\n },\n\n /**\n * Crea Input de texto como elemento Dom\n *\n * @param {Object} props - config para Input\n * @param {Object} dataDay - valores de item y Dia, opcional\n * @return {Object} Elemento Dom del input creado\n */\n createInputText(props, dataDay) {\n let value = \"\";\n\n if (dataDay && dataDay.values) {\n value = _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getVarByPath(dataDay, props.varName);\n }\n\n let elem = _util_domUtils__WEBPACK_IMPORTED_MODULE_0__[\"default\"].createElementFromHTML(`\n <div class=\"input-section ${props.isHidden ? 'hide' : ''} \" input-key=\"${props.key || \"\"}\">\n <span class=\"text-subtitle d-block\">\n ${props.label}\n </span>\n <input type=\"text\" class=\"nav-input\" value=\"${value}\">\n </div>`);\n let inputElem = elem.querySelector(\"input\");\n this.addKeyDownInputEvents(inputElem, elem, props);\n return elem;\n },\n\n /**\n * Crea Input Numero Flotante, como elemento Dom\n *\n * @param {Object} props - config para Input\n * @param {Object} dataDay - valores de item y Dia, opcional\n * @return {Object} Elemento Dom del input creado\n */\n createInputFloat(props, dataDay) {\n let value = \"\";\n\n if (dataDay && dataDay.values) {\n value = _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getVarByPath(dataDay, props.varName);\n }\n\n let elem = _util_domUtils__WEBPACK_IMPORTED_MODULE_0__[\"default\"].createElementFromHTML(`\n <div class=\"input-section ${props.isHidden ? 'hide' : ''} \" input-key=\"${props.key || \"\"}\">\n <span class=\"text-subtitle d-block\">\n ${props.label}\n </span>\n <input type=\"number\" class=\"nav-input\" value=\"${value}\">\n </div>`);\n let inputElem = elem.querySelector(\"input\");\n this.addKeyDownInputEvents(inputElem, elem, props);\n return elem;\n },\n\n createDataList(props, dataDay, daySelected, selected) {\n let list = [];\n\n if (dataDay && dataDay.values) {\n list = _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getVarByPath(dataDay, props.varName) || [];\n }\n\n let searchInput = ` <div class=\"search-input-container\">\n <input id=\"\" type=\"text\" name=\"\" class=\"search-input\" placeholder=\"buscar\">\n <button class=\"search-input-clear\">\n ${_util_icons__WEBPACK_IMPORTED_MODULE_3__[\"default\"].closeIcon}\n </button>\n </div>`;\n let editBtn = \"\";\n\n if (props.editButton) {\n editBtn = `<button class=\"cap-btn-outline cap-btn-sm edit-btn\" input-key=\"${props.editButton.key}\">\n ${props.editButton.label} \n </button> `;\n }\n\n let str = `\n <div class=\"input-section ${props.isHidden ? 'hide' : ''} \" input-key=\"${props.key || \"\"}\">\n <div class=\"input-section-title\">\n <span class=\"text-subtitle d-block\">\n ${props.label}\n </span>\n ${editBtn}\t\n </div>\n <div class=\"input-box \" input-key=\"${props.key || \"\"}\">\n ${searchInput}\n </div>\n </div> `;\n let $el = _util_domUtils__WEBPACK_IMPORTED_MODULE_0__[\"default\"].createElementFromHTML(str);\n let $searchInput = $el.querySelector(\".search-input\");\n let $searchInputClear = $el.querySelector(\".search-input-clear\");\n let $inputBox = $el.querySelector(\".input-box\");\n list.map((item, j) => {\n let label = _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getVarByPath(item, props.varNameLabel) || dataDay.label || \"__\";\n let $elItem = this.createDataListItem({\n label,\n valueText: _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getVarByPath(item, props.varNameValueText) || \"\",\n subText: _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getVarByPath(item, props.varNameSubText) || \"\",\n id: \"list-item-\" + (dataDay.id || j),\n key: \"list-item-\" + (dataDay.id || j),\n tooltip: _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getVarByPath(item, props.varNameTooltip) || label,\n //colorIcon: \"c-red\",\n link: _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getVarByPath(item, props.varNameLink) || null,\n suffix: _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getVarByPath(item, props.varNameSuffix) || null //value: JSON.stringify(utils.getVarByPath(item, props.varNameInput)) || {}\n\n });\n $inputBox.appendChild($elItem);\n });\n $searchInputClear.addEventListener(\"click\", e => {\n $searchInput.value = \"\";\n $searchInput.dispatchEvent(new Event(\"input\", {\n bubbles: true\n }));\n });\n $searchInput.addEventListener(\"keydown\", e => {\n if (e.key === \"Escape\") {\n $searchInput.value = \"\";\n $searchInput.dispatchEvent(new Event(\"input\", {\n bubbles: true\n }));\n }\n });\n $searchInput.addEventListener(\"input\", e => {\n let $inputs = [];\n $inputs = $el.querySelectorAll(\".mini-input-section\") || [];\n $inputs.forEach($i => {\n let label = $i.getAttribute(\"label\");\n let search = $searchInput.value;\n\n if (label.toLowerCase().includes(search.toLowerCase())) {\n $i.classList.remove(\"hide\");\n } else {\n $i.classList.add(\"hide\");\n }\n });\n });\n let button = $el.querySelector(\"button.edit-btn\");\n\n if (button && props.editButton && props.editButton.onClick) {\n button.addEventListener(\"click\", e => props.editButton.onClick({\n event: e,\n props,\n dataDay,\n daySelected,\n selected,\n $element: $el\n }));\n }\n\n return $el;\n },\n\n createDataListItem({\n label = \"\",\n valueText = \"\",\n subText = \"\",\n id = \"\",\n key = \"\",\n tooltip = \"\",\n colorIcon = \"\",\n link = null,\n suffix = null,\n value = \"\"\n }) {\n let tooltipStr = \"\";\n let iconStr = null;\n let linkStr = \"\";\n let str = \"\";\n\n if (tooltip) {\n tooltipStr = `\n <div class=\"mini-input-section--tooltip\">\n ${tooltip}\n </div>`;\n }\n\n if (colorIcon) {\n if (_util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].isHexColor(itemFormated.colorIcon)) {\n iconStr = `<div class=\"mini-input-section--icon\" style=\"background:${colorIcon}\"> </div>`;\n } else {\n iconStr = `<div class=\"mini-input-section--icon ${colorIcon}\"> </div>`;\n }\n }\n\n if (link) {\n linkStr = `<a class=\"mini-input-section--link\" target=\"_blank\" href=\"${link}\">${_util_icons__WEBPACK_IMPORTED_MODULE_3__[\"default\"].linkIcon}</a> `;\n }\n\n str += `\n <div class=\"mini-input-section ${iconStr ? \"has-icon\" : \"\"} \" label=\"${label}\" data-id=\"${id}\" data-key=\"${key}\" data-value=\"${value || ''}\">\n <label>\n ${iconStr || \"\"}\n\n <div class=\"mini-input-section--titles\">\n <div class=\"mini-input-section--title truncate\">\n ${label}\n </div>\n <div class=\"mini-input-section--subtitle truncate\">\n ${subText}\n </div>\n </div>\n\n <div class=\"mini-input-section--content\" >\n ${valueText}\n </div>\n <div class=\"mini-input-section--suffix\" >\n ${suffix}\n </div>\n\n ${linkStr}\n\n </label>\n ${tooltipStr}\n </div>`;\n return _util_domUtils__WEBPACK_IMPORTED_MODULE_0__[\"default\"].createElementFromHTML(str);\n },\n\n createList(props, dataDay) {\n let tabsContainer = \"\";\n\n if (props.tabs) {\n let tabs = \"\";\n props.tabs.forEach(tab => {\n tabs += `\n <div class=\"input-box-tab\" tab-key=\"${tab.key}\">\n ${tab.name}\n </div>`;\n });\n tabsContainer = `\n <div class=\"input-box-tab-container\">\n ${tabs}\n </div>\n `;\n }\n\n let searchInput = `\n <div class=\"search-input-container\">\n <input id=\"\" type=\"text\" name=\"\" class=\"search-input\" placeholder=\"buscar\">\n <button class=\"search-input-clear\">\n ${_util_icons__WEBPACK_IMPORTED_MODULE_3__[\"default\"].closeIcon}\n </button>\n </div>\n `;\n let str = `\n <div class=\"input-section ${props.isHidden ? 'hide' : ''} \" input-key=\"${props.key || \"\"}\">\n <span class=\"text-subtitle d-block\">\n ${props.label}\n </span>\n\n ${tabsContainer}\n <div class=\"input-box \" input-key=\"${props.key || \"\"}\">\n\n ${searchInput}\n `; //TODO obtener input segun fila\n\n if (props.inputs) {\n props.inputs.forEach(i => {\n if (i.isTitle) {\n let tooltip = \"\";\n let icon = null;\n\n if (i.tooltip) {\n tooltip = `\n <div class=\"mini-input-section--tooltip\">\n ${i.tooltip}\n ${i.suffix ? \"(\" + i.suffix + \")\" : \"\"}\n </div>`;\n }\n\n if (i.colorIcon) {\n if (_util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].isHexColor(i.colorIcon)) {\n icon = `<div class=\"mini-input-section--icon\" style=\"background:${i.colorIcon}\"> </div>`;\n } else {\n icon = `<div class=\"mini-input-section--icon ${i.colorIcon}\"> </div>`;\n }\n }\n\n str += `\n <div class=\"mini-input-section is-title ${icon ? \"has-icon\" : \"\"}\" input-tab-key=\"${i.tabKey || \"\"}\" label=\"${i.label}\">\n <label>\n ${icon || \"\"}\n <div class=\"mini-input-section--title truncate\">\n ${i.label}\n </div>\n </label>\n ${tooltip}\n </div>`;\n } else {\n let tooltip = \"\";\n let icon = null;\n let link = \"\";\n\n if (i.tooltip) {\n tooltip = `\n <div class=\"mini-input-section--tooltip\">\n ${i.tooltip}\n </div>`;\n }\n\n if (i.colorIcon) {\n if (_util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].isHexColor(i.colorIcon)) {\n icon = `<div class=\"mini-input-section--icon\" style=\"background:${i.colorIcon}\"> </div>`;\n } else {\n icon = `<div class=\"mini-input-section--icon ${i.colorIcon}\"> </div>`;\n }\n }\n\n if (i.link) {\n link = `<a class=\"mini-input-section--link\" target=\"_blank\" href=\"${i.link}\">\n ${_util_icons__WEBPACK_IMPORTED_MODULE_3__[\"default\"].linkIcon}\n </a> `;\n }\n\n str += `\n <div class=\"mini-input-section ${icon ? \"has-icon\" : \"\"}\" input-tab-key=\"${i.tabKey || \"\"}\" label=\"${i.label}\">\n <label>\n\n ${icon}\n\n <div class=\"mini-input-section--title truncate\">\n ${i.label}\n </div>\n\n <div class=\"mini-input-section--suffix\" >${i.suffix ? \"(\" + i.suffix + \")\" : \"\"}</div>\n\n ${link}\n\n </label>\n <div class=\"mini-input-section--footer\">\n <span class=\"start\"> start</span>\n <span class=\"end\"> end </span>\n </div>\n ${tooltip}\n </div>`;\n }\n });\n }\n\n str += `\n </div>\n </div> `;\n let $el = _util_domUtils__WEBPACK_IMPORTED_MODULE_0__[\"default\"].createElementFromHTML(str);\n let $tabs = $el.querySelectorAll(\".input-box-tab[tab-key]\") || [];\n let $searchInput = $el.querySelector(\".search-input\") || null;\n let $searchInputClear = $el.querySelector(\".search-input-clear\") || null;\n $tabs.forEach(t => {\n t.addEventListener(\"click\", e => {\n this.selectInputBoxTab(t, $el);\n $searchInput.value = \"\";\n $searchInput.dispatchEvent(new Event(\"input\", {\n bubbles: true\n }));\n });\n });\n\n if ($searchInputClear) {\n $searchInputClear.addEventListener(\"click\", e => {\n $searchInput.value = \"\";\n $searchInput.dispatchEvent(new Event(\"input\", {\n bubbles: true\n }));\n });\n }\n\n if ($searchInput) {\n $searchInput.addEventListener(\"keydown\", e => {\n if (e.key === \"Escape\") {\n $searchInput.value = \"\";\n $searchInput.dispatchEvent(new Event(\"input\", {\n bubbles: true\n }));\n }\n });\n $searchInput.addEventListener(\"input\", e => {\n let $tabSelected = $el.querySelector(\".input-box-tab[tab-key].active\") || null;\n let $inputs = [];\n\n if ($tabSelected) {\n let tabKey = $tabSelected.getAttribute(\"tab-key\");\n $inputs = $el.querySelectorAll(\".mini-input-section[input-tab-key='\" + tabKey + \"']\") || [];\n } else {\n $inputs = $el.querySelectorAll(\".mini-input-section\") || [];\n }\n\n $inputs.forEach($i => {\n let label = $i.getAttribute(\"label\");\n let search = $searchInput.value;\n\n if (label.toLowerCase().includes(search.toLowerCase())) {\n $i.classList.remove(\"hide\");\n } else {\n $i.classList.add(\"hide\");\n }\n });\n });\n }\n\n this.selectInputBoxTab(_.first($tabs), $el);\n return $el;\n },\n\n /**\n * Crea InputBox, como elemento Dom\n * un InputBox es un contenedor con una lista de inputs\n *\n * @param {Object} props - config para Input\n * @param {Object} dataDay - valores de item y Dia, opcional\n * @return {Object} Elemento Dom del input creado\n */\n createInputBox(props, dataDay) {\n let value = [];\n\n if (dataDay && dataDay.values) {\n value = _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getVarByPath(dataDay, props.varName);\n }\n\n let tabsContainer = \"\";\n\n if (props.tabs) {\n let tabs = \"\";\n props.tabs.forEach(tab => {\n tabs += `\n <div class=\"input-box-tab\" tab-key=\"${tab.key}\">\n ${tab.name}\n </div>`;\n });\n tabsContainer = `\n <div class=\"input-box-tab-container\">\n ${tabs}\n </div>\n `;\n }\n\n let searchInput = `\n <div class=\"search-input-container\">\n <input id=\"\" type=\"text\" name=\"\" class=\"search-input\" placeholder=\"buscar\">\n <button class=\"search-input-clear\">\n ${_util_icons__WEBPACK_IMPORTED_MODULE_3__[\"default\"].closeIcon}\n </button>\n </div>\n `;\n let str = `\n <div class=\"input-section ${props.isHidden ? 'hide' : ''} \" input-key=\"${props.key || \"\"}\">\n <span class=\"text-subtitle d-block\">\n ${props.label}\n </span>\n\n ${tabsContainer}\n\n <div class=\"input-box \" input-key=\"${props.key || \"\"}\">\n\n ${searchInput}\n `;\n\n if (props.inputs) {\n props.inputs.forEach(i => {\n if (i.isTitle) {\n let tooltip = \"\";\n let icon = \"\";\n\n if (i.tooltip) {\n tooltip = `\n <div class=\"mini-input-section--tooltip\">\n ${i.tooltip}\n ${i.suffix ? \"(\" + i.suffix + \")\" : \"\"}\n </div>`;\n }\n\n if (i.colorIcon) {\n if (_util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].isHexColor(i.colorIcon)) {\n icon = `<div class=\"mini-input-section--icon\" style=\"background:${i.colorIcon}\"> </div>`;\n } else {\n icon = `<div class=\"mini-input-section--icon ${i.colorIcon}\"> </div>`;\n }\n }\n\n str += `\n <div class=\"mini-input-section is-title\" input-tab-key=\"${i.tabKey || \"\"}\" label=\"${i.label}\">\n <label>\n ${icon}\n <div class=\"mini-input-section--title truncate\">\n ${i.label}\n </div>\n </label>\n ${tooltip}\n </div>`;\n } else {\n let value_found = value ? value.find(val => val.id == i.id) : null;\n let v = value_found || \"\";\n let inputValue = props.varNameInput && v[props.varNameInput] ? v[props.varNameInput] : v.value;\n let tooltip = \"\";\n let icon = \"\";\n let link = \"\";\n\n if (i.tooltip) {\n tooltip = `\n <div class=\"mini-input-section--tooltip\">\n ${i.tooltip}\n </div>`;\n }\n\n if (i.colorIcon) {\n if (_util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].isHexColor(i.colorIcon)) {\n icon = `<div class=\"mini-input-section--icon\" style=\"background:${i.colorIcon}\"> </div>`;\n } else {\n icon = `<div class=\"mini-input-section--icon ${i.colorIcon}\"> </div>`;\n }\n }\n\n if (i.link) {\n link = `<a class=\"mini-input-section--link\" target=\"_blank\" href=\"${i.link}\">\n ${_util_icons__WEBPACK_IMPORTED_MODULE_3__[\"default\"].linkIcon}\n </a> `;\n }\n\n str += `\n <div class=\"mini-input-section ${icon ? \"has-icon\" : \"\"}\" input-tab-key=\"${i.tabKey || \"\"}\" label=\"${i.label}\">\n <label>\n <input type=\"number\"\n class=\"mini-input\"\n input-id=\"${i.id || \"\"}\"\n input-key=\"${i.key || i.label}\"\n value=\"${inputValue || \"\"}\">\n\n ${icon || \"\"}\n\n <div class=\"mini-input-section--title truncate\">\n ${i.label}\n </div>\n\n <div class=\"mini-input-section--suffix\" >${i.suffix ? \"(\" + i.suffix + \")\" : \"\"}</div>\n\n ${link}\n\n </label>\n ${tooltip}\n </div>`;\n }\n });\n }\n\n str += `\n </div>\n </div> `;\n let $el = _util_domUtils__WEBPACK_IMPORTED_MODULE_0__[\"default\"].createElementFromHTML(str);\n let $tabs = $el.querySelectorAll(\".input-box-tab[tab-key]\") || [];\n let $inputs = $el.querySelectorAll(\"input.mini-input\") || [];\n let $searchInput = $el.querySelector(\".search-input\") || null;\n let $searchInputClear = $el.querySelector(\".search-input-clear\") || null;\n $tabs.forEach(t => {\n t.addEventListener(\"click\", e => {\n this.selectInputBoxTab(t, $el);\n $searchInput.value = \"\";\n $searchInput.dispatchEvent(new Event(\"input\", {\n bubbles: true\n }));\n });\n });\n\n if ($searchInputClear) {\n $searchInputClear.addEventListener(\"click\", e => {\n $searchInput.value = \"\";\n $searchInput.dispatchEvent(new Event(\"input\", {\n bubbles: true\n }));\n });\n }\n\n if ($searchInput) {\n $searchInput.addEventListener(\"keydown\", e => {\n if (e.key === \"Escape\") {\n $searchInput.value = \"\";\n $searchInput.dispatchEvent(new Event(\"input\", {\n bubbles: true\n }));\n }\n });\n $searchInput.addEventListener(\"input\", e => {\n let $tabSelected = $el.querySelector(\".input-box-tab[tab-key].active\") || null;\n let $inputs = [];\n\n if ($tabSelected) {\n let tabKey = $tabSelected.getAttribute(\"tab-key\");\n $inputs = $el.querySelectorAll(\".mini-input-section[input-tab-key='\" + tabKey + \"']\") || [];\n } else {\n $inputs = $el.querySelectorAll(\".mini-input-section\") || [];\n }\n\n $inputs.forEach($i => {\n let label = $i.getAttribute(\"label\");\n let search = $searchInput.value;\n\n if (label.toLowerCase().includes(search.toLowerCase())) {\n $i.classList.remove(\"hide\");\n } else {\n $i.classList.add(\"hide\");\n }\n });\n });\n }\n\n this.selectInputBoxTab(_.first($tabs), $el);\n $inputs.forEach(i => this.addKeyDownInputEvents(i, $el, props));\n return $el;\n },\n\n selectInputBoxTab($tab, $el) {\n let $tabs = $el.querySelectorAll(\".input-box-tab[tab-key]\") || [];\n let $inputSections = $el.querySelectorAll(\".mini-input-section\") || [];\n $tabs.forEach(t => {\n t.classList.remove(\"active\");\n });\n\n if ($tab) {\n $tab.classList.add(\"active\");\n $inputSections.forEach(i => {\n let key = i.getAttribute(\"input-tab-key\");\n\n if (key == $tab.getAttribute(\"tab-key\")) {\n i.classList.remove(\"hide\");\n } else {\n i.classList.add(\"hide\");\n }\n });\n }\n },\n\n /**\n * Crea Checkbox, como elemento Dom\n *\n * @param {Object} props - config para Input\n * @param {Object} dataDay - valores de item y Dia, opcional\n * @return {Object} Elemento Dom del input creado\n */\n createInputCheckbox(props, dataDay) {\n let value = \"\";\n\n if (dataDay && dataDay.values) {\n value = _util_utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getVarByPath(dataDay, props.varName);\n }\n\n let r = _util_domUtils__WEBPACK_IMPORTED_MODULE_0__[\"default\"].createElementFromHTML(`\n <div class=\"input-section ${props.isHidden ? 'hide' : ''} \" input-key=\"${props.key || \"\"}\">\n <label>\n <input type=\"checkbox\" name=\"${props.key || \"\"}\" input-key=\"${props.key || \"\"}\" ${value ? \"checked\" : \"\"}>\n ${props.label}\n </label>\n </div>`);\n return r;\n },\n\n createInputButtonsGroup(props) {\n let $container = _util_domUtils__WEBPACK_IMPORTED_MODULE_0__[\"default\"].createElementFromHTML(`\n <div class=\"input-section ${props.isHidden ? 'hide' : ''} \" input-key=\"${props.key || \"\"}\">\n <div class=\"buttons-group\"> </div>\n </div>`);\n let $containerButtonGroup = $container.querySelector(\".buttons-group\");\n let $buttons = [];\n $buttons = props.buttons.map(buttonProp => {\n let buttonStr = `\n <button \n name=\"${buttonProp.key || \"\"}\" \n input-key=\"${buttonProp.key || \"\"}\"\n class=\"cap-btn-outline cap-btn-sm ${buttonProp.isSelected ? 'selected' : ''} \">\n ${buttonProp.label}\n </button>`;\n let $button = _util_domUtils__WEBPACK_IMPORTED_MODULE_0__[\"default\"].createElementFromHTML(buttonStr);\n $containerButtonGroup.append($button);\n $button.addEventListener(\"click\", e => {\n if (props.isSelectable) {\n $buttons.forEach($b => $b.classList.remove(\"selected\"));\n $button.classList.add(\"selected\");\n }\n\n buttonProp.onClick({\n props,\n event: e,\n buttonsElements: $buttons\n });\n });\n return $button;\n });\n return $container;\n },\n\n createInputButton(props) {\n let r = _util_domUtils__WEBPACK_IMPORTED_MODULE_0__[\"default\"].createElementFromHTML(`\n <div class=\"input-section ${props.isHidden ? 'hide' : ''} \" input-key=\"${props.key || \"\"}\">\n <button \n name=\"${props.key || \"\"}\"\n input-key=\"${props.key || \"\"}\"\n class=\"cap-btn-outline\">\n ${props.label}\n </button>\n </div>`);\n let button = r.querySelector(\"button\");\n button.addEventListener(\"click\", e => props.onClick({\n props,\n event: e\n }));\n return r;\n },\n\n addKeyDownInputEvents($input, $inputContainer, props) {\n $input.addEventListener(\"keydown\", function (event) {\n if (event.keyCode === 13) {\n //ENTER\n $input.dispatchEvent(new CustomEvent(\"saveMultiInput\", {\n bubbles: true,\n cancelable: false\n }));\n }\n\n if (event.keyCode === 27) {\n //ESC\n $input.dispatchEvent(new CustomEvent(\"cancelMultiInput\", {\n bubbles: true,\n cancelable: false\n }));\n }\n });\n $input.addEventListener(\"input\", e => {\n if (props.onInput) {\n props.onInput({\n event: e,\n value: e.srcElement.value,\n props,\n $element: $inputContainer\n });\n }\n });\n },\n\n createContextMenu({\n config,\n $capibaraElem = null,\n evt = null,\n date = null,\n item = null,\n selected = [],\n tabSelected = null,\n left = null,\n top = null,\n name = \"\"\n }) {\n if (config.timeline.contextMenu === undefined) return {\n elem: null,\n isVisible: false\n };\n let className = \"\";\n let style = \"\";\n let strHtml = \"\";\n let leftPosition = null;\n let topPosition = null;\n let isVisible = true;\n let boundRectCapibara = null;\n let gap = 15; //px\n\n if ($capibaraElem) {\n boundRectCapibara = $capibaraElem.getBoundingClientRect();\n }\n\n if (evt && boundRectCapibara) {\n left = evt.clientX;\n top = evt.clientY - boundRectCapibara.top;\n }\n\n if (left) {\n leftPosition = left;\n }\n\n if (top) {\n topPosition = top;\n }\n\n if (leftPosition !== null & topPosition !== null) {\n if (boundRectCapibara) {\n let transformStyle = \"\";\n\n if (topPosition > boundRectCapibara.height * 2 / 6 && topPosition <= boundRectCapibara.height * 4 / 6) {\n transformStyle += `translateY(-50%)`;\n }\n\n if (topPosition > boundRectCapibara.height * 4 / 6) {\n transformStyle += `translateY(-100%)`;\n }\n\n if (leftPosition > boundRectCapibara.width * 4 / 6) {\n transformStyle += `translateX(-100%)`;\n leftPosition -= gap;\n } else {\n leftPosition += gap;\n }\n\n if (transformStyle != \"\") {\n style += ` transform: ${transformStyle};`;\n }\n }\n\n style += `top: ${topPosition}px; left: ${leftPosition}px;`;\n } else {\n className += \"cm-hide\";\n isVisible = false;\n }\n\n strHtml += ` <div class=\"cap-context-menu-container ${className}\">\n <div class=\"cap-context-menu\" style=\"${style}\">\n </div>\n </div>`;\n let $contextMenuContainer = _util_domUtils__WEBPACK_IMPORTED_MODULE_0__[\"default\"].createElementFromHTML(strHtml);\n let $contextMenu = $contextMenuContainer.querySelector(\".cap-context-menu\");\n config.timeline.contextMenu.options.forEach(option => {\n if (option.showIf) {\n let show = option.showIf({\n item,\n date,\n selected,\n name,\n tabSelected\n });\n if (!show) return;\n }\n\n let isEnabled = true;\n let isClickeable = true;\n\n if (option.enableIf) {\n isEnabled = option.enableIf({\n item,\n date,\n selected,\n name,\n tabSelected\n });\n }\n\n let optionClassName = \"\";\n let strIcon = \"\";\n let label = \"\";\n\n if (!isEnabled) {\n optionClassName += \"is-disabled \";\n }\n\n if (option.isDivider) {\n isClickeable = false;\n optionClassName += \"is-divider \";\n }\n\n if (option.label) {\n label = `<span>${option.label}</span>`;\n }\n\n if (option.icon) {\n strIcon = `<div class=\"cap-context-menu_item_icon\">\n <svg viewBox=\"0 0 24 24\">\n <path d=\"${option.icon}\" />\n </svg>\n </div>`;\n }\n\n let optionStrHtml = `\n <div class=\"cap-context-menu_item ${optionClassName}\">\n ${strIcon}\n ${label}\n </div>`;\n let $option = _util_domUtils__WEBPACK_IMPORTED_MODULE_0__[\"default\"].createElementFromHTML(optionStrHtml);\n\n if (isEnabled && isClickeable) {\n $option.addEventListener(\"click\", evtClick => option.onClick({\n config,\n evt: evtClick,\n date,\n item,\n selected,\n tabSelected\n }));\n } else {\n $option.addEventListener(\"click\", evtClick => {\n evtClick.preventDefault();\n evtClick.stopPropagation();\n });\n }\n\n $contextMenu.append($option);\n });\n return {\n elem: $contextMenuContainer,\n isVisible\n };\n }\n\n});//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"./src/util/tableElements.js.js","sources":["webpack://Capibara/./src/util/tableElements.js?1d86"],"sourcesContent":["import dom from \"../util/domUtils\";\nimport utils from \"../util/utils\";\nimport dateUtils from \"../util/dateUtils\";\nimport icons from \"../util/icons\";\nimport domUtils from \"../util/domUtils\";\n\nexport default {\n  /**\n   * Crea elemento Table\n   * Contendrá los elementos que apareceran dentro de la tabla de planilla\n   * Se Usa para :\n   *    - Agregar background con patron estilo tabla\n   *    - Agregar dayMouseOver, div que indica posicion de mouse\n   *    - Agregar DetailDay, para detalles de datos en tabla\n   *    - Agregar SelectedContainer, para dias seleccionados\n   *    - Agregar FloatBoxContainer, para visualizacion de datos en tabla\n   *\n   * @param {Object} config - Configuracion capibara\n   * @return {Object} Elemento Dom creado\n   */\n  createAgTable(config) {\n    let e = dom.createElement(\"div\", { className: \"capibara\" });\n    if (config.timeline.dark) {\n      e.classList.add(\"dark-theme\");\n    }\n    if (config.timeline.header.extend.isShow) {\n      e.classList.add(\"header-extended\");\n    }\n    return e;\n  },\n\n  /**\n   * Recrea Background, que es el fondo grid, como tabla\n   *\n   * @param {Object} config - Configuracion capibara\n   * @param {Object} $elem - Elemento relacionado, donde se cre el background\n   * @return {Object} Elemento Dom Corner Footer\n   */\n  redrawBackground(config, $elem) {\n    return this.createBackground(config, $elem);\n  },\n\n  /**\n   * Crea y posiciona fondo de tabla\n   * Este fondo contiene un patron de CSS que le da la apariencia de tabla\n   * por lo cual se debe reposicionar segun la fecha de inicio, para hacer\n   * calzar los fines de semana\n   *\n   * @param {Object} config - Configuracion capibara\n   * @param {Object} [$elem = null] - Elemento background, si es null, lo crea\n   * @return {Object} elemento Dom Background\n   */\n  createBackground(config, $elem = null) {\n    let { height, width, dayWidth } = utils.getTableDimensions(config);\n\n    let start = new Date(config.timeline.start);\n    let end = new Date(config.timeline.end);\n\n    end.setTime(end.getTime() + dateUtils.dayInMilliseconds); // add 24 hours\n\n    let dCorrected = new Date(\n      start.valueOf() + start.getTimezoneOffset() * 60000\n    );\n    let weekDay = dCorrected.getDay();\n    let diffWeekDays = (weekDay - 1) * dayWidth * -1;\n\n    $elem = $elem || dom.createElement(\"div\", { className: \"background-grid\" });\n    $elem.style[\"background-position\"] =\n      diffWeekDays + \"px 0, 0 0, \" + diffWeekDays + \"px 0\";\n    $elem.style.width = width + \"px\";\n    $elem.style.height = height + 1 + \"px\";\n    return $elem;\n  },\n\n  /**\n   * Crea Plot Container Vertical\n   * Los plots son elementos que agregan secciones de fondo en la planilla\n   *\n   * @param {Object} config - Configuracion capibara\n   * @return {Object} Elemento Dom plotVerticalContainer\n   */\n  createPlotVerticalContainer(config) {\n    let $elem = dom.createElement(\"div\", {\n      className: \"plot-vertical-container\"\n    });\n    return this.redrawPlotVerticalContainer(config, $elem);\n  },\n\n  createPlotHorizontalContainer(config) {\n    let $elem = dom.createElement(\"div\", {\n      className: \"plot-horizontal-container\"\n    });\n    return this.redrawPlotHorizontalContainer(config, $elem);\n  },\n\n  /**\n   * Recrea plotVerticalContainer, usando elemento existente\n   * usa un elemento existente para usar la funcion para redibujar el elemento\n   *\n   * Los Plots se insertan como divs, con posicion especificada,\n   * con ancho de dia\n   *\n   * @param {Object} config - Configuracion capibara\n   * @param {Object} $elem - Elemento Dom donde crea plotVerticalContainer\n   * @return {Object} Elemento Dom plotVerticalContainer\n   */\n  redrawPlotVerticalContainer(config, $elem) {\n    $elem.innerHTML = \"\";\n    if (config.timeline.plots && config.timeline.plots.vertical) {\n      let { height, dayWidth } = utils.getTableDimensions(config);\n\n      config.timeline.plots.vertical.forEach((p) => {\n        let diffDays = Math.floor(\n          dateUtils.diffDays(config.timeline.start, p.date)\n        );\n        let left = diffDays * dayWidth;\n        let plot = dom.createElement(\"div\", {\n          classNames: [\"plot-vertical\", p.className || \"\"],\n          style: {\n            \"margin-left\": left + \"px\",\n            height: height + \"px\"\n          }\n        });\n        $elem.appendChild(plot);\n      });\n    }\n    return $elem;\n  },\n\n  redrawPlotHorizontalContainer(config, $elem) {\n    $elem.innerHTML = \"\";\n    if (config.timeline.plots && config.timeline.plots.horizontal) {\n      let { width, itemHeight } = utils.getTableDimensions(config);\n      config.timeline.plots.horizontal.forEach((p) => {\n        let item = utils.getItemById(config, p.idNode, p.typeNode);\n        let topPosition = utils.getPositionByItem(config, item, \"parent\");\n        let plot = dom.createElement(\"div\", {\n          classNames: [\"plot-horizontal\", p.className || \"\"],\n          style: {\n            \"margin-top\": topPosition * itemHeight + \"px\",\n            width: width + \"px\"\n          }\n        });\n        $elem.appendChild(plot);\n      });\n    }\n    return $elem;\n  },\n\n  /**\n   * Crea Corner Izquierdo\n   * Se usa para :\n   *    - titulos relacionados con los datos del sidebar izquierdo\n   *    - titulos para inputs de header, absolute a la derecha\n   *    - boton para mostrar/ocultar sidebar izquierdo\n   *    - promedios\n   *\n   * @param {Object} config - Configuracion capibara\n   * @return {Object} Elemento Dom Corner\n   */\n  createCorner(config, tab = null) {\n    let $elem = dom.createElement(\"div\", { className: \"corner\" });\n    return this.redrawCorner($elem, config, tab);\n  },\n\n  redrawCorner($elem, config, tab = null) {\n    let labelsInitialCorner = config.timeline.nav.left.initial.vars\n      .filter(\n        (v) =>\n          v.onlyTab == undefined || (v.onlyTab && tab && v.onlyTab == tab.key)\n      )\n      .map((d) => `<span class=\"item-col\">${d.label}</span>`)\n      .join(\"\");\n\n    let labelsExtendCorner = config.timeline.nav.left.extend.vars\n      .filter(\n        (v) =>\n          v.onlyTab == undefined || (v.onlyTab && tab && v.onlyTab == tab.key)\n      )\n      .map((d) => `<span class=\"item-col\">${d.label}</span>`)\n      .join(\"\");\n\n    let labelsHeaderExtend = config.timeline.header.extend.data\n      .map((d) => {\n        if (d.isHidden) return \"\";\n\n        let avg = \"\";\n        let tooltip = \"\";\n        let className = \"\";\n        let isAccent = d.isAccent;\n\n        if (d.average) {\n          avg = ` <span class=\"average \"> ( <span> <span class=\"symbol\">x̄</span> ${d.average} </span>)  </span>   `;\n\n          tooltip = `cap-tooltip=\"Promedio ${d.label} : ${d.average} ${\n            d.suffix || \"\"\n          }\"`;\n        }\n\n        if (d.color) {\n          if (isAccent) {\n            className = d.color ? \"c-\" + d.color + \"--background\" : \"\";\n          } else {\n            className = d.color ? \"c-\" + d.color + \"--text \" : \"\";\n          }\n        }\n\n        return `<div class=\"input-title-container ${\n          isAccent ? \"input-title--accent\" : \"\"\n        } ${d.isPersistent ? \"persistent\" : \"\"}\">\n                                  <span ${tooltip} class=\"input-title ${className}\">\n                                    ${avg}\n                                    ${d.label}\n                                  </span>\n\n                                </div>`;\n      })\n      .join(\"\");\n\n    let toggleSidebarBtnString = `\n          <button toggle-sidebar class=\"cap-btn-icon cap-btn-icon-raised cap-btn-toggle-sidebar \">\n          ${icons.chevronRight}\n          </button> `;\n\n    if (config.timeline.nav.left.hideToggleSidebarButton) {\n      toggleSidebarBtnString = \"\";\n    }\n\n    let template = `<div>\n\n          ${toggleSidebarBtnString}\n        <div class=\"corner-title\">\n          <span class=\"bottom-text\">\n            ${config.timeline.corner.left.label}\n          </span>\n        </div>\n\n        <div class=\"initial-corner\">\n          <div class=\"initial-corner-title\">\n            <span class=\"bottom-container hide\">\n              ${config.timeline.corner.initial.label}\n            </span>\n\n            <div class=\"bottom-container\">\n              ${labelsInitialCorner}\n            </div>\n\n          </div>\n        </div>\n\n\n        <div class=\"extend-corner\">\n          <div class=\"ex-corner-title\">\n            <span class=\"bottom-container hide\">\n              ${config.timeline.corner.extend.label}\n            </span>\n\n            <div class=\"bottom-container\">\n              ${labelsExtendCorner}\n            </div>\n\n          </div>\n        </div>\n\n\n        <div class=\"cap-btn-nav-corner\">\n          <div class=\"input-titles\">\n              ${labelsHeaderExtend}\n          </div>\n        </div>\n\n        <div class=\"progress-bar progress-bar-left hide-progress\"></div>\n\n      </div>`;\n\n    let r = dom.createElementFromHTML(template);\n\n    $elem.innerHTML = \"\";\n    $elem.append(r);\n\n    let toggleSidebar = $elem.querySelector(\"[toggle-sidebar]\");\n    if (toggleSidebar) {\n      toggleSidebar.addEventListener(\"click\", (e) => {\n        r.dispatchEvent(\n          new CustomEvent(\"toggleSidebar\", {\n            bubbles: true,\n            cancelable: false\n          })\n        );\n      });\n    }\n\n    return $elem;\n  },\n\n  /**\n   * Crea Corner Derecho\n   * Se usa para :\n   *    - titulos relacionados con los datos del sidebar Derecho\n   *\n   * @param {Object} config - Configuracion capibara\n   * @return {Object} Elemento Dom corner\n   */\n  createCornerRight(config, tab = null) {\n    let $elem = dom.createElement(\"div\", { classNames: [\"corner\", \"right\"] });\n    return this.redrawCornerRight($elem, config, tab);\n  },\n\n  redrawCornerRight($el, config, tab = null) {\n    let label = \"\";\n\n    if (config.timeline.corner.right.label) {\n      ` <span>\n            ${config.timeline.corner.right.label}\n          </span>`;\n    }\n\n    let str = `\n        <div class=\"corner-title\">\n        ${label}\n        <div class=\"btn-container\"></div>\n        </div>\n        <div class=\"progress-bar progress-bar-right hide-progress\"></div>\n    `;\n    $el.innerHTML = str.trim();\n    let $btnContainer = $el.querySelector(\".btn-container\");\n\n    if (config.timeline.corner.right.buttons) {\n      config.timeline.corner.right.buttons.forEach((btn) => {\n        let isEnabled = btn.getIsEnabled ? btn.getIsEnabled() : true;\n        if (isEnabled) {\n          let $btn = dom.createElementFromHTML(`\n                        <button class=\"corner-btn cap-btn-raised\">\n                          ${btn.label || \"\"}\n                        </button> `);\n\n          if (btn.onClick) {\n            $btn.addEventListener(\"click\", btn.onClick);\n          }\n\n          $btnContainer.appendChild($btn);\n        }\n      });\n    }\n    if (config.timeline.corner.right.inputs) {\n      config.timeline.corner.right.inputs.forEach((input) => {\n        let $input = this.createCornerRightInput({ inputConfig: input });\n        $btnContainer.appendChild($btn);\n      });\n    }\n    return $el;\n  },\n\n  createCornerRightInput({ inputConfig, dataDay = null, daySelected = null }) {\n    let r = null;\n    switch (inputConfig.type) {\n      case \"autocomplete-crud\":\n        r = this.createCornerRightInputAutocompleteCrud({\n          inputConfig,\n          dataDay,\n          daySelected\n        });\n        break;\n    }\n    return r;\n  },\n\n  createCornerRightInputAutocompleteCrud({\n    inputConfig,\n    dataDay,\n    daySelected\n  }) {\n    let elem = \"test\";\n    return elem;\n  },\n\n  /**\n   * Crea Header Top\n   * Se usa para :\n   *    - Manejo de tabs\n   *    - Botones de navegación y selección de fecha\n   *    - Boton toggle Dark mode\n   *    - Boton toggle Header extended\n   *\n   * @param {Object} config - Configuracion capibara\n   * @return {Object} Elemento Dom\n   */\n\n  createHeaderTop(config, tabSelected = null) {\n    return this.redrawHeaderTop(config, tabSelected, dom.createElement(\"div\"));\n  },\n\n  redrawHeaderTop(config, tabSelected = null, $elem) {\n    let str = `\n      <div class=\"header-top\">`;\n\n    if (config.timeline.tabs) {\n      let showTabs = true;\n\n      if (config.timeline.tabs.filter((t) => !t.isHidden).length == 0) {\n        showTabs = false;\n      }\n\n      if (showTabs) {\n        str += ` <div class=\"tab-select-container c-d-desktop-none c-d-mobile-flex\">\n                  <select class=\"tabs-select\" >`;\n\n        config.timeline.tabs.forEach((tab) => {\n          if (!tab.isHidden) {\n            str += ` <option ${\n              tab == tabSelected ? 'selected=\"selected\"' : \"\"\n            } value=\"${tab.id}\"> ${tab.label} </option>`;\n          }\n        });\n\n        str += `</select> </div>`;\n\n        str += ` <div class=\"tabs-container c-d-desktop-flex c-d-mobile-none\">`;\n\n        config.timeline.tabs.forEach((tab) => {\n          if (!tab.isHidden) {\n            str += ` <button\n                        class=\"tab ${tab.disabled ? \"disabled\" : \"\"}  ${\n                          tab == tabSelected ? \"active\" : \"\"\n                        }  ${tab.color}\"\n                        color=\"${tab.color}\"\n                        input-key=\"${tab.id}\"\n                        ${\n                          tab.tooltip ? 'cap-tooltip=\"' + tab.tooltip + '\"' : \"\"\n                        } >\n                    <span>${tab.label}</span>\n                    ${tab.icon || \"\"}\n                  </button>\n                  `;\n          }\n        });\n\n        str += `</div>`;\n      }\n    }\n\n    if (tabSelected) {\n      if (tabSelected.legends) {\n        str += ` \n        <button toggle-legends class=\"cap-btn-icon cap-btn-icon-raised \">\n          ${icons.toggleLegends}\n        </button> \n\n        <div class=\"legends-container force-mobile-style hide\"> `;\n\n        tabSelected.legends.forEach((legend) => {\n          let colorClass = \"\";\n          let colorBg = \"\";\n\n          if (utils.isHexColor(legend.color)) {\n            colorBg = \"background:\" + legend.color;\n          } else {\n            colorClass = legend.color ? legend.color + \"--background\" : \"\";\n          }\n\n          str += ` <div\n                      class=\"legend ${legend.active ? \"active\" : \"\"}\"\n                      input-key=\"${legend.key}\"\n                      ${\n                        legend.tooltip ? `cap-tooltip=\"${legend.tooltip}\"` : \"\"\n                      } >\n                  <div class=\"icon-legend ${colorClass} ${\n                    legend.shape\n                  }\" style=\"${colorBg}\"></div>\n                  <span>${legend.label}</span>\n                </div>`;\n        });\n\n        str += `</div>`;\n      }\n    }\n\n    str += `\n\n          <div class=\"spacer\"></div>\n\n\n\n          <button cap-btn-prev class=\"cap-btn-icon cap-btn-icon-raised\">\n             ${icons.arrowLeft}\n             ${icons.loadingIcon} \n          </button>\n\n\n          <button cap-btn-calendar class=\"cap-btn-icon cap-btn-icon-raised\">\n            ${icons.calendar}\n            ${icons.loadingIcon}\n          </button>\n\n          <button cap-btn-next class=\"cap-btn-icon cap-btn-icon-raised\">\n            ${icons.arrowRight}\n            ${icons.loadingIcon}\n          </button>\n\n          <div class=\"spacer\"></div>\n\n          <button toggle-dark class=\"cap-btn-icon cap-btn-header c-d-mobile-none ${\n            config.timeline.withDarkToggle == false ? \"hide\" : \"\"\n          }\">\n            ${icons.dark}\n            ${icons.light}\n          </button>`;\n\n    if (config.timeline.header.extend.enabled !== false) {\n      str += `<button toggle-header class=\"cap-btn-icon cap-btn-icon-raised\">\n          ${icons.chevronDown}\n          </button>`;\n    }\n\n    str += ` <div class=\"button-right-container\"></div>\n        </div>`;\n    /*\n          `\n          <button toggle-sidebar-right class=\"cap-btn-icon cap-btn-icon-raised\">\n            <span>\n              <svg style=\"width:24px;height:24px\" viewBox=\"0 0 24 24\">\n                  <path fill=\"currentColor\" d=\"M15.41,16.58L10.83,12L15.41,7.41L14,6L8,12L14,18L15.41,16.58Z\" />\n              </svg>\n            </span>\n          </button>\n\n      </div>\n    `;\n    */\n\n    let $r = dom.createElementFromHTML(str);\n    $elem.replaceWith($r);\n\n    if (config.timeline.header.rightButtons) {\n      let $buttonContainer = $r.querySelector(\".button-right-container\");\n      config.timeline.header.rightButtons.forEach((button) => {\n        let hasBadge = false;\n        if (button.hasBadge) {\n          hasBadge = button.hasBadge();\n        }\n        let str = `<button class=\"cap-btn-icon cap-btn-icon-raised ${\n          hasBadge ? \"cap-btn-has-badge\" : \"\"\n        }\">\n            <span>\n              <svg style=\"width:24px;height:24px\" viewBox=\"0 0 24 24\">\n                  <path fill=\"currentColor\" d=\"${button.icon}\" />\n              </svg>\n            </span>\n          </button>`;\n        let $button = dom.createElementFromHTML(str);\n        $button.addEventListener(\"click\", (evt) => button.onClick({ evt }));\n        $buttonContainer.append($button);\n      });\n    }\n\n    let $toggleDark = $r.querySelector(\"[toggle-dark]\");\n    if ($toggleDark) {\n      $toggleDark.addEventListener(\"click\", (e) => {\n        $r.dispatchEvent(\n          new CustomEvent(\"toggleDark\", {\n            bubbles: true,\n            cancelable: false\n          })\n        );\n      });\n    }\n\n    let $btnCalendar = $r.querySelector(\"[cap-btn-calendar]\");\n    if ($btnCalendar) {\n      $btnCalendar.addEventListener(\"click\", (e) => {\n        let x = e.x;\n        let y = e.y;\n        $r.dispatchEvent(\n          new CustomEvent(\"clickCalendarIcon\", {\n            bubbles: true,\n            cancelable: false,\n            detail: { x, y }\n          })\n        );\n      });\n    }\n\n    let $btnToggleHeader = $r.querySelector(\"[toggle-header]\");\n    if ($btnToggleHeader) {\n      $btnToggleHeader.addEventListener(\"click\", (e) => {\n        $r.dispatchEvent(\n          new CustomEvent(\"toggleHeader\", {\n            bubbles: true,\n            cancelable: false\n          })\n        );\n      });\n    }\n\n    /*\n    $r.querySelector(\"[toggle-sidebar-right]\").addEventListener(\"click\", e => {\n      $r.dispatchEvent(new CustomEvent(\"toggleSidebarRight\", {\n        bubbles: true,\n        cancelable: false,\n      }));\n    });\n    */\n\n    $r.querySelector(\"[cap-btn-prev]\").addEventListener(\"click\", (e) => {\n      $r.dispatchEvent(\n        new CustomEvent(\"headerPrev\", {\n          bubbles: true,\n          cancelable: false,\n          detail: {\n            originalEvt: e\n          }\n        })\n      );\n    });\n\n    $r.querySelector(\"[cap-btn-calendar]\").addEventListener(\"click\", (e) => {\n      $r.dispatchEvent(\n        new CustomEvent(\"headerCalendar\", {\n          bubbles: true,\n          cancelable: false,\n          detail: {\n            originalEvt: e\n          }\n        })\n      );\n    });\n\n    $r.querySelector(\"[cap-btn-next]\").addEventListener(\"click\", (e) => {\n      $r.dispatchEvent(\n        new CustomEvent(\"headerNext\", {\n          bubbles: true,\n          cancelable: false,\n          detail: {\n            originalEvt: e\n          }\n        })\n      );\n    });\n\n    let $toggleLegendsBtn = $r.querySelector(\"[toggle-legends]\");\n    if ($toggleLegendsBtn) {\n      $toggleLegendsBtn.addEventListener(\"click\", (e) => {\n        let $legendContainer = $r.querySelector(\".legends-container\");\n        if ($legendContainer) {\n          $legendContainer.classList.toggle(\"hide\");\n        }\n      });\n    }\n\n    $r.querySelectorAll(\".legend\").forEach(($legend) => {\n      $legend.addEventListener(\"click\", (e) => {\n        let key = e.currentTarget.getAttribute(\"input-key\");\n\n        if (key) {\n          let legendSelected = tabSelected.legends.find(\n            (tab) => tab.key === key\n          );\n          if (legendSelected) {\n            $r.dispatchEvent(\n              new CustomEvent(\"selectLegendHeader\", {\n                bubbles: true,\n                cancelable: false,\n                detail: {\n                  legend: legendSelected,\n                  $legend\n                }\n              })\n            );\n          }\n        }\n      });\n    });\n\n    $r.querySelectorAll(\".tab:not(.disabled)\").forEach(($tab) => {\n      $tab.addEventListener(\"click\", (e) => {\n        let key = e.currentTarget.getAttribute(\"input-key\");\n\n        if (key) {\n          let tabSelected = config.timeline.tabs.find((tab) => tab.id == key);\n          if (tabSelected) {\n            $r.dispatchEvent(\n              new CustomEvent(\"selectTabHeader\", {\n                bubbles: true,\n                cancelable: false,\n                detail: {\n                  tab: tabSelected\n                }\n              })\n            );\n          }\n        }\n      });\n    });\n\n    $r.querySelectorAll(\".tabs-select:not(.disabled)\").forEach(($tab) => {\n      $tab.addEventListener(\"change\", (e) => {\n        let key = parseFloat(e.currentTarget.value);\n\n        if (key) {\n          let tabSelected = config.timeline.tabs.find((tab) => tab.id == key);\n          if (tabSelected) {\n            $r.dispatchEvent(\n              new CustomEvent(\"selectTabHeader\", {\n                bubbles: true,\n                cancelable: false,\n                detail: {\n                  tab: tabSelected\n                }\n              })\n            );\n          }\n        }\n      });\n    });\n\n    return $r;\n  },\n\n  /**\n   * Crea Header\n   * Se usa para :\n   *    - Mostrar fechas en header\n   *\n   * @param {Object} config - Configuracion capibara\n   * @return {Object} Elemento Dom\n   */\n  createHeader(config) {\n    let $elem = dom.createElement(\"header\");\n    return this.redrawHeader(config, $elem);\n  },\n\n  /**\n   * Recrea Header, usado para redibujar\n   * utiliza $elem como elemento dom donde recrearlo\n   *\n   * @param {Object} config - Configuracion capibara\n   * @param {Object} $elem - Elemento Dom donde crea Header\n   * @return {Object} Elemento Dom\n   */\n  redrawHeader(config, $elem) {\n    let datesTree = dateUtils.getDateTreeRange(\n      new Date(config.timeline.start),\n      new Date(config.timeline.end)\n    );\n\n    let str = `<div class=\"header-container\"> `;\n\n    Object.keys(datesTree).forEach((keyY) => {\n      let year = datesTree[keyY];\n      str += `<div class=\"agno-calendario\">\n              <span class=\"agno hide\">${keyY}</span>\n              <div class=\"meses\">`;\n\n      Object.keys(year).forEach((keyM) => {\n        let month = datesTree[keyY][keyM];\n        str += ` <div class=\"mes-calendario\">\n                    <div class=\"mes ${\n                      Object.keys(month).length < 4\n                        ? \"mes-reduced mes-reduced-\" + Object.keys(month).length\n                        : \"\"\n                    }\">\n                      <div class=\"mes-label\">\n                        ${utils.getMonthByPosition(keyM)} ${keyY}\n                      </div>\n                    </div>\n                    <div class=\"dias\">`;\n        Object.keys(month).forEach((keyD) => {\n          let day = datesTree[keyY][keyM][keyD];\n          let isWeekend = day.isWeekend;\n          let isToday = day.isToday;\n          let date = dateUtils.formatDate(day.Date);\n          str += `<div class=\"dia-calendario ${isToday ? \"today\" : \"\"}  ${\n            isWeekend ? \"weekend\" : \"\"\n          } ${\n            config.timeline.dateSelectable ? \"is-clickeable\" : \"\"\n          }\" date=\"${date}\">${keyD}</div>`;\n        });\n        str += `</div></div>`;\n      });\n      str += `</div> </div>`;\n    });\n\n    str += `</div>`;\n    $elem.innerHTML = \"\";\n    $elem.append(dom.createElementFromHTML(str));\n\n    if (config.timeline.dateSelectable) {\n      $elem.querySelectorAll(\".dia-calendario[date]\").forEach(($dia) => {\n        $dia.addEventListener(\"contextmenu\", (evt) => {\n          $elem.dispatchEvent(\n            new CustomEvent(\"contextMenuDate\", {\n              bubbles: true,\n              cancelable: false,\n              detail: {\n                $elem: $dia,\n                date: $dia.getAttribute(\"date\"),\n                clientX: evt.clientX,\n                clientY: evt.clientY\n              }\n            })\n          );\n        });\n\n        $dia.addEventListener(\"click\", (evt) => {\n          $elem.dispatchEvent(\n            new CustomEvent(\"clickDate\", {\n              bubbles: true,\n              cancelable: false,\n              detail: {\n                $elem: $dia,\n                date: $dia.getAttribute(\"date\")\n              }\n            })\n          );\n        });\n      });\n    }\n\n    return $elem;\n  },\n\n  /**\n   * Crea Header extended\n   * Se usa para :\n   *    -Mostrar inputs y datos para fechas en header\n   *\n   * @param {Object} config - Configuracion capibara\n   * @return {Object} Elemento Dom headerExtended\n   */\n  createHeaderExtended(config) {\n    if (config.timeline.header.extend.enabled == false) return null;\n\n    let dates = dateUtils.getDateRange(\n      new Date(config.timeline.start),\n      new Date(config.timeline.end)\n    );\n    let str = `<div class=\"header-container-extended\">`;\n\n    config.timeline.header.extend.data.forEach((d, d_index) => {\n      if (d.isHidden) return \"\";\n\n      let isPersistent = d.isPersistent;\n      str += `<div class=\"input-list ${isPersistent ? \"persistent\" : \"\"}\">`;\n      str += dates\n        .map((date) => {\n          let value = \"\";\n          let isFuture = dateUtils.isFuture(date);\n          let isToday = dateUtils.isToday(date);\n\n          if (d.data) {\n            let dataFounded = d.data.find((dataInput) => {\n              return dateUtils.isSameDate(new Date(dataInput.date), date);\n            });\n            if (dataFounded) {\n              value = dataFounded.value || \"\";\n            }\n          }\n\n          if (\n            d.editable === false ||\n            (isFuture && d.editableFuture == false) ||\n            (isToday && d.editableToday == false)\n          ) {\n            return `<div>\n                      <span date=\"${date}\" \n                            index=\"${d_index}\" \n                            class=\"${date.varName} ${\n                              d.color ? \"c-\" + d.color + \"--text\" : \"\"\n                            }\" > \n                            ${value} \n                            </span>\n                    </div>`;\n          }\n\n          let isDisabled = false;\n          if (config.timeline.editable === false) {\n            isDisabled = true;\n          }\n\n          return `<div class=\"dia-input\">\n                  <input \n                  date=\"${date}\" \n                  index=\"${d_index}\" \n                  class=\"header-input \n                  ${date.varName} ${d.color ? \"c-\" + d.color + \"--text\" : \"\"}\" \n                  type=\"number\"\n                  ${isDisabled ? \"disabled\" : \"\"} \n                  value=\"${value}\">\n                </div>`;\n        })\n        .join(\"\");\n      str += `</div>`;\n    });\n\n    str += `</div>`;\n\n    let r = dom.createElementFromHTML(str);\n\n    r.querySelectorAll(\"input.header-input\").forEach((input) => {\n      input.addEventListener(\"input\", (e) => {\n        let date = e.currentTarget.getAttribute(\"date\");\n        let index = e.currentTarget.getAttribute(\"index\");\n        let value = e.currentTarget.value;\n        let typeData = config.timeline.header.extend.data[index];\n\n        //refresh config value\n        let data = typeData.data.find((d) =>\n          dateUtils.isSameDate(new Date(d.date), new Date(date))\n        );\n        data.value = value;\n\n        r.dispatchEvent(\n          new CustomEvent(\"changeInputHeader\", {\n            bubbles: true,\n            cancelable: false,\n            detail: {\n              date: date,\n              typeData: typeData,\n              value: value\n            }\n          })\n        );\n      });\n    });\n\n    return r;\n  },\n\n  /**\n   * Crear Sidebar Izquierdo\n   *    - Maneja items como arbol de 2 niveles (parent, children)\n   *    - El sidebar se divide en navList - InitialNav - extendedNav - BtnNav\n   *    - Se agrega itemDetail, para detalles de items\n   *\n   *\n   * TODO: para evitar incrustar las ids en los inputs, se deben crear\n   * los nodos uno por uno como elemento DOM, y agregarles los eventos directamente\n   * ahora se hace seleccionando todos los inputs con querySelectorAll\n   *\n   * @param {Object} config - Configuracion capibara\n   * @return {Object} Elemento Dom Sidebar Izquierdo\n   */\n  createNavLeft(config, tab = null) {\n    let $elem = dom.createElement(\"nav\", { className: \"left\" });\n    return this.redrawNavLeft($elem, config, tab);\n  },\n\n  /**\n   * Recrea Sidebar izquierdo, usado para redibujar\n   * Utiliza $elem como elemento dom donde recrearlo\n   *\n   *\n   * @param {Object} $elem - Elemento Dom donde crea el sidebar izquierdo\n   * @param {Object} config - Configuracion capibara\n   * @return {Object} Elemento Dom navLeft\n   */\n\n  redrawNavLeft($elem, config, tab = null) {\n    let navList = \"\";\n    let initialNavList = \"\";\n    let exNavList = \"\";\n    let btnNavList = \"\";\n    let isDisabled = false;\n    if (config.timeline.editable === false) {\n      isDisabled = true;\n    }\n\n    config.data.forEach((d) => {\n      if (d.isHidden) return;\n\n      navList += `\n       <div class=\"nav-item\">\n\n\n        <div class=\"nav-item-container parent\">`;\n\n      if (d.children) {\n        navList += `<button class=\"tree-icon ${\n          d.isClosed ? \"\" : \"cap-rotate\"\n        }\" item-id=\"${d.id || -1}\" type-node=\"${d.type || \"\"}\" >\n        ${icons.chevronDown}\n                       </button>`;\n      }\n\n      navList += `\n          <div class=\"item-title truncate full-width ${\n            d.clickeable ? \"clickeable\" : \"\"\n          }\n                      ${d.navOver ? \"hoverable\" : \"\"} \" item-id=\"${\n                        d.id || -1\n                      }\" type-node=\"${d.type || \"\"}\" >\n            ${d.label}\n          </div>\n        </div>`;\n\n      if (d.children) {\n        navList += `\n              <div class=\"children-items ${\n                d.isClosed ? \"hide\" : \"\"\n              } \" child-list=\"${d.id || -1}\">`;\n\n        d.children.forEach((c) => {\n          if (c.isHidden) return;\n\n          navList += `\n                <div class=\"child-nav-item\">\n                  <div class=\"nav-item-container\">\n                    `;\n\n          /*\n                    <span class=\"nav-item-icon\">\n                      <svg style=\"width:24px;height:24px\" viewBox=\"0 0 24 24\">\n                          <path fill=\"currentColor\" d=\"M19,15L13,21L11.58,19.58L15.17,16H4V4H6V14H15.17L11.58,10.42L13,9L19,15Z\" />\n                      </svg>\n                    </span>\n                      */\n\n          navList += `\n                    ${\n                      c.light\n                        ? '<span class=\"light ' +\n                          (c.light ? c.light + \"-light\" : \"\") +\n                          '\"></span>'\n                        : \"\"\n                    }\n\n                    <div class=\"item-title ${c.clickeable ? \"clickeable\" : \"\"}\n                      ${c.navOver ? \"hoverable\" : \"\"}\" item-id=\"${\n                        c.id || -1\n                      }\" type-node=\"${c.type || \"\"}\">\n                      <div class=\"truncate\">\n                        ${c.label}\n                      </div>\n                    </div>\n                  </div>\n                </div>`;\n        });\n\n        navList += `\n              </div>`;\n      }\n\n      navList += `</div>`;\n\n      //initial\n      initialNavList += `<div class=\"initial-nav-item parent\">`;\n      if (d.withNav) {\n        config.timeline.nav.left.initial.vars.forEach((v) => {\n          let value = utils.getVarByPath(d.values, v.varName);\n\n          if (v.round && !isNaN(value)) {\n            value = utils.round(value, v.round);\n          }\n          if (v.input) {\n            switch (v.input) {\n              case \"hour\":\n                value = value.split(\":\");\n                let hhValue = value[0];\n                let mmValue = value[1];\n                initialNavList += `\n                            <div class=\"item-col has-input\">\n                              <div class=\"hour-input\">\n                                <input type=\"number\"\n                                      input-type=\"time\"\n                                      max=\"23\"\n                                      min=\"00\"\n                                      input-key=\"${v.key || \"\"}\"\n                                      item-id=\"${d.id || -1}\"\n                                      type-node=\"${d.type || \"\"}\"\n                                      value=\"${hhValue}\"\n                                      ${isDisabled ? \"disabled\" : \"\"}\n                                      class=\"hh\">\n                                <span>:</span>\n                                <input type=\"number\"\n                                      input-type=\"time\"\n                                      max=\"59\"\n                                      min=\"00\"\n                                      input-key=\"${v.key || \"\"}\"\n                                      item-id=\"${d.id || -1}\"\n                                      type-node=\"${d.type || \"\"}\"\n                                      value=\"${mmValue}\"\n                                      ${isDisabled ? \"disabled\" : \"\"}\n                                      class=\"mm\">\n                              </div>\n                            </div>`;\n                break;\n              case \"text\":\n              case \"number\":\n              default:\n                initialNavList += `\n                            <div class=\"item-col has-input\">\n                              <input  \n                                      type=\"${v.input || \"text\"}\"\n                                      input-type=\"${v.input || \"text\"}\"\n                                      input-key=\"${v.key || \"\"}\"\n                                      item-id=\"${d.id || -1}\"\n                                      type-node=\"${d.type || \"\"}\"\n                                      ${isDisabled ? \"disabled\" : \"\"}\n                                      value=\"${value}\"/>\n                            </div>`;\n            }\n          } else {\n            initialNavList += `\n                          <div class=\"item-col\">\n                            ${value}\n                          </div>`;\n          }\n        });\n      }\n\n      initialNavList += `\n                  </div>`;\n\n      if (d.children) {\n        d.children.forEach((c) => {\n          if (c.isHidden) return;\n          initialNavList += `<div class=\"child-initial-nav-item ${\n            d.isClosed ? \"hide\" : \"\"\n          }\" child=\"${d.id || -1}\">`;\n\n          if (c.withNav !== false) {\n            config.timeline.nav.left.initial.vars.forEach((v) => {\n              if (v.onlyTab && tab && v.onlyTab !== tab.key) return;\n\n              let value = utils.getVarByPath(c.values, v.varName);\n              if (v.round && !isNaN(value)) {\n                value = utils.round(value, v.round);\n              }\n              if (v.input) {\n                switch (v.input) {\n                  case \"hour\":\n                    value = value.split(\":\");\n                    let hhValue = value[0];\n                    let mmValue = value[1];\n                    initialNavList += `\n                                  <div class=\"item-col has-input\">\n                                    <div class=\"hour-input\">\n                                      <input type=\"number\"\n                                            input-type=\"time\"\n                                            max=\"23\"\n                                            min=\"00\"\n                                            input-key=\"${v.key || \"\"}\"\n                                            item-id=\"${c.id || -1}\"\n                                            type-node=\"${c.type || \"\"}\"\n                                            value=\"${hhValue}\"\n                                            ${isDisabled ? \"disabled\" : \"\"}\n                                            class=\"hh\">\n                                      <span>:</span>\n                                      <input type=\"number\"\n                                            input-type=\"time\"\n                                            max=\"59\"\n                                            min=\"00\"\n                                            input-key=\"${v.key || \"\"}\"\n                                            item-id=\"${c.id || -1}\"\n                                            type-node=\"${c.type || \"\"}\"\n                                            value=\"${mmValue}\"\n                                            ${isDisabled ? \"disabled\" : \"\"}\n                                            class=\"mm\">\n                                    </div>\n                                  </div>`;\n                    break;\n                  case \"text\":\n                  case \"number\":\n                  default:\n                    initialNavList += `\n                                  <div class=\"item-col has-input\">\n                                    <input\n                                            type=\"${v.input || \"text\"}\"\n                                            input-type=\"${v.input || \"text\"}\"\n                                            input-key=\"${v.key || \"\"}\"\n                                            item-id=\"${c.id || -1}\"\n                                            type-node=\"${c.type || \"\"}\"\n                                            ${isDisabled ? \"disabled\" : \"\"}\n                                            value=\"${value}\"/>\n                                  </div>`;\n                }\n              } else {\n                initialNavList += `\n                                <div class=\"item-col\">\n                                  ${value}\n                                </div>`;\n              }\n            });\n          }\n          initialNavList += `\n                      </div>`;\n        });\n      }\n\n      //Ext\n      exNavList += `<div class=\"ex-nav-item parent\">`;\n      if (d.withExNav) {\n        config.timeline.nav.left.extend.vars.forEach((v) => {\n          let value = utils.getVarByPath(d.values, v.varName);\n          if (v.round && !isNaN(value)) {\n            value = utils.round(value, v.round);\n          }\n          if (v.input) {\n            switch (v.input) {\n              case \"hour\":\n                value = value.split(\":\");\n                let hhValue = value[0];\n                let mmValue = value[1];\n                exNavList += `\n                            <div class=\"item-col has-input\">\n                              <div class=\"hour-input\">\n                                <input type=\"number\"\n                                      input-type=\"time\"\n                                      max=\"23\"\n                                      min=\"0\"\n                                      input-key=\"${v.key || \"\"}\"\n                                      item-id=\"${d.id || -1}\"\n                                      type-node=\"${d.type || \"\"}\"\n                                      value=\"${hhValue}\"\n                                      ${isDisabled ? \"disabled\" : \"\"}\n                                      class=\"hh\">\n                                <span>:</span>\n                                <input type=\"number\"\n                                      input-type=\"time\"\n                                      max=\"59\"\n                                      min=\"0\"\n                                      input-key=\"${v.key || \"\"}\"\n                                      item-id=\"${d.id || -1}\"\n                                      type-node=\"${d.type || \"\"}\"\n                                      value=\"${mmValue}\"\n                                      ${isDisabled ? \"disabled\" : \"\"}\n                                      class=\"mm\">\n                              </div>\n                            </div>`;\n                break;\n              case \"text\":\n              case \"number\":\n              default:\n                exNavList += `\n                            <div class=\"item-col has-input\">\n                              <input\n                                      type=\"${v.input || \"text\"}\"\n                                      input-type=\"${v.input || \"text\"}\"\n                                      input-key=\"${v.key || \"\"}\"\n                                      item-id=\"${d.id || -1}\"\n                                      type-node=\"${d.type || \"\"}\"\n                                      ${isDisabled ? \"disabled\" : \"\"}\n                                      value=\"${value}\"/>\n                            </div>`;\n            }\n          } else {\n            exNavList += `\n                          <div class=\"item-col\">\n                            ${value}\n                          </div>`;\n          }\n        });\n      }\n\n      exNavList += `\n                  </div>`;\n\n      if (d.children) {\n        d.children.forEach((c) => {\n          if (c.isHidden) return;\n          exNavList += `<div class=\"child-ex-nav-item ${\n            d.isClosed ? \"hide\" : \"\"\n          }\" child=\"${d.id || -1}\">`;\n\n          if (c.withNav !== false) {\n            config.timeline.nav.left.extend.vars.forEach((v) => {\n              if (v.onlyTab && tab && v.onlyTab !== tab.key) return;\n\n              let value = utils.getVarByPath(c.values, v.varName);\n              if (v.round && !isNaN(value)) {\n                value = utils.round(value, v.round);\n              }\n\n              if (v.input) {\n                switch (v.input) {\n                  case \"hour\":\n                    value = value ? value.split(\":\") : [0, 0];\n                    let hhValue = value[0];\n                    let mmValue = value[1];\n                    exNavList += `\n                                  <div class=\"item-col has-input\">\n                                    <div class=\"hour-input\">\n                                      <input type=\"number\"\n                                            input-type=\"time\"\n                                            max=\"23\"\n                                            min=\"0\"\n                                            input-key=\"${v.key || \"\"}\"\n                                            item-id=\"${c.id || -1}\"\n                                            type-node=\"${c.type || \"\"}\"\n                                            value=\"${hhValue}\"\n                                            ${isDisabled ? \"disabled\" : \"\"}\n                                            class=\"hh\">\n                                      <span>:</span>\n                                      <input type=\"number\"\n                                            input-type=\"time\"\n                                            max=\"59\"\n                                            min=\"0\"\n                                            input-key=\"${v.key || \"\"}\"\n                                            item-id=\"${c.id || -1}\"\n                                            type-node=\"${c.type || \"\"}\"\n                                            value=\"${mmValue}\"\n                                            ${isDisabled ? \"disabled\" : \"\"}\n                                            class=\"mm\">\n                                    </div>\n                                  </div>`;\n                    break;\n                  case \"text\":\n                  case \"number\":\n                  default:\n                    exNavList += `\n                                  <div class=\"item-col has-input\">\n                                    <input  \n                                            type=\"${v.input || \"text\"}\"\n                                            input-type=\"${v.input || \"text\"}\"\n                                            input-key=\"${v.key || \"\"}\"\n                                            item-id=\"${c.id || -1}\"\n                                            type-node=\"${c.type || \"\"}\"\n                                            ${isDisabled ? \"disabled\" : \"\"}\n                                            value=\"${value}\"/>\n                                  </div>`;\n                }\n              } else {\n                exNavList += `\n                                <div class=\"item-col\">\n                                  ${value}\n                                </div>`;\n              }\n            });\n          }\n          exNavList += `\n                      </div>`;\n        });\n      }\n\n      //buttons\n      btnNavList += `<div class=\"cap-btn-nav-item parent\">\n                        <div class=\"cap-btn-nav-item-content\">`;\n      if (\n        config.timeline.nav.left.buttons &&\n        config.timeline.nav.left.buttons.vars\n      ) {\n        config.timeline.nav.left.buttons.vars.forEach((btn) => {\n          if (d.withBtnNav) {\n            let btnContent = \"\";\n            let className = btn.className || \"\";\n\n            if (btn.icon) {\n              btnContent = btn.icon ? btn.icon : \"\";\n            }\n\n            if (btn.iconFormatter) {\n              btnContent = btn.iconFormatter ? btn.iconFormatter(d, btn) : \"\";\n            }\n\n            if (btn.shape) {\n              className += \" cap-btn-\" + btn.shape;\n              btnContent += `<span> ${\n                btn.formatter ? btn.formatter(d, btn) : \"\"\n              } </span> `;\n            }\n            if (btn.btnClassNameFormatter) {\n              let newClassName = btn.btnClassNameFormatter(d, btn);\n              if (newClassName) {\n                className += \" \" + newClassName;\n              }\n            }\n\n            btnNavList += `\n                    <button class=\"cap-btn-shape ${className}\"\n                            input-key=\"${btn.key || \"\"}\"\n                            item-id=\"${d.id || -1}\"\n                            ${isDisabled ? \"disabled\" : \"\"}\n                            type-node=\"${d.type || \"\"}\">\n                            ${btnContent}\n                    </button>`;\n          }\n        });\n      }\n      btnNavList += `\n                      </div>\n                    </div>`;\n\n      if (d.children) {\n        d.children.forEach((c) => {\n          if (c.isHidden) return;\n\n          //buttons\n          btnNavList += `<div class=\"cap-btn-child-nav-item parent ${\n            d.isClosed ? \"hide\" : \"\"\n          }\" child=\"${d.id || -1}\">\n                            <div class=\"cap-btn-nav-item-content\">`;\n\n          if (\n            config.timeline.nav.left.buttons &&\n            config.timeline.nav.left.buttons.vars\n          ) {\n            config.timeline.nav.left.buttons.vars.forEach((btn) => {\n              if (c.withNav !== false) {\n                let btnContent = \"\";\n                let className = btn.className || \"\";\n\n                if (btn.icon) {\n                  btnContent = btn.icon ? btn.icon : \"\";\n                }\n\n                if (btn.iconFormatter) {\n                  btnContent = btn.iconFormatter\n                    ? btn.iconFormatter(c, btn)\n                    : \"\";\n                }\n\n                if (btn.shape) {\n                  className += \" cap-btn-\" + btn.shape;\n                  btnContent += `<span> ${\n                    btn.formatter ? btn.formatter(c, btn) : \"\"\n                  } </span> `;\n                }\n                if (btn.btnClassNameFormatter) {\n                  let newClassName = btn.btnClassNameFormatter(c, btn);\n                  if (newClassName) {\n                    className += \" \" + newClassName;\n                  }\n                }\n\n                btnNavList += `\n                      <button class=\"cap-btn-shape ${className}\"\n                              input-key=\"${btn.key || \"\"}\"\n                              item-id=\"${c.id || -1}\"\n                              ${isDisabled ? \"disabled\" : \"\"}\n                              type-node=\"${c.type || \"\"}\">\n                              ${btnContent}\n                      </button>`;\n              }\n            });\n          }\n\n          btnNavList += `\n                          </div>\n                        </div>`;\n        });\n      }\n    });\n\n    let itemDetail = ` <div class=\"detail-nav-item hide\">\n                          ${this.getDetailNavItemContent()}\n                        </div>`;\n\n    let str = `<div class=\"nav-container\">\n                      ${itemDetail}\n                    <div class=\"nav-item-list\">\n                      ${navList}\n                    </div>\n                    <div class=\"initial-nav-list\">\n                      ${initialNavList}\n                    </div>\n                    <div class=\"extend-nav-list\">\n                      ${exNavList}\n                    </div>\n                    <div class=\"cap-btn-nav-list\">\n                      ${btnNavList}\n                    </div>\n                  </div>`;\n\n    let navContainer = dom.createElementFromHTML(str);\n    $elem.innerHTML = \"\";\n    $elem.append(navContainer);\n\n    //detalle de nav-item\n    $elem.querySelectorAll(\".item-title.hoverable\").forEach((i) => {\n      i.addEventListener(\"mouseover\", (e) => {\n        let pos = utils.eventToPositionNavLeft(config, e, $elem);\n        let itemId = i.getAttribute(\"item-id\");\n        let item = utils.getItemById(config, itemId);\n        let typeNode = i.getAttribute(\"type-node\");\n        i.dispatchEvent(\n          new CustomEvent(\"overNavItem\", {\n            bubbles: true,\n            cancelable: false,\n            detail: {\n              originalEvt: e,\n              item: item,\n              type: typeNode,\n              pos: pos\n            }\n          })\n        );\n      });\n    });\n\n    //oculta detalle de nav-item, al salir del nav-item-list\n    $elem.querySelectorAll(\".nav-item-list\").forEach((i) => {\n      i.addEventListener(\"mouseleave\", (e) => {\n        i.dispatchEvent(\n          new CustomEvent(\"leaveNavItem\", {\n            bubbles: true,\n            cancelable: false\n          })\n        );\n      });\n    });\n\n    //oculta detalle de nav-item-list, al salir de nav-item\n    $elem.querySelectorAll(\".item-title:not(.hoverable)\").forEach((i) => {\n      i.addEventListener(\"mousemove\", (e) => {\n        i.dispatchEvent(\n          new CustomEvent(\"leaveNavItem\", {\n            bubbles: true,\n            cancelable: false\n          })\n        );\n      });\n    });\n\n    $elem.querySelectorAll(\".item-title.clickeable\").forEach((i) => {\n      i.addEventListener(\"click\", (e) => {\n        let itemId = i.getAttribute(\"item-id\");\n        let typeNode = i.getAttribute(\"type-node\");\n        let value = i.value;\n        i.dispatchEvent(\n          new CustomEvent(\"clickNavLeftItem\", {\n            bubbles: true,\n            cancelable: false,\n            detail: {\n              itemId: itemId,\n              type: typeNode,\n              value: value\n            }\n          })\n        );\n      });\n    });\n\n    $elem.querySelectorAll(\"input\").forEach((i) => {\n      i.addEventListener(\"change\", (e) => {\n        let inputType = i.getAttribute(\"input-type\");\n        let key = i.getAttribute(\"input-key\");\n        let itemId = i.getAttribute(\"item-id\");\n        let typeNode = i.getAttribute(\"type-node\");\n        let item = utils.getItemById(config, itemId);\n        let value = i.value;\n        if (inputType == \"time\") {\n          let hh_input = i.parentElement.querySelector(\"input.hh\").value;\n          let mm_input = i.parentElement.querySelector(\"input.mm\").value;\n          mm_input = mm_input < 10 ? \"0\" + parseFloat(mm_input) : mm_input;\n          i.parentElement.querySelector(\"input.mm\").value = mm_input;\n          value = hh_input + \":\" + mm_input;\n        }\n        i.dispatchEvent(\n          new CustomEvent(\"saveNavLeftInput\", {\n            bubbles: true,\n            cancelable: false,\n            detail: {\n              key: key,\n              itemId: itemId,\n              item: item,\n              type: typeNode,\n              value: value,\n              tabSelected: tab\n            }\n          })\n        );\n      });\n    });\n\n    $elem.querySelectorAll(\"button.cap-btn-shape\").forEach((i) => {\n      i.addEventListener(\"click\", (e) => {\n        let key = i.getAttribute(\"input-key\");\n        let itemId = i.getAttribute(\"item-id\");\n        let typeNode = i.getAttribute(\"type-node\");\n        i.dispatchEvent(\n          new CustomEvent(\"clickNavLeftButton\", {\n            bubbles: true,\n            cancelable: false,\n            detail: {\n              key: key,\n              itemId: itemId,\n              type: typeNode\n            }\n          })\n        );\n      });\n    });\n\n    $elem.querySelectorAll(\"button.tree-icon\").forEach((i) => {\n      i.addEventListener(\"click\", (e) => {\n        let itemId = i.getAttribute(\"item-id\");\n        let typeNode = i.getAttribute(\"type-node\");\n        let dataConfig = config.data.find((d) => d.id == itemId);\n\n        let $navItem = e.currentTarget.closest(\".nav-item\");\n        let $children = $navItem.querySelector(\".children-items\");\n        let itemsToHide = e.currentTarget\n          .closest(\"nav.left\")\n          .querySelectorAll(\n            \"[child='\" + itemId + \"'], [child-list='\" + itemId + \"']\"\n          );\n\n        if ($children) {\n          if ($children.classList.contains(\"hide\")) {\n            e.currentTarget.classList.add(\"cap-rotate\");\n            itemsToHide.forEach((i) => i.classList.remove(\"hide\"));\n            dataConfig.isClosed = false;\n          } else {\n            e.currentTarget.classList.remove(\"cap-rotate\");\n            itemsToHide.forEach((i) => i.classList.add(\"hide\"));\n            dataConfig.isClosed = true;\n          }\n        }\n\n        i.dispatchEvent(\n          new CustomEvent(\"clickNavLeftTreeIcon\", {\n            bubbles: true,\n            cancelable: false,\n            detail: {\n              itemId: itemId,\n              type: typeNode\n            }\n          })\n        );\n\n        //e.currentTarget.parent\n      });\n    });\n\n    return $elem;\n  },\n\n  /**\n   * Crea Html como String, para el detalle de items en el Sidebar Izquierdo\n   *\n   * @param {Object} [item={}] - Configuracion de item\n   * @return {String} Html de ventana de detalle\n   */\n  getDetailNavItemContent(item = {}) {\n    if (item.navOver == undefined) item.navOver = {};\n\n    return `\n                    <div class=\"header-detail\">\n                      <div class=\"detail-title truncate\">\n                        ${item.label || \"\"}\n                      </div>\n                      <div class=\"detail-subtitle\">\n                        ${item.navOver.subtitle || \"\"}\n                      </div>\n                      <div class=\"header-chip ${\n                        item.light ? item.light + \"-light\" : \"\"\n                      }  ${item.navOver.chip ? \"\" : \"hide\"}\">\n                        ${item.navOver.chip || \"\"}\n                      </div>\n                    </div>\n\n                    <div class=\"detail-container\">\n                      ${item.navOver.content || \"\"}\n                    </div>`;\n  },\n\n  /**\n   * Crea Sidebar Derecho\n   * Usado principalmente para formulario de ingreso de datos para los dias\n   * seleccionados\n   *\n   * @param {Object} config - Configuracion capibara\n   * @param {Object} tab - Tab de referencia, para la creacion del formulario\n   * @return {Object} {element, inputs}, element es el elemento Dom del sidebar,\n   *                  inputs es un array de elementos Dom de cada input creado\n   *                  (no son elementos html de tipo input)\n   */\n  createNavRight(config, tab = null) {\n    var $elem = dom.createElement(\"nav\", { className: \"right\" });\n    return this.redrawNavRight(config, $elem, tab, []);\n  },\n\n  /**\n   * Recrea Sidebar Derecho\n   * Utiliza $elem como elemento dom donde recrearlo\n   *\n   * @param {Object} config - Configuracion capibara\n   * @param {Object} $elem - Elemento Dom donde crea el sidebar derecho\n   * @param {Object} tab - Tab de referencia, para la creacion del formulario\n   * @param {Object} dataDay - datos del dia seleccionando, para autorrelleno de formulario\n   * @param {Object} daySelected - datos del dia seleccionado\n   * @param {String} daySelected.date - fecha del dia seleccionado\n   * @param {Object} daySelected.item - Item de Sidebar relacionado al dia seleccionado\n   * @param {Object} daySelected.pos - posicion de dia seleccionado\n   * @return {Object} Elemento Dom Sidebar Derecho\n   */\n  redrawNavRight(\n    config,\n    $elem,\n    selected = null,\n    tab = null,\n    dataDay = null,\n    daySelected = null\n  ) {\n    let $navRight = $elem; //dom.createElement(\"nav\",{className:\"right\"});\n    let $divContainer = dom.createElement(\"div\", {\n      className: \"nav-input-container\"\n    });\n    let $inputs = [];\n    let checkboxInputs = [];\n    let inputsWithReload = [];\n    let tabSelected = tab;\n    selected = selected || [daySelected];\n\n    if (tabSelected && tabSelected.inputs) {\n      tabSelected.inputs.forEach((i) => {\n        if (i.disabled) return;\n\n        let $input = this.createInput(i, dataDay, daySelected, selected);\n        if ($input) {\n          $divContainer.appendChild($input);\n          $inputs.push($input);\n\n          if (i.type == \"checkbox\") {\n            checkboxInputs.push($input);\n          }\n\n          if (i.reloadOnSelect != null) {\n            inputsWithReload.push({ $input, config: i });\n          }\n        }\n      });\n    }\n\n    //manejo de eventos para inputs con showIf\n    if (checkboxInputs) {\n      checkboxInputs.forEach(($c) => {\n        //obtiene key de checkbox\n        let key = $c.getAttribute(\"input-key\");\n        let props = tabSelected.inputs.find((i) => {\n          return i.key == key;\n        });\n\n        let isChecked = false;\n        if (dataDay) {\n          isChecked = utils.getVarByPath(dataDay, props.varName);\n        }\n\n        //obtiene inputs relacionados desde config para mostrar/ocultar\n        let inputsToHide = tabSelected.inputs.filter((i) => {\n          return i.showIf && i.showIf == key;\n        });\n        let inputsToHideKeys = inputsToHide.map((i) => i.key);\n\n        //obtiene inputs del dom, filtrando con inputsToHide\n        let $inputsHidden = $inputs.filter(($i) => {\n          let inputKey = $i.getAttribute(\"input-key\");\n          return inputsToHideKeys.indexOf(inputKey) > -1;\n        });\n\n        //si hay inputs,\n        if ($inputsHidden) {\n          if (!isChecked) {\n            $inputsHidden.forEach(($i) => {\n              $i.classList.add(\"hide\");\n            });\n          }\n          $c.addEventListener(\"input\", (e) => {\n            $inputsHidden.forEach(($i) => {\n              let fn = $c.querySelector(\"input[type='checkbox']\").checked\n                ? \"remove\"\n                : \"add\";\n              $i.classList[fn](\"hide\");\n            });\n          });\n        }\n      });\n    }\n\n    let saveCancelBtns = this.createNavRightbuttons();\n    $divContainer.appendChild(saveCancelBtns);\n    $navRight.innerHTML = \"\";\n    $navRight.appendChild($divContainer);\n\n    return {\n      element: $navRight,\n      inputs: $inputs,\n      inputsWithReload,\n      saveCancelBtns\n    };\n  },\n\n  /**\n   * Crea Corner inferior izquierdo, como titulo para footer\n   *\n   * @param {Object} config - Configuracion capibara\n   * @return {Object} Elemento Dom Corner Footer\n   */\n  createCornerFooter(config) {\n    if (\n      config.timeline.footer === undefined ||\n      config.timeline.footer.enabled == false\n    )\n      return null;\n    let str = \"\";\n\n    if (config.timeline.footer) {\n      str += `<div class=\"corner-footer\">\n          <div class=\"corner-title\">\n            <span>\n              ${config.timeline.footer.label}\n            </span>\n          </div>\n        </div>`;\n    }\n    return dom.createElementFromHTML(str);\n  },\n\n  /**\n   * Crea Footer para planilla\n   * Inicialmente creado para totales\n   *\n   * @param {Object} config - Configuracion capibara\n   * @return {Object} Elemento Dom Corner Footer\n   */\n  createFooter(config) {\n    if (\n      config.timeline.footer === undefined ||\n      config.timeline.footer.enabled == false\n    )\n      return null;\n\n    let str = `\n        <footer>\n          <div class=\"footer-container\">\n          `;\n    config.timeline.footer.data.forEach((d) => {\n      str += `\n              <div class=\"footer-item\">${d.value}</div>\n            `;\n    });\n    str += `\n          </div>\n        </footer>\n        `;\n\n    return dom.createElementFromHTML(str);\n  },\n\n  /**\n   * Crea Footer para planilla\n   * Inicialmente creado para totales\n   *\n   * @param {Object} config - Configuracion capibara\n   * @param {Object[]} selected - array de objetos, de dias seleccionados\n   * @return {Object} Elemento Dom Corner Footer\n   */\n  createSelectBoard(config, selected) {\n    let $elem = dom.createElement(\"div\", { className: \"select-container\" });\n    return this.redrawSelectBoard($elem, selected);\n  },\n\n  /**\n   * Crea linea vertical para fecha Actual\n   *\n   * @param {Object} config - Configuracion capibara\n   * @return {Object} Elemento Dom Corner Footer\n   */\n  createTodayLine(config) {\n    return this.redrawTodayLine(\n      config,\n      dom.createElement(\"div\", { className: \"today-line\" })\n    );\n  },\n\n  /**\n   * Recrea linea vertical para fecha Actual\n   * si el elemento $elem no es enviado, se crea un nuevo elemento\n   *\n   * Si el dia actual no esta dentro del rango de fechas del config,\n   * deshabilita la linea con la clase css .disable-line\n   *\n   * @param {Object} config - Configuracion capibara\n   * @param {Object} [$elem=null] - Elemento Dom donde recrea la linea, si es null, la crea\n   * @return {Object} Elemento Dom Corner Footer\n   */\n  redrawTodayLine(config, $elem = null) {\n    let endTime = new Date(config.timeline.end).getTime();\n    let todayTime = new Date().getTime();\n    let { height, dayWidth } = utils.getTableDimensions(config);\n\n    if ($elem == null)\n      $elem = dom.createElement(\"div\", { className: \"today-line\" });\n\n    if (endTime < todayTime) {\n      $elem.classList.add(\"disable-line\");\n    } else {\n      $elem.classList.remove(\"disable-line\");\n    }\n\n    let diffDays = Math.floor(\n      dateUtils.diffDays(\n        config.timeline.start,\n        dateUtils.formatDate(new Date())\n      )\n    );\n    let diff = diffDays * dayWidth;\n    diff += dayWidth / 2 - 2; // para centrar linea\n    Object.assign($elem.style, {\n      \"margin-left\": diff + \"px\",\n      height: height + \"px\"\n    });\n    return $elem;\n  },\n\n  /**\n   * Crea elemento FloatBox, que contiene los datos que se muestra en la tabla\n   *\n   * @param {Object} config - Configuracion capibara\n   * @param {Object} tab - Tab de referencia, para mostrar datos configurados por tab\n   * @return {Object} Elemento Dom Corner Footer\n   */\n  createFloatBox(config, tab) {\n    let $container = dom.createElement(\"div\", {\n      className: \"float-box-container\"\n    });\n    return this.redrawFloatBox(config, tab, $container);\n  },\n\n  /**\n   * Recrea elemento FloatBox, que contiene los datos que se muestra en la tabla\n   * Se usa principalmente para mostrar datos en la tabla de la planilla\n   * los muestra de manera flotante, calculando el Top y el Left segun la poscion\n   *\n   * Se consideran los elementos padres ocultos, para ocultar los datos\n   *\n   * Se insertan los elementos FloatBox, como elemento con datos de un item y dia especifico\n   *\n   *\n   * @param {Object} config - Configuracion capibara\n   * @param {Object} tab - Tab de referencia, para mostrar datos configurados por tab\n   * @return {Object} Elemento Dom Corner Footer\n   */\n  redrawFloatBox(config, tab, $container) {\n    $container.innerHTML = \"\";\n    //let tabSelected = tab || null;\n\n    config.data.forEach((de) => {\n      if (de.isHidden) return;\n      de.children.forEach((ds) => {\n        if (ds.isHidden) return;\n\n        ds.data.forEach((data) => {\n          if (\n            (!data.message || data.message.value == null) &&\n            (data.values == null ||\n              data.values == undefined ||\n              Object.entries(data.values).length === 0)\n          ) {\n            return null;\n          }\n\n          //children Data\n          let position = this.getPositionFloatBox(config, data, ds);\n\n          let className = \"\";\n\n          if (data.errors && data.errors.length > 0) {\n            className += \"has-errors \";\n          }\n\n          if (de.isClosed) {\n            className += \"hide \";\n          }\n\n          let msg = null;\n          if (tab.floaBox && tab.floatBox.messagePath) {\n            msg = utils.getVarByPath(data, tab.floatBox.messagePath);\n          }\n\n          if (msg || (data.message && data.message.value)) {\n            className += \"has-message \";\n          }\n\n          let str = `\n                <div class=\"float-box ${className} ${de.isClosed ? \"hide\" : \"\"}\"\n                     style=\"${position ? position : \"\"}\"\n                     item-id=\"${ds.id || -1}\"\n                     type-node=\"${ds.type || \"\"}\"> `;\n\n          let strExt = `\n                <div class=\"float-box-ext ${de.isClosed ? \"hide\" : \"\"}\"\n                      style=\"${position ? position : \"\"}\"\n                      item-id=\"${ds.id || -1}-ext\"\n                      type-node=\"${ds.type || \"\"}\">\n                  <div class=\"long-bar-container\">`;\n\n          if (tab && tab.floatBox) {\n            if (tab.floatBox.plots) {\n              str += `<div class=\"plot-floatbox-container\">`;\n              tab.floatBox.plots.forEach((n) => {\n                let cssVars = \"\";\n                let className = \"\";\n                if (utils.getVarByPath(data.values, n.varName) !== null) {\n                  if (n.color) {\n                    cssVars = `--local-color:${n.color};`;\n                  }\n\n                  className = n.className || \"\";\n\n                  str += `<div class=\"plot-floatbox ${className} ${\n                    n.style || \"\"\n                  }\" style=\"${cssVars} \"></div>`;\n                }\n              });\n              str += `\n                        </div>`;\n            }\n\n            //numeros en el floatBox\n            if (tab.floatBox.nums) {\n              tab.floatBox.nums.forEach((n) => {\n                if (tab.legends && n.tabKey) {\n                  let legend = tab.legends.find((l) => l.key == n.tabKey);\n                  if (legend && !legend.active) return;\n                }\n\n                let dataFloatBox = null;\n                let className = \"\";\n                let showIf = true;\n                let hideIf = false;\n                let colorClass = \"\";\n                let colorStyle = \"\";\n                let classNamesExt = \"\";\n                let colorStyleExt = \"\";\n                let cssVars = \"\";\n\n                if (n.varName) {\n                  dataFloatBox = utils.getVarByPath(data.values, n.varName);\n                }\n\n                if (n.varShow) {\n                  showIf = Boolean(utils.getVarByPath(data.values, n.varShow));\n                  dataFloatBox = dataFloatBox || \"\";\n                }\n\n                if (n.varHide) {\n                  hideIf = Boolean(utils.getVarByPath(data.values, n.varHide));\n                }\n\n                if (n.shape) {\n                  className += \"shape-\" + n.shape;\n                }\n\n                if (n.color) {\n                  if (utils.isHexColor(n.color)) {\n                    colorStyle = `--local-color: ${n.color};`;\n                  } else {\n                    colorClass = n.color;\n                  }\n                }\n\n                if (n.longBar) {\n                  if (n.longBarColor) {\n                    let longBarColor = utils.getVarByPath(\n                      data.values,\n                      n.longBarColor\n                    );\n                    let longBarOpacity =\n                      utils.getVarByPath(data.values, n.longBarOpacity) || null;\n                    if (longBarColor) {\n                      if (utils.isHexColor(longBarColor)) {\n                        colorStyleExt = `--local-color: ${longBarColor}; ${\n                          longBarOpacity\n                            ? \"--local-opacity: \" + longBarOpacity\n                            : \"\"\n                        }; `;\n                      } else {\n                        classNamesExt = longBarColor;\n                      }\n                    } else if (colorClass && colorClass != \"\") {\n                      classNamesExt = colorClass;\n                    } else if (colorStyle && colorStyle != \"\") {\n                      colorStyleExt = colorStyle;\n                    }\n                  }\n\n                  if(n.longBarClassName){\n                    classNamesExt += \" \" + n.longBarClassName;\n                  }\n\n                  let longBar = utils.getVarByPath(data.values, n.longBar);\n                  if (longBar) {\n                    cssVars = `--long:${longBar};`;\n                  }\n                }\n\n                if (dataFloatBox !== null && showIf && !hideIf) {\n                  str += `<span class=\"data ${colorClass} ${className}\" style=\"${colorStyle}\">\n                                ${\n                                  typeof dataFloatBox == \"string\"\n                                    ? dataFloatBox\n                                    : \"\"\n                                }\n                                ${\n                                  typeof dataFloatBox == \"number\"\n                                    ? utils.round(dataFloatBox, n.round)\n                                    : \"\"\n                                }\n                              </span>`;\n\n                  if (n.longBar && cssVars) {\n                    strExt += `<div class=\"long-bar ${classNamesExt}\" style=\"${colorStyleExt} ${cssVars} \"></div> `;\n                  }\n                }\n              });\n            }\n\n            //puntos en el floatBox\n            if (tab.floatBox.dots) {\n              str += `<div class=\"dot-container-middle\">`;\n              tab.floatBox.dots.forEach((dot) => {\n                if (utils.getVarByPath(data.values, dot.varName) !== null) {\n\n                  let className = \"\";\n                  let colorClass = \"\";\n                  let colorStyle = \"\";\n\n                  if (dot.shape) {\n                    className +=  dot.shape;\n                  }\n\n                  if (dot.color) {\n                    if (utils.isHexColor(dot.color)) {\n                      colorStyle = `--local-color: ${dot.color}`;\n                    } else {\n                      colorClass = dot.color;\n                    }\n                  }\n\n                  str += `\n                       <div class=\"dot ${colorClass} ${className}\" style=\"${colorStyle}\" ></div>`;\n\n                }\n              });\n              str += `\n                        </div>`;\n            }\n\n            //fila de puntos en floatBox\n            if (tab.floatBox.rowDots) {\n              tab.floatBox.rowDots.forEach((row) => {\n                let freeColumns = 4;\n                str += `<span class=\"rowdot--row \">`;\n\n                row.forEach((dot) => {\n                  if (tab.legends && dot.tabKey) {\n                    let legend = tab.legends.find((l) => l.key == dot.tabKey);\n                    if (legend && !legend.active) return;\n                  }\n\n                  let dataFloatBox = null;\n                  let className = \"\";\n                  let showIf = true;\n                  let hideIf = false;\n                  let colorClass = \"\";\n                  let colorStyle = \"\";\n\n                  if (dot.varName) {\n                    dataFloatBox = utils.getVarByPath(data.values, dot.varName);\n                    dataFloatBox = parseInt(dataFloatBox);\n                  }\n\n                  if (dot.varShow) {\n                    showIf = Boolean(\n                      utils.getVarByPath(data.values, dot.varShow)\n                    );\n                    dataFloatBox = dataFloatBox || \"\";\n                  }\n\n                  if (dot.varHide) {\n                    hideIf = Boolean(\n                      utils.getVarByPath(data.values, dot.varHide)\n                    );\n                  }\n\n                  if (dot.shape) {\n                    className += \" shape-\" + dot.shape;\n                  }\n\n                  if (dot.color) {\n                    if (utils.isHexColor(dot.color)) {\n                      colorStyle = `--local-color: ${dot.color}`;\n                    } else {\n                      colorClass = dot.color;\n                    }\n                  }\n\n                  if (\n                    dataFloatBox !== null &&\n                    dataFloatBox > 0 &&\n                    showIf &&\n                    !hideIf &&\n                    freeColumns > 0\n                  ) {\n                    let n =\n                      dataFloatBox > freeColumns ? freeColumns : dataFloatBox;\n                    freeColumns -= n;\n                    for (let index = 0; index < n; index++) {\n                      str += `<div class=\"rowdot--dot ${colorClass} ${className}\" style=\"${colorStyle}\"></div>`;\n                    }\n                  }\n                });\n\n                str += `</span>`;\n              });\n            }\n          }\n\n          str += `\n                </div>`;\n          strExt += `\n              </div>\n                </div>`;\n\n          let $elem = dom.createElementFromHTML(str);\n\n          let $elemExt = dom.createElementFromHTML(strExt);\n\n          $elem.addEventListener(\"mouseover\", (e) => {\n            $elem.dispatchEvent(\n              new CustomEvent(\"mouseOverFloatBox\", {\n                bubbles: true,\n                cancelable: false,\n                detail: {\n                  item: ds,\n                  data: data,\n                  originalEvt: e\n                }\n              })\n            );\n          });\n\n          $elem.addEventListener(\"click\", (e) => {\n            $elem.dispatchEvent(\n              new CustomEvent(\"clickFloatBox\", {\n                bubbles: true,\n                cancelable: false,\n                detail: {\n                  item: ds,\n                  data: data,\n                  originalEvt: e\n                }\n              })\n            );\n          });\n\n          $container.appendChild($elem);\n          $container.appendChild($elemExt);\n        });\n      });\n    });\n\n    return $container;\n  },\n\n  /**\n   * Crea DetailDay, detalle de valores de item y Dia\n   * se usa para:\n   *    - Muestra nombre de item y detalles\n   *    - Muestra capsulas de datos\n   *    - Muestra Pills, pildoras de datos resumidos\n   *    - Muestra alertas\n   *    - Muestra Mensaje\n   *\n   * @param {Object} config - Configuracion capibara\n   * @param {Object} item - Item relacionado\n   * @param {Object} dataDay - valores de item y Dia\n   * @param {Boolean} [onlyStringContent = false] - para escoger si devuelve String o DomElement\n   * @return {String|Object} Elemento como String o DomElement\n   */\n  createDetailDay(\n    config,\n    item = {},\n    dataDay,\n    tabSelected,\n    onlyStringContent = false\n  ) {\n    let str = `\n          <div class=\"header-detail\">\n            <div class=\"title truncate\">\n              ${item.label || \"\"}\n            </div>\n            <div class=\"subtitle\">\n              ${dataDay ? dateUtils.formatDateReadeable(dataDay.date) : \"\"}\n            </div>\n          </div>\n\n          <div class=\"list-detail list\">`;\n\n    //CAPSULES\n    if (dataDay) {\n      config.timeline.detailDay.capsules.forEach((cap) => {\n        //para comprobar si tiene datos, se obtiene el primer valor\n        //de la lista de values de una capsula\n        let hasValues =\n          cap.values.filter(\n            (v) => utils.getVarByPath(dataDay.values, v.varName) !== null\n          ).length > 0;\n        let hideIf = false;\n\n        if (cap.hideIf) {\n          hideIf = Boolean(utils.getVarByPath(dataDay.values, cap.hideIf));\n        }\n\n        let colorClass = \"\";\n        let colorStyle = \"\";\n\n        if (cap.color) {\n          if (utils.isHexColor(cap.color)) {\n            colorStyle = `--local-color: ${cap.color};`;\n            colorStyle += `--local-color-font: ${cap.color};`;\n          } else {\n            colorClass = cap.color;\n          }\n        }\n        if (hasValues && !hideIf) {\n          str += `\n              <div class=\"item-detail ${colorClass}\" style=\"${colorStyle}\">\n\n                <div class=\"left-icon ${cap.shape || \"\"} \"></div>\n\n                <div class=\"name\">\n                  <span>\n                    ${cap.title || \"\"}\n                  </span>\n                </div>`;\n\n          str += `\n          <div class=\"item-description\"> `;\n\n          cap.values.forEach((v) => {\n            let value = v.varName\n              ? utils.getVarByPath(dataDay.values, v.varName)\n              : null;\n\n            if (cap.isLabeledArray) {\n              value.forEach((valueLabeled) => {\n                let outputValue = null;\n                let valueName = v.valueName ? v.valueName : \"value\";\n\n                let tempValue = utils.getVarByPath(valueLabeled, valueName);\n\n                if (tempValue) {\n                  outputValue = v.round\n                    ? utils.round(tempValue, v.round)\n                    : tempValue;\n                }\n\n                if (v.formatter) {\n                  outputValue = v.formatter(valueLabeled);\n                }\n\n                if (typeof outputValue == \"number\") {\n                  outputValue = utils.formatNumber(outputValue);\n                }\n\n                str +=\n                  outputValue == null\n                    ? \"\"\n                    : `\n                      <div class=\"desc ${v.showColumn ? \"desc-column\" : \"\"}\">\n                        <div class=\"label\">\n                          ${v.hideLabel ? \"\" : valueLabeled.label}\n                        </div >\n                        <div class=\"val\">\n                          <span class=\"prefix\">\n                            ${v.prefix || \"\"}\n                          </span>\n                          <span class=\"value\">\n                            ${outputValue}\n                          </span>\n                          <span class=\"suffix\">\n                            ${valueLabeled.suffix || v.suffix || \"\"}\n                          </span>\n                        </div>\n                      </div>`;\n              });\n            } else {\n              let outputValue = v.round ? utils.round(value, v.round) : value;\n\n              if (v.formatter) {\n                outputValue = v.formatter({ options: v, dataDay, outputValue });\n              }\n\n              if (typeof outputValue == \"number\") {\n                outputValue = utils.formatNumber(outputValue);\n              }\n\n              str +=\n                outputValue == null\n                  ? \"\"\n                  : `\n                    <div class=\"desc\">\n                          <span class=\"prefix\">\n                            ${v.prefix || \"\"}\n                          </span>\n                          <span class=\"value\">\n                            ${outputValue}\n                          </span>\n                          <span class=\"suffix\">\n                            ${v.suffix || \"\"}\n                          </span>\n                    </div>`;\n            }\n          });\n\n          str += `\n                </div>`;\n\n          str += `\n              </div>`; // end .item-detail\n        }\n      });\n    }\n\n    str += `\n        </div>`; // list-detail\n\n    //PILLS\n    if (\n      config.timeline.detailDay.pillsVarName &&\n      dataDay &&\n      dataDay.values[config.timeline.detailDay.pillsVarName]\n    ) {\n      str += `\n          <div class=\"elements-detail\">\n            <div class=\"name\"> ${config.timeline.detailDay.pillsTitle} </div>\n            <div class=\"elements-list\">`;\n\n      dataDay.values[config.timeline.detailDay.pillsVarName].forEach((e) => {\n        let value = e.value;\n\n        if (typeof outputValue == \"number\") {\n          value = utils.formatNumber(value);\n        }\n\n        str += `\n            <div class=\"element-detail\">\n              <b>${e.label}</b>\n              ${value}\n            </div>`;\n      });\n\n      str += `\n            </div>\n            </div>`; //end .element-detail > .element-list\n    }\n\n    //str += `</div>`;\n\n    if (dataDay && dataDay.errors && dataDay.errors.length > 0) {\n      dataDay.errors.forEach((err) => {\n        str += `\n          <div class=\"alert\">\n            ${icons.alert}\n            ${err.label}\n          </div>`;\n      });\n    }\n\n    let msg = null;\n    let author = null;\n    let dateMsg = null;\n    if (dataDay && tabSelected.floatBox && tabSelected.floatBox.messagePath) {\n      msg = utils.getVarByPath(dataDay, tabSelected.floatBox.messagePath);\n    }\n\n    if (!msg && dataDay && dataDay.message && dataDay.message.value) {\n      msg = dataDay.message.value;\n      author = dataDay.message.author;\n      dateMsg = dateUtils.formatDateReadeable(new Date(dataDay.message.date));\n    }\n\n    if (msg) {\n      //msg = msg.replace(/(\\r\\n|\\r|\\n)/g, '<br>');\n      str += `\n          <div class=\"msj-container\">\n            <div class=\"msj\">\n            <pre>${msg || \"\"}</pre>\n            </div>\n            <div class=\"msj-detail\">\n              <span class=\"email\"> ${author || \"\"} </span>\n              <span class=\"date\"> ${dateMsg || \"\"} </span>\n            </div>\n        </div>`;\n    }\n\n    let strContainer = `<div class=\"detail-day dd-hide\"> ${str} </div>`;\n\n    if (onlyStringContent) return str;\n\n    return dom.createElementFromHTML(strContainer);\n  },\n\n  /**\n   * Recrea HTML de detailDay\n   *\n   * @param {Object} config - Configuracion capibara\n   * @param {Object} item - Item relacionado\n   * @param {Object} dataDay - valores de item y Dia\n   * @return {String} Elemento como String, de detailDay\n   */\n  redrawDetailDay(config, item, dataDay, tabSelected) {\n    return this.createDetailDay(config, item, dataDay, tabSelected, true);\n  },\n\n  /**\n   * Reposiciona FloatBox\n   * verifica si el parent esta desplegado, para ocultar los datos\n   *\n   * Solo actualiza las alturas de los floatbox\n   * no recrea los floatbox, es mas optimo\n   *\n   * @param {Object} config - Configuracion capibara\n   * @param {Object} item - Item relacionado\n   */\n  repositionFloatBox(config, $floatBoxContainer) {\n    $floatBoxContainer.querySelectorAll(\".float-box\").forEach(($f) => {\n      let itemId = $f.getAttribute(\"item-id\");\n      let itemHeight = parseFloat(\n        utils.getCSSVariable(config, \"--item-height\")\n      );\n      let item, parent;\n      ({ item, parent } = utils.getItemById(config, itemId, \"child\", true));\n      if (item) {\n        let top = utils.getPositionByItem(config, item);\n        $f.style.top = top * itemHeight + \"px\";\n        if (parent && parent.isClosed) {\n          $f.classList.add(\"hide\");\n        } else if ($f.classList.contains(\"hide\")) {\n          $f.classList.remove(\"hide\");\n        }\n      }\n    });\n  },\n\n  /**\n   * Recrea indicadores de dias seleccionados\n   *\n   * @param {Object} $elem - Elemento Dom donde crea los elementos seleccionados\n   * @param {Object[]} selected - Array con los dias seleccionados\n   * @return {Object} Elemento Dom que contiene los indicadores de dias seleccionados\n   */\n  redrawSelectBoard($elem, selected) {\n    $elem.innerHTML = \"\";\n    let hasNumber = true;\n\n    if (selected) {\n      if (selected.length == 1) hasNumber = false;\n\n      selected.forEach((s) => {\n        let attributes = [];\n\n        if (hasNumber) {\n          attributes.push({ name: \"cap-badge\", value: s.index });\n        }\n        let $s = dom.createElement(\"div\", {\n          className: \"selected-day\",\n          attributes\n        });\n        $s.style.left = s.pos.left + \"px\";\n        $s.style.top = s.pos.top + \"px\";\n        $elem.append($s);\n      });\n    }\n    return $elem;\n  },\n\n  /**\n   * Obtiene String con estilos CSS de la posicion de un floatBox\n   * calculado segun item y fecha de los valores\n   *\n   * @param {Object} config - Configuracion capibara, para ver fecha de inicio\n   * @param {Object} data - Datos del dia indicado\n   * @param {Object} item - Item relacionado\n   * @return {String} String CSS top y left , para posicionar floatBox en table\n   */\n  getPositionFloatBox(config, data, item) {\n    let left = dateUtils.diffDays(config.timeline.start, data.date);\n    let top = utils.getPositionByItem(config, item);\n    let dayWidth = parseFloat(utils.getCSSVariable(config, \"--day-width\"));\n    let itemHeight = parseFloat(utils.getCSSVariable(config, \"--item-height\"));\n    left *= dayWidth;\n    top *= itemHeight;\n    return \"top: \" + top + \".5px; left:\" + left + \".5px;\";\n  },\n\n  /**\n   * Crea Boton como elemento Dom\n   *\n   * @param {Object} props - propiedades para boton\n   * @param {String} props.className - classes css para boton\n   * @param {*} props.key - key para identificar a boton\n   * @param {String} props.label - Texto boton\n   * @return {Object} Elemento Dom del boton creado\n   */\n  createButton(props) {\n    return dom.createElementFromHTML(`\n            <button class=\"${props.className || \"\"}\" input-key=\"${\n              props.key || \"\"\n            }\">\n              ${props.label || \"\"}\n            </button>`);\n  },\n\n  /**\n   * Crea Botones de guardar y cancelar los datos de formulario del sidebar derecho\n   *\n   * @return {Object} Elemento Dom del botones creados\n   */\n  createNavRightbuttons() {\n    let saveBtn = this.createButton({\n      label: \"Guardar\",\n      className: \"cap-btn-raised\"\n    });\n    let cancelBtn = this.createButton({\n      label: \"Cancelar\",\n      className: \"cap-btn-outline\"\n    });\n    let btnSection = dom.createElementFromHTML(\n      `<div class=\"button-section\"></div>`\n    );\n    btnSection.appendChild(saveBtn);\n    btnSection.appendChild(cancelBtn);\n\n    saveBtn.addEventListener(\"click\", (e) => {\n      saveBtn.dispatchEvent(\n        new CustomEvent(\"saveMultiInput\", {\n          bubbles: true,\n          cancelable: false\n        })\n      );\n    });\n\n    cancelBtn.addEventListener(\"click\", (e) => {\n      cancelBtn.dispatchEvent(\n        new CustomEvent(\"cancelMultiInput\", {\n          bubbles: true,\n          cancelable: false\n        })\n      );\n    });\n\n    return btnSection;\n  },\n\n  /**\n   * Crea Input como elemento Dom\n   *\n   * @param {Object} props - config para Input\n   * @param {Object} [dataDay = null] - valores de item y Dia, opcional\n   * @param {Object} [daySelected = null] - datos del dia seleccionado\n   * @param {Object[]} [selected = []] - array de objetos, de dias seleccionados\n   * @return {Object} Elemento Dom del input creado\n   */\n  createInput(props, dataDay = null, daySelected = null, selected = []) {\n    let r = null;\n\n    if (props.ignoreRender == true) return r;\n\n    switch (props.type) {\n      case \"custom\":\n        r = props.render ? props.render({props, dataDay, daySelected, selected}) : null;\n        r.setAttribute(\"input-key\", props.key);\n        break;\n      case \"select\":\n        r = this.createInputSelect(props, dataDay, daySelected);\n        break;\n      case \"file\":\n        r = this.createInputFile(props, dataDay);\n        break;\n      case \"fileLink\":\n        r = this.createFileLink(props, dataDay);\n        break;\n      case \"text\":\n        r = this.createText(props, selected);\n        break;\n      case \"title\":\n        r = this.createTitle(props);\n        break;\n      case \"number\":\n        r = this.createInputNumber(props, dataDay);\n        break;\n      case \"float\":\n        r = this.createInputFloat(props, dataDay);\n        break;\n      case \"message\":\n        r = this.createInputMessage(props, dataDay);\n        break;\n      case \"textarea\":\n        r = this.createInputTextArea(props, dataDay);\n        break;\n      case \"checkbox\":\n        r = this.createInputCheckbox(props, dataDay);\n        break;\n      case \"inputList\":\n        r = this.createInputList(props, dataDay, daySelected);\n        break;\n      case \"input-box\":\n        r = this.createInputBox(props, dataDay);\n        break;\n      case \"list\":\n        r = this.createList(props, dataDay);\n        break;\n      case \"data-list\":\n        r = this.createDataList(props, dataDay, daySelected, selected);\n        break;\n      case \"button\":\n        r = this.createInputButton(props, dataDay);\n        break;\n      case \"buttons-group\":\n        r = this.createInputButtonsGroup(props, dataDay);\n        break;\n      case \"time\":\n        r = this.createInputTime(props, dataDay);\n        break;\n      case \"text\":\n      default:\n        r = this.createInputText(props, dataDay);\n    }\n\n    return r;\n  },\n\n  /**\n   * Crea Input con formato Hora, como elemento Dom\n   *\n   * Usa 2 inputs, hora y minutos\n   *\n   * el value que interpreta es String HH:MM\n   *\n   * @param {Object} props - config para Input\n   * @param {Object} [dataDay = null] - valores de item y Dia, opcional\n   * @return {Object} Elemento Dom del input creado\n   */\n  createInputTime(props, dataDay) {\n    let hhValue = \"\";\n    let mmValue = \"\";\n\n    if (dataDay && dataDay.values) {\n      let value = utils.getVarByPath(dataDay, props.varName);\n\n      if (value) {\n        value = value.split(\":\");\n        hhValue = value[0];\n        mmValue = value[1];\n      }\n    }\n\n    let $elem = dom.createElementFromHTML(`\n          <div class=\"input-section ${props.isHidden ? 'hide':''} \" input-key=\"${props.key || \"\"}\">\n            <span class=\"text-subtitle d-block\">\n              ${props.label || \"\"}\n            </span>\n            <div class=\"d-flex\">\n              <div class=\"time\">\n                <input type=\"number\"\n                      class=\"hour\"\n                      id=\"test\"\n                      placeholder=\"00\"\n                      min=\"0\"\n                      max=\"24\"\n                      value=\"${hhValue}\">\n                <span class=\"symbol\">:</span>\n                <input type=\"number\"\n                      class=\"minutes\"\n                      placeholder=\"00\"\n                      min=\"0\"\n                      max=\"59\"\n                      value=\"${mmValue}\">\n              </div>\n              <span class=\"text-hint\">\n                ${props.textHint || \"\"}\n              </span>\n            </div>\n          </div>`);\n\n    let $hhInput = $elem.querySelector(\".hour\");\n    let $mmInput = $elem.querySelector(\".minutes\");\n\n    $hhInput.addEventListener(\"input\", (e) => {\n      $hhInput.dispatchEvent(\n        new CustomEvent(\"changeTimeInputHH\", {\n          bubbles: true,\n          cancelable: false,\n          detail: {\n            key: props.key,\n            value: e.srcElement.value\n          }\n        })\n      );\n    });\n\n    $mmInput.addEventListener(\"input\", (e) => {\n      $mmInput.dispatchEvent(\n        new CustomEvent(\"changeTimeInputMM\", {\n          bubbles: true,\n          cancelable: false,\n          detail: {\n            key: props.key,\n            value: e.srcElement.value\n          }\n        })\n      );\n    });\n\n    this.addKeyDownInputEvents($hhInput, $elem, props);\n    this.addKeyDownInputEvents($mmInput, $elem, props);\n\n    return $elem;\n  },\n\n  /**\n   * Crea Text como elemento Dom\n   * Se configura como input, pero no devuelve datos, es un texto\n   *\n   * @param {Object} props - config para Input\n   * @return {Object} Elemento Dom del input creado\n   */\n  createText(props, selected) {\n    let label = props.label;\n    if (props.formatter) {\n      label = props.formatter({ selected });\n    }\n    let $elem = dom.createElementFromHTML(`\n          <div class=\"input-section ${props.isHidden ? 'hide':''} \" input-key=\"${props.key || \"\"}\">\n            <span class=\"${props.classNames || \"\"}\">\n            ${label}\n            </span>\n          </div>`);\n    return $elem;\n  },\n\n  /**\n   * Crea Title como elemento Dom\n   * Se configura como input, pero no devuelve datos, es un texto\n   *\n   * @param {Object} props - config para Input\n   * @return {Object} Elemento Dom del input creado\n   */\n  createTitle(props) {\n    let classNames = \"text-title\";\n    if (props.isSubtitle) {\n      classNames = \"text-subtitle\";\n    }\n    return dom.createElementFromHTML(`\n          <div class=\"input-section ${props.isHidden ? 'hide': ''} \" input-key=\"${props.key || \"\"}\">\n            <span class=\"${classNames}\">\n              ${props.label}\n            </span>\n          </div>`);\n  },\n\n  /**\n   * Crea Input tipo Numerico como elemento Dom\n   *\n   * @param {Object} props - config para Input\n   * @param {Object} dataDay - valores de item y Dia, opcional\n   * @return {Object} Elemento Dom del input creado\n   */\n  createInputNumber(props, dataDay) {\n    let value = \"\";\n    if (dataDay && dataDay.values) {\n      value = utils.getVarByPath(dataDay, props.varName);\n    }\n    value = value || \"\";\n\n    let elem = dom.createElementFromHTML(`\n          <div class=\"input-section ${props.classNames || \"\"} ${props.isHidden ? 'hide':''} \" input-key=\"${\n            props.key || \"\"\n          }\">\n            <div class=\"input-section-title\">\n              <span class=\"text-subtitle\">\n                ${props.label}\n              </span>\n              <span class=\"text-subtitle-2 \">\n                ${props.suffix ? \"(\" + props.suffix + \")\" : \"\"}\n              </span>\n            </div>\n            <div class=\"d-flex\">\n              <input type=\"number\"\n                    class=\"nav-input\"\n                    value=\"${value}\">\n\n              <span class=\"text-hint\">\n                  ${props.textHint || \"\"}\n              </span>\n            </div>\n          </div>`);\n\n    let inputElem = elem.querySelector(\"input\");\n\n    this.addKeyDownInputEvents(inputElem, elem, props);\n\n    return elem;\n  },\n\n  /**\n   * Crea Input tipo FIlepicker como elemento Dom\n   *\n   * @param {Object} props - config para Input\n   * @param {Object} dataDay - valores de item y Dia, opcional\n   * @return {Object} Elemento Dom del input creado\n   */\n  createInputFile(props, dataDay) {\n    let value = \"\";\n    let fileName = \"\";\n    let filePath = \"\";\n\n    if (dataDay && dataDay.values) {\n      value = utils.getVarByPath(dataDay, props.varName);\n      fileName = utils.getVarByPath(dataDay, props.fileNameValue);\n      filePath = utils.getVarByPath(dataDay, props.filePathValue);\n    }\n\n    value = value || \"\";\n    fileName = fileName || \"\";\n    filePath = filePath || \"\";\n\n    let elem = dom.createElementFromHTML(`\n          <div class=\"input-section ${props.classNames || \"\"} ${props.isHidden ? 'hide':''} \" input-key=\"${\n            props.key || \"\"\n          }\">\n\n            <div class=\"input-section-title\">\n              <span class=\"text-subtitle\">\n                ${props.label}\n              </span>\n            </div>\n\n            <div class=\"nav-input-file\" >\n              <button class=\"small-close clear-file-input\">x</button>\n              <label >\n                <span class=\"nav-input-file-label\">\n                  ${props.pickerLabel || \"Seleccionar Archivo\"}\n                </span>\n                <input type=\"file\" value=\"${value}\">\n              </label>\n            </div>\n\n            <div class=\"input-section-link\">\n              <a href=\"${filePath}\" target=\"_blank\" >\n                ${fileName}\n              </a>\n            </div>\n\n          </div>`);\n\n    let $inputElem = elem.querySelector(\"input\");\n    let $clearBtn = elem.querySelector(\".clear-file-input\");\n    let $fileInputLabel = elem.querySelector(\".nav-input-file-label\");\n\n    $inputElem.addEventListener(\"change\", (evt) => {\n      let fileName = $inputElem.files[0].name;\n      $fileInputLabel.textContent = fileName;\n    });\n\n    $clearBtn.addEventListener(\"click\", (evt) => {\n      $inputElem.value = \"\";\n      $fileInputLabel.textContent = props.pickerLabel || \"Seleccionar Archivo\";\n      evt.stopPropagation();\n    });\n\n    return elem;\n  },\n\n  createFileLink(props, dataDay) {\n    let fileName = \"\";\n    let filePath = \"\";\n\n    if (dataDay && dataDay.values) {\n      //value = utils.getVarByPath(dataDay, props.varName);\n      fileName = utils.getVarByPath(dataDay, props.fileNameValue);\n      filePath = utils.getVarByPath(dataDay, props.filePathValue);\n    }\n\n    if (fileName == \"\") return null;\n\n    fileName = fileName || \"\";\n    filePath = filePath || \"\";\n\n    let elem = dom.createElementFromHTML(`\n          <div class=\"input-section ${props.classNames || \"\"} ${props.isHidden ? 'hide':''} \" input-key=\"${\n            props.key || \"\"\n          }\">\n\n            <div class=\"input-section-title\">\n              <span class=\"text-subtitle\">\n                ${props.label}\n              </span>\n            </div>\n\n            <div class=\"input-section-link\">\n              <a href=\"${filePath}\" target=\"_blank\" >\n                ${fileName}\n              </a>\n            </div>\n\n          </div>`);\n\n    return elem;\n  },\n\n  /**\n   * Crea lista de Inputs, con array de valores, como elemento Dom\n   *\n   * @param {Object} props - config para Input\n   * @param {Object} dataDay - valores de item y Dia, opcional\n   * @param {Object} [daySelected = null] - datos del dia seleccionado\n   * @return {Object} Elemento Dom del input creado\n   */\n  createInputList(props, dataDay, daySelected = null) {\n    let inputList = [];\n\n    //obtiene inputs default, para crearlos, sin valores\n    if (\n      daySelected &&\n      Array.isArray(daySelected.item.values[props.inputList])\n    ) {\n      inputList = daySelected.item.values[props.inputList].map((inputRow) => {\n        //limpia inputList inputs\n        inputRow.inputs.map((input) => {\n          input.value = null;\n          return input;\n        });\n\n        //obtiene valores del dia\n        if (dataDay && dataDay.values) {\n          let inputValues = utils.getVarByPath(dataDay, props.valuesPath);\n\n          //autorrellena\n          if (inputValues) {\n            inputRow.inputs.forEach((input) => {\n              let values = inputValues.find((v) => v.id == inputRow.id);\n              input.value = values ? values[input.varName] : null;\n            });\n          }\n        }\n\n        return inputRow;\n      });\n    }\n\n    let str = `<div input-key=\"${props.key || \"\"}\" class=\"input-section-list ${props.isHidden ? 'hide': ''} \">\n            <div class=\"input-section-title\">\n              <span class=\"text-title\">\n                ${props.label}\n              </span> \n            </div>`;\n    inputList.forEach((inputRow) => {\n      str += `\n                  <div class=\"input-section ${\n                    props.toRight ? \"to-right\" : \"\"\n                  }\" >\n                      <span class=\"text-subtitle\">\n                        ${inputRow.label}\n                      </span>`;\n\n      inputRow.inputs.forEach((input) => {\n        str += ` \n                    <div class=\"input-section-col\" >\n                      <span class=\"text-subtitle \">\n                        ${input.label}\n                      </span>\n                      <input type=\"number\"\n                            input-id=\"${inputRow.id}\"\n                            input-label=\"${input.label}\"\n                            class=\"nav-input small\"\n                            value=\"${input.value}\">\n                    </div>`;\n      });\n      str += `\n                  </div>`;\n    });\n    str += `</div>`;\n\n    let elem = dom.createElementFromHTML(str);\n\n    let inputsElem = elem.querySelectorAll(\"input\");\n    inputsElem.forEach((inputElem) => this.addKeyDownInputEvents(inputElem, elem, props));\n    return elem;\n  },\n\n  createInputSelect(props, dataDay, daySelected = null) {\n    let value = null;\n    let options = props.options;\n\n    if (dataDay && dataDay.values) {\n      let val = utils.getVarByPath(dataDay, props.varName);\n      value = val ? val.value : null;\n    }\n\n    let str = `<div input-key=\"${props.key || \"\"}\" class=\"${props.isHidden ? 'hide': ''}\" >\n                  <div class=\"input-section \" >\n                      <span class=\"text-subtitle\">\n                        ${props.label}\n                      </span>\n\n                      <select class=\"input-select\">\n\n                 <option value=\"\" ${value == null ? \"selected\" : \"\"}>\n                  ${props.noDataLabel || \"-- sin asignar --\"}\n                 </option>\n\n        `;\n\n    options.forEach((option) => {\n      str += `\n                 <option value=\"${option.id}\" ${\n                   option.id == value ? \"selected\" : \"\"\n                 }>\n                 ${option.label}\n                 </option>\n                `;\n    });\n    str += `\n\n                      </select>\n                  </div>\n\n      </div>`;\n\n    let elem = dom.createElementFromHTML(str);\n\n    return elem;\n  },\n\n  /**\n   * Crea Input de texto TextArea como elemento Dom\n   *\n   * @param {Object} props - config para Input\n   * @param {Object} dataDay - valores de item y Dia, opcional\n   * @return {Object} Elemento Dom del input creado\n   */\n  createInputTextArea(props, dataDay) {\n    let value = \"\";\n    if (dataDay && dataDay.values) {\n      value = utils.getVarByPath(dataDay, props.varName);\n    }\n    let elem = dom.createElementFromHTML(`\n          <div class=\"input-section ${props.isHidden ? 'hide':''} \" input-key=\"${props.key || \"\"}\">\n            <span class=\"text-subtitle d-block\">\n              ${props.label}\n            </span>\n            <textarea class=\"\" value=\"${value}\"></textarea>\n          </div>`);\n\n    let inputElem = elem.querySelector(\"textarea\");\n    this.addKeyDownInputEvents(inputElem, elem, props);\n    return elem;\n  },\n\n  /**\n   * Crea Input de Mensaje como elemento Dom\n   * utiliza TextArea\n   *\n   * @param {Object} props - config para Input\n   * @param {Object} dataDay - valores de item y Dia, opcional\n   * @return {Object} Elemento Dom del input creado\n   */\n  createInputMessage(props, dataDay) {\n    let value = dataDay ? utils.getVarByPath(dataDay, props.varName) : null;\n    let elem = dom.createElementFromHTML(`\n          <div class=\"input-section msj-input-container ${props.isHidden ? 'hide':''} \"\n              input-key=\"${props.key || \"\"}\">\n            <span class=\"text-subtitle d-block\">\n              Mensaje\n            </span>\n            <textarea class=\"msj\">${value || \"\"}</textarea>\n          </div>`);\n\n    let inputElem = elem.querySelector(\"textarea\");\n    //this.addKeyDownInputEvents(inputElem);\n    return elem;\n  },\n\n  /**\n   * Crea Input de texto como elemento Dom\n   *\n   * @param {Object} props - config para Input\n   * @param {Object} dataDay - valores de item y Dia, opcional\n   * @return {Object} Elemento Dom del input creado\n   */\n  createInputText(props, dataDay) {\n    let value = \"\";\n    if (dataDay && dataDay.values) {\n      value = utils.getVarByPath(dataDay, props.varName);\n    }\n    let elem = dom.createElementFromHTML(`\n          <div class=\"input-section ${props.isHidden ? 'hide':''} \" input-key=\"${props.key || \"\"}\">\n            <span class=\"text-subtitle d-block\">\n              ${props.label}\n            </span>\n            <input type=\"text\" class=\"nav-input\" value=\"${value}\">\n          </div>`);\n\n    let inputElem = elem.querySelector(\"input\");\n    this.addKeyDownInputEvents(inputElem, elem, props);\n    return elem;\n  },\n\n  /**\n   * Crea Input Numero Flotante, como elemento Dom\n   *\n   * @param {Object} props - config para Input\n   * @param {Object} dataDay - valores de item y Dia, opcional\n   * @return {Object} Elemento Dom del input creado\n   */\n  createInputFloat(props, dataDay) {\n    let value = \"\";\n    if (dataDay && dataDay.values) {\n      value = utils.getVarByPath(dataDay, props.varName);\n    }\n    let elem = dom.createElementFromHTML(`\n          <div class=\"input-section ${props.isHidden ? 'hide':''} \" input-key=\"${props.key || \"\"}\">\n            <span class=\"text-subtitle d-block\">\n              ${props.label}\n            </span>\n            <input type=\"number\" class=\"nav-input\" value=\"${value}\">\n          </div>`);\n\n    let inputElem = elem.querySelector(\"input\");\n    this.addKeyDownInputEvents(inputElem, elem, props);\n    return elem;\n  },\n\n  createDataList(props, dataDay, daySelected, selected) {\n    let list = [];\n    if (dataDay && dataDay.values) {\n      list = utils.getVarByPath(dataDay, props.varName) || [];\n    }\n\n    let searchInput = ` <div class=\"search-input-container\">\n                          <input id=\"\" type=\"text\" name=\"\" class=\"search-input\" placeholder=\"buscar\">\n                          <button class=\"search-input-clear\">\n                          ${icons.closeIcon}\n                          </button>\n                        </div>`;\n\n    let editBtn = \"\";\n\n    if (props.editButton) {\n      editBtn = `<button class=\"cap-btn-outline cap-btn-sm edit-btn\" input-key=\"${props.editButton.key}\">\n                    ${props.editButton.label} \n                  </button> `;\n    }\n\n    let str = `\n      <div class=\"input-section ${props.isHidden ? 'hide':''} \" input-key=\"${props.key || \"\"}\">\n        <div class=\"input-section-title\">\n            <span class=\"text-subtitle d-block\">\n                ${props.label}\n              </span>\n              ${editBtn}\t\n        </div>\n        <div class=\"input-box \" input-key=\"${props.key || \"\"}\">\n            ${searchInput}\n        </div>\n      </div> `;\n\n    let $el = dom.createElementFromHTML(str);\n    let $searchInput = $el.querySelector(\".search-input\");\n    let $searchInputClear = $el.querySelector(\".search-input-clear\");\n    let $inputBox = $el.querySelector(\".input-box\");\n\n    list.map((item, j) => {\n      let label =\n        utils.getVarByPath(item, props.varNameLabel) || dataDay.label || \"__\";\n\n      let $elItem = this.createDataListItem({\n        label,\n        valueText: utils.getVarByPath(item, props.varNameValueText) || \"\",\n        subText: utils.getVarByPath(item, props.varNameSubText) || \"\",\n        id: \"list-item-\" + (dataDay.id || j),\n        key: \"list-item-\" + (dataDay.id || j),\n        tooltip: utils.getVarByPath(item, props.varNameTooltip) || label,\n        //colorIcon: \"c-red\",\n        link: utils.getVarByPath(item, props.varNameLink) || null,\n        suffix: utils.getVarByPath(item, props.varNameSuffix) || null,\n        //value: JSON.stringify(utils.getVarByPath(item, props.varNameInput)) || {}\n      });\n      $inputBox.appendChild($elItem);\n    });\n\n    $searchInputClear.addEventListener(\"click\", (e) => {\n      $searchInput.value = \"\";\n      $searchInput.dispatchEvent(new Event(\"input\", { bubbles: true }));\n    });\n\n    $searchInput.addEventListener(\"keydown\", (e) => {\n      if (e.key === \"Escape\") {\n        $searchInput.value = \"\";\n        $searchInput.dispatchEvent(new Event(\"input\", { bubbles: true }));\n      }\n    });\n\n    $searchInput.addEventListener(\"input\", (e) => {\n      let $inputs = [];\n      $inputs = $el.querySelectorAll(\".mini-input-section\") || [];\n      $inputs.forEach(($i) => {\n        let label = $i.getAttribute(\"label\");\n        let search = $searchInput.value;\n        if (label.toLowerCase().includes(search.toLowerCase())) {\n          $i.classList.remove(\"hide\");\n        } else {\n          $i.classList.add(\"hide\");\n        }\n      });\n    });\n\n    let button = $el.querySelector(\"button.edit-btn\");\n    if (button && props.editButton && props.editButton.onClick) {\n      button.addEventListener(\"click\", (e) =>\n        props.editButton.onClick({\n          event: e,\n          props,\n          dataDay,\n          daySelected,\n          selected,\n          $element: $el\n        })\n      );\n    }\n\n    return $el;\n  },\n\n  createDataListItem({\n    label = \"\",\n    valueText = \"\",\n    subText = \"\",\n    id = \"\",\n    key = \"\",\n    tooltip = \"\",\n    colorIcon = \"\",\n    link = null,\n    suffix = null,\n    value = \"\"\n  }) {\n    let tooltipStr = \"\";\n    let iconStr = null;\n    let linkStr = \"\";\n    let str = \"\";\n\n    if (tooltip) {\n      tooltipStr = `\n                  <div class=\"mini-input-section--tooltip\">\n                    ${tooltip}\n                  </div>`;\n    }\n\n    if (colorIcon) {\n      if (utils.isHexColor(itemFormated.colorIcon)) {\n        iconStr = `<div class=\"mini-input-section--icon\" style=\"background:${colorIcon}\"> </div>`;\n      } else {\n        iconStr = `<div class=\"mini-input-section--icon ${colorIcon}\"> </div>`;\n      }\n    }\n\n    if (link) {\n      linkStr = `<a class=\"mini-input-section--link\" target=\"_blank\" href=\"${link}\">${icons.linkIcon}</a> `;\n    }\n\n    str += `\n            <div class=\"mini-input-section ${\n              iconStr ? \"has-icon\" : \"\"\n            } \" label=\"${label}\" data-id=\"${id}\" data-key=\"${key}\" data-value=\"${value || ''}\">\n              <label>\n                ${iconStr || \"\"}\n\n                <div class=\"mini-input-section--titles\">\n                  <div class=\"mini-input-section--title truncate\">\n                    ${label}\n                  </div>\n                  <div class=\"mini-input-section--subtitle truncate\">\n                    ${subText}\n                  </div>\n                </div>\n\n                <div class=\"mini-input-section--content\" >\n                  ${valueText}\n                </div>\n                <div class=\"mini-input-section--suffix\" >\n                  ${suffix}\n                </div>\n\n                ${linkStr}\n\n              </label>\n              ${tooltipStr}\n            </div>`;\n    return dom.createElementFromHTML(str);\n  },\n\n  createList(props, dataDay) {\n    let tabsContainer = \"\";\n\n    if (props.tabs) {\n      let tabs = \"\";\n      props.tabs.forEach((tab) => {\n        tabs += `\n        <div class=\"input-box-tab\" tab-key=\"${tab.key}\">\n          ${tab.name}\n        </div>`;\n      });\n\n      tabsContainer = `\n        <div class=\"input-box-tab-container\">\n        ${tabs}\n        </div>\n      `;\n    }\n\n    let searchInput = `\n      <div class=\"search-input-container\">\n        <input id=\"\" type=\"text\" name=\"\" class=\"search-input\" placeholder=\"buscar\">\n        <button class=\"search-input-clear\">\n         ${icons.closeIcon}\n        </button>\n      </div>\n    `;\n\n    let str = `\n      <div class=\"input-section ${props.isHidden ? 'hide':''} \" input-key=\"${props.key || \"\"}\">\n           <span class=\"text-subtitle d-block\">\n              ${props.label}\n            </span>\n\n            ${tabsContainer}\n        <div class=\"input-box \" input-key=\"${props.key || \"\"}\">\n\n            ${searchInput}\n      `;\n\n    //TODO obtener input segun fila\n    if (props.inputs) {\n      props.inputs.forEach((i) => {\n        if (i.isTitle) {\n          let tooltip = \"\";\n          let icon = null;\n\n          if (i.tooltip) {\n            tooltip = `\n                  <div class=\"mini-input-section--tooltip\">\n                    ${i.tooltip}\n                    ${i.suffix ? \"(\" + i.suffix + \")\" : \"\"}\n                  </div>`;\n          }\n\n          if (i.colorIcon) {\n            if (utils.isHexColor(i.colorIcon)) {\n              icon = `<div class=\"mini-input-section--icon\" style=\"background:${i.colorIcon}\"> </div>`;\n            } else {\n              icon = `<div class=\"mini-input-section--icon ${i.colorIcon}\"> </div>`;\n            }\n          }\n\n          str += `\n            <div class=\"mini-input-section is-title  ${\n              icon ? \"has-icon\" : \"\"\n            }\" input-tab-key=\"${i.tabKey || \"\"}\" label=\"${i.label}\">\n              <label>\n                ${icon || \"\"}\n                <div class=\"mini-input-section--title truncate\">\n                  ${i.label}\n                </div>\n              </label>\n              ${tooltip}\n            </div>`;\n        } else {\n          let tooltip = \"\";\n          let icon = null;\n          let link = \"\";\n\n          if (i.tooltip) {\n            tooltip = `\n                  <div class=\"mini-input-section--tooltip\">\n                    ${i.tooltip}\n                  </div>`;\n          }\n\n          if (i.colorIcon) {\n            if (utils.isHexColor(i.colorIcon)) {\n              icon = `<div class=\"mini-input-section--icon\" style=\"background:${i.colorIcon}\"> </div>`;\n            } else {\n              icon = `<div class=\"mini-input-section--icon ${i.colorIcon}\"> </div>`;\n            }\n          }\n\n          if (i.link) {\n            link = `<a class=\"mini-input-section--link\" target=\"_blank\" href=\"${i.link}\">\n                ${icons.linkIcon}\n                </a> `;\n          }\n\n          str += `\n            <div class=\"mini-input-section  ${\n              icon ? \"has-icon\" : \"\"\n            }\" input-tab-key=\"${i.tabKey || \"\"}\" label=\"${i.label}\">\n              <label>\n\n                ${icon}\n\n                <div class=\"mini-input-section--title truncate\">\n                  ${i.label}\n                </div>\n\n                <div class=\"mini-input-section--suffix\" >${\n                  i.suffix ? \"(\" + i.suffix + \")\" : \"\"\n                }</div>\n\n                ${link}\n\n              </label>\n              <div class=\"mini-input-section--footer\">\n                <span class=\"start\"> start</span>\n                <span class=\"end\"> end </span>\n              </div>\n              ${tooltip}\n            </div>`;\n        }\n      });\n    }\n\n    str += `\n        </div>\n      </div> `;\n\n    let $el = dom.createElementFromHTML(str);\n    let $tabs = $el.querySelectorAll(\".input-box-tab[tab-key]\") || [];\n    let $searchInput = $el.querySelector(\".search-input\") || null;\n    let $searchInputClear = $el.querySelector(\".search-input-clear\") || null;\n\n    $tabs.forEach((t) => {\n      t.addEventListener(\"click\", (e) => {\n        this.selectInputBoxTab(t, $el);\n        $searchInput.value = \"\";\n        $searchInput.dispatchEvent(new Event(\"input\", { bubbles: true }));\n      });\n    });\n\n    if ($searchInputClear) {\n      $searchInputClear.addEventListener(\"click\", (e) => {\n        $searchInput.value = \"\";\n        $searchInput.dispatchEvent(new Event(\"input\", { bubbles: true }));\n      });\n    }\n\n    if ($searchInput) {\n      $searchInput.addEventListener(\"keydown\", (e) => {\n        if (e.key === \"Escape\") {\n          $searchInput.value = \"\";\n          $searchInput.dispatchEvent(new Event(\"input\", { bubbles: true }));\n        }\n      });\n\n      $searchInput.addEventListener(\"input\", (e) => {\n        let $tabSelected =\n          $el.querySelector(\".input-box-tab[tab-key].active\") || null;\n        let $inputs = [];\n        if ($tabSelected) {\n          let tabKey = $tabSelected.getAttribute(\"tab-key\");\n          $inputs =\n            $el.querySelectorAll(\n              \".mini-input-section[input-tab-key='\" + tabKey + \"']\"\n            ) || [];\n        } else {\n          $inputs = $el.querySelectorAll(\".mini-input-section\") || [];\n        }\n        $inputs.forEach(($i) => {\n          let label = $i.getAttribute(\"label\");\n          let search = $searchInput.value;\n          if (label.toLowerCase().includes(search.toLowerCase())) {\n            $i.classList.remove(\"hide\");\n          } else {\n            $i.classList.add(\"hide\");\n          }\n        });\n      });\n    }\n\n    this.selectInputBoxTab(_.first($tabs), $el);\n\n    return $el;\n  },\n\n  /**\n   * Crea InputBox, como elemento Dom\n   * un InputBox es un contenedor con una lista de inputs\n   *\n   * @param {Object} props - config para Input\n   * @param {Object} dataDay - valores de item y Dia, opcional\n   * @return {Object} Elemento Dom del input creado\n   */\n  createInputBox(props, dataDay) {\n    let value = [];\n    if (dataDay && dataDay.values) {\n      value = utils.getVarByPath(dataDay, props.varName);\n    }\n\n    let tabsContainer = \"\";\n\n    if (props.tabs) {\n      let tabs = \"\";\n      props.tabs.forEach((tab) => {\n        tabs += `\n        <div class=\"input-box-tab\" tab-key=\"${tab.key}\">\n          ${tab.name}\n        </div>`;\n      });\n\n      tabsContainer = `\n        <div class=\"input-box-tab-container\">\n        ${tabs}\n        </div>\n      `;\n    }\n\n    let searchInput = `\n      <div class=\"search-input-container\">\n        <input id=\"\" type=\"text\" name=\"\" class=\"search-input\" placeholder=\"buscar\">\n        <button class=\"search-input-clear\">\n         ${icons.closeIcon}\n        </button>\n      </div>\n    `;\n\n    let str = `\n      <div class=\"input-section ${props.isHidden ? 'hide':''} \" input-key=\"${props.key || \"\"}\">\n           <span class=\"text-subtitle d-block\">\n              ${props.label}\n            </span>\n\n            ${tabsContainer}\n\n            <div class=\"input-box \" input-key=\"${props.key || \"\"}\">\n\n            ${searchInput}\n      `;\n\n    if (props.inputs) {\n      props.inputs.forEach((i) => {\n        if (i.isTitle) {\n          let tooltip = \"\";\n          let icon = \"\";\n\n          if (i.tooltip) {\n            tooltip = `\n                  <div class=\"mini-input-section--tooltip\">\n                    ${i.tooltip}\n                    ${i.suffix ? \"(\" + i.suffix + \")\" : \"\"}\n                  </div>`;\n          }\n\n          if (i.colorIcon) {\n            if (utils.isHexColor(i.colorIcon)) {\n              icon = `<div class=\"mini-input-section--icon\" style=\"background:${i.colorIcon}\"> </div>`;\n            } else {\n              icon = `<div class=\"mini-input-section--icon ${i.colorIcon}\"> </div>`;\n            }\n          }\n\n          str += `\n            <div class=\"mini-input-section is-title\" input-tab-key=\"${\n              i.tabKey || \"\"\n            }\" label=\"${i.label}\">\n              <label>\n                ${icon}\n                <div class=\"mini-input-section--title truncate\">\n                  ${i.label}\n                </div>\n              </label>\n              ${tooltip}\n            </div>`;\n        } else {\n          let value_found = value ? value.find((val) => val.id == i.id) : null;\n          let v = value_found || \"\";\n          let inputValue =\n            props.varNameInput && v[props.varNameInput]\n              ? v[props.varNameInput]\n              : v.value;\n          let tooltip = \"\";\n          let icon = \"\";\n          let link = \"\";\n\n          if (i.tooltip) {\n            tooltip = `\n                  <div class=\"mini-input-section--tooltip\">\n                    ${i.tooltip}\n                  </div>`;\n          }\n\n          if (i.colorIcon) {\n            if (utils.isHexColor(i.colorIcon)) {\n              icon = `<div class=\"mini-input-section--icon\" style=\"background:${i.colorIcon}\"> </div>`;\n            } else {\n              icon = `<div class=\"mini-input-section--icon ${i.colorIcon}\"> </div>`;\n            }\n          }\n\n          if (i.link) {\n            link = `<a class=\"mini-input-section--link\" target=\"_blank\" href=\"${i.link}\">\n                ${icons.linkIcon}\n                </a> `;\n          }\n\n          str += `\n            <div class=\"mini-input-section ${\n              icon ? \"has-icon\" : \"\"\n            }\" input-tab-key=\"${i.tabKey || \"\"}\" label=\"${i.label}\">\n              <label>\n                <input type=\"number\"\n                      class=\"mini-input\"\n                      input-id=\"${i.id || \"\"}\"\n                      input-key=\"${i.key || i.label}\"\n                      value=\"${inputValue || \"\"}\">\n\n                ${icon || \"\"}\n\n                <div class=\"mini-input-section--title truncate\">\n                  ${i.label}\n                </div>\n\n                <div class=\"mini-input-section--suffix\" >${\n                  i.suffix ? \"(\" + i.suffix + \")\" : \"\"\n                }</div>\n\n                ${link}\n\n              </label>\n              ${tooltip}\n            </div>`;\n        }\n      });\n    }\n\n    str += `\n        </div>\n      </div> `;\n\n    let $el = dom.createElementFromHTML(str);\n    let $tabs = $el.querySelectorAll(\".input-box-tab[tab-key]\") || [];\n    let $inputs = $el.querySelectorAll(\"input.mini-input\") || [];\n    let $searchInput = $el.querySelector(\".search-input\") || null;\n    let $searchInputClear = $el.querySelector(\".search-input-clear\") || null;\n\n    $tabs.forEach((t) => {\n      t.addEventListener(\"click\", (e) => {\n        this.selectInputBoxTab(t, $el);\n        $searchInput.value = \"\";\n        $searchInput.dispatchEvent(new Event(\"input\", { bubbles: true }));\n      });\n    });\n\n    if ($searchInputClear) {\n      $searchInputClear.addEventListener(\"click\", (e) => {\n        $searchInput.value = \"\";\n        $searchInput.dispatchEvent(new Event(\"input\", { bubbles: true }));\n      });\n    }\n\n    if ($searchInput) {\n      $searchInput.addEventListener(\"keydown\", (e) => {\n        if (e.key === \"Escape\") {\n          $searchInput.value = \"\";\n          $searchInput.dispatchEvent(new Event(\"input\", { bubbles: true }));\n        }\n      });\n\n      $searchInput.addEventListener(\"input\", (e) => {\n        let $tabSelected =\n          $el.querySelector(\".input-box-tab[tab-key].active\") || null;\n        let $inputs = [];\n        if ($tabSelected) {\n          let tabKey = $tabSelected.getAttribute(\"tab-key\");\n          $inputs =\n            $el.querySelectorAll(\n              \".mini-input-section[input-tab-key='\" + tabKey + \"']\"\n            ) || [];\n        } else {\n          $inputs = $el.querySelectorAll(\".mini-input-section\") || [];\n        }\n        $inputs.forEach(($i) => {\n          let label = $i.getAttribute(\"label\");\n          let search = $searchInput.value;\n          if (label.toLowerCase().includes(search.toLowerCase())) {\n            $i.classList.remove(\"hide\");\n          } else {\n            $i.classList.add(\"hide\");\n          }\n        });\n      });\n    }\n\n    this.selectInputBoxTab(_.first($tabs), $el);\n\n    $inputs.forEach((i) => this.addKeyDownInputEvents(i, $el, props));\n\n    return $el;\n  },\n\n  selectInputBoxTab($tab, $el) {\n    let $tabs = $el.querySelectorAll(\".input-box-tab[tab-key]\") || [];\n    let $inputSections = $el.querySelectorAll(\".mini-input-section\") || [];\n\n    $tabs.forEach((t) => {\n      t.classList.remove(\"active\");\n    });\n\n    if ($tab) {\n      $tab.classList.add(\"active\");\n\n      $inputSections.forEach((i) => {\n        let key = i.getAttribute(\"input-tab-key\");\n        if (key == $tab.getAttribute(\"tab-key\")) {\n          i.classList.remove(\"hide\");\n        } else {\n          i.classList.add(\"hide\");\n        }\n      });\n    }\n  },\n\n  /**\n   * Crea Checkbox, como elemento Dom\n   *\n   * @param {Object} props - config para Input\n   * @param {Object} dataDay - valores de item y Dia, opcional\n   * @return {Object} Elemento Dom del input creado\n   */\n  createInputCheckbox(props, dataDay) {\n    let value = \"\";\n    if (dataDay && dataDay.values) {\n      value = utils.getVarByPath(dataDay, props.varName);\n    }\n    let r = dom.createElementFromHTML(`\n      <div class=\"input-section ${props.isHidden ? 'hide':''} \" input-key=\"${props.key || \"\"}\">\n        <label>\n          <input type=\"checkbox\" name=\"${props.key || \"\"}\" input-key=\"${\n            props.key || \"\"\n          }\" ${value ? \"checked\" : \"\"}>\n          ${props.label}\n        </label>\n      </div>`);\n\n    return r;\n  },\n\n  createInputButtonsGroup(props) {\n    let $container = dom.createElementFromHTML(`\n      <div class=\"input-section ${props.isHidden ? 'hide':''} \" input-key=\"${props.key || \"\"}\">\n        <div class=\"buttons-group\"> </div>\n      </div>`);\n\n    let $containerButtonGroup = $container.querySelector(\".buttons-group\");\n\n    let $buttons = [];\n    $buttons = props.buttons.map((buttonProp) => {\n      let buttonStr = `\n        <button \n          name=\"${buttonProp.key || \"\"}\" \n          input-key=\"${buttonProp.key || \"\"}\"\n          class=\"cap-btn-outline cap-btn-sm ${buttonProp.isSelected ? 'selected' : ''} \">\n          ${buttonProp.label}\n        </button>`;\n\n      let $button = domUtils.createElementFromHTML(buttonStr);\n      $containerButtonGroup.append($button);\n\n      $button.addEventListener(\"click\", (e) => {\n        if (props.isSelectable) {\n          $buttons.forEach(($b) => $b.classList.remove(\"selected\"));\n          $button.classList.add(\"selected\");\n        }\n        buttonProp.onClick({ props, event: e, buttonsElements: $buttons });\n      });\n      return $button;\n    });\n\n    return $container;\n  },\n\n  createInputButton(props) {\n    let r = dom.createElementFromHTML(`\n      <div class=\"input-section ${props.isHidden ? 'hide':''} \" input-key=\"${props.key || \"\"}\">\n          <button \n            name=\"${props.key || \"\"}\"\n            input-key=\"${props.key || \"\"}\"\n            class=\"cap-btn-outline\">\n            ${props.label}\n          </button>\n      </div>`);\n\n    let button = r.querySelector(\"button\");\n    button.addEventListener(\"click\", (e) => props.onClick({ props, event: e }));\n\n    return r;\n  },\n\n  addKeyDownInputEvents($input, $inputContainer, props) {\n    $input.addEventListener(\"keydown\", function (event) {\n      if (event.keyCode === 13) {\n        //ENTER\n        $input.dispatchEvent(\n          new CustomEvent(\"saveMultiInput\", {\n            bubbles: true,\n            cancelable: false\n          })\n        );\n      }\n      if (event.keyCode === 27) {\n        //ESC\n        $input.dispatchEvent(\n          new CustomEvent(\"cancelMultiInput\", {\n            bubbles: true,\n            cancelable: false\n          })\n        );\n      }\n    });\n    $input.addEventListener(\"input\", (e) => {\n      if(props.onInput){\n        props.onInput({\n          event:e,\n          value: e.srcElement.value,\n          props,\n          $element: $inputContainer\n        });\n      }\n    });\n  },\n\n  createContextMenu({\n    config,\n    $capibaraElem = null,\n    evt = null,\n    date = null,\n    item = null,\n    selected = [],\n    tabSelected = null,\n    left = null,\n    top = null,\n    name = \"\"\n  }) {\n    if (config.timeline.contextMenu === undefined)\n      return { elem: null, isVisible: false };\n\n    let className = \"\";\n    let style = \"\";\n    let strHtml = \"\";\n    let leftPosition = null;\n    let topPosition = null;\n    let isVisible = true;\n    let boundRectCapibara = null;\n    let gap = 15; //px\n\n    if ($capibaraElem) {\n      boundRectCapibara = $capibaraElem.getBoundingClientRect();\n    }\n\n    if (evt && boundRectCapibara) {\n      left = evt.clientX;\n      top = evt.clientY - boundRectCapibara.top;\n    }\n\n    if (left) {\n      leftPosition = left;\n    }\n\n    if (top) {\n      topPosition = top;\n    }\n\n    if ((leftPosition !== null) & (topPosition !== null)) {\n      if (boundRectCapibara) {\n        let transformStyle = \"\";\n        if (\n          topPosition > (boundRectCapibara.height * 2) / 6 &&\n          topPosition <= (boundRectCapibara.height * 4) / 6\n        ) {\n          transformStyle += `translateY(-50%)`;\n        }\n        if (topPosition > (boundRectCapibara.height * 4) / 6) {\n          transformStyle += `translateY(-100%)`;\n        }\n\n        if (leftPosition > (boundRectCapibara.width * 4) / 6) {\n          transformStyle += `translateX(-100%)`;\n          leftPosition -= gap;\n        } else {\n          leftPosition += gap;\n        }\n        if (transformStyle != \"\") {\n          style += ` transform: ${transformStyle};`;\n        }\n      }\n\n      style += `top: ${topPosition}px; left: ${leftPosition}px;`;\n    } else {\n      className += \"cm-hide\";\n      isVisible = false;\n    }\n\n    strHtml += ` <div class=\"cap-context-menu-container ${className}\">\n                    <div class=\"cap-context-menu\" style=\"${style}\">\n                    </div>\n                 </div>`;\n\n    let $contextMenuContainer = dom.createElementFromHTML(strHtml);\n    let $contextMenu = $contextMenuContainer.querySelector(\".cap-context-menu\");\n\n    config.timeline.contextMenu.options.forEach((option) => {\n      if (option.showIf) {\n        let show = option.showIf({ item, date, selected, name, tabSelected });\n        if (!show) return;\n      }\n\n      let isEnabled = true;\n      let isClickeable = true;\n      if (option.enableIf) {\n        isEnabled = option.enableIf({\n          item,\n          date,\n          selected,\n          name,\n          tabSelected\n        });\n      }\n\n      let optionClassName = \"\";\n      let strIcon = \"\";\n      let label = \"\";\n\n      if (!isEnabled) {\n        optionClassName += \"is-disabled \";\n      }\n\n      if (option.isDivider) {\n        isClickeable = false;\n        optionClassName += \"is-divider \";\n      }\n\n      if (option.label) {\n        label = `<span>${option.label}</span>`;\n      }\n\n      if (option.icon) {\n        strIcon = `<div class=\"cap-context-menu_item_icon\">\n                      <svg viewBox=\"0 0 24 24\">\n                        <path d=\"${option.icon}\" />\n                      </svg>\n                  </div>`;\n      }\n\n      let optionStrHtml = `\n        <div class=\"cap-context-menu_item ${optionClassName}\">\n          ${strIcon}\n          ${label}\n        </div>`;\n\n      let $option = dom.createElementFromHTML(optionStrHtml);\n\n      if (isEnabled && isClickeable) {\n        $option.addEventListener(\"click\", (evtClick) =>\n          option.onClick({\n            config,\n            evt: evtClick,\n            date,\n            item,\n            selected,\n            tabSelected\n          })\n        );\n      } else {\n        $option.addEventListener(\"click\", (evtClick) => {\n          evtClick.preventDefault();\n          evtClick.stopPropagation();\n        });\n      }\n\n      $contextMenu.append($option);\n    });\n\n    return {\n      elem: $contextMenuContainer,\n      isVisible\n    };\n  }\n};\n"],"mappings":"AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AAAA;AACA;AAAA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AAAA;AAAA;AAAA;AAEA;AACA;AAEA;AACA;AACA;AAGA;AACA;AAEA;AAAA;AAAA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AADA;AAGA;AACA;AACA;AACA;AACA;AACA;AADA;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AAAA;AAAA;AAAA;AAEA;AACA;AAGA;AACA;AACA;AACA;AACA;AACA;AAFA;AAFA;AAOA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAFA;AAFA;AAOA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AAQA;AAQA;AAEA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AAEA;AACA;AAEA;AACA;AAAA;AACA;AACA;AAEA;AACA;AAFA;AAKA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AAAA;AAAA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AAAA;AAAA;AAAA;AAAA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AAHA;AAKA;AAPA;AACA;AAQA;AACA;AACA;AACA;AACA;AACA;AACA;AAHA;AAKA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AAGA;AACA;AAEA;AAEA;AAEA;AACA;AACA;AACA;AAGA;AACA;AACA;AAGA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAGA;AAGA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AAAA;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AAEA;AACA;AAFA;AAKA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AAAA;AAAA;AAAA;AAHA;AAMA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AAEA;AACA;AAFA;AAKA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AAEA;AACA;AACA;AACA;AADA;AAHA;AAQA;AAEA;AACA;AAEA;AACA;AACA;AACA;AADA;AAHA;AAQA;AAEA;AACA;AAEA;AACA;AACA;AACA;AADA;AAHA;AAQA;AAEA;AACA;AAAA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AAEA;AACA;AACA;AACA;AACA;AAFA;AAHA;AASA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AAEA;AACA;AACA;AACA;AADA;AAHA;AAQA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AAEA;AACA;AACA;AACA;AADA;AAHA;AAQA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAKA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AAKA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAKA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AAJA;AAHA;AAWA;AAEA;AACA;AAEA;AACA;AACA;AACA;AACA;AAFA;AAHA;AASA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AAIA;AAEA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AAKA;AACA;AACA;AACA;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AAEA;AAEA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AAGA;AAEA;AAEA;AACA;AACA;AACA;AACA;AACA;AAHA;AAHA;AAUA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAGA;AACA;AACA;AACA;AACA;AACA;AAGA;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AAIA;AACA;AAEA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAOA;AACA;AACA;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AA7CA;AA+CA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAGA;AACA;AACA;AAEA;AACA;AAAA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AA7CA;AA+CA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AA7CA;AA+CA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAGA;AACA;AACA;AAEA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AA7CA;AA+CA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AAIA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAGA;AACA;AAAA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AAGA;AACA;AACA;AAIA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAGA;AACA;AACA;AACA;AACA;AAGA;AACA;AAAA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AAJA;AAHA;AAWA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AAFA;AAKA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AAFA;AAKA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AAHA;AAHA;AAUA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AANA;AAHA;AAaA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AAHA;AAHA;AAUA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AAKA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAFA;AAHA;AAWA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAQA;AACA;AAAA;AACA;AADA;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAJA;AAMA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAKA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAMA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AAAA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AAAA;AAAA;AAEA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAMA;AACA;AACA;AAAA;AACA;AACA;AAFA;AAIA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AADA;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AAEA;AACA;AAMA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AAEA;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAIA;AACA;AACA;AACA;AACA;AAKA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAKA;AAKA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAGA;AACA;AACA;AACA;AACA;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAOA;AAEA;AACA;AAAA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AAEA;AAEA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AAHA;AAHA;AAUA;AAEA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AAHA;AAHA;AAUA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAOA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAIA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AAEA;AACA;AACA;AAGA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAIA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAIA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AAAA;AAKA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAGA;AACA;AAAA;AAAA;AAAA;AACA;AAAA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAAA;AAAA;AAAA;AACA;AACA;AAAA;AACA;AACA;AAFA;AAIA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAFA;AAIA;AACA;AACA;AAFA;AAIA;AAGA;AACA;AAEA;AACA;AAEA;AACA;AAFA;AAKA;AAEA;AACA;AAEA;AACA;AAFA;AAKA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AAAA;AACA;AACA;AA1DA;AACA;AA4DA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AAEA;AACA;AAEA;AACA;AACA;AACA;AACA;AAFA;AAHA;AASA;AAEA;AACA;AAEA;AACA;AACA;AACA;AACA;AAFA;AAHA;AASA;AAEA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AAAA;AAAA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AAAA;AAEA;AACA;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AAEA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AAEA;AACA;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AAIA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAGA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AAEA;AACA;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAVA;AAYA;AACA;AAEA;AACA;AACA;AAAA;AAAA;AACA;AAEA;AACA;AACA;AACA;AAAA;AAAA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AAAA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AANA;AASA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAVA;AAYA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AAAA;AACA;AACA;AAEA;AACA;AAEA;AACA;AAAA;AACA;AACA;AAIA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAIA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AAAA;AACA;AACA;AAEA;AACA;AAEA;AACA;AAAA;AACA;AACA;AAIA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AAEA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AAGA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AAAA;AAAA;AAAA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AAFA;AAKA;AACA;AAAA;AACA;AACA;AAEA;AACA;AAFA;AAKA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAJA;AAMA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAVA;AAYA;AACA;AAAA;AAAA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AAIA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AAEA;AACA;AACA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AALA;AAOA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AANA;AASA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AAFA;AAIA;AACA;AAn/HA","sourceRoot":""}\n//# sourceURL=webpack-internal:///./src/util/tableElements.js\n");
259
259
 
260
260
  /***/ }),
261
261