/******/ (() => { // webpackBootstrap /******/ var __webpack_modules__ = ({ /***/ 4: /***/ (() => { const themeToggleDarkIcon = document.getElementById('themeToggleDarkIcon'); const themeToggleLightIcon = document.getElementById('themeToggleLightIcon'); if (themeToggleDarkIcon && themeToggleLightIcon) { // Change the icons inside the button based on previous settings if (localStorage.getItem('color-theme') === 'dark' || (!('color-theme' in localStorage) && window.matchMedia('(prefers-color-scheme: dark)').matches)) { themeToggleLightIcon.classList.remove('hidden'); } else { themeToggleDarkIcon.classList.remove('hidden'); } } const themeToggleBtn = document.getElementById('themeToggle'); let event = new Event('dark-mode'); if (themeToggleBtn) { themeToggleBtn.addEventListener('click', function() { // toggle icons themeToggleDarkIcon.classList.toggle('hidden'); themeToggleLightIcon.classList.toggle('hidden'); // if set via local storage previously if (localStorage.getItem('color-theme')) { if (localStorage.getItem('color-theme') === 'light') { document.documentElement.classList.add('dark'); localStorage.setItem('color-theme', 'dark'); } else { document.documentElement.classList.remove('dark'); localStorage.setItem('color-theme', 'light'); } // if NOT set via local storage previously } else { if (document.documentElement.classList.contains('dark')) { document.documentElement.classList.remove('dark'); localStorage.setItem('color-theme', 'light'); } else { document.documentElement.classList.add('dark'); localStorage.setItem('color-theme', 'dark'); } } document.dispatchEvent(event); }); } /***/ }), /***/ 391: /***/ (() => { document.addEventListener('DOMContentLoaded', function () { const $currentYearText = document.getElementById('currentYear'); if ($currentYearText) { $currentYearText.textContent = new Date().getFullYear(); } }); /***/ }), /***/ 756: /***/ (() => { function toggleStickyNavbar() { if (window.scrollY > 0) { navbar.setAttribute('data-sticky', 'true'); } else { navbar.setAttribute('data-sticky', 'false'); } } const navbar = document.querySelector("#mainNavbar"); if(navbar) { toggleStickyNavbar(); window.addEventListener("scroll", function () { toggleStickyNavbar(); }); } /***/ }) /******/ }); /************************************************************************/ /******/ // The module cache /******/ var __webpack_module_cache__ = {}; /******/ /******/ // The require function /******/ function __webpack_require__(moduleId) { /******/ // Check if module is in cache /******/ var cachedModule = __webpack_module_cache__[moduleId]; /******/ if (cachedModule !== undefined) { /******/ return cachedModule.exports; /******/ } /******/ // Create a new module (and put it into the cache) /******/ var module = __webpack_module_cache__[moduleId] = { /******/ // no module.id needed /******/ // no module.loaded needed /******/ exports: {} /******/ }; /******/ /******/ // Execute the module function /******/ __webpack_modules__[moduleId](module, module.exports, __webpack_require__); /******/ /******/ // Return the exports of the module /******/ return module.exports; /******/ } /******/ /************************************************************************/ // This entry needs to be wrapped in an IIFE because it needs to be in strict mode. (() => { "use strict"; ;// ./node_modules/flowbite/lib/esm/dom/events.js var Events = /** @class */ (function () { function Events(eventType, eventFunctions) { if (eventFunctions === void 0) { eventFunctions = []; } this._eventType = eventType; this._eventFunctions = eventFunctions; } Events.prototype.init = function () { var _this = this; this._eventFunctions.forEach(function (eventFunction) { if (typeof window !== 'undefined') { window.addEventListener(_this._eventType, eventFunction); } }); }; return Events; }()); /* harmony default export */ const events = (Events); //# sourceMappingURL=events.js.map ;// ./node_modules/flowbite/lib/esm/dom/instances.js var Instances = /** @class */ (function () { function Instances() { this._instances = { Accordion: {}, Carousel: {}, Collapse: {}, Dial: {}, Dismiss: {}, Drawer: {}, Dropdown: {}, Modal: {}, Popover: {}, Tabs: {}, Tooltip: {}, InputCounter: {}, CopyClipboard: {}, Datepicker: {}, }; } Instances.prototype.addInstance = function (component, instance, id, override) { if (override === void 0) { override = false; } if (!this._instances[component]) { console.warn("Flowbite: Component ".concat(component, " does not exist.")); return false; } if (this._instances[component][id] && !override) { console.warn("Flowbite: Instance with ID ".concat(id, " already exists.")); return; } if (override && this._instances[component][id]) { this._instances[component][id].destroyAndRemoveInstance(); } this._instances[component][id ? id : this._generateRandomId()] = instance; }; Instances.prototype.getAllInstances = function () { return this._instances; }; Instances.prototype.getInstances = function (component) { if (!this._instances[component]) { console.warn("Flowbite: Component ".concat(component, " does not exist.")); return false; } return this._instances[component]; }; Instances.prototype.getInstance = function (component, id) { if (!this._componentAndInstanceCheck(component, id)) { return; } if (!this._instances[component][id]) { console.warn("Flowbite: Instance with ID ".concat(id, " does not exist.")); return; } return this._instances[component][id]; }; Instances.prototype.destroyAndRemoveInstance = function (component, id) { if (!this._componentAndInstanceCheck(component, id)) { return; } this.destroyInstanceObject(component, id); this.removeInstance(component, id); }; Instances.prototype.removeInstance = function (component, id) { if (!this._componentAndInstanceCheck(component, id)) { return; } delete this._instances[component][id]; }; Instances.prototype.destroyInstanceObject = function (component, id) { if (!this._componentAndInstanceCheck(component, id)) { return; } this._instances[component][id].destroy(); }; Instances.prototype.instanceExists = function (component, id) { if (!this._instances[component]) { return false; } if (!this._instances[component][id]) { return false; } return true; }; Instances.prototype._generateRandomId = function () { return Math.random().toString(36).substr(2, 9); }; Instances.prototype._componentAndInstanceCheck = function (component, id) { if (!this._instances[component]) { console.warn("Flowbite: Component ".concat(component, " does not exist.")); return false; } if (!this._instances[component][id]) { console.warn("Flowbite: Instance with ID ".concat(id, " does not exist.")); return false; } return true; }; return Instances; }()); var instances = new Instances(); /* harmony default export */ const dom_instances = (instances); if (typeof window !== 'undefined') { window.FlowbiteInstances = instances; } //# sourceMappingURL=instances.js.map ;// ./node_modules/flowbite/lib/esm/components/accordion/index.js var __assign = (undefined && undefined.__assign) || function () { __assign = Object.assign || function(t) { for (var s, i = 1, n = arguments.length; i < n; i++) { s = arguments[i]; for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p]; } return t; }; return __assign.apply(this, arguments); }; var Default = { alwaysOpen: false, activeClasses: 'bg-gray-100 dark:bg-gray-800 text-gray-900 dark:text-white', inactiveClasses: 'text-gray-500 dark:text-gray-400', onOpen: function () { }, onClose: function () { }, onToggle: function () { }, }; var DefaultInstanceOptions = { id: null, override: true, }; var Accordion = /** @class */ (function () { function Accordion(accordionEl, items, options, instanceOptions) { if (accordionEl === void 0) { accordionEl = null; } if (items === void 0) { items = []; } if (options === void 0) { options = Default; } if (instanceOptions === void 0) { instanceOptions = DefaultInstanceOptions; } this._instanceId = instanceOptions.id ? instanceOptions.id : accordionEl.id; this._accordionEl = accordionEl; this._items = items; this._options = __assign(__assign({}, Default), options); this._initialized = false; this.init(); dom_instances.addInstance('Accordion', this, this._instanceId, instanceOptions.override); } Accordion.prototype.init = function () { var _this = this; if (this._items.length && !this._initialized) { // show accordion item based on click this._items.forEach(function (item) { if (item.active) { _this.open(item.id); } var clickHandler = function () { _this.toggle(item.id); }; item.triggerEl.addEventListener('click', clickHandler); // Store the clickHandler in a property of the item for removal later item.clickHandler = clickHandler; }); this._initialized = true; } }; Accordion.prototype.destroy = function () { if (this._items.length && this._initialized) { this._items.forEach(function (item) { item.triggerEl.removeEventListener('click', item.clickHandler); // Clean up by deleting the clickHandler property from the item delete item.clickHandler; }); this._initialized = false; } }; Accordion.prototype.removeInstance = function () { dom_instances.removeInstance('Accordion', this._instanceId); }; Accordion.prototype.destroyAndRemoveInstance = function () { this.destroy(); this.removeInstance(); }; Accordion.prototype.getItem = function (id) { return this._items.filter(function (item) { return item.id === id; })[0]; }; Accordion.prototype.open = function (id) { var _a, _b; var _this = this; var item = this.getItem(id); // don't hide other accordions if always open if (!this._options.alwaysOpen) { this._items.map(function (i) { var _a, _b; if (i !== item) { (_a = i.triggerEl.classList).remove.apply(_a, _this._options.activeClasses.split(' ')); (_b = i.triggerEl.classList).add.apply(_b, _this._options.inactiveClasses.split(' ')); i.targetEl.classList.add('hidden'); i.triggerEl.setAttribute('aria-expanded', 'false'); i.active = false; // rotate icon if set if (i.iconEl) { i.iconEl.classList.add('rotate-180'); } } }); } // show active item (_a = item.triggerEl.classList).add.apply(_a, this._options.activeClasses.split(' ')); (_b = item.triggerEl.classList).remove.apply(_b, this._options.inactiveClasses.split(' ')); item.triggerEl.setAttribute('aria-expanded', 'true'); item.targetEl.classList.remove('hidden'); item.active = true; // rotate icon if set if (item.iconEl) { item.iconEl.classList.remove('rotate-180'); } // callback function this._options.onOpen(this, item); }; Accordion.prototype.toggle = function (id) { var item = this.getItem(id); if (item.active) { this.close(id); } else { this.open(id); } // callback function this._options.onToggle(this, item); }; Accordion.prototype.close = function (id) { var _a, _b; var item = this.getItem(id); (_a = item.triggerEl.classList).remove.apply(_a, this._options.activeClasses.split(' ')); (_b = item.triggerEl.classList).add.apply(_b, this._options.inactiveClasses.split(' ')); item.targetEl.classList.add('hidden'); item.triggerEl.setAttribute('aria-expanded', 'false'); item.active = false; // rotate icon if set if (item.iconEl) { item.iconEl.classList.add('rotate-180'); } // callback function this._options.onClose(this, item); }; Accordion.prototype.updateOnOpen = function (callback) { this._options.onOpen = callback; }; Accordion.prototype.updateOnClose = function (callback) { this._options.onClose = callback; }; Accordion.prototype.updateOnToggle = function (callback) { this._options.onToggle = callback; }; return Accordion; }()); function initAccordions() { document.querySelectorAll('[data-accordion]').forEach(function ($accordionEl) { var alwaysOpen = $accordionEl.getAttribute('data-accordion'); var activeClasses = $accordionEl.getAttribute('data-active-classes'); var inactiveClasses = $accordionEl.getAttribute('data-inactive-classes'); var items = []; $accordionEl .querySelectorAll('[data-accordion-target]') .forEach(function ($triggerEl) { // Consider only items that directly belong to $accordionEl // (to make nested accordions work). if ($triggerEl.closest('[data-accordion]') === $accordionEl) { var item = { id: $triggerEl.getAttribute('data-accordion-target'), triggerEl: $triggerEl, targetEl: document.querySelector($triggerEl.getAttribute('data-accordion-target')), iconEl: $triggerEl.querySelector('[data-accordion-icon]'), active: $triggerEl.getAttribute('aria-expanded') === 'true' ? true : false, }; items.push(item); } }); new Accordion($accordionEl, items, { alwaysOpen: alwaysOpen === 'open' ? true : false, activeClasses: activeClasses ? activeClasses : Default.activeClasses, inactiveClasses: inactiveClasses ? inactiveClasses : Default.inactiveClasses, }); }); } if (typeof window !== 'undefined') { window.Accordion = Accordion; window.initAccordions = initAccordions; } /* harmony default export */ const accordion = ((/* unused pure expression or super */ null && (Accordion))); //# sourceMappingURL=index.js.map ;// ./node_modules/flowbite/lib/esm/components/collapse/index.js var collapse_assign = (undefined && undefined.__assign) || function () { collapse_assign = Object.assign || function(t) { for (var s, i = 1, n = arguments.length; i < n; i++) { s = arguments[i]; for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p]; } return t; }; return collapse_assign.apply(this, arguments); }; var collapse_Default = { onCollapse: function () { }, onExpand: function () { }, onToggle: function () { }, }; var collapse_DefaultInstanceOptions = { id: null, override: true, }; var Collapse = /** @class */ (function () { function Collapse(targetEl, triggerEl, options, instanceOptions) { if (targetEl === void 0) { targetEl = null; } if (triggerEl === void 0) { triggerEl = null; } if (options === void 0) { options = collapse_Default; } if (instanceOptions === void 0) { instanceOptions = collapse_DefaultInstanceOptions; } this._instanceId = instanceOptions.id ? instanceOptions.id : targetEl.id; this._targetEl = targetEl; this._triggerEl = triggerEl; this._options = collapse_assign(collapse_assign({}, collapse_Default), options); this._visible = false; this._initialized = false; this.init(); dom_instances.addInstance('Collapse', this, this._instanceId, instanceOptions.override); } Collapse.prototype.init = function () { var _this = this; if (this._triggerEl && this._targetEl && !this._initialized) { if (this._triggerEl.hasAttribute('aria-expanded')) { this._visible = this._triggerEl.getAttribute('aria-expanded') === 'true'; } else { // fix until v2 not to break previous single collapses which became dismiss this._visible = !this._targetEl.classList.contains('hidden'); } this._clickHandler = function () { _this.toggle(); }; this._triggerEl.addEventListener('click', this._clickHandler); this._initialized = true; } }; Collapse.prototype.destroy = function () { if (this._triggerEl && this._initialized) { this._triggerEl.removeEventListener('click', this._clickHandler); this._initialized = false; } }; Collapse.prototype.removeInstance = function () { dom_instances.removeInstance('Collapse', this._instanceId); }; Collapse.prototype.destroyAndRemoveInstance = function () { this.destroy(); this.removeInstance(); }; Collapse.prototype.collapse = function () { this._targetEl.classList.add('hidden'); if (this._triggerEl) { this._triggerEl.setAttribute('aria-expanded', 'false'); } this._visible = false; // callback function this._options.onCollapse(this); }; Collapse.prototype.expand = function () { this._targetEl.classList.remove('hidden'); if (this._triggerEl) { this._triggerEl.setAttribute('aria-expanded', 'true'); } this._visible = true; // callback function this._options.onExpand(this); }; Collapse.prototype.toggle = function () { if (this._visible) { this.collapse(); } else { this.expand(); } // callback function this._options.onToggle(this); }; Collapse.prototype.updateOnCollapse = function (callback) { this._options.onCollapse = callback; }; Collapse.prototype.updateOnExpand = function (callback) { this._options.onExpand = callback; }; Collapse.prototype.updateOnToggle = function (callback) { this._options.onToggle = callback; }; return Collapse; }()); function initCollapses() { document .querySelectorAll('[data-collapse-toggle]') .forEach(function ($triggerEl) { var targetId = $triggerEl.getAttribute('data-collapse-toggle'); var $targetEl = document.getElementById(targetId); // check if the target element exists if ($targetEl) { if (!dom_instances.instanceExists('Collapse', $targetEl.getAttribute('id'))) { new Collapse($targetEl, $triggerEl); } else { // if instance exists already for the same target element then create a new one with a different trigger element new Collapse($targetEl, $triggerEl, {}, { id: $targetEl.getAttribute('id') + '_' + dom_instances._generateRandomId(), }); } } else { console.error("The target element with id \"".concat(targetId, "\" does not exist. Please check the data-collapse-toggle attribute.")); } }); } if (typeof window !== 'undefined') { window.Collapse = Collapse; window.initCollapses = initCollapses; } /* harmony default export */ const collapse = ((/* unused pure expression or super */ null && (Collapse))); //# sourceMappingURL=index.js.map ;// ./node_modules/flowbite/lib/esm/components/carousel/index.js var carousel_assign = (undefined && undefined.__assign) || function () { carousel_assign = Object.assign || function(t) { for (var s, i = 1, n = arguments.length; i < n; i++) { s = arguments[i]; for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p]; } return t; }; return carousel_assign.apply(this, arguments); }; var carousel_Default = { defaultPosition: 0, indicators: { items: [], activeClasses: 'bg-white dark:bg-gray-800', inactiveClasses: 'bg-white/50 dark:bg-gray-800/50 hover:bg-white dark:hover:bg-gray-800', }, interval: 3000, onNext: function () { }, onPrev: function () { }, onChange: function () { }, }; var carousel_DefaultInstanceOptions = { id: null, override: true, }; var Carousel = /** @class */ (function () { function Carousel(carouselEl, items, options, instanceOptions) { if (carouselEl === void 0) { carouselEl = null; } if (items === void 0) { items = []; } if (options === void 0) { options = carousel_Default; } if (instanceOptions === void 0) { instanceOptions = carousel_DefaultInstanceOptions; } this._instanceId = instanceOptions.id ? instanceOptions.id : carouselEl.id; this._carouselEl = carouselEl; this._items = items; this._options = carousel_assign(carousel_assign(carousel_assign({}, carousel_Default), options), { indicators: carousel_assign(carousel_assign({}, carousel_Default.indicators), options.indicators) }); this._activeItem = this.getItem(this._options.defaultPosition); this._indicators = this._options.indicators.items; this._intervalDuration = this._options.interval; this._intervalInstance = null; this._initialized = false; this.init(); dom_instances.addInstance('Carousel', this, this._instanceId, instanceOptions.override); } /** * initialize carousel and items based on active one */ Carousel.prototype.init = function () { var _this = this; if (this._items.length && !this._initialized) { this._items.map(function (item) { item.el.classList.add('absolute', 'inset-0', 'transition-transform', 'transform'); }); // if no active item is set then first position is default if (this.getActiveItem()) { this.slideTo(this.getActiveItem().position); } else { this.slideTo(0); } this._indicators.map(function (indicator, position) { indicator.el.addEventListener('click', function () { _this.slideTo(position); }); }); this._initialized = true; } }; Carousel.prototype.destroy = function () { if (this._initialized) { this._initialized = false; } }; Carousel.prototype.removeInstance = function () { dom_instances.removeInstance('Carousel', this._instanceId); }; Carousel.prototype.destroyAndRemoveInstance = function () { this.destroy(); this.removeInstance(); }; Carousel.prototype.getItem = function (position) { return this._items[position]; }; /** * Slide to the element based on id * @param {*} position */ Carousel.prototype.slideTo = function (position) { var nextItem = this._items[position]; var rotationItems = { left: nextItem.position === 0 ? this._items[this._items.length - 1] : this._items[nextItem.position - 1], middle: nextItem, right: nextItem.position === this._items.length - 1 ? this._items[0] : this._items[nextItem.position + 1], }; this._rotate(rotationItems); this._setActiveItem(nextItem); if (this._intervalInstance) { this.pause(); this.cycle(); } this._options.onChange(this); }; /** * Based on the currently active item it will go to the next position */ Carousel.prototype.next = function () { var activeItem = this.getActiveItem(); var nextItem = null; // check if last item if (activeItem.position === this._items.length - 1) { nextItem = this._items[0]; } else { nextItem = this._items[activeItem.position + 1]; } this.slideTo(nextItem.position); // callback function this._options.onNext(this); }; /** * Based on the currently active item it will go to the previous position */ Carousel.prototype.prev = function () { var activeItem = this.getActiveItem(); var prevItem = null; // check if first item if (activeItem.position === 0) { prevItem = this._items[this._items.length - 1]; } else { prevItem = this._items[activeItem.position - 1]; } this.slideTo(prevItem.position); // callback function this._options.onPrev(this); }; /** * This method applies the transform classes based on the left, middle, and right rotation carousel items * @param {*} rotationItems */ Carousel.prototype._rotate = function (rotationItems) { // reset this._items.map(function (item) { item.el.classList.add('hidden'); }); // Handling the case when there is only one item if (this._items.length === 1) { rotationItems.middle.el.classList.remove('-translate-x-full', 'translate-x-full', 'translate-x-0', 'hidden', 'z-10'); rotationItems.middle.el.classList.add('translate-x-0', 'z-20'); return; } // left item (previously active) rotationItems.left.el.classList.remove('-translate-x-full', 'translate-x-full', 'translate-x-0', 'hidden', 'z-20'); rotationItems.left.el.classList.add('-translate-x-full', 'z-10'); // currently active item rotationItems.middle.el.classList.remove('-translate-x-full', 'translate-x-full', 'translate-x-0', 'hidden', 'z-10'); rotationItems.middle.el.classList.add('translate-x-0', 'z-30'); // right item (upcoming active) rotationItems.right.el.classList.remove('-translate-x-full', 'translate-x-full', 'translate-x-0', 'hidden', 'z-30'); rotationItems.right.el.classList.add('translate-x-full', 'z-20'); }; /** * Set an interval to cycle through the carousel items */ Carousel.prototype.cycle = function () { var _this = this; if (typeof window !== 'undefined') { this._intervalInstance = window.setInterval(function () { _this.next(); }, this._intervalDuration); } }; /** * Clears the cycling interval */ Carousel.prototype.pause = function () { clearInterval(this._intervalInstance); }; /** * Get the currently active item */ Carousel.prototype.getActiveItem = function () { return this._activeItem; }; /** * Set the currently active item and data attribute * @param {*} position */ Carousel.prototype._setActiveItem = function (item) { var _a, _b; var _this = this; this._activeItem = item; var position = item.position; // update the indicators if available if (this._indicators.length) { this._indicators.map(function (indicator) { var _a, _b; indicator.el.setAttribute('aria-current', 'false'); (_a = indicator.el.classList).remove.apply(_a, _this._options.indicators.activeClasses.split(' ')); (_b = indicator.el.classList).add.apply(_b, _this._options.indicators.inactiveClasses.split(' ')); }); (_a = this._indicators[position].el.classList).add.apply(_a, this._options.indicators.activeClasses.split(' ')); (_b = this._indicators[position].el.classList).remove.apply(_b, this._options.indicators.inactiveClasses.split(' ')); this._indicators[position].el.setAttribute('aria-current', 'true'); } }; Carousel.prototype.updateOnNext = function (callback) { this._options.onNext = callback; }; Carousel.prototype.updateOnPrev = function (callback) { this._options.onPrev = callback; }; Carousel.prototype.updateOnChange = function (callback) { this._options.onChange = callback; }; return Carousel; }()); function initCarousels() { document.querySelectorAll('[data-carousel]').forEach(function ($carouselEl) { var interval = $carouselEl.getAttribute('data-carousel-interval'); var slide = $carouselEl.getAttribute('data-carousel') === 'slide' ? true : false; var items = []; var defaultPosition = 0; if ($carouselEl.querySelectorAll('[data-carousel-item]').length) { Array.from($carouselEl.querySelectorAll('[data-carousel-item]')).map(function ($carouselItemEl, position) { items.push({ position: position, el: $carouselItemEl, }); if ($carouselItemEl.getAttribute('data-carousel-item') === 'active') { defaultPosition = position; } }); } var indicators = []; if ($carouselEl.querySelectorAll('[data-carousel-slide-to]').length) { Array.from($carouselEl.querySelectorAll('[data-carousel-slide-to]')).map(function ($indicatorEl) { indicators.push({ position: parseInt($indicatorEl.getAttribute('data-carousel-slide-to')), el: $indicatorEl, }); }); } var carousel = new Carousel($carouselEl, items, { defaultPosition: defaultPosition, indicators: { items: indicators, }, interval: interval ? interval : carousel_Default.interval, }); if (slide) { carousel.cycle(); } // check for controls var carouselNextEl = $carouselEl.querySelector('[data-carousel-next]'); var carouselPrevEl = $carouselEl.querySelector('[data-carousel-prev]'); if (carouselNextEl) { carouselNextEl.addEventListener('click', function () { carousel.next(); }); } if (carouselPrevEl) { carouselPrevEl.addEventListener('click', function () { carousel.prev(); }); } }); } if (typeof window !== 'undefined') { window.Carousel = Carousel; window.initCarousels = initCarousels; } /* harmony default export */ const carousel = ((/* unused pure expression or super */ null && (Carousel))); //# sourceMappingURL=index.js.map ;// ./node_modules/flowbite/lib/esm/components/dismiss/index.js var dismiss_assign = (undefined && undefined.__assign) || function () { dismiss_assign = Object.assign || function(t) { for (var s, i = 1, n = arguments.length; i < n; i++) { s = arguments[i]; for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p]; } return t; }; return dismiss_assign.apply(this, arguments); }; var dismiss_Default = { transition: 'transition-opacity', duration: 300, timing: 'ease-out', onHide: function () { }, }; var dismiss_DefaultInstanceOptions = { id: null, override: true, }; var Dismiss = /** @class */ (function () { function Dismiss(targetEl, triggerEl, options, instanceOptions) { if (targetEl === void 0) { targetEl = null; } if (triggerEl === void 0) { triggerEl = null; } if (options === void 0) { options = dismiss_Default; } if (instanceOptions === void 0) { instanceOptions = dismiss_DefaultInstanceOptions; } this._instanceId = instanceOptions.id ? instanceOptions.id : targetEl.id; this._targetEl = targetEl; this._triggerEl = triggerEl; this._options = dismiss_assign(dismiss_assign({}, dismiss_Default), options); this._initialized = false; this.init(); dom_instances.addInstance('Dismiss', this, this._instanceId, instanceOptions.override); } Dismiss.prototype.init = function () { var _this = this; if (this._triggerEl && this._targetEl && !this._initialized) { this._clickHandler = function () { _this.hide(); }; this._triggerEl.addEventListener('click', this._clickHandler); this._initialized = true; } }; Dismiss.prototype.destroy = function () { if (this._triggerEl && this._initialized) { this._triggerEl.removeEventListener('click', this._clickHandler); this._initialized = false; } }; Dismiss.prototype.removeInstance = function () { dom_instances.removeInstance('Dismiss', this._instanceId); }; Dismiss.prototype.destroyAndRemoveInstance = function () { this.destroy(); this.removeInstance(); }; Dismiss.prototype.hide = function () { var _this = this; this._targetEl.classList.add(this._options.transition, "duration-".concat(this._options.duration), this._options.timing, 'opacity-0'); setTimeout(function () { _this._targetEl.classList.add('hidden'); }, this._options.duration); // callback function this._options.onHide(this, this._targetEl); }; Dismiss.prototype.updateOnHide = function (callback) { this._options.onHide = callback; }; return Dismiss; }()); function initDismisses() { document.querySelectorAll('[data-dismiss-target]').forEach(function ($triggerEl) { var targetId = $triggerEl.getAttribute('data-dismiss-target'); var $dismissEl = document.querySelector(targetId); if ($dismissEl) { new Dismiss($dismissEl, $triggerEl); } else { console.error("The dismiss element with id \"".concat(targetId, "\" does not exist. Please check the data-dismiss-target attribute.")); } }); } if (typeof window !== 'undefined') { window.Dismiss = Dismiss; window.initDismisses = initDismisses; } /* harmony default export */ const dismiss = ((/* unused pure expression or super */ null && (Dismiss))); //# sourceMappingURL=index.js.map ;// ./node_modules/@popperjs/core/lib/dom-utils/getWindow.js function getWindow(node) { if (node == null) { return window; } if (node.toString() !== '[object Window]') { var ownerDocument = node.ownerDocument; return ownerDocument ? ownerDocument.defaultView || window : window; } return node; } ;// ./node_modules/@popperjs/core/lib/dom-utils/instanceOf.js function isElement(node) { var OwnElement = getWindow(node).Element; return node instanceof OwnElement || node instanceof Element; } function isHTMLElement(node) { var OwnElement = getWindow(node).HTMLElement; return node instanceof OwnElement || node instanceof HTMLElement; } function isShadowRoot(node) { // IE 11 has no ShadowRoot if (typeof ShadowRoot === 'undefined') { return false; } var OwnElement = getWindow(node).ShadowRoot; return node instanceof OwnElement || node instanceof ShadowRoot; } ;// ./node_modules/@popperjs/core/lib/utils/math.js var math_max = Math.max; var math_min = Math.min; var round = Math.round; ;// ./node_modules/@popperjs/core/lib/utils/userAgent.js function getUAString() { var uaData = navigator.userAgentData; if (uaData != null && uaData.brands && Array.isArray(uaData.brands)) { return uaData.brands.map(function (item) { return item.brand + "/" + item.version; }).join(' '); } return navigator.userAgent; } ;// ./node_modules/@popperjs/core/lib/dom-utils/isLayoutViewport.js function isLayoutViewport() { return !/^((?!chrome|android).)*safari/i.test(getUAString()); } ;// ./node_modules/@popperjs/core/lib/dom-utils/getBoundingClientRect.js function getBoundingClientRect(element, includeScale, isFixedStrategy) { if (includeScale === void 0) { includeScale = false; } if (isFixedStrategy === void 0) { isFixedStrategy = false; } var clientRect = element.getBoundingClientRect(); var scaleX = 1; var scaleY = 1; if (includeScale && isHTMLElement(element)) { scaleX = element.offsetWidth > 0 ? round(clientRect.width) / element.offsetWidth || 1 : 1; scaleY = element.offsetHeight > 0 ? round(clientRect.height) / element.offsetHeight || 1 : 1; } var _ref = isElement(element) ? getWindow(element) : window, visualViewport = _ref.visualViewport; var addVisualOffsets = !isLayoutViewport() && isFixedStrategy; var x = (clientRect.left + (addVisualOffsets && visualViewport ? visualViewport.offsetLeft : 0)) / scaleX; var y = (clientRect.top + (addVisualOffsets && visualViewport ? visualViewport.offsetTop : 0)) / scaleY; var width = clientRect.width / scaleX; var height = clientRect.height / scaleY; return { width: width, height: height, top: y, right: x + width, bottom: y + height, left: x, x: x, y: y }; } ;// ./node_modules/@popperjs/core/lib/dom-utils/getWindowScroll.js function getWindowScroll(node) { var win = getWindow(node); var scrollLeft = win.pageXOffset; var scrollTop = win.pageYOffset; return { scrollLeft: scrollLeft, scrollTop: scrollTop }; } ;// ./node_modules/@popperjs/core/lib/dom-utils/getHTMLElementScroll.js function getHTMLElementScroll(element) { return { scrollLeft: element.scrollLeft, scrollTop: element.scrollTop }; } ;// ./node_modules/@popperjs/core/lib/dom-utils/getNodeScroll.js function getNodeScroll(node) { if (node === getWindow(node) || !isHTMLElement(node)) { return getWindowScroll(node); } else { return getHTMLElementScroll(node); } } ;// ./node_modules/@popperjs/core/lib/dom-utils/getNodeName.js function getNodeName(element) { return element ? (element.nodeName || '').toLowerCase() : null; } ;// ./node_modules/@popperjs/core/lib/dom-utils/getDocumentElement.js function getDocumentElement(element) { // $FlowFixMe[incompatible-return]: assume body is always available return ((isElement(element) ? element.ownerDocument : // $FlowFixMe[prop-missing] element.document) || window.document).documentElement; } ;// ./node_modules/@popperjs/core/lib/dom-utils/getWindowScrollBarX.js function getWindowScrollBarX(element) { // If has a CSS width greater than the viewport, then this will be // incorrect for RTL. // Popper 1 is broken in this case and never had a bug report so let's assume // it's not an issue. I don't think anyone ever specifies width on // anyway. // Browsers where the left scrollbar doesn't cause an issue report `0` for // this (e.g. Edge 2019, IE11, Safari) return getBoundingClientRect(getDocumentElement(element)).left + getWindowScroll(element).scrollLeft; } ;// ./node_modules/@popperjs/core/lib/dom-utils/getComputedStyle.js function getComputedStyle(element) { return getWindow(element).getComputedStyle(element); } ;// ./node_modules/@popperjs/core/lib/dom-utils/isScrollParent.js function isScrollParent(element) { // Firefox wants us to check `-x` and `-y` variations as well var _getComputedStyle = getComputedStyle(element), overflow = _getComputedStyle.overflow, overflowX = _getComputedStyle.overflowX, overflowY = _getComputedStyle.overflowY; return /auto|scroll|overlay|hidden/.test(overflow + overflowY + overflowX); } ;// ./node_modules/@popperjs/core/lib/dom-utils/getCompositeRect.js function isElementScaled(element) { var rect = element.getBoundingClientRect(); var scaleX = round(rect.width) / element.offsetWidth || 1; var scaleY = round(rect.height) / element.offsetHeight || 1; return scaleX !== 1 || scaleY !== 1; } // Returns the composite rect of an element relative to its offsetParent. // Composite means it takes into account transforms as well as layout. function getCompositeRect(elementOrVirtualElement, offsetParent, isFixed) { if (isFixed === void 0) { isFixed = false; } var isOffsetParentAnElement = isHTMLElement(offsetParent); var offsetParentIsScaled = isHTMLElement(offsetParent) && isElementScaled(offsetParent); var documentElement = getDocumentElement(offsetParent); var rect = getBoundingClientRect(elementOrVirtualElement, offsetParentIsScaled, isFixed); var scroll = { scrollLeft: 0, scrollTop: 0 }; var offsets = { x: 0, y: 0 }; if (isOffsetParentAnElement || !isOffsetParentAnElement && !isFixed) { if (getNodeName(offsetParent) !== 'body' || // https://github.com/popperjs/popper-core/issues/1078 isScrollParent(documentElement)) { scroll = getNodeScroll(offsetParent); } if (isHTMLElement(offsetParent)) { offsets = getBoundingClientRect(offsetParent, true); offsets.x += offsetParent.clientLeft; offsets.y += offsetParent.clientTop; } else if (documentElement) { offsets.x = getWindowScrollBarX(documentElement); } } return { x: rect.left + scroll.scrollLeft - offsets.x, y: rect.top + scroll.scrollTop - offsets.y, width: rect.width, height: rect.height }; } ;// ./node_modules/@popperjs/core/lib/dom-utils/getLayoutRect.js // Returns the layout rect of an element relative to its offsetParent. Layout // means it doesn't take into account transforms. function getLayoutRect(element) { var clientRect = getBoundingClientRect(element); // Use the clientRect sizes if it's not been transformed. // Fixes https://github.com/popperjs/popper-core/issues/1223 var width = element.offsetWidth; var height = element.offsetHeight; if (Math.abs(clientRect.width - width) <= 1) { width = clientRect.width; } if (Math.abs(clientRect.height - height) <= 1) { height = clientRect.height; } return { x: element.offsetLeft, y: element.offsetTop, width: width, height: height }; } ;// ./node_modules/@popperjs/core/lib/dom-utils/getParentNode.js function getParentNode(element) { if (getNodeName(element) === 'html') { return element; } return (// this is a quicker (but less type safe) way to save quite some bytes from the bundle // $FlowFixMe[incompatible-return] // $FlowFixMe[prop-missing] element.assignedSlot || // step into the shadow DOM of the parent of a slotted node element.parentNode || ( // DOM Element detected isShadowRoot(element) ? element.host : null) || // ShadowRoot detected // $FlowFixMe[incompatible-call]: HTMLElement is a Node getDocumentElement(element) // fallback ); } ;// ./node_modules/@popperjs/core/lib/dom-utils/getScrollParent.js function getScrollParent(node) { if (['html', 'body', '#document'].indexOf(getNodeName(node)) >= 0) { // $FlowFixMe[incompatible-return]: assume body is always available return node.ownerDocument.body; } if (isHTMLElement(node) && isScrollParent(node)) { return node; } return getScrollParent(getParentNode(node)); } ;// ./node_modules/@popperjs/core/lib/dom-utils/listScrollParents.js /* given a DOM element, return the list of all scroll parents, up the list of ancesors until we get to the top window object. This list is what we attach scroll listeners to, because if any of these parent elements scroll, we'll need to re-calculate the reference element's position. */ function listScrollParents(element, list) { var _element$ownerDocumen; if (list === void 0) { list = []; } var scrollParent = getScrollParent(element); var isBody = scrollParent === ((_element$ownerDocumen = element.ownerDocument) == null ? void 0 : _element$ownerDocumen.body); var win = getWindow(scrollParent); var target = isBody ? [win].concat(win.visualViewport || [], isScrollParent(scrollParent) ? scrollParent : []) : scrollParent; var updatedList = list.concat(target); return isBody ? updatedList : // $FlowFixMe[incompatible-call]: isBody tells us target will be an HTMLElement here updatedList.concat(listScrollParents(getParentNode(target))); } ;// ./node_modules/@popperjs/core/lib/dom-utils/isTableElement.js function isTableElement(element) { return ['table', 'td', 'th'].indexOf(getNodeName(element)) >= 0; } ;// ./node_modules/@popperjs/core/lib/dom-utils/getOffsetParent.js function getTrueOffsetParent(element) { if (!isHTMLElement(element) || // https://github.com/popperjs/popper-core/issues/837 getComputedStyle(element).position === 'fixed') { return null; } return element.offsetParent; } // `.offsetParent` reports `null` for fixed elements, while absolute elements // return the containing block function getContainingBlock(element) { var isFirefox = /firefox/i.test(getUAString()); var isIE = /Trident/i.test(getUAString()); if (isIE && isHTMLElement(element)) { // In IE 9, 10 and 11 fixed elements containing block is always established by the viewport var elementCss = getComputedStyle(element); if (elementCss.position === 'fixed') { return null; } } var currentNode = getParentNode(element); if (isShadowRoot(currentNode)) { currentNode = currentNode.host; } while (isHTMLElement(currentNode) && ['html', 'body'].indexOf(getNodeName(currentNode)) < 0) { var css = getComputedStyle(currentNode); // This is non-exhaustive but covers the most common CSS properties that // create a containing block. // https://developer.mozilla.org/en-US/docs/Web/CSS/Containing_block#identifying_the_containing_block if (css.transform !== 'none' || css.perspective !== 'none' || css.contain === 'paint' || ['transform', 'perspective'].indexOf(css.willChange) !== -1 || isFirefox && css.willChange === 'filter' || isFirefox && css.filter && css.filter !== 'none') { return currentNode; } else { currentNode = currentNode.parentNode; } } return null; } // Gets the closest ancestor positioned element. Handles some edge cases, // such as table ancestors and cross browser bugs. function getOffsetParent(element) { var window = getWindow(element); var offsetParent = getTrueOffsetParent(element); while (offsetParent && isTableElement(offsetParent) && getComputedStyle(offsetParent).position === 'static') { offsetParent = getTrueOffsetParent(offsetParent); } if (offsetParent && (getNodeName(offsetParent) === 'html' || getNodeName(offsetParent) === 'body' && getComputedStyle(offsetParent).position === 'static')) { return window; } return offsetParent || getContainingBlock(element) || window; } ;// ./node_modules/@popperjs/core/lib/enums.js var enums_top = 'top'; var bottom = 'bottom'; var right = 'right'; var left = 'left'; var auto = 'auto'; var basePlacements = [enums_top, bottom, right, left]; var start = 'start'; var end = 'end'; var clippingParents = 'clippingParents'; var viewport = 'viewport'; var popper = 'popper'; var reference = 'reference'; var variationPlacements = /*#__PURE__*/basePlacements.reduce(function (acc, placement) { return acc.concat([placement + "-" + start, placement + "-" + end]); }, []); var enums_placements = /*#__PURE__*/[].concat(basePlacements, [auto]).reduce(function (acc, placement) { return acc.concat([placement, placement + "-" + start, placement + "-" + end]); }, []); // modifiers that need to read the DOM var beforeRead = 'beforeRead'; var read = 'read'; var afterRead = 'afterRead'; // pure-logic modifiers var beforeMain = 'beforeMain'; var main = 'main'; var afterMain = 'afterMain'; // modifier with the purpose to write to the DOM (or write into a framework state) var beforeWrite = 'beforeWrite'; var write = 'write'; var afterWrite = 'afterWrite'; var modifierPhases = [beforeRead, read, afterRead, beforeMain, main, afterMain, beforeWrite, write, afterWrite]; ;// ./node_modules/@popperjs/core/lib/utils/orderModifiers.js // source: https://stackoverflow.com/questions/49875255 function order(modifiers) { var map = new Map(); var visited = new Set(); var result = []; modifiers.forEach(function (modifier) { map.set(modifier.name, modifier); }); // On visiting object, check for its dependencies and visit them recursively function sort(modifier) { visited.add(modifier.name); var requires = [].concat(modifier.requires || [], modifier.requiresIfExists || []); requires.forEach(function (dep) { if (!visited.has(dep)) { var depModifier = map.get(dep); if (depModifier) { sort(depModifier); } } }); result.push(modifier); } modifiers.forEach(function (modifier) { if (!visited.has(modifier.name)) { // check for visited object sort(modifier); } }); return result; } function orderModifiers(modifiers) { // order based on dependencies var orderedModifiers = order(modifiers); // order based on phase return modifierPhases.reduce(function (acc, phase) { return acc.concat(orderedModifiers.filter(function (modifier) { return modifier.phase === phase; })); }, []); } ;// ./node_modules/@popperjs/core/lib/utils/debounce.js function debounce(fn) { var pending; return function () { if (!pending) { pending = new Promise(function (resolve) { Promise.resolve().then(function () { pending = undefined; resolve(fn()); }); }); } return pending; }; } ;// ./node_modules/@popperjs/core/lib/utils/mergeByName.js function mergeByName(modifiers) { var merged = modifiers.reduce(function (merged, current) { var existing = merged[current.name]; merged[current.name] = existing ? Object.assign({}, existing, current, { options: Object.assign({}, existing.options, current.options), data: Object.assign({}, existing.data, current.data) }) : current; return merged; }, {}); // IE11 does not support Object.values return Object.keys(merged).map(function (key) { return merged[key]; }); } ;// ./node_modules/@popperjs/core/lib/createPopper.js var DEFAULT_OPTIONS = { placement: 'bottom', modifiers: [], strategy: 'absolute' }; function areValidElements() { for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) { args[_key] = arguments[_key]; } return !args.some(function (element) { return !(element && typeof element.getBoundingClientRect === 'function'); }); } function popperGenerator(generatorOptions) { if (generatorOptions === void 0) { generatorOptions = {}; } var _generatorOptions = generatorOptions, _generatorOptions$def = _generatorOptions.defaultModifiers, defaultModifiers = _generatorOptions$def === void 0 ? [] : _generatorOptions$def, _generatorOptions$def2 = _generatorOptions.defaultOptions, defaultOptions = _generatorOptions$def2 === void 0 ? DEFAULT_OPTIONS : _generatorOptions$def2; return function createPopper(reference, popper, options) { if (options === void 0) { options = defaultOptions; } var state = { placement: 'bottom', orderedModifiers: [], options: Object.assign({}, DEFAULT_OPTIONS, defaultOptions), modifiersData: {}, elements: { reference: reference, popper: popper }, attributes: {}, styles: {} }; var effectCleanupFns = []; var isDestroyed = false; var instance = { state: state, setOptions: function setOptions(setOptionsAction) { var options = typeof setOptionsAction === 'function' ? setOptionsAction(state.options) : setOptionsAction; cleanupModifierEffects(); state.options = Object.assign({}, defaultOptions, state.options, options); state.scrollParents = { reference: isElement(reference) ? listScrollParents(reference) : reference.contextElement ? listScrollParents(reference.contextElement) : [], popper: listScrollParents(popper) }; // Orders the modifiers based on their dependencies and `phase` // properties var orderedModifiers = orderModifiers(mergeByName([].concat(defaultModifiers, state.options.modifiers))); // Strip out disabled modifiers state.orderedModifiers = orderedModifiers.filter(function (m) { return m.enabled; }); runModifierEffects(); return instance.update(); }, // Sync update – it will always be executed, even if not necessary. This // is useful for low frequency updates where sync behavior simplifies the // logic. // For high frequency updates (e.g. `resize` and `scroll` events), always // prefer the async Popper#update method forceUpdate: function forceUpdate() { if (isDestroyed) { return; } var _state$elements = state.elements, reference = _state$elements.reference, popper = _state$elements.popper; // Don't proceed if `reference` or `popper` are not valid elements // anymore if (!areValidElements(reference, popper)) { return; } // Store the reference and popper rects to be read by modifiers state.rects = { reference: getCompositeRect(reference, getOffsetParent(popper), state.options.strategy === 'fixed'), popper: getLayoutRect(popper) }; // Modifiers have the ability to reset the current update cycle. The // most common use case for this is the `flip` modifier changing the // placement, which then needs to re-run all the modifiers, because the // logic was previously ran for the previous placement and is therefore // stale/incorrect state.reset = false; state.placement = state.options.placement; // On each update cycle, the `modifiersData` property for each modifier // is filled with the initial data specified by the modifier. This means // it doesn't persist and is fresh on each update. // To ensure persistent data, use `${name}#persistent` state.orderedModifiers.forEach(function (modifier) { return state.modifiersData[modifier.name] = Object.assign({}, modifier.data); }); for (var index = 0; index < state.orderedModifiers.length; index++) { if (state.reset === true) { state.reset = false; index = -1; continue; } var _state$orderedModifie = state.orderedModifiers[index], fn = _state$orderedModifie.fn, _state$orderedModifie2 = _state$orderedModifie.options, _options = _state$orderedModifie2 === void 0 ? {} : _state$orderedModifie2, name = _state$orderedModifie.name; if (typeof fn === 'function') { state = fn({ state: state, options: _options, name: name, instance: instance }) || state; } } }, // Async and optimistically optimized update – it will not be executed if // not necessary (debounced to run at most once-per-tick) update: debounce(function () { return new Promise(function (resolve) { instance.forceUpdate(); resolve(state); }); }), destroy: function destroy() { cleanupModifierEffects(); isDestroyed = true; } }; if (!areValidElements(reference, popper)) { return instance; } instance.setOptions(options).then(function (state) { if (!isDestroyed && options.onFirstUpdate) { options.onFirstUpdate(state); } }); // Modifiers have the ability to execute arbitrary code before the first // update cycle runs. They will be executed in the same order as the update // cycle. This is useful when a modifier adds some persistent data that // other modifiers need to use, but the modifier is run after the dependent // one. function runModifierEffects() { state.orderedModifiers.forEach(function (_ref) { var name = _ref.name, _ref$options = _ref.options, options = _ref$options === void 0 ? {} : _ref$options, effect = _ref.effect; if (typeof effect === 'function') { var cleanupFn = effect({ state: state, name: name, instance: instance, options: options }); var noopFn = function noopFn() {}; effectCleanupFns.push(cleanupFn || noopFn); } }); } function cleanupModifierEffects() { effectCleanupFns.forEach(function (fn) { return fn(); }); effectCleanupFns = []; } return instance; }; } var createPopper = /*#__PURE__*/(/* unused pure expression or super */ null && (popperGenerator())); // eslint-disable-next-line import/no-unused-modules ;// ./node_modules/@popperjs/core/lib/modifiers/eventListeners.js // eslint-disable-next-line import/no-unused-modules var passive = { passive: true }; function effect(_ref) { var state = _ref.state, instance = _ref.instance, options = _ref.options; var _options$scroll = options.scroll, scroll = _options$scroll === void 0 ? true : _options$scroll, _options$resize = options.resize, resize = _options$resize === void 0 ? true : _options$resize; var window = getWindow(state.elements.popper); var scrollParents = [].concat(state.scrollParents.reference, state.scrollParents.popper); if (scroll) { scrollParents.forEach(function (scrollParent) { scrollParent.addEventListener('scroll', instance.update, passive); }); } if (resize) { window.addEventListener('resize', instance.update, passive); } return function () { if (scroll) { scrollParents.forEach(function (scrollParent) { scrollParent.removeEventListener('scroll', instance.update, passive); }); } if (resize) { window.removeEventListener('resize', instance.update, passive); } }; } // eslint-disable-next-line import/no-unused-modules /* harmony default export */ const eventListeners = ({ name: 'eventListeners', enabled: true, phase: 'write', fn: function fn() {}, effect: effect, data: {} }); ;// ./node_modules/@popperjs/core/lib/utils/getBasePlacement.js function getBasePlacement(placement) { return placement.split('-')[0]; } ;// ./node_modules/@popperjs/core/lib/utils/getVariation.js function getVariation(placement) { return placement.split('-')[1]; } ;// ./node_modules/@popperjs/core/lib/utils/getMainAxisFromPlacement.js function getMainAxisFromPlacement(placement) { return ['top', 'bottom'].indexOf(placement) >= 0 ? 'x' : 'y'; } ;// ./node_modules/@popperjs/core/lib/utils/computeOffsets.js function computeOffsets(_ref) { var reference = _ref.reference, element = _ref.element, placement = _ref.placement; var basePlacement = placement ? getBasePlacement(placement) : null; var variation = placement ? getVariation(placement) : null; var commonX = reference.x + reference.width / 2 - element.width / 2; var commonY = reference.y + reference.height / 2 - element.height / 2; var offsets; switch (basePlacement) { case enums_top: offsets = { x: commonX, y: reference.y - element.height }; break; case bottom: offsets = { x: commonX, y: reference.y + reference.height }; break; case right: offsets = { x: reference.x + reference.width, y: commonY }; break; case left: offsets = { x: reference.x - element.width, y: commonY }; break; default: offsets = { x: reference.x, y: reference.y }; } var mainAxis = basePlacement ? getMainAxisFromPlacement(basePlacement) : null; if (mainAxis != null) { var len = mainAxis === 'y' ? 'height' : 'width'; switch (variation) { case start: offsets[mainAxis] = offsets[mainAxis] - (reference[len] / 2 - element[len] / 2); break; case end: offsets[mainAxis] = offsets[mainAxis] + (reference[len] / 2 - element[len] / 2); break; default: } } return offsets; } ;// ./node_modules/@popperjs/core/lib/modifiers/popperOffsets.js function popperOffsets(_ref) { var state = _ref.state, name = _ref.name; // Offsets are the actual position the popper needs to have to be // properly positioned near its reference element // This is the most basic placement, and will be adjusted by // the modifiers in the next step state.modifiersData[name] = computeOffsets({ reference: state.rects.reference, element: state.rects.popper, strategy: 'absolute', placement: state.placement }); } // eslint-disable-next-line import/no-unused-modules /* harmony default export */ const modifiers_popperOffsets = ({ name: 'popperOffsets', enabled: true, phase: 'read', fn: popperOffsets, data: {} }); ;// ./node_modules/@popperjs/core/lib/modifiers/computeStyles.js // eslint-disable-next-line import/no-unused-modules var unsetSides = { top: 'auto', right: 'auto', bottom: 'auto', left: 'auto' }; // Round the offsets to the nearest suitable subpixel based on the DPR. // Zooming can change the DPR, but it seems to report a value that will // cleanly divide the values into the appropriate subpixels. function roundOffsetsByDPR(_ref, win) { var x = _ref.x, y = _ref.y; var dpr = win.devicePixelRatio || 1; return { x: round(x * dpr) / dpr || 0, y: round(y * dpr) / dpr || 0 }; } function mapToStyles(_ref2) { var _Object$assign2; var popper = _ref2.popper, popperRect = _ref2.popperRect, placement = _ref2.placement, variation = _ref2.variation, offsets = _ref2.offsets, position = _ref2.position, gpuAcceleration = _ref2.gpuAcceleration, adaptive = _ref2.adaptive, roundOffsets = _ref2.roundOffsets, isFixed = _ref2.isFixed; var _offsets$x = offsets.x, x = _offsets$x === void 0 ? 0 : _offsets$x, _offsets$y = offsets.y, y = _offsets$y === void 0 ? 0 : _offsets$y; var _ref3 = typeof roundOffsets === 'function' ? roundOffsets({ x: x, y: y }) : { x: x, y: y }; x = _ref3.x; y = _ref3.y; var hasX = offsets.hasOwnProperty('x'); var hasY = offsets.hasOwnProperty('y'); var sideX = left; var sideY = enums_top; var win = window; if (adaptive) { var offsetParent = getOffsetParent(popper); var heightProp = 'clientHeight'; var widthProp = 'clientWidth'; if (offsetParent === getWindow(popper)) { offsetParent = getDocumentElement(popper); if (getComputedStyle(offsetParent).position !== 'static' && position === 'absolute') { heightProp = 'scrollHeight'; widthProp = 'scrollWidth'; } } // $FlowFixMe[incompatible-cast]: force type refinement, we compare offsetParent with window above, but Flow doesn't detect it offsetParent = offsetParent; if (placement === enums_top || (placement === left || placement === right) && variation === end) { sideY = bottom; var offsetY = isFixed && offsetParent === win && win.visualViewport ? win.visualViewport.height : // $FlowFixMe[prop-missing] offsetParent[heightProp]; y -= offsetY - popperRect.height; y *= gpuAcceleration ? 1 : -1; } if (placement === left || (placement === enums_top || placement === bottom) && variation === end) { sideX = right; var offsetX = isFixed && offsetParent === win && win.visualViewport ? win.visualViewport.width : // $FlowFixMe[prop-missing] offsetParent[widthProp]; x -= offsetX - popperRect.width; x *= gpuAcceleration ? 1 : -1; } } var commonStyles = Object.assign({ position: position }, adaptive && unsetSides); var _ref4 = roundOffsets === true ? roundOffsetsByDPR({ x: x, y: y }, getWindow(popper)) : { x: x, y: y }; x = _ref4.x; y = _ref4.y; if (gpuAcceleration) { var _Object$assign; return Object.assign({}, commonStyles, (_Object$assign = {}, _Object$assign[sideY] = hasY ? '0' : '', _Object$assign[sideX] = hasX ? '0' : '', _Object$assign.transform = (win.devicePixelRatio || 1) <= 1 ? "translate(" + x + "px, " + y + "px)" : "translate3d(" + x + "px, " + y + "px, 0)", _Object$assign)); } return Object.assign({}, commonStyles, (_Object$assign2 = {}, _Object$assign2[sideY] = hasY ? y + "px" : '', _Object$assign2[sideX] = hasX ? x + "px" : '', _Object$assign2.transform = '', _Object$assign2)); } function computeStyles(_ref5) { var state = _ref5.state, options = _ref5.options; var _options$gpuAccelerat = options.gpuAcceleration, gpuAcceleration = _options$gpuAccelerat === void 0 ? true : _options$gpuAccelerat, _options$adaptive = options.adaptive, adaptive = _options$adaptive === void 0 ? true : _options$adaptive, _options$roundOffsets = options.roundOffsets, roundOffsets = _options$roundOffsets === void 0 ? true : _options$roundOffsets; var commonStyles = { placement: getBasePlacement(state.placement), variation: getVariation(state.placement), popper: state.elements.popper, popperRect: state.rects.popper, gpuAcceleration: gpuAcceleration, isFixed: state.options.strategy === 'fixed' }; if (state.modifiersData.popperOffsets != null) { state.styles.popper = Object.assign({}, state.styles.popper, mapToStyles(Object.assign({}, commonStyles, { offsets: state.modifiersData.popperOffsets, position: state.options.strategy, adaptive: adaptive, roundOffsets: roundOffsets }))); } if (state.modifiersData.arrow != null) { state.styles.arrow = Object.assign({}, state.styles.arrow, mapToStyles(Object.assign({}, commonStyles, { offsets: state.modifiersData.arrow, position: 'absolute', adaptive: false, roundOffsets: roundOffsets }))); } state.attributes.popper = Object.assign({}, state.attributes.popper, { 'data-popper-placement': state.placement }); } // eslint-disable-next-line import/no-unused-modules /* harmony default export */ const modifiers_computeStyles = ({ name: 'computeStyles', enabled: true, phase: 'beforeWrite', fn: computeStyles, data: {} }); ;// ./node_modules/@popperjs/core/lib/modifiers/applyStyles.js // This modifier takes the styles prepared by the `computeStyles` modifier // and applies them to the HTMLElements such as popper and arrow function applyStyles(_ref) { var state = _ref.state; Object.keys(state.elements).forEach(function (name) { var style = state.styles[name] || {}; var attributes = state.attributes[name] || {}; var element = state.elements[name]; // arrow is optional + virtual elements if (!isHTMLElement(element) || !getNodeName(element)) { return; } // Flow doesn't support to extend this property, but it's the most // effective way to apply styles to an HTMLElement // $FlowFixMe[cannot-write] Object.assign(element.style, style); Object.keys(attributes).forEach(function (name) { var value = attributes[name]; if (value === false) { element.removeAttribute(name); } else { element.setAttribute(name, value === true ? '' : value); } }); }); } function applyStyles_effect(_ref2) { var state = _ref2.state; var initialStyles = { popper: { position: state.options.strategy, left: '0', top: '0', margin: '0' }, arrow: { position: 'absolute' }, reference: {} }; Object.assign(state.elements.popper.style, initialStyles.popper); state.styles = initialStyles; if (state.elements.arrow) { Object.assign(state.elements.arrow.style, initialStyles.arrow); } return function () { Object.keys(state.elements).forEach(function (name) { var element = state.elements[name]; var attributes = state.attributes[name] || {}; var styleProperties = Object.keys(state.styles.hasOwnProperty(name) ? state.styles[name] : initialStyles[name]); // Set all values to an empty string to unset them var style = styleProperties.reduce(function (style, property) { style[property] = ''; return style; }, {}); // arrow is optional + virtual elements if (!isHTMLElement(element) || !getNodeName(element)) { return; } Object.assign(element.style, style); Object.keys(attributes).forEach(function (attribute) { element.removeAttribute(attribute); }); }); }; } // eslint-disable-next-line import/no-unused-modules /* harmony default export */ const modifiers_applyStyles = ({ name: 'applyStyles', enabled: true, phase: 'write', fn: applyStyles, effect: applyStyles_effect, requires: ['computeStyles'] }); ;// ./node_modules/@popperjs/core/lib/modifiers/offset.js // eslint-disable-next-line import/no-unused-modules function distanceAndSkiddingToXY(placement, rects, offset) { var basePlacement = getBasePlacement(placement); var invertDistance = [left, enums_top].indexOf(basePlacement) >= 0 ? -1 : 1; var _ref = typeof offset === 'function' ? offset(Object.assign({}, rects, { placement: placement })) : offset, skidding = _ref[0], distance = _ref[1]; skidding = skidding || 0; distance = (distance || 0) * invertDistance; return [left, right].indexOf(basePlacement) >= 0 ? { x: distance, y: skidding } : { x: skidding, y: distance }; } function offset(_ref2) { var state = _ref2.state, options = _ref2.options, name = _ref2.name; var _options$offset = options.offset, offset = _options$offset === void 0 ? [0, 0] : _options$offset; var data = enums_placements.reduce(function (acc, placement) { acc[placement] = distanceAndSkiddingToXY(placement, state.rects, offset); return acc; }, {}); var _data$state$placement = data[state.placement], x = _data$state$placement.x, y = _data$state$placement.y; if (state.modifiersData.popperOffsets != null) { state.modifiersData.popperOffsets.x += x; state.modifiersData.popperOffsets.y += y; } state.modifiersData[name] = data; } // eslint-disable-next-line import/no-unused-modules /* harmony default export */ const modifiers_offset = ({ name: 'offset', enabled: true, phase: 'main', requires: ['popperOffsets'], fn: offset }); ;// ./node_modules/@popperjs/core/lib/utils/getOppositePlacement.js var hash = { left: 'right', right: 'left', bottom: 'top', top: 'bottom' }; function getOppositePlacement(placement) { return placement.replace(/left|right|bottom|top/g, function (matched) { return hash[matched]; }); } ;// ./node_modules/@popperjs/core/lib/utils/getOppositeVariationPlacement.js var getOppositeVariationPlacement_hash = { start: 'end', end: 'start' }; function getOppositeVariationPlacement(placement) { return placement.replace(/start|end/g, function (matched) { return getOppositeVariationPlacement_hash[matched]; }); } ;// ./node_modules/@popperjs/core/lib/dom-utils/getViewportRect.js function getViewportRect(element, strategy) { var win = getWindow(element); var html = getDocumentElement(element); var visualViewport = win.visualViewport; var width = html.clientWidth; var height = html.clientHeight; var x = 0; var y = 0; if (visualViewport) { width = visualViewport.width; height = visualViewport.height; var layoutViewport = isLayoutViewport(); if (layoutViewport || !layoutViewport && strategy === 'fixed') { x = visualViewport.offsetLeft; y = visualViewport.offsetTop; } } return { width: width, height: height, x: x + getWindowScrollBarX(element), y: y }; } ;// ./node_modules/@popperjs/core/lib/dom-utils/getDocumentRect.js // Gets the entire size of the scrollable document area, even extending outside // of the `` and `
` rect bounds if horizontally scrollable function getDocumentRect(element) { var _element$ownerDocumen; var html = getDocumentElement(element); var winScroll = getWindowScroll(element); var body = (_element$ownerDocumen = element.ownerDocument) == null ? void 0 : _element$ownerDocumen.body; var width = math_max(html.scrollWidth, html.clientWidth, body ? body.scrollWidth : 0, body ? body.clientWidth : 0); var height = math_max(html.scrollHeight, html.clientHeight, body ? body.scrollHeight : 0, body ? body.clientHeight : 0); var x = -winScroll.scrollLeft + getWindowScrollBarX(element); var y = -winScroll.scrollTop; if (getComputedStyle(body || html).direction === 'rtl') { x += math_max(html.clientWidth, body ? body.clientWidth : 0) - width; } return { width: width, height: height, x: x, y: y }; } ;// ./node_modules/@popperjs/core/lib/dom-utils/contains.js function contains(parent, child) { var rootNode = child.getRootNode && child.getRootNode(); // First, attempt with faster native method if (parent.contains(child)) { return true; } // then fallback to custom implementation with Shadow DOM support else if (rootNode && isShadowRoot(rootNode)) { var next = child; do { if (next && parent.isSameNode(next)) { return true; } // $FlowFixMe[prop-missing]: need a better way to handle this... next = next.parentNode || next.host; } while (next); } // Give up, the result is false return false; } ;// ./node_modules/@popperjs/core/lib/utils/rectToClientRect.js function rectToClientRect(rect) { return Object.assign({}, rect, { left: rect.x, top: rect.y, right: rect.x + rect.width, bottom: rect.y + rect.height }); } ;// ./node_modules/@popperjs/core/lib/dom-utils/getClippingRect.js function getInnerBoundingClientRect(element, strategy) { var rect = getBoundingClientRect(element, false, strategy === 'fixed'); rect.top = rect.top + element.clientTop; rect.left = rect.left + element.clientLeft; rect.bottom = rect.top + element.clientHeight; rect.right = rect.left + element.clientWidth; rect.width = element.clientWidth; rect.height = element.clientHeight; rect.x = rect.left; rect.y = rect.top; return rect; } function getClientRectFromMixedType(element, clippingParent, strategy) { return clippingParent === viewport ? rectToClientRect(getViewportRect(element, strategy)) : isElement(clippingParent) ? getInnerBoundingClientRect(clippingParent, strategy) : rectToClientRect(getDocumentRect(getDocumentElement(element))); } // A "clipping parent" is an overflowable container with the characteristic of // clipping (or hiding) overflowing elements with a position different from // `initial` function getClippingParents(element) { var clippingParents = listScrollParents(getParentNode(element)); var canEscapeClipping = ['absolute', 'fixed'].indexOf(getComputedStyle(element).position) >= 0; var clipperElement = canEscapeClipping && isHTMLElement(element) ? getOffsetParent(element) : element; if (!isElement(clipperElement)) { return []; } // $FlowFixMe[incompatible-return]: https://github.com/facebook/flow/issues/1414 return clippingParents.filter(function (clippingParent) { return isElement(clippingParent) && contains(clippingParent, clipperElement) && getNodeName(clippingParent) !== 'body'; }); } // Gets the maximum area that the element is visible in due to any number of // clipping parents function getClippingRect(element, boundary, rootBoundary, strategy) { var mainClippingParents = boundary === 'clippingParents' ? getClippingParents(element) : [].concat(boundary); var clippingParents = [].concat(mainClippingParents, [rootBoundary]); var firstClippingParent = clippingParents[0]; var clippingRect = clippingParents.reduce(function (accRect, clippingParent) { var rect = getClientRectFromMixedType(element, clippingParent, strategy); accRect.top = math_max(rect.top, accRect.top); accRect.right = math_min(rect.right, accRect.right); accRect.bottom = math_min(rect.bottom, accRect.bottom); accRect.left = math_max(rect.left, accRect.left); return accRect; }, getClientRectFromMixedType(element, firstClippingParent, strategy)); clippingRect.width = clippingRect.right - clippingRect.left; clippingRect.height = clippingRect.bottom - clippingRect.top; clippingRect.x = clippingRect.left; clippingRect.y = clippingRect.top; return clippingRect; } ;// ./node_modules/@popperjs/core/lib/utils/getFreshSideObject.js function getFreshSideObject() { return { top: 0, right: 0, bottom: 0, left: 0 }; } ;// ./node_modules/@popperjs/core/lib/utils/mergePaddingObject.js function mergePaddingObject(paddingObject) { return Object.assign({}, getFreshSideObject(), paddingObject); } ;// ./node_modules/@popperjs/core/lib/utils/expandToHashMap.js function expandToHashMap(value, keys) { return keys.reduce(function (hashMap, key) { hashMap[key] = value; return hashMap; }, {}); } ;// ./node_modules/@popperjs/core/lib/utils/detectOverflow.js // eslint-disable-next-line import/no-unused-modules function detectOverflow(state, options) { if (options === void 0) { options = {}; } var _options = options, _options$placement = _options.placement, placement = _options$placement === void 0 ? state.placement : _options$placement, _options$strategy = _options.strategy, strategy = _options$strategy === void 0 ? state.strategy : _options$strategy, _options$boundary = _options.boundary, boundary = _options$boundary === void 0 ? clippingParents : _options$boundary, _options$rootBoundary = _options.rootBoundary, rootBoundary = _options$rootBoundary === void 0 ? viewport : _options$rootBoundary, _options$elementConte = _options.elementContext, elementContext = _options$elementConte === void 0 ? popper : _options$elementConte, _options$altBoundary = _options.altBoundary, altBoundary = _options$altBoundary === void 0 ? false : _options$altBoundary, _options$padding = _options.padding, padding = _options$padding === void 0 ? 0 : _options$padding; var paddingObject = mergePaddingObject(typeof padding !== 'number' ? padding : expandToHashMap(padding, basePlacements)); var altContext = elementContext === popper ? reference : popper; var popperRect = state.rects.popper; var element = state.elements[altBoundary ? altContext : elementContext]; var clippingClientRect = getClippingRect(isElement(element) ? element : element.contextElement || getDocumentElement(state.elements.popper), boundary, rootBoundary, strategy); var referenceClientRect = getBoundingClientRect(state.elements.reference); var popperOffsets = computeOffsets({ reference: referenceClientRect, element: popperRect, strategy: 'absolute', placement: placement }); var popperClientRect = rectToClientRect(Object.assign({}, popperRect, popperOffsets)); var elementClientRect = elementContext === popper ? popperClientRect : referenceClientRect; // positive = overflowing the clipping rect // 0 or negative = within the clipping rect var overflowOffsets = { top: clippingClientRect.top - elementClientRect.top + paddingObject.top, bottom: elementClientRect.bottom - clippingClientRect.bottom + paddingObject.bottom, left: clippingClientRect.left - elementClientRect.left + paddingObject.left, right: elementClientRect.right - clippingClientRect.right + paddingObject.right }; var offsetData = state.modifiersData.offset; // Offsets can be applied only to the popper element if (elementContext === popper && offsetData) { var offset = offsetData[placement]; Object.keys(overflowOffsets).forEach(function (key) { var multiply = [right, bottom].indexOf(key) >= 0 ? 1 : -1; var axis = [enums_top, bottom].indexOf(key) >= 0 ? 'y' : 'x'; overflowOffsets[key] += offset[axis] * multiply; }); } return overflowOffsets; } ;// ./node_modules/@popperjs/core/lib/utils/computeAutoPlacement.js function computeAutoPlacement(state, options) { if (options === void 0) { options = {}; } var _options = options, placement = _options.placement, boundary = _options.boundary, rootBoundary = _options.rootBoundary, padding = _options.padding, flipVariations = _options.flipVariations, _options$allowedAutoP = _options.allowedAutoPlacements, allowedAutoPlacements = _options$allowedAutoP === void 0 ? enums_placements : _options$allowedAutoP; var variation = getVariation(placement); var placements = variation ? flipVariations ? variationPlacements : variationPlacements.filter(function (placement) { return getVariation(placement) === variation; }) : basePlacements; var allowedPlacements = placements.filter(function (placement) { return allowedAutoPlacements.indexOf(placement) >= 0; }); if (allowedPlacements.length === 0) { allowedPlacements = placements; } // $FlowFixMe[incompatible-type]: Flow seems to have problems with two array unions... var overflows = allowedPlacements.reduce(function (acc, placement) { acc[placement] = detectOverflow(state, { placement: placement, boundary: boundary, rootBoundary: rootBoundary, padding: padding })[getBasePlacement(placement)]; return acc; }, {}); return Object.keys(overflows).sort(function (a, b) { return overflows[a] - overflows[b]; }); } ;// ./node_modules/@popperjs/core/lib/modifiers/flip.js // eslint-disable-next-line import/no-unused-modules function getExpandedFallbackPlacements(placement) { if (getBasePlacement(placement) === auto) { return []; } var oppositePlacement = getOppositePlacement(placement); return [getOppositeVariationPlacement(placement), oppositePlacement, getOppositeVariationPlacement(oppositePlacement)]; } function flip(_ref) { var state = _ref.state, options = _ref.options, name = _ref.name; if (state.modifiersData[name]._skip) { return; } var _options$mainAxis = options.mainAxis, checkMainAxis = _options$mainAxis === void 0 ? true : _options$mainAxis, _options$altAxis = options.altAxis, checkAltAxis = _options$altAxis === void 0 ? true : _options$altAxis, specifiedFallbackPlacements = options.fallbackPlacements, padding = options.padding, boundary = options.boundary, rootBoundary = options.rootBoundary, altBoundary = options.altBoundary, _options$flipVariatio = options.flipVariations, flipVariations = _options$flipVariatio === void 0 ? true : _options$flipVariatio, allowedAutoPlacements = options.allowedAutoPlacements; var preferredPlacement = state.options.placement; var basePlacement = getBasePlacement(preferredPlacement); var isBasePlacement = basePlacement === preferredPlacement; var fallbackPlacements = specifiedFallbackPlacements || (isBasePlacement || !flipVariations ? [getOppositePlacement(preferredPlacement)] : getExpandedFallbackPlacements(preferredPlacement)); var placements = [preferredPlacement].concat(fallbackPlacements).reduce(function (acc, placement) { return acc.concat(getBasePlacement(placement) === auto ? computeAutoPlacement(state, { placement: placement, boundary: boundary, rootBoundary: rootBoundary, padding: padding, flipVariations: flipVariations, allowedAutoPlacements: allowedAutoPlacements }) : placement); }, []); var referenceRect = state.rects.reference; var popperRect = state.rects.popper; var checksMap = new Map(); var makeFallbackChecks = true; var firstFittingPlacement = placements[0]; for (var i = 0; i < placements.length; i++) { var placement = placements[i]; var _basePlacement = getBasePlacement(placement); var isStartVariation = getVariation(placement) === start; var isVertical = [enums_top, bottom].indexOf(_basePlacement) >= 0; var len = isVertical ? 'width' : 'height'; var overflow = detectOverflow(state, { placement: placement, boundary: boundary, rootBoundary: rootBoundary, altBoundary: altBoundary, padding: padding }); var mainVariationSide = isVertical ? isStartVariation ? right : left : isStartVariation ? bottom : enums_top; if (referenceRect[len] > popperRect[len]) { mainVariationSide = getOppositePlacement(mainVariationSide); } var altVariationSide = getOppositePlacement(mainVariationSide); var checks = []; if (checkMainAxis) { checks.push(overflow[_basePlacement] <= 0); } if (checkAltAxis) { checks.push(overflow[mainVariationSide] <= 0, overflow[altVariationSide] <= 0); } if (checks.every(function (check) { return check; })) { firstFittingPlacement = placement; makeFallbackChecks = false; break; } checksMap.set(placement, checks); } if (makeFallbackChecks) { // `2` may be desired in some cases – research later var numberOfChecks = flipVariations ? 3 : 1; var _loop = function _loop(_i) { var fittingPlacement = placements.find(function (placement) { var checks = checksMap.get(placement); if (checks) { return checks.slice(0, _i).every(function (check) { return check; }); } }); if (fittingPlacement) { firstFittingPlacement = fittingPlacement; return "break"; } }; for (var _i = numberOfChecks; _i > 0; _i--) { var _ret = _loop(_i); if (_ret === "break") break; } } if (state.placement !== firstFittingPlacement) { state.modifiersData[name]._skip = true; state.placement = firstFittingPlacement; state.reset = true; } } // eslint-disable-next-line import/no-unused-modules /* harmony default export */ const modifiers_flip = ({ name: 'flip', enabled: true, phase: 'main', fn: flip, requiresIfExists: ['offset'], data: { _skip: false } }); ;// ./node_modules/@popperjs/core/lib/utils/getAltAxis.js function getAltAxis(axis) { return axis === 'x' ? 'y' : 'x'; } ;// ./node_modules/@popperjs/core/lib/utils/within.js function within(min, value, max) { return math_max(min, math_min(value, max)); } function withinMaxClamp(min, value, max) { var v = within(min, value, max); return v > max ? max : v; } ;// ./node_modules/@popperjs/core/lib/modifiers/preventOverflow.js function preventOverflow(_ref) { var state = _ref.state, options = _ref.options, name = _ref.name; var _options$mainAxis = options.mainAxis, checkMainAxis = _options$mainAxis === void 0 ? true : _options$mainAxis, _options$altAxis = options.altAxis, checkAltAxis = _options$altAxis === void 0 ? false : _options$altAxis, boundary = options.boundary, rootBoundary = options.rootBoundary, altBoundary = options.altBoundary, padding = options.padding, _options$tether = options.tether, tether = _options$tether === void 0 ? true : _options$tether, _options$tetherOffset = options.tetherOffset, tetherOffset = _options$tetherOffset === void 0 ? 0 : _options$tetherOffset; var overflow = detectOverflow(state, { boundary: boundary, rootBoundary: rootBoundary, padding: padding, altBoundary: altBoundary }); var basePlacement = getBasePlacement(state.placement); var variation = getVariation(state.placement); var isBasePlacement = !variation; var mainAxis = getMainAxisFromPlacement(basePlacement); var altAxis = getAltAxis(mainAxis); var popperOffsets = state.modifiersData.popperOffsets; var referenceRect = state.rects.reference; var popperRect = state.rects.popper; var tetherOffsetValue = typeof tetherOffset === 'function' ? tetherOffset(Object.assign({}, state.rects, { placement: state.placement })) : tetherOffset; var normalizedTetherOffsetValue = typeof tetherOffsetValue === 'number' ? { mainAxis: tetherOffsetValue, altAxis: tetherOffsetValue } : Object.assign({ mainAxis: 0, altAxis: 0 }, tetherOffsetValue); var offsetModifierState = state.modifiersData.offset ? state.modifiersData.offset[state.placement] : null; var data = { x: 0, y: 0 }; if (!popperOffsets) { return; } if (checkMainAxis) { var _offsetModifierState$; var mainSide = mainAxis === 'y' ? enums_top : left; var altSide = mainAxis === 'y' ? bottom : right; var len = mainAxis === 'y' ? 'height' : 'width'; var offset = popperOffsets[mainAxis]; var min = offset + overflow[mainSide]; var max = offset - overflow[altSide]; var additive = tether ? -popperRect[len] / 2 : 0; var minLen = variation === start ? referenceRect[len] : popperRect[len]; var maxLen = variation === start ? -popperRect[len] : -referenceRect[len]; // We need to include the arrow in the calculation so the arrow doesn't go // outside the reference bounds var arrowElement = state.elements.arrow; var arrowRect = tether && arrowElement ? getLayoutRect(arrowElement) : { width: 0, height: 0 }; var arrowPaddingObject = state.modifiersData['arrow#persistent'] ? state.modifiersData['arrow#persistent'].padding : getFreshSideObject(); var arrowPaddingMin = arrowPaddingObject[mainSide]; var arrowPaddingMax = arrowPaddingObject[altSide]; // If the reference length is smaller than the arrow length, we don't want // to include its full size in the calculation. If the reference is small // and near the edge of a boundary, the popper can overflow even if the // reference is not overflowing as well (e.g. virtual elements with no // width or height) var arrowLen = within(0, referenceRect[len], arrowRect[len]); var minOffset = isBasePlacement ? referenceRect[len] / 2 - additive - arrowLen - arrowPaddingMin - normalizedTetherOffsetValue.mainAxis : minLen - arrowLen - arrowPaddingMin - normalizedTetherOffsetValue.mainAxis; var maxOffset = isBasePlacement ? -referenceRect[len] / 2 + additive + arrowLen + arrowPaddingMax + normalizedTetherOffsetValue.mainAxis : maxLen + arrowLen + arrowPaddingMax + normalizedTetherOffsetValue.mainAxis; var arrowOffsetParent = state.elements.arrow && getOffsetParent(state.elements.arrow); var clientOffset = arrowOffsetParent ? mainAxis === 'y' ? arrowOffsetParent.clientTop || 0 : arrowOffsetParent.clientLeft || 0 : 0; var offsetModifierValue = (_offsetModifierState$ = offsetModifierState == null ? void 0 : offsetModifierState[mainAxis]) != null ? _offsetModifierState$ : 0; var tetherMin = offset + minOffset - offsetModifierValue - clientOffset; var tetherMax = offset + maxOffset - offsetModifierValue; var preventedOffset = within(tether ? math_min(min, tetherMin) : min, offset, tether ? math_max(max, tetherMax) : max); popperOffsets[mainAxis] = preventedOffset; data[mainAxis] = preventedOffset - offset; } if (checkAltAxis) { var _offsetModifierState$2; var _mainSide = mainAxis === 'x' ? enums_top : left; var _altSide = mainAxis === 'x' ? bottom : right; var _offset = popperOffsets[altAxis]; var _len = altAxis === 'y' ? 'height' : 'width'; var _min = _offset + overflow[_mainSide]; var _max = _offset - overflow[_altSide]; var isOriginSide = [enums_top, left].indexOf(basePlacement) !== -1; var _offsetModifierValue = (_offsetModifierState$2 = offsetModifierState == null ? void 0 : offsetModifierState[altAxis]) != null ? _offsetModifierState$2 : 0; var _tetherMin = isOriginSide ? _min : _offset - referenceRect[_len] - popperRect[_len] - _offsetModifierValue + normalizedTetherOffsetValue.altAxis; var _tetherMax = isOriginSide ? _offset + referenceRect[_len] + popperRect[_len] - _offsetModifierValue - normalizedTetherOffsetValue.altAxis : _max; var _preventedOffset = tether && isOriginSide ? withinMaxClamp(_tetherMin, _offset, _tetherMax) : within(tether ? _tetherMin : _min, _offset, tether ? _tetherMax : _max); popperOffsets[altAxis] = _preventedOffset; data[altAxis] = _preventedOffset - _offset; } state.modifiersData[name] = data; } // eslint-disable-next-line import/no-unused-modules /* harmony default export */ const modifiers_preventOverflow = ({ name: 'preventOverflow', enabled: true, phase: 'main', fn: preventOverflow, requiresIfExists: ['offset'] }); ;// ./node_modules/@popperjs/core/lib/modifiers/arrow.js // eslint-disable-next-line import/no-unused-modules var toPaddingObject = function toPaddingObject(padding, state) { padding = typeof padding === 'function' ? padding(Object.assign({}, state.rects, { placement: state.placement })) : padding; return mergePaddingObject(typeof padding !== 'number' ? padding : expandToHashMap(padding, basePlacements)); }; function arrow(_ref) { var _state$modifiersData$; var state = _ref.state, name = _ref.name, options = _ref.options; var arrowElement = state.elements.arrow; var popperOffsets = state.modifiersData.popperOffsets; var basePlacement = getBasePlacement(state.placement); var axis = getMainAxisFromPlacement(basePlacement); var isVertical = [left, right].indexOf(basePlacement) >= 0; var len = isVertical ? 'height' : 'width'; if (!arrowElement || !popperOffsets) { return; } var paddingObject = toPaddingObject(options.padding, state); var arrowRect = getLayoutRect(arrowElement); var minProp = axis === 'y' ? enums_top : left; var maxProp = axis === 'y' ? bottom : right; var endDiff = state.rects.reference[len] + state.rects.reference[axis] - popperOffsets[axis] - state.rects.popper[len]; var startDiff = popperOffsets[axis] - state.rects.reference[axis]; var arrowOffsetParent = getOffsetParent(arrowElement); var clientSize = arrowOffsetParent ? axis === 'y' ? arrowOffsetParent.clientHeight || 0 : arrowOffsetParent.clientWidth || 0 : 0; var centerToReference = endDiff / 2 - startDiff / 2; // Make sure the arrow doesn't overflow the popper if the center point is // outside of the popper bounds var min = paddingObject[minProp]; var max = clientSize - arrowRect[len] - paddingObject[maxProp]; var center = clientSize / 2 - arrowRect[len] / 2 + centerToReference; var offset = within(min, center, max); // Prevents breaking syntax highlighting... var axisProp = axis; state.modifiersData[name] = (_state$modifiersData$ = {}, _state$modifiersData$[axisProp] = offset, _state$modifiersData$.centerOffset = offset - center, _state$modifiersData$); } function arrow_effect(_ref2) { var state = _ref2.state, options = _ref2.options; var _options$element = options.element, arrowElement = _options$element === void 0 ? '[data-popper-arrow]' : _options$element; if (arrowElement == null) { return; } // CSS selector if (typeof arrowElement === 'string') { arrowElement = state.elements.popper.querySelector(arrowElement); if (!arrowElement) { return; } } if (!contains(state.elements.popper, arrowElement)) { return; } state.elements.arrow = arrowElement; } // eslint-disable-next-line import/no-unused-modules /* harmony default export */ const modifiers_arrow = ({ name: 'arrow', enabled: true, phase: 'main', fn: arrow, effect: arrow_effect, requires: ['popperOffsets'], requiresIfExists: ['preventOverflow'] }); ;// ./node_modules/@popperjs/core/lib/modifiers/hide.js function getSideOffsets(overflow, rect, preventedOffsets) { if (preventedOffsets === void 0) { preventedOffsets = { x: 0, y: 0 }; } return { top: overflow.top - rect.height - preventedOffsets.y, right: overflow.right - rect.width + preventedOffsets.x, bottom: overflow.bottom - rect.height + preventedOffsets.y, left: overflow.left - rect.width - preventedOffsets.x }; } function isAnySideFullyClipped(overflow) { return [enums_top, right, bottom, left].some(function (side) { return overflow[side] >= 0; }); } function hide(_ref) { var state = _ref.state, name = _ref.name; var referenceRect = state.rects.reference; var popperRect = state.rects.popper; var preventedOffsets = state.modifiersData.preventOverflow; var referenceOverflow = detectOverflow(state, { elementContext: 'reference' }); var popperAltOverflow = detectOverflow(state, { altBoundary: true }); var referenceClippingOffsets = getSideOffsets(referenceOverflow, referenceRect); var popperEscapeOffsets = getSideOffsets(popperAltOverflow, popperRect, preventedOffsets); var isReferenceHidden = isAnySideFullyClipped(referenceClippingOffsets); var hasPopperEscaped = isAnySideFullyClipped(popperEscapeOffsets); state.modifiersData[name] = { referenceClippingOffsets: referenceClippingOffsets, popperEscapeOffsets: popperEscapeOffsets, isReferenceHidden: isReferenceHidden, hasPopperEscaped: hasPopperEscaped }; state.attributes.popper = Object.assign({}, state.attributes.popper, { 'data-popper-reference-hidden': isReferenceHidden, 'data-popper-escaped': hasPopperEscaped }); } // eslint-disable-next-line import/no-unused-modules /* harmony default export */ const modifiers_hide = ({ name: 'hide', enabled: true, phase: 'main', requiresIfExists: ['preventOverflow'], fn: hide }); ;// ./node_modules/@popperjs/core/lib/popper.js var defaultModifiers = [eventListeners, modifiers_popperOffsets, modifiers_computeStyles, modifiers_applyStyles, modifiers_offset, modifiers_flip, modifiers_preventOverflow, modifiers_arrow, modifiers_hide]; var popper_createPopper = /*#__PURE__*/popperGenerator({ defaultModifiers: defaultModifiers }); // eslint-disable-next-line import/no-unused-modules // eslint-disable-next-line import/no-unused-modules // eslint-disable-next-line import/no-unused-modules ;// ./node_modules/flowbite/lib/esm/components/dropdown/index.js var dropdown_assign = (undefined && undefined.__assign) || function () { dropdown_assign = Object.assign || function(t) { for (var s, i = 1, n = arguments.length; i < n; i++) { s = arguments[i]; for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p]; } return t; }; return dropdown_assign.apply(this, arguments); }; var __spreadArray = (undefined && undefined.__spreadArray) || function (to, from, pack) { if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) { if (ar || !(i in from)) { if (!ar) ar = Array.prototype.slice.call(from, 0, i); ar[i] = from[i]; } } return to.concat(ar || Array.prototype.slice.call(from)); }; /* eslint-disable @typescript-eslint/no-empty-function */ var dropdown_Default = { placement: 'bottom', triggerType: 'click', offsetSkidding: 0, offsetDistance: 10, delay: 300, ignoreClickOutsideClass: false, onShow: function () { }, onHide: function () { }, onToggle: function () { }, }; var dropdown_DefaultInstanceOptions = { id: null, override: true, }; var Dropdown = /** @class */ (function () { function Dropdown(targetElement, triggerElement, options, instanceOptions) { if (targetElement === void 0) { targetElement = null; } if (triggerElement === void 0) { triggerElement = null; } if (options === void 0) { options = dropdown_Default; } if (instanceOptions === void 0) { instanceOptions = dropdown_DefaultInstanceOptions; } this._instanceId = instanceOptions.id ? instanceOptions.id : targetElement.id; this._targetEl = targetElement; this._triggerEl = triggerElement; this._options = dropdown_assign(dropdown_assign({}, dropdown_Default), options); this._popperInstance = null; this._visible = false; this._initialized = false; this.init(); dom_instances.addInstance('Dropdown', this, this._instanceId, instanceOptions.override); } Dropdown.prototype.init = function () { if (this._triggerEl && this._targetEl && !this._initialized) { this._popperInstance = this._createPopperInstance(); this._setupEventListeners(); this._initialized = true; } }; Dropdown.prototype.destroy = function () { var _this = this; var triggerEvents = this._getTriggerEvents(); // Remove click event listeners for trigger element if (this._options.triggerType === 'click') { triggerEvents.showEvents.forEach(function (ev) { _this._triggerEl.removeEventListener(ev, _this._clickHandler); }); } // Remove hover event listeners for trigger and target elements if (this._options.triggerType === 'hover') { triggerEvents.showEvents.forEach(function (ev) { _this._triggerEl.removeEventListener(ev, _this._hoverShowTriggerElHandler); _this._targetEl.removeEventListener(ev, _this._hoverShowTargetElHandler); }); triggerEvents.hideEvents.forEach(function (ev) { _this._triggerEl.removeEventListener(ev, _this._hoverHideHandler); _this._targetEl.removeEventListener(ev, _this._hoverHideHandler); }); } this._popperInstance.destroy(); this._initialized = false; }; Dropdown.prototype.removeInstance = function () { dom_instances.removeInstance('Dropdown', this._instanceId); }; Dropdown.prototype.destroyAndRemoveInstance = function () { this.destroy(); this.removeInstance(); }; Dropdown.prototype._setupEventListeners = function () { var _this = this; var triggerEvents = this._getTriggerEvents(); this._clickHandler = function () { _this.toggle(); }; // click event handling for trigger element if (this._options.triggerType === 'click') { triggerEvents.showEvents.forEach(function (ev) { _this._triggerEl.addEventListener(ev, _this._clickHandler); }); } this._hoverShowTriggerElHandler = function (ev) { if (ev.type === 'click') { _this.toggle(); } else { setTimeout(function () { _this.show(); }, _this._options.delay); } }; this._hoverShowTargetElHandler = function () { _this.show(); }; this._hoverHideHandler = function () { setTimeout(function () { if (!_this._targetEl.matches(':hover')) { _this.hide(); } }, _this._options.delay); }; // hover event handling for trigger element if (this._options.triggerType === 'hover') { triggerEvents.showEvents.forEach(function (ev) { _this._triggerEl.addEventListener(ev, _this._hoverShowTriggerElHandler); _this._targetEl.addEventListener(ev, _this._hoverShowTargetElHandler); }); triggerEvents.hideEvents.forEach(function (ev) { _this._triggerEl.addEventListener(ev, _this._hoverHideHandler); _this._targetEl.addEventListener(ev, _this._hoverHideHandler); }); } }; Dropdown.prototype._createPopperInstance = function () { return popper_createPopper(this._triggerEl, this._targetEl, { placement: this._options.placement, modifiers: [ { name: 'offset', options: { offset: [ this._options.offsetSkidding, this._options.offsetDistance, ], }, }, ], }); }; Dropdown.prototype._setupClickOutsideListener = function () { var _this = this; this._clickOutsideEventListener = function (ev) { _this._handleClickOutside(ev, _this._targetEl); }; document.body.addEventListener('click', this._clickOutsideEventListener, true); }; Dropdown.prototype._removeClickOutsideListener = function () { document.body.removeEventListener('click', this._clickOutsideEventListener, true); }; Dropdown.prototype._handleClickOutside = function (ev, targetEl) { var clickedEl = ev.target; // Ignore clicks on the trigger element (ie. a datepicker input) var ignoreClickOutsideClass = this._options.ignoreClickOutsideClass; var isIgnored = false; if (ignoreClickOutsideClass) { var ignoredClickOutsideEls = document.querySelectorAll(".".concat(ignoreClickOutsideClass)); ignoredClickOutsideEls.forEach(function (el) { if (el.contains(clickedEl)) { isIgnored = true; return; } }); } // Ignore clicks on the target element (ie. dropdown itself) if (clickedEl !== targetEl && !targetEl.contains(clickedEl) && !this._triggerEl.contains(clickedEl) && !isIgnored && this.isVisible()) { this.hide(); } }; Dropdown.prototype._getTriggerEvents = function () { switch (this._options.triggerType) { case 'hover': return { showEvents: ['mouseenter', 'click'], hideEvents: ['mouseleave'], }; case 'click': return { showEvents: ['click'], hideEvents: [], }; case 'none': return { showEvents: [], hideEvents: [], }; default: return { showEvents: ['click'], hideEvents: [], }; } }; Dropdown.prototype.toggle = function () { if (this.isVisible()) { this.hide(); } else { this.show(); } this._options.onToggle(this); }; Dropdown.prototype.isVisible = function () { return this._visible; }; Dropdown.prototype.show = function () { this._targetEl.classList.remove('hidden'); this._targetEl.classList.add('block'); this._targetEl.removeAttribute('aria-hidden'); // Enable the event listeners this._popperInstance.setOptions(function (options) { return (dropdown_assign(dropdown_assign({}, options), { modifiers: __spreadArray(__spreadArray([], options.modifiers, true), [ { name: 'eventListeners', enabled: true }, ], false) })); }); this._setupClickOutsideListener(); // Update its position this._popperInstance.update(); this._visible = true; // callback function this._options.onShow(this); }; Dropdown.prototype.hide = function () { this._targetEl.classList.remove('block'); this._targetEl.classList.add('hidden'); this._targetEl.setAttribute('aria-hidden', 'true'); // Disable the event listeners this._popperInstance.setOptions(function (options) { return (dropdown_assign(dropdown_assign({}, options), { modifiers: __spreadArray(__spreadArray([], options.modifiers, true), [ { name: 'eventListeners', enabled: false }, ], false) })); }); this._visible = false; this._removeClickOutsideListener(); // callback function this._options.onHide(this); }; Dropdown.prototype.updateOnShow = function (callback) { this._options.onShow = callback; }; Dropdown.prototype.updateOnHide = function (callback) { this._options.onHide = callback; }; Dropdown.prototype.updateOnToggle = function (callback) { this._options.onToggle = callback; }; return Dropdown; }()); function initDropdowns() { document .querySelectorAll('[data-dropdown-toggle]') .forEach(function ($triggerEl) { var dropdownId = $triggerEl.getAttribute('data-dropdown-toggle'); var $dropdownEl = document.getElementById(dropdownId); if ($dropdownEl) { var placement = $triggerEl.getAttribute('data-dropdown-placement'); var offsetSkidding = $triggerEl.getAttribute('data-dropdown-offset-skidding'); var offsetDistance = $triggerEl.getAttribute('data-dropdown-offset-distance'); var triggerType = $triggerEl.getAttribute('data-dropdown-trigger'); var delay = $triggerEl.getAttribute('data-dropdown-delay'); var ignoreClickOutsideClass = $triggerEl.getAttribute('data-dropdown-ignore-click-outside-class'); new Dropdown($dropdownEl, $triggerEl, { placement: placement ? placement : dropdown_Default.placement, triggerType: triggerType ? triggerType : dropdown_Default.triggerType, offsetSkidding: offsetSkidding ? parseInt(offsetSkidding) : dropdown_Default.offsetSkidding, offsetDistance: offsetDistance ? parseInt(offsetDistance) : dropdown_Default.offsetDistance, delay: delay ? parseInt(delay) : dropdown_Default.delay, ignoreClickOutsideClass: ignoreClickOutsideClass ? ignoreClickOutsideClass : dropdown_Default.ignoreClickOutsideClass, }); } else { console.error("The dropdown element with id \"".concat(dropdownId, "\" does not exist. Please check the data-dropdown-toggle attribute.")); } }); } if (typeof window !== 'undefined') { window.Dropdown = Dropdown; window.initDropdowns = initDropdowns; } /* harmony default export */ const dropdown = ((/* unused pure expression or super */ null && (Dropdown))); //# sourceMappingURL=index.js.map ;// ./node_modules/flowbite/lib/esm/components/modal/index.js var modal_assign = (undefined && undefined.__assign) || function () { modal_assign = Object.assign || function(t) { for (var s, i = 1, n = arguments.length; i < n; i++) { s = arguments[i]; for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p]; } return t; }; return modal_assign.apply(this, arguments); }; var modal_Default = { placement: 'center', backdropClasses: 'bg-gray-900/50 dark:bg-gray-900/80 fixed inset-0 z-40', backdrop: 'dynamic', closable: true, onHide: function () { }, onShow: function () { }, onToggle: function () { }, }; var modal_DefaultInstanceOptions = { id: null, override: true, }; var Modal = /** @class */ (function () { function Modal(targetEl, options, instanceOptions) { if (targetEl === void 0) { targetEl = null; } if (options === void 0) { options = modal_Default; } if (instanceOptions === void 0) { instanceOptions = modal_DefaultInstanceOptions; } this._eventListenerInstances = []; this._instanceId = instanceOptions.id ? instanceOptions.id : targetEl.id; this._targetEl = targetEl; this._options = modal_assign(modal_assign({}, modal_Default), options); this._isHidden = true; this._backdropEl = null; this._initialized = false; this.init(); dom_instances.addInstance('Modal', this, this._instanceId, instanceOptions.override); } Modal.prototype.init = function () { var _this = this; if (this._targetEl && !this._initialized) { this._getPlacementClasses().map(function (c) { _this._targetEl.classList.add(c); }); this._initialized = true; } }; Modal.prototype.destroy = function () { if (this._initialized) { this.removeAllEventListenerInstances(); this._destroyBackdropEl(); this._initialized = false; } }; Modal.prototype.removeInstance = function () { dom_instances.removeInstance('Modal', this._instanceId); }; Modal.prototype.destroyAndRemoveInstance = function () { this.destroy(); this.removeInstance(); }; Modal.prototype._createBackdrop = function () { var _a; if (this._isHidden) { var backdropEl = document.createElement('div'); (_a = backdropEl.classList).add.apply(_a, this._options.backdropClasses.split(' ')); document.querySelector('body').append(backdropEl); this._backdropEl = backdropEl; } }; Modal.prototype._destroyBackdropEl = function () { if (!this._isHidden && this._backdropEl) { this._backdropEl.remove(); this._backdropEl = null; } }; Modal.prototype._setupModalCloseEventListeners = function () { var _this = this; if (this._options.backdrop === 'dynamic') { this._clickOutsideEventListener = function (ev) { _this._handleOutsideClick(ev.target); }; this._targetEl.addEventListener('click', this._clickOutsideEventListener, true); } this._keydownEventListener = function (ev) { if (ev.key === 'Escape') { _this.hide(); } }; document.body.addEventListener('keydown', this._keydownEventListener, true); }; Modal.prototype._removeModalCloseEventListeners = function () { if (this._options.backdrop === 'dynamic') { this._targetEl.removeEventListener('click', this._clickOutsideEventListener, true); } document.body.removeEventListener('keydown', this._keydownEventListener, true); }; Modal.prototype._handleOutsideClick = function (target) { if (target === this._targetEl || (target === this._backdropEl && this.isVisible())) { this.hide(); } }; Modal.prototype._getPlacementClasses = function () { switch (this._options.placement) { // top case 'top-left': return ['justify-start', 'items-start']; case 'top-center': return ['justify-center', 'items-start']; case 'top-right': return ['justify-end', 'items-start']; // center case 'center-left': return ['justify-start', 'items-center']; case 'center': return ['justify-center', 'items-center']; case 'center-right': return ['justify-end', 'items-center']; // bottom case 'bottom-left': return ['justify-start', 'items-end']; case 'bottom-center': return ['justify-center', 'items-end']; case 'bottom-right': return ['justify-end', 'items-end']; default: return ['justify-center', 'items-center']; } }; Modal.prototype.toggle = function () { if (this._isHidden) { this.show(); } else { this.hide(); } // callback function this._options.onToggle(this); }; Modal.prototype.show = function () { if (this.isHidden) { this._targetEl.classList.add('flex'); this._targetEl.classList.remove('hidden'); this._targetEl.setAttribute('aria-modal', 'true'); this._targetEl.setAttribute('role', 'dialog'); this._targetEl.removeAttribute('aria-hidden'); this._createBackdrop(); this._isHidden = false; // Add keyboard event listener to the document if (this._options.closable) { this._setupModalCloseEventListeners(); } // prevent body scroll document.body.classList.add('overflow-hidden'); // callback function this._options.onShow(this); } }; Modal.prototype.hide = function () { if (this.isVisible) { this._targetEl.classList.add('hidden'); this._targetEl.classList.remove('flex'); this._targetEl.setAttribute('aria-hidden', 'true'); this._targetEl.removeAttribute('aria-modal'); this._targetEl.removeAttribute('role'); this._destroyBackdropEl(); this._isHidden = true; // re-apply body scroll document.body.classList.remove('overflow-hidden'); if (this._options.closable) { this._removeModalCloseEventListeners(); } // callback function this._options.onHide(this); } }; Modal.prototype.isVisible = function () { return !this._isHidden; }; Modal.prototype.isHidden = function () { return this._isHidden; }; Modal.prototype.addEventListenerInstance = function (element, type, handler) { this._eventListenerInstances.push({ element: element, type: type, handler: handler, }); }; Modal.prototype.removeAllEventListenerInstances = function () { this._eventListenerInstances.map(function (eventListenerInstance) { eventListenerInstance.element.removeEventListener(eventListenerInstance.type, eventListenerInstance.handler); }); this._eventListenerInstances = []; }; Modal.prototype.getAllEventListenerInstances = function () { return this._eventListenerInstances; }; Modal.prototype.updateOnShow = function (callback) { this._options.onShow = callback; }; Modal.prototype.updateOnHide = function (callback) { this._options.onHide = callback; }; Modal.prototype.updateOnToggle = function (callback) { this._options.onToggle = callback; }; return Modal; }()); function initModals() { // initiate modal based on data-modal-target document.querySelectorAll('[data-modal-target]').forEach(function ($triggerEl) { var modalId = $triggerEl.getAttribute('data-modal-target'); var $modalEl = document.getElementById(modalId); if ($modalEl) { var placement = $modalEl.getAttribute('data-modal-placement'); var backdrop = $modalEl.getAttribute('data-modal-backdrop'); new Modal($modalEl, { placement: placement ? placement : modal_Default.placement, backdrop: backdrop ? backdrop : modal_Default.backdrop, }); } else { console.error("Modal with id ".concat(modalId, " does not exist. Are you sure that the data-modal-target attribute points to the correct modal id?.")); } }); // toggle modal visibility document.querySelectorAll('[data-modal-toggle]').forEach(function ($triggerEl) { var modalId = $triggerEl.getAttribute('data-modal-toggle'); var $modalEl = document.getElementById(modalId); if ($modalEl) { var modal_1 = dom_instances.getInstance('Modal', modalId); if (modal_1) { var toggleModal = function () { modal_1.toggle(); }; $triggerEl.addEventListener('click', toggleModal); modal_1.addEventListenerInstance($triggerEl, 'click', toggleModal); } else { console.error("Modal with id ".concat(modalId, " has not been initialized. Please initialize it using the data-modal-target attribute.")); } } else { console.error("Modal with id ".concat(modalId, " does not exist. Are you sure that the data-modal-toggle attribute points to the correct modal id?")); } }); // show modal on click if exists based on id document.querySelectorAll('[data-modal-show]').forEach(function ($triggerEl) { var modalId = $triggerEl.getAttribute('data-modal-show'); var $modalEl = document.getElementById(modalId); if ($modalEl) { var modal_2 = dom_instances.getInstance('Modal', modalId); if (modal_2) { var showModal = function () { modal_2.show(); }; $triggerEl.addEventListener('click', showModal); modal_2.addEventListenerInstance($triggerEl, 'click', showModal); } else { console.error("Modal with id ".concat(modalId, " has not been initialized. Please initialize it using the data-modal-target attribute.")); } } else { console.error("Modal with id ".concat(modalId, " does not exist. Are you sure that the data-modal-show attribute points to the correct modal id?")); } }); // hide modal on click if exists based on id document.querySelectorAll('[data-modal-hide]').forEach(function ($triggerEl) { var modalId = $triggerEl.getAttribute('data-modal-hide'); var $modalEl = document.getElementById(modalId); if ($modalEl) { var modal_3 = dom_instances.getInstance('Modal', modalId); if (modal_3) { var hideModal = function () { modal_3.hide(); }; $triggerEl.addEventListener('click', hideModal); modal_3.addEventListenerInstance($triggerEl, 'click', hideModal); } else { console.error("Modal with id ".concat(modalId, " has not been initialized. Please initialize it using the data-modal-target attribute.")); } } else { console.error("Modal with id ".concat(modalId, " does not exist. Are you sure that the data-modal-hide attribute points to the correct modal id?")); } }); } if (typeof window !== 'undefined') { window.Modal = Modal; window.initModals = initModals; } /* harmony default export */ const modal = ((/* unused pure expression or super */ null && (Modal))); //# sourceMappingURL=index.js.map ;// ./node_modules/flowbite/lib/esm/components/drawer/index.js var drawer_assign = (undefined && undefined.__assign) || function () { drawer_assign = Object.assign || function(t) { for (var s, i = 1, n = arguments.length; i < n; i++) { s = arguments[i]; for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p]; } return t; }; return drawer_assign.apply(this, arguments); }; var drawer_Default = { placement: 'left', bodyScrolling: false, backdrop: true, edge: false, edgeOffset: 'bottom-[60px]', backdropClasses: 'bg-gray-900/50 dark:bg-gray-900/80 fixed inset-0 z-30', onShow: function () { }, onHide: function () { }, onToggle: function () { }, }; var drawer_DefaultInstanceOptions = { id: null, override: true, }; var Drawer = /** @class */ (function () { function Drawer(targetEl, options, instanceOptions) { if (targetEl === void 0) { targetEl = null; } if (options === void 0) { options = drawer_Default; } if (instanceOptions === void 0) { instanceOptions = drawer_DefaultInstanceOptions; } this._eventListenerInstances = []; this._instanceId = instanceOptions.id ? instanceOptions.id : targetEl.id; this._targetEl = targetEl; this._options = drawer_assign(drawer_assign({}, drawer_Default), options); this._visible = false; this._initialized = false; this.init(); dom_instances.addInstance('Drawer', this, this._instanceId, instanceOptions.override); } Drawer.prototype.init = function () { var _this = this; // set initial accessibility attributes if (this._targetEl && !this._initialized) { this._targetEl.setAttribute('aria-hidden', 'true'); this._targetEl.classList.add('transition-transform'); // set base placement classes this._getPlacementClasses(this._options.placement).base.map(function (c) { _this._targetEl.classList.add(c); }); this._handleEscapeKey = function (event) { if (event.key === 'Escape') { // if 'Escape' key is pressed if (_this.isVisible()) { // if the Drawer is visible _this.hide(); // hide the Drawer } } }; // add keyboard event listener to document document.addEventListener('keydown', this._handleEscapeKey); this._initialized = true; } }; Drawer.prototype.destroy = function () { if (this._initialized) { this.removeAllEventListenerInstances(); this._destroyBackdropEl(); // Remove the keyboard event listener document.removeEventListener('keydown', this._handleEscapeKey); this._initialized = false; } }; Drawer.prototype.removeInstance = function () { dom_instances.removeInstance('Drawer', this._instanceId); }; Drawer.prototype.destroyAndRemoveInstance = function () { this.destroy(); this.removeInstance(); }; Drawer.prototype.hide = function () { var _this = this; // based on the edge option show placement classes if (this._options.edge) { this._getPlacementClasses(this._options.placement + '-edge').active.map(function (c) { _this._targetEl.classList.remove(c); }); this._getPlacementClasses(this._options.placement + '-edge').inactive.map(function (c) { _this._targetEl.classList.add(c); }); } else { this._getPlacementClasses(this._options.placement).active.map(function (c) { _this._targetEl.classList.remove(c); }); this._getPlacementClasses(this._options.placement).inactive.map(function (c) { _this._targetEl.classList.add(c); }); } // set accessibility attributes this._targetEl.setAttribute('aria-hidden', 'true'); this._targetEl.removeAttribute('aria-modal'); this._targetEl.removeAttribute('role'); // enable body scroll if (!this._options.bodyScrolling) { document.body.classList.remove('overflow-hidden'); } // destroy backdrop if (this._options.backdrop) { this._destroyBackdropEl(); } this._visible = false; // callback function this._options.onHide(this); }; Drawer.prototype.show = function () { var _this = this; if (this._options.edge) { this._getPlacementClasses(this._options.placement + '-edge').active.map(function (c) { _this._targetEl.classList.add(c); }); this._getPlacementClasses(this._options.placement + '-edge').inactive.map(function (c) { _this._targetEl.classList.remove(c); }); } else { this._getPlacementClasses(this._options.placement).active.map(function (c) { _this._targetEl.classList.add(c); }); this._getPlacementClasses(this._options.placement).inactive.map(function (c) { _this._targetEl.classList.remove(c); }); } // set accessibility attributes this._targetEl.setAttribute('aria-modal', 'true'); this._targetEl.setAttribute('role', 'dialog'); this._targetEl.removeAttribute('aria-hidden'); // disable body scroll if (!this._options.bodyScrolling) { document.body.classList.add('overflow-hidden'); } // show backdrop if (this._options.backdrop) { this._createBackdrop(); } this._visible = true; // callback function this._options.onShow(this); }; Drawer.prototype.toggle = function () { if (this.isVisible()) { this.hide(); } else { this.show(); } }; Drawer.prototype._createBackdrop = function () { var _a; var _this = this; if (!this._visible) { var backdropEl = document.createElement('div'); backdropEl.setAttribute('drawer-backdrop', ''); (_a = backdropEl.classList).add.apply(_a, this._options.backdropClasses.split(' ')); document.querySelector('body').append(backdropEl); backdropEl.addEventListener('click', function () { _this.hide(); }); } }; Drawer.prototype._destroyBackdropEl = function () { if (this._visible && document.querySelector('[drawer-backdrop]') !== null) { document.querySelector('[drawer-backdrop]').remove(); } }; Drawer.prototype._getPlacementClasses = function (placement) { switch (placement) { case 'top': return { base: ['top-0', 'left-0', 'right-0'], active: ['transform-none'], inactive: ['-translate-y-full'], }; case 'right': return { base: ['right-0', 'top-0'], active: ['transform-none'], inactive: ['translate-x-full'], }; case 'bottom': return { base: ['bottom-0', 'left-0', 'right-0'], active: ['transform-none'], inactive: ['translate-y-full'], }; case 'left': return { base: ['left-0', 'top-0'], active: ['transform-none'], inactive: ['-translate-x-full'], }; case 'bottom-edge': return { base: ['left-0', 'top-0'], active: ['transform-none'], inactive: ['translate-y-full', this._options.edgeOffset], }; default: return { base: ['left-0', 'top-0'], active: ['transform-none'], inactive: ['-translate-x-full'], }; } }; Drawer.prototype.isHidden = function () { return !this._visible; }; Drawer.prototype.isVisible = function () { return this._visible; }; Drawer.prototype.addEventListenerInstance = function (element, type, handler) { this._eventListenerInstances.push({ element: element, type: type, handler: handler, }); }; Drawer.prototype.removeAllEventListenerInstances = function () { this._eventListenerInstances.map(function (eventListenerInstance) { eventListenerInstance.element.removeEventListener(eventListenerInstance.type, eventListenerInstance.handler); }); this._eventListenerInstances = []; }; Drawer.prototype.getAllEventListenerInstances = function () { return this._eventListenerInstances; }; Drawer.prototype.updateOnShow = function (callback) { this._options.onShow = callback; }; Drawer.prototype.updateOnHide = function (callback) { this._options.onHide = callback; }; Drawer.prototype.updateOnToggle = function (callback) { this._options.onToggle = callback; }; return Drawer; }()); function initDrawers() { document.querySelectorAll('[data-drawer-target]').forEach(function ($triggerEl) { // mandatory var drawerId = $triggerEl.getAttribute('data-drawer-target'); var $drawerEl = document.getElementById(drawerId); if ($drawerEl) { var placement = $triggerEl.getAttribute('data-drawer-placement'); var bodyScrolling = $triggerEl.getAttribute('data-drawer-body-scrolling'); var backdrop = $triggerEl.getAttribute('data-drawer-backdrop'); var edge = $triggerEl.getAttribute('data-drawer-edge'); var edgeOffset = $triggerEl.getAttribute('data-drawer-edge-offset'); new Drawer($drawerEl, { placement: placement ? placement : drawer_Default.placement, bodyScrolling: bodyScrolling ? bodyScrolling === 'true' ? true : false : drawer_Default.bodyScrolling, backdrop: backdrop ? backdrop === 'true' ? true : false : drawer_Default.backdrop, edge: edge ? (edge === 'true' ? true : false) : drawer_Default.edge, edgeOffset: edgeOffset ? edgeOffset : drawer_Default.edgeOffset, }); } else { console.error("Drawer with id ".concat(drawerId, " not found. Are you sure that the data-drawer-target attribute points to the correct drawer id?")); } }); document.querySelectorAll('[data-drawer-toggle]').forEach(function ($triggerEl) { var drawerId = $triggerEl.getAttribute('data-drawer-toggle'); var $drawerEl = document.getElementById(drawerId); if ($drawerEl) { var drawer_1 = dom_instances.getInstance('Drawer', drawerId); if (drawer_1) { var toggleDrawer = function () { drawer_1.toggle(); }; $triggerEl.addEventListener('click', toggleDrawer); drawer_1.addEventListenerInstance($triggerEl, 'click', toggleDrawer); } else { console.error("Drawer with id ".concat(drawerId, " has not been initialized. Please initialize it using the data-drawer-target attribute.")); } } else { console.error("Drawer with id ".concat(drawerId, " not found. Are you sure that the data-drawer-target attribute points to the correct drawer id?")); } }); document .querySelectorAll('[data-drawer-dismiss], [data-drawer-hide]') .forEach(function ($triggerEl) { var drawerId = $triggerEl.getAttribute('data-drawer-dismiss') ? $triggerEl.getAttribute('data-drawer-dismiss') : $triggerEl.getAttribute('data-drawer-hide'); var $drawerEl = document.getElementById(drawerId); if ($drawerEl) { var drawer_2 = dom_instances.getInstance('Drawer', drawerId); if (drawer_2) { var hideDrawer = function () { drawer_2.hide(); }; $triggerEl.addEventListener('click', hideDrawer); drawer_2.addEventListenerInstance($triggerEl, 'click', hideDrawer); } else { console.error("Drawer with id ".concat(drawerId, " has not been initialized. Please initialize it using the data-drawer-target attribute.")); } } else { console.error("Drawer with id ".concat(drawerId, " not found. Are you sure that the data-drawer-target attribute points to the correct drawer id")); } }); document.querySelectorAll('[data-drawer-show]').forEach(function ($triggerEl) { var drawerId = $triggerEl.getAttribute('data-drawer-show'); var $drawerEl = document.getElementById(drawerId); if ($drawerEl) { var drawer_3 = dom_instances.getInstance('Drawer', drawerId); if (drawer_3) { var showDrawer = function () { drawer_3.show(); }; $triggerEl.addEventListener('click', showDrawer); drawer_3.addEventListenerInstance($triggerEl, 'click', showDrawer); } else { console.error("Drawer with id ".concat(drawerId, " has not been initialized. Please initialize it using the data-drawer-target attribute.")); } } else { console.error("Drawer with id ".concat(drawerId, " not found. Are you sure that the data-drawer-target attribute points to the correct drawer id?")); } }); } if (typeof window !== 'undefined') { window.Drawer = Drawer; window.initDrawers = initDrawers; } /* harmony default export */ const drawer = ((/* unused pure expression or super */ null && (Drawer))); //# sourceMappingURL=index.js.map ;// ./node_modules/flowbite/lib/esm/components/tabs/index.js var tabs_assign = (undefined && undefined.__assign) || function () { tabs_assign = Object.assign || function(t) { for (var s, i = 1, n = arguments.length; i < n; i++) { s = arguments[i]; for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p]; } return t; }; return tabs_assign.apply(this, arguments); }; var tabs_Default = { defaultTabId: null, activeClasses: 'text-blue-600 hover:text-blue-600 dark:text-blue-500 dark:hover:text-blue-500 border-blue-600 dark:border-blue-500', inactiveClasses: 'dark:border-transparent text-gray-500 hover:text-gray-600 dark:text-gray-400 border-gray-100 hover:border-gray-300 dark:border-gray-700 dark:hover:text-gray-300', onShow: function () { }, }; var tabs_DefaultInstanceOptions = { id: null, override: true, }; var Tabs = /** @class */ (function () { function Tabs(tabsEl, items, options, instanceOptions) { if (tabsEl === void 0) { tabsEl = null; } if (items === void 0) { items = []; } if (options === void 0) { options = tabs_Default; } if (instanceOptions === void 0) { instanceOptions = tabs_DefaultInstanceOptions; } this._instanceId = instanceOptions.id ? instanceOptions.id : tabsEl.id; this._tabsEl = tabsEl; this._items = items; this._activeTab = options ? this.getTab(options.defaultTabId) : null; this._options = tabs_assign(tabs_assign({}, tabs_Default), options); this._initialized = false; this.init(); dom_instances.addInstance('Tabs', this, this._instanceId, instanceOptions.override); } Tabs.prototype.init = function () { var _this = this; if (this._items.length && !this._initialized) { // set the first tab as active if not set by explicitly if (!this._activeTab) { this.setActiveTab(this._items[0]); } // force show the first default tab this.show(this._activeTab.id, true); // show tab content based on click this._items.map(function (tab) { tab.triggerEl.addEventListener('click', function (event) { event.preventDefault(); _this.show(tab.id); }); }); } }; Tabs.prototype.destroy = function () { if (this._initialized) { this._initialized = false; } }; Tabs.prototype.removeInstance = function () { this.destroy(); dom_instances.removeInstance('Tabs', this._instanceId); }; Tabs.prototype.destroyAndRemoveInstance = function () { this.destroy(); this.removeInstance(); }; Tabs.prototype.getActiveTab = function () { return this._activeTab; }; Tabs.prototype.setActiveTab = function (tab) { this._activeTab = tab; }; Tabs.prototype.getTab = function (id) { return this._items.filter(function (t) { return t.id === id; })[0]; }; Tabs.prototype.show = function (id, forceShow) { var _a, _b; var _this = this; if (forceShow === void 0) { forceShow = false; } var tab = this.getTab(id); // don't do anything if already active if (tab === this._activeTab && !forceShow) { return; } // hide other tabs this._items.map(function (t) { var _a, _b; if (t !== tab) { (_a = t.triggerEl.classList).remove.apply(_a, _this._options.activeClasses.split(' ')); (_b = t.triggerEl.classList).add.apply(_b, _this._options.inactiveClasses.split(' ')); t.targetEl.classList.add('hidden'); t.triggerEl.setAttribute('aria-selected', 'false'); } }); // show active tab (_a = tab.triggerEl.classList).add.apply(_a, this._options.activeClasses.split(' ')); (_b = tab.triggerEl.classList).remove.apply(_b, this._options.inactiveClasses.split(' ')); tab.triggerEl.setAttribute('aria-selected', 'true'); tab.targetEl.classList.remove('hidden'); this.setActiveTab(tab); // callback function this._options.onShow(this, tab); }; Tabs.prototype.updateOnShow = function (callback) { this._options.onShow = callback; }; return Tabs; }()); function initTabs() { document.querySelectorAll('[data-tabs-toggle]').forEach(function ($parentEl) { var tabItems = []; var activeClasses = $parentEl.getAttribute('data-tabs-active-classes'); var inactiveClasses = $parentEl.getAttribute('data-tabs-inactive-classes'); var defaultTabId = null; $parentEl .querySelectorAll('[role="tab"]') .forEach(function ($triggerEl) { var isActive = $triggerEl.getAttribute('aria-selected') === 'true'; var tab = { id: $triggerEl.getAttribute('data-tabs-target'), triggerEl: $triggerEl, targetEl: document.querySelector($triggerEl.getAttribute('data-tabs-target')), }; tabItems.push(tab); if (isActive) { defaultTabId = tab.id; } }); new Tabs($parentEl, tabItems, { defaultTabId: defaultTabId, activeClasses: activeClasses ? activeClasses : tabs_Default.activeClasses, inactiveClasses: inactiveClasses ? inactiveClasses : tabs_Default.inactiveClasses, }); }); } if (typeof window !== 'undefined') { window.Tabs = Tabs; window.initTabs = initTabs; } /* harmony default export */ const tabs = ((/* unused pure expression or super */ null && (Tabs))); //# sourceMappingURL=index.js.map ;// ./node_modules/flowbite/lib/esm/components/tooltip/index.js var tooltip_assign = (undefined && undefined.__assign) || function () { tooltip_assign = Object.assign || function(t) { for (var s, i = 1, n = arguments.length; i < n; i++) { s = arguments[i]; for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p]; } return t; }; return tooltip_assign.apply(this, arguments); }; var tooltip_spreadArray = (undefined && undefined.__spreadArray) || function (to, from, pack) { if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) { if (ar || !(i in from)) { if (!ar) ar = Array.prototype.slice.call(from, 0, i); ar[i] = from[i]; } } return to.concat(ar || Array.prototype.slice.call(from)); }; /* eslint-disable @typescript-eslint/no-empty-function */ var tooltip_Default = { placement: 'top', triggerType: 'hover', onShow: function () { }, onHide: function () { }, onToggle: function () { }, }; var tooltip_DefaultInstanceOptions = { id: null, override: true, }; var Tooltip = /** @class */ (function () { function Tooltip(targetEl, triggerEl, options, instanceOptions) { if (targetEl === void 0) { targetEl = null; } if (triggerEl === void 0) { triggerEl = null; } if (options === void 0) { options = tooltip_Default; } if (instanceOptions === void 0) { instanceOptions = tooltip_DefaultInstanceOptions; } this._instanceId = instanceOptions.id ? instanceOptions.id : targetEl.id; this._targetEl = targetEl; this._triggerEl = triggerEl; this._options = tooltip_assign(tooltip_assign({}, tooltip_Default), options); this._popperInstance = null; this._visible = false; this._initialized = false; this.init(); dom_instances.addInstance('Tooltip', this, this._instanceId, instanceOptions.override); } Tooltip.prototype.init = function () { if (this._triggerEl && this._targetEl && !this._initialized) { this._setupEventListeners(); this._popperInstance = this._createPopperInstance(); this._initialized = true; } }; Tooltip.prototype.destroy = function () { var _this = this; if (this._initialized) { // remove event listeners associated with the trigger element var triggerEvents = this._getTriggerEvents(); triggerEvents.showEvents.forEach(function (ev) { _this._triggerEl.removeEventListener(ev, _this._showHandler); }); triggerEvents.hideEvents.forEach(function (ev) { _this._triggerEl.removeEventListener(ev, _this._hideHandler); }); // remove event listeners for keydown this._removeKeydownListener(); // remove event listeners for click outside this._removeClickOutsideListener(); // destroy the Popper instance if you have one (assuming this._popperInstance is the Popper instance) if (this._popperInstance) { this._popperInstance.destroy(); } this._initialized = false; } }; Tooltip.prototype.removeInstance = function () { dom_instances.removeInstance('Tooltip', this._instanceId); }; Tooltip.prototype.destroyAndRemoveInstance = function () { this.destroy(); this.removeInstance(); }; Tooltip.prototype._setupEventListeners = function () { var _this = this; var triggerEvents = this._getTriggerEvents(); this._showHandler = function () { _this.show(); }; this._hideHandler = function () { _this.hide(); }; triggerEvents.showEvents.forEach(function (ev) { _this._triggerEl.addEventListener(ev, _this._showHandler); }); triggerEvents.hideEvents.forEach(function (ev) { _this._triggerEl.addEventListener(ev, _this._hideHandler); }); }; Tooltip.prototype._createPopperInstance = function () { return popper_createPopper(this._triggerEl, this._targetEl, { placement: this._options.placement, modifiers: [ { name: 'offset', options: { offset: [0, 8], }, }, ], }); }; Tooltip.prototype._getTriggerEvents = function () { switch (this._options.triggerType) { case 'hover': return { showEvents: ['mouseenter', 'focus'], hideEvents: ['mouseleave', 'blur'], }; case 'click': return { showEvents: ['click', 'focus'], hideEvents: ['focusout', 'blur'], }; case 'none': return { showEvents: [], hideEvents: [], }; default: return { showEvents: ['mouseenter', 'focus'], hideEvents: ['mouseleave', 'blur'], }; } }; Tooltip.prototype._setupKeydownListener = function () { var _this = this; this._keydownEventListener = function (ev) { if (ev.key === 'Escape') { _this.hide(); } }; document.body.addEventListener('keydown', this._keydownEventListener, true); }; Tooltip.prototype._removeKeydownListener = function () { document.body.removeEventListener('keydown', this._keydownEventListener, true); }; Tooltip.prototype._setupClickOutsideListener = function () { var _this = this; this._clickOutsideEventListener = function (ev) { _this._handleClickOutside(ev, _this._targetEl); }; document.body.addEventListener('click', this._clickOutsideEventListener, true); }; Tooltip.prototype._removeClickOutsideListener = function () { document.body.removeEventListener('click', this._clickOutsideEventListener, true); }; Tooltip.prototype._handleClickOutside = function (ev, targetEl) { var clickedEl = ev.target; if (clickedEl !== targetEl && !targetEl.contains(clickedEl) && !this._triggerEl.contains(clickedEl) && this.isVisible()) { this.hide(); } }; Tooltip.prototype.isVisible = function () { return this._visible; }; Tooltip.prototype.toggle = function () { if (this.isVisible()) { this.hide(); } else { this.show(); } }; Tooltip.prototype.show = function () { this._targetEl.classList.remove('opacity-0', 'invisible'); this._targetEl.classList.add('opacity-100', 'visible'); // Enable the event listeners this._popperInstance.setOptions(function (options) { return (tooltip_assign(tooltip_assign({}, options), { modifiers: tooltip_spreadArray(tooltip_spreadArray([], options.modifiers, true), [ { name: 'eventListeners', enabled: true }, ], false) })); }); // handle click outside this._setupClickOutsideListener(); // handle esc keydown this._setupKeydownListener(); // Update its position this._popperInstance.update(); // set visibility this._visible = true; // callback function this._options.onShow(this); }; Tooltip.prototype.hide = function () { this._targetEl.classList.remove('opacity-100', 'visible'); this._targetEl.classList.add('opacity-0', 'invisible'); // Disable the event listeners this._popperInstance.setOptions(function (options) { return (tooltip_assign(tooltip_assign({}, options), { modifiers: tooltip_spreadArray(tooltip_spreadArray([], options.modifiers, true), [ { name: 'eventListeners', enabled: false }, ], false) })); }); // handle click outside this._removeClickOutsideListener(); // handle esc keydown this._removeKeydownListener(); // set visibility this._visible = false; // callback function this._options.onHide(this); }; Tooltip.prototype.updateOnShow = function (callback) { this._options.onShow = callback; }; Tooltip.prototype.updateOnHide = function (callback) { this._options.onHide = callback; }; Tooltip.prototype.updateOnToggle = function (callback) { this._options.onToggle = callback; }; return Tooltip; }()); function initTooltips() { document.querySelectorAll('[data-tooltip-target]').forEach(function ($triggerEl) { var tooltipId = $triggerEl.getAttribute('data-tooltip-target'); var $tooltipEl = document.getElementById(tooltipId); if ($tooltipEl) { var triggerType = $triggerEl.getAttribute('data-tooltip-trigger'); var placement = $triggerEl.getAttribute('data-tooltip-placement'); new Tooltip($tooltipEl, $triggerEl, { placement: placement ? placement : tooltip_Default.placement, triggerType: triggerType ? triggerType : tooltip_Default.triggerType, }); } else { console.error("The tooltip element with id \"".concat(tooltipId, "\" does not exist. Please check the data-tooltip-target attribute.")); } }); } if (typeof window !== 'undefined') { window.Tooltip = Tooltip; window.initTooltips = initTooltips; } /* harmony default export */ const tooltip = ((/* unused pure expression or super */ null && (Tooltip))); //# sourceMappingURL=index.js.map ;// ./node_modules/flowbite/lib/esm/components/popover/index.js var popover_assign = (undefined && undefined.__assign) || function () { popover_assign = Object.assign || function(t) { for (var s, i = 1, n = arguments.length; i < n; i++) { s = arguments[i]; for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p]; } return t; }; return popover_assign.apply(this, arguments); }; var popover_spreadArray = (undefined && undefined.__spreadArray) || function (to, from, pack) { if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) { if (ar || !(i in from)) { if (!ar) ar = Array.prototype.slice.call(from, 0, i); ar[i] = from[i]; } } return to.concat(ar || Array.prototype.slice.call(from)); }; /* eslint-disable @typescript-eslint/no-empty-function */ var popover_Default = { placement: 'top', offset: 10, triggerType: 'hover', onShow: function () { }, onHide: function () { }, onToggle: function () { }, }; var popover_DefaultInstanceOptions = { id: null, override: true, }; var Popover = /** @class */ (function () { function Popover(targetEl, triggerEl, options, instanceOptions) { if (targetEl === void 0) { targetEl = null; } if (triggerEl === void 0) { triggerEl = null; } if (options === void 0) { options = popover_Default; } if (instanceOptions === void 0) { instanceOptions = popover_DefaultInstanceOptions; } this._instanceId = instanceOptions.id ? instanceOptions.id : targetEl.id; this._targetEl = targetEl; this._triggerEl = triggerEl; this._options = popover_assign(popover_assign({}, popover_Default), options); this._popperInstance = null; this._visible = false; this._initialized = false; this.init(); dom_instances.addInstance('Popover', this, instanceOptions.id ? instanceOptions.id : this._targetEl.id, instanceOptions.override); } Popover.prototype.init = function () { if (this._triggerEl && this._targetEl && !this._initialized) { this._setupEventListeners(); this._popperInstance = this._createPopperInstance(); this._initialized = true; } }; Popover.prototype.destroy = function () { var _this = this; if (this._initialized) { // remove event listeners associated with the trigger element and target element var triggerEvents = this._getTriggerEvents(); triggerEvents.showEvents.forEach(function (ev) { _this._triggerEl.removeEventListener(ev, _this._showHandler); _this._targetEl.removeEventListener(ev, _this._showHandler); }); triggerEvents.hideEvents.forEach(function (ev) { _this._triggerEl.removeEventListener(ev, _this._hideHandler); _this._targetEl.removeEventListener(ev, _this._hideHandler); }); // remove event listeners for keydown this._removeKeydownListener(); // remove event listeners for click outside this._removeClickOutsideListener(); // destroy the Popper instance if you have one (assuming this._popperInstance is the Popper instance) if (this._popperInstance) { this._popperInstance.destroy(); } this._initialized = false; } }; Popover.prototype.removeInstance = function () { dom_instances.removeInstance('Popover', this._instanceId); }; Popover.prototype.destroyAndRemoveInstance = function () { this.destroy(); this.removeInstance(); }; Popover.prototype._setupEventListeners = function () { var _this = this; var triggerEvents = this._getTriggerEvents(); this._showHandler = function () { _this.show(); }; this._hideHandler = function () { setTimeout(function () { if (!_this._targetEl.matches(':hover')) { _this.hide(); } }, 100); }; triggerEvents.showEvents.forEach(function (ev) { _this._triggerEl.addEventListener(ev, _this._showHandler); _this._targetEl.addEventListener(ev, _this._showHandler); }); triggerEvents.hideEvents.forEach(function (ev) { _this._triggerEl.addEventListener(ev, _this._hideHandler); _this._targetEl.addEventListener(ev, _this._hideHandler); }); }; Popover.prototype._createPopperInstance = function () { return popper_createPopper(this._triggerEl, this._targetEl, { placement: this._options.placement, modifiers: [ { name: 'offset', options: { offset: [0, this._options.offset], }, }, ], }); }; Popover.prototype._getTriggerEvents = function () { switch (this._options.triggerType) { case 'hover': return { showEvents: ['mouseenter', 'focus'], hideEvents: ['mouseleave', 'blur'], }; case 'click': return { showEvents: ['click', 'focus'], hideEvents: ['focusout', 'blur'], }; case 'none': return { showEvents: [], hideEvents: [], }; default: return { showEvents: ['mouseenter', 'focus'], hideEvents: ['mouseleave', 'blur'], }; } }; Popover.prototype._setupKeydownListener = function () { var _this = this; this._keydownEventListener = function (ev) { if (ev.key === 'Escape') { _this.hide(); } }; document.body.addEventListener('keydown', this._keydownEventListener, true); }; Popover.prototype._removeKeydownListener = function () { document.body.removeEventListener('keydown', this._keydownEventListener, true); }; Popover.prototype._setupClickOutsideListener = function () { var _this = this; this._clickOutsideEventListener = function (ev) { _this._handleClickOutside(ev, _this._targetEl); }; document.body.addEventListener('click', this._clickOutsideEventListener, true); }; Popover.prototype._removeClickOutsideListener = function () { document.body.removeEventListener('click', this._clickOutsideEventListener, true); }; Popover.prototype._handleClickOutside = function (ev, targetEl) { var clickedEl = ev.target; if (clickedEl !== targetEl && !targetEl.contains(clickedEl) && !this._triggerEl.contains(clickedEl) && this.isVisible()) { this.hide(); } }; Popover.prototype.isVisible = function () { return this._visible; }; Popover.prototype.toggle = function () { if (this.isVisible()) { this.hide(); } else { this.show(); } this._options.onToggle(this); }; Popover.prototype.show = function () { this._targetEl.classList.remove('opacity-0', 'invisible'); this._targetEl.classList.add('opacity-100', 'visible'); // Enable the event listeners this._popperInstance.setOptions(function (options) { return (popover_assign(popover_assign({}, options), { modifiers: popover_spreadArray(popover_spreadArray([], options.modifiers, true), [ { name: 'eventListeners', enabled: true }, ], false) })); }); // handle click outside this._setupClickOutsideListener(); // handle esc keydown this._setupKeydownListener(); // Update its position this._popperInstance.update(); // set visibility to true this._visible = true; // callback function this._options.onShow(this); }; Popover.prototype.hide = function () { this._targetEl.classList.remove('opacity-100', 'visible'); this._targetEl.classList.add('opacity-0', 'invisible'); // Disable the event listeners this._popperInstance.setOptions(function (options) { return (popover_assign(popover_assign({}, options), { modifiers: popover_spreadArray(popover_spreadArray([], options.modifiers, true), [ { name: 'eventListeners', enabled: false }, ], false) })); }); // handle click outside this._removeClickOutsideListener(); // handle esc keydown this._removeKeydownListener(); // set visibility to false this._visible = false; // callback function this._options.onHide(this); }; Popover.prototype.updateOnShow = function (callback) { this._options.onShow = callback; }; Popover.prototype.updateOnHide = function (callback) { this._options.onHide = callback; }; Popover.prototype.updateOnToggle = function (callback) { this._options.onToggle = callback; }; return Popover; }()); function initPopovers() { document.querySelectorAll('[data-popover-target]').forEach(function ($triggerEl) { var popoverID = $triggerEl.getAttribute('data-popover-target'); var $popoverEl = document.getElementById(popoverID); if ($popoverEl) { var triggerType = $triggerEl.getAttribute('data-popover-trigger'); var placement = $triggerEl.getAttribute('data-popover-placement'); var offset = $triggerEl.getAttribute('data-popover-offset'); new Popover($popoverEl, $triggerEl, { placement: placement ? placement : popover_Default.placement, offset: offset ? parseInt(offset) : popover_Default.offset, triggerType: triggerType ? triggerType : popover_Default.triggerType, }); } else { console.error("The popover element with id \"".concat(popoverID, "\" does not exist. Please check the data-popover-target attribute.")); } }); } if (typeof window !== 'undefined') { window.Popover = Popover; window.initPopovers = initPopovers; } /* harmony default export */ const popover = ((/* unused pure expression or super */ null && (Popover))); //# sourceMappingURL=index.js.map ;// ./node_modules/flowbite/lib/esm/components/dial/index.js var dial_assign = (undefined && undefined.__assign) || function () { dial_assign = Object.assign || function(t) { for (var s, i = 1, n = arguments.length; i < n; i++) { s = arguments[i]; for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p]; } return t; }; return dial_assign.apply(this, arguments); }; var dial_Default = { triggerType: 'hover', onShow: function () { }, onHide: function () { }, onToggle: function () { }, }; var dial_DefaultInstanceOptions = { id: null, override: true, }; var Dial = /** @class */ (function () { function Dial(parentEl, triggerEl, targetEl, options, instanceOptions) { if (parentEl === void 0) { parentEl = null; } if (triggerEl === void 0) { triggerEl = null; } if (targetEl === void 0) { targetEl = null; } if (options === void 0) { options = dial_Default; } if (instanceOptions === void 0) { instanceOptions = dial_DefaultInstanceOptions; } this._instanceId = instanceOptions.id ? instanceOptions.id : targetEl.id; this._parentEl = parentEl; this._triggerEl = triggerEl; this._targetEl = targetEl; this._options = dial_assign(dial_assign({}, dial_Default), options); this._visible = false; this._initialized = false; this.init(); dom_instances.addInstance('Dial', this, this._instanceId, instanceOptions.override); } Dial.prototype.init = function () { var _this = this; if (this._triggerEl && this._targetEl && !this._initialized) { var triggerEventTypes = this._getTriggerEventTypes(this._options.triggerType); this._showEventHandler = function () { _this.show(); }; triggerEventTypes.showEvents.forEach(function (ev) { _this._triggerEl.addEventListener(ev, _this._showEventHandler); _this._targetEl.addEventListener(ev, _this._showEventHandler); }); this._hideEventHandler = function () { if (!_this._parentEl.matches(':hover')) { _this.hide(); } }; triggerEventTypes.hideEvents.forEach(function (ev) { _this._parentEl.addEventListener(ev, _this._hideEventHandler); }); this._initialized = true; } }; Dial.prototype.destroy = function () { var _this = this; if (this._initialized) { var triggerEventTypes = this._getTriggerEventTypes(this._options.triggerType); triggerEventTypes.showEvents.forEach(function (ev) { _this._triggerEl.removeEventListener(ev, _this._showEventHandler); _this._targetEl.removeEventListener(ev, _this._showEventHandler); }); triggerEventTypes.hideEvents.forEach(function (ev) { _this._parentEl.removeEventListener(ev, _this._hideEventHandler); }); this._initialized = false; } }; Dial.prototype.removeInstance = function () { dom_instances.removeInstance('Dial', this._instanceId); }; Dial.prototype.destroyAndRemoveInstance = function () { this.destroy(); this.removeInstance(); }; Dial.prototype.hide = function () { this._targetEl.classList.add('hidden'); if (this._triggerEl) { this._triggerEl.setAttribute('aria-expanded', 'false'); } this._visible = false; // callback function this._options.onHide(this); }; Dial.prototype.show = function () { this._targetEl.classList.remove('hidden'); if (this._triggerEl) { this._triggerEl.setAttribute('aria-expanded', 'true'); } this._visible = true; // callback function this._options.onShow(this); }; Dial.prototype.toggle = function () { if (this._visible) { this.hide(); } else { this.show(); } }; Dial.prototype.isHidden = function () { return !this._visible; }; Dial.prototype.isVisible = function () { return this._visible; }; Dial.prototype._getTriggerEventTypes = function (triggerType) { switch (triggerType) { case 'hover': return { showEvents: ['mouseenter', 'focus'], hideEvents: ['mouseleave', 'blur'], }; case 'click': return { showEvents: ['click', 'focus'], hideEvents: ['focusout', 'blur'], }; case 'none': return { showEvents: [], hideEvents: [], }; default: return { showEvents: ['mouseenter', 'focus'], hideEvents: ['mouseleave', 'blur'], }; } }; Dial.prototype.updateOnShow = function (callback) { this._options.onShow = callback; }; Dial.prototype.updateOnHide = function (callback) { this._options.onHide = callback; }; Dial.prototype.updateOnToggle = function (callback) { this._options.onToggle = callback; }; return Dial; }()); function initDials() { document.querySelectorAll('[data-dial-init]').forEach(function ($parentEl) { var $triggerEl = $parentEl.querySelector('[data-dial-toggle]'); if ($triggerEl) { var dialId = $triggerEl.getAttribute('data-dial-toggle'); var $dialEl = document.getElementById(dialId); if ($dialEl) { var triggerType = $triggerEl.getAttribute('data-dial-trigger'); new Dial($parentEl, $triggerEl, $dialEl, { triggerType: triggerType ? triggerType : dial_Default.triggerType, }); } else { console.error("Dial with id ".concat(dialId, " does not exist. Are you sure that the data-dial-toggle attribute points to the correct modal id?")); } } else { console.error("Dial with id ".concat($parentEl.id, " does not have a trigger element. Are you sure that the data-dial-toggle attribute exists?")); } }); } if (typeof window !== 'undefined') { window.Dial = Dial; window.initDials = initDials; } /* harmony default export */ const dial = ((/* unused pure expression or super */ null && (Dial))); //# sourceMappingURL=index.js.map ;// ./node_modules/flowbite/lib/esm/components/input-counter/index.js var input_counter_assign = (undefined && undefined.__assign) || function () { input_counter_assign = Object.assign || function(t) { for (var s, i = 1, n = arguments.length; i < n; i++) { s = arguments[i]; for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p]; } return t; }; return input_counter_assign.apply(this, arguments); }; var input_counter_Default = { minValue: null, maxValue: null, onIncrement: function () { }, onDecrement: function () { }, }; var input_counter_DefaultInstanceOptions = { id: null, override: true, }; var InputCounter = /** @class */ (function () { function InputCounter(targetEl, incrementEl, decrementEl, options, instanceOptions) { if (targetEl === void 0) { targetEl = null; } if (incrementEl === void 0) { incrementEl = null; } if (decrementEl === void 0) { decrementEl = null; } if (options === void 0) { options = input_counter_Default; } if (instanceOptions === void 0) { instanceOptions = input_counter_DefaultInstanceOptions; } this._instanceId = instanceOptions.id ? instanceOptions.id : targetEl.id; this._targetEl = targetEl; this._incrementEl = incrementEl; this._decrementEl = decrementEl; this._options = input_counter_assign(input_counter_assign({}, input_counter_Default), options); this._initialized = false; this.init(); dom_instances.addInstance('InputCounter', this, this._instanceId, instanceOptions.override); } InputCounter.prototype.init = function () { var _this = this; if (this._targetEl && !this._initialized) { this._inputHandler = function (event) { { var target = event.target; // check if the value is numeric if (!/^\d*$/.test(target.value)) { // Regex to check if the value is numeric target.value = target.value.replace(/[^\d]/g, ''); // Remove non-numeric characters } // check for max value if (_this._options.maxValue !== null && parseInt(target.value) > _this._options.maxValue) { target.value = _this._options.maxValue.toString(); } // check for min value if (_this._options.minValue !== null && parseInt(target.value) < _this._options.minValue) { target.value = _this._options.minValue.toString(); } } }; this._incrementClickHandler = function () { _this.increment(); }; this._decrementClickHandler = function () { _this.decrement(); }; // Add event listener to restrict input to numeric values only this._targetEl.addEventListener('input', this._inputHandler); if (this._incrementEl) { this._incrementEl.addEventListener('click', this._incrementClickHandler); } if (this._decrementEl) { this._decrementEl.addEventListener('click', this._decrementClickHandler); } this._initialized = true; } }; InputCounter.prototype.destroy = function () { if (this._targetEl && this._initialized) { this._targetEl.removeEventListener('input', this._inputHandler); if (this._incrementEl) { this._incrementEl.removeEventListener('click', this._incrementClickHandler); } if (this._decrementEl) { this._decrementEl.removeEventListener('click', this._decrementClickHandler); } this._initialized = false; } }; InputCounter.prototype.removeInstance = function () { dom_instances.removeInstance('InputCounter', this._instanceId); }; InputCounter.prototype.destroyAndRemoveInstance = function () { this.destroy(); this.removeInstance(); }; InputCounter.prototype.getCurrentValue = function () { return parseInt(this._targetEl.value) || 0; }; InputCounter.prototype.increment = function () { // don't increment if the value is already at the maximum value if (this._options.maxValue !== null && this.getCurrentValue() >= this._options.maxValue) { return; } this._targetEl.value = (this.getCurrentValue() + 1).toString(); this._options.onIncrement(this); }; InputCounter.prototype.decrement = function () { // don't decrement if the value is already at the minimum value if (this._options.minValue !== null && this.getCurrentValue() <= this._options.minValue) { return; } this._targetEl.value = (this.getCurrentValue() - 1).toString(); this._options.onDecrement(this); }; InputCounter.prototype.updateOnIncrement = function (callback) { this._options.onIncrement = callback; }; InputCounter.prototype.updateOnDecrement = function (callback) { this._options.onDecrement = callback; }; return InputCounter; }()); function initInputCounters() { document.querySelectorAll('[data-input-counter]').forEach(function ($targetEl) { var targetId = $targetEl.id; var $incrementEl = document.querySelector('[data-input-counter-increment="' + targetId + '"]'); var $decrementEl = document.querySelector('[data-input-counter-decrement="' + targetId + '"]'); var minValue = $targetEl.getAttribute('data-input-counter-min'); var maxValue = $targetEl.getAttribute('data-input-counter-max'); // check if the target element exists if ($targetEl) { if (!dom_instances.instanceExists('InputCounter', $targetEl.getAttribute('id'))) { new InputCounter($targetEl, $incrementEl ? $incrementEl : null, $decrementEl ? $decrementEl : null, { minValue: minValue ? parseInt(minValue) : null, maxValue: maxValue ? parseInt(maxValue) : null, }); } } else { console.error("The target element with id \"".concat(targetId, "\" does not exist. Please check the data-input-counter attribute.")); } }); } if (typeof window !== 'undefined') { window.InputCounter = InputCounter; window.initInputCounters = initInputCounters; } /* harmony default export */ const input_counter = ((/* unused pure expression or super */ null && (InputCounter))); //# sourceMappingURL=index.js.map ;// ./node_modules/flowbite/lib/esm/components/clipboard/index.js var clipboard_assign = (undefined && undefined.__assign) || function () { clipboard_assign = Object.assign || function(t) { for (var s, i = 1, n = arguments.length; i < n; i++) { s = arguments[i]; for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p]; } return t; }; return clipboard_assign.apply(this, arguments); }; var clipboard_Default = { htmlEntities: false, contentType: 'input', onCopy: function () { }, }; var clipboard_DefaultInstanceOptions = { id: null, override: true, }; var CopyClipboard = /** @class */ (function () { function CopyClipboard(triggerEl, targetEl, options, instanceOptions) { if (triggerEl === void 0) { triggerEl = null; } if (targetEl === void 0) { targetEl = null; } if (options === void 0) { options = clipboard_Default; } if (instanceOptions === void 0) { instanceOptions = clipboard_DefaultInstanceOptions; } this._instanceId = instanceOptions.id ? instanceOptions.id : targetEl.id; this._triggerEl = triggerEl; this._targetEl = targetEl; this._options = clipboard_assign(clipboard_assign({}, clipboard_Default), options); this._initialized = false; this.init(); dom_instances.addInstance('CopyClipboard', this, this._instanceId, instanceOptions.override); } CopyClipboard.prototype.init = function () { var _this = this; if (this._targetEl && this._triggerEl && !this._initialized) { this._triggerElClickHandler = function () { _this.copy(); }; // clicking on the trigger element should copy the value of the target element if (this._triggerEl) { this._triggerEl.addEventListener('click', this._triggerElClickHandler); } this._initialized = true; } }; CopyClipboard.prototype.destroy = function () { if (this._triggerEl && this._targetEl && this._initialized) { if (this._triggerEl) { this._triggerEl.removeEventListener('click', this._triggerElClickHandler); } this._initialized = false; } }; CopyClipboard.prototype.removeInstance = function () { dom_instances.removeInstance('CopyClipboard', this._instanceId); }; CopyClipboard.prototype.destroyAndRemoveInstance = function () { this.destroy(); this.removeInstance(); }; CopyClipboard.prototype.getTargetValue = function () { if (this._options.contentType === 'input') { return this._targetEl.value; } if (this._options.contentType === 'innerHTML') { return this._targetEl.innerHTML; } if (this._options.contentType === 'textContent') { return this._targetEl.textContent.replace(/\s+/g, ' ').trim(); } }; CopyClipboard.prototype.copy = function () { var textToCopy = this.getTargetValue(); // Check if HTMLEntities option is enabled if (this._options.htmlEntities) { // Encode the text using HTML entities textToCopy = this.decodeHTML(textToCopy); } // Create a temporary textarea element var tempTextArea = document.createElement('textarea'); tempTextArea.value = textToCopy; document.body.appendChild(tempTextArea); // Select the text inside the textarea and copy it to the clipboard tempTextArea.select(); document.execCommand('copy'); // Remove the temporary textarea document.body.removeChild(tempTextArea); // Callback function this._options.onCopy(this); return textToCopy; }; // Function to encode text into HTML entities CopyClipboard.prototype.decodeHTML = function (html) { var textarea = document.createElement('textarea'); textarea.innerHTML = html; return textarea.textContent; }; CopyClipboard.prototype.updateOnCopyCallback = function (callback) { this._options.onCopy = callback; }; return CopyClipboard; }()); function initCopyClipboards() { document .querySelectorAll('[data-copy-to-clipboard-target]') .forEach(function ($triggerEl) { var targetId = $triggerEl.getAttribute('data-copy-to-clipboard-target'); var $targetEl = document.getElementById(targetId); var contentType = $triggerEl.getAttribute('data-copy-to-clipboard-content-type'); var htmlEntities = $triggerEl.getAttribute('data-copy-to-clipboard-html-entities'); // check if the target element exists if ($targetEl) { if (!dom_instances.instanceExists('CopyClipboard', $targetEl.getAttribute('id'))) { new CopyClipboard($triggerEl, $targetEl, { htmlEntities: htmlEntities && htmlEntities === 'true' ? true : clipboard_Default.htmlEntities, contentType: contentType ? contentType : clipboard_Default.contentType, }); } } else { console.error("The target element with id \"".concat(targetId, "\" does not exist. Please check the data-copy-to-clipboard-target attribute.")); } }); } if (typeof window !== 'undefined') { window.CopyClipboard = CopyClipboard; window.initClipboards = initCopyClipboards; } /* harmony default export */ const clipboard = ((/* unused pure expression or super */ null && (CopyClipboard))); //# sourceMappingURL=index.js.map ;// ./node_modules/flowbite-datepicker/dist/main.esm.js function _arrayLikeToArray(r, a) { (null == a || a > r.length) && (a = r.length); for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e]; return n; } function _arrayWithHoles(r) { if (Array.isArray(r)) return r; } function _arrayWithoutHoles(r) { if (Array.isArray(r)) return _arrayLikeToArray(r); } function _assertThisInitialized(e) { if (void 0 === e) throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); return e; } function _callSuper(t, o, e) { return o = _getPrototypeOf(o), _possibleConstructorReturn(t, _isNativeReflectConstruct() ? Reflect.construct(o, e || [], _getPrototypeOf(t).constructor) : o.apply(t, e)); } function _classCallCheck(a, n) { if (!(a instanceof n)) throw new TypeError("Cannot call a class as a function"); } function _defineProperties(e, r) { for (var t = 0; t < r.length; t++) { var o = r[t]; o.enumerable = o.enumerable || !1, o.configurable = !0, "value" in o && (o.writable = !0), Object.defineProperty(e, _toPropertyKey(o.key), o); } } function _createClass(e, r, t) { return r && _defineProperties(e.prototype, r), t && _defineProperties(e, t), Object.defineProperty(e, "prototype", { writable: !1 }), e; } function _get() { return _get = "undefined" != typeof Reflect && Reflect.get ? Reflect.get.bind() : function (e, t, r) { var p = _superPropBase(e, t); if (p) { var n = Object.getOwnPropertyDescriptor(p, t); return n.get ? n.get.call(arguments.length < 3 ? e : r) : n.value; } }, _get.apply(null, arguments); } function _getPrototypeOf(t) { return _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf.bind() : function (t) { return t.__proto__ || Object.getPrototypeOf(t); }, _getPrototypeOf(t); } function _inherits(t, e) { if ("function" != typeof e && null !== e) throw new TypeError("Super expression must either be null or a function"); t.prototype = Object.create(e && e.prototype, { constructor: { value: t, writable: !0, configurable: !0 } }), Object.defineProperty(t, "prototype", { writable: !1 }), e && _setPrototypeOf(t, e); } function _isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct = function () { return !!t; })(); } function _iterableToArray(r) { if ("undefined" != typeof Symbol && null != r[Symbol.iterator] || null != r["@@iterator"]) return Array.from(r); } function _iterableToArrayLimit(r, l) { var t = null == r ? null : "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (null != t) { var e, n, i, u, a = [], f = !0, o = !1; try { if (i = (t = t.call(r)).next, 0 === l) { if (Object(t) !== t) return; f = !1; } else for (; !(f = (e = i.call(t)).done) && (a.push(e.value), a.length !== l); f = !0); } catch (r) { o = !0, n = r; } finally { try { if (!f && null != t.return && (u = t.return(), Object(u) !== u)) return; } finally { if (o) throw n; } } return a; } } function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } function _possibleConstructorReturn(t, e) { if (e && ("object" == typeof e || "function" == typeof e)) return e; if (void 0 !== e) throw new TypeError("Derived constructors may only return object or undefined"); return _assertThisInitialized(t); } function _setPrototypeOf(t, e) { return _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function (t, e) { return t.__proto__ = e, t; }, _setPrototypeOf(t, e); } function _slicedToArray(r, e) { return _arrayWithHoles(r) || _iterableToArrayLimit(r, e) || _unsupportedIterableToArray(r, e) || _nonIterableRest(); } function _superPropBase(t, o) { for (; !{}.hasOwnProperty.call(t, o) && null !== (t = _getPrototypeOf(t));); return t; } function _toConsumableArray(r) { return _arrayWithoutHoles(r) || _iterableToArray(r) || _unsupportedIterableToArray(r) || _nonIterableSpread(); } function _toPrimitive(t, r) { if ("object" != typeof t || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != typeof i) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == typeof i ? i : i + ""; } function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } function _unsupportedIterableToArray(r, a) { if (r) { if ("string" == typeof r) return _arrayLikeToArray(r, a); var t = {}.toString.call(r).slice(8, -1); return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? Array.from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? _arrayLikeToArray(r, a) : void 0; } } function hasProperty(obj, prop) { return Object.prototype.hasOwnProperty.call(obj, prop); } function lastItemOf(arr) { return arr[arr.length - 1]; } // push only the items not included in the array function pushUnique(arr) { for (var _len = arguments.length, items = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) { items[_key - 1] = arguments[_key]; } items.forEach(function (item) { if (arr.includes(item)) { return; } arr.push(item); }); return arr; } function stringToArray(str, separator) { // convert empty string to an empty array return str ? str.split(separator) : []; } function isInRange(testVal, min, max) { var minOK = min === undefined || testVal >= min; var maxOK = max === undefined || testVal <= max; return minOK && maxOK; } function limitToRange(val, min, max) { if (val < min) { return min; } if (val > max) { return max; } return val; } function createTagRepeat(tagName, repeat) { var attributes = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {}; var index = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : 0; var html = arguments.length > 4 && arguments[4] !== undefined ? arguments[4] : ''; var openTagSrc = Object.keys(attributes).reduce(function (src, attr) { var val = attributes[attr]; if (typeof val === 'function') { val = val(index); } return "".concat(src, " ").concat(attr, "=\"").concat(val, "\""); }, tagName); html += "<".concat(openTagSrc, ">").concat(tagName, ">"); var next = index + 1; return next < repeat ? createTagRepeat(tagName, repeat, attributes, next, html) : html; } // Remove the spacing surrounding tags for HTML parser not to create text nodes // before/after elements function optimizeTemplateHTML(html) { return html.replace(/>\s+/g, '>').replace(/\s+, '<'); } function stripTime(timeValue) { return new Date(timeValue).setHours(0, 0, 0, 0); } function today() { return new Date().setHours(0, 0, 0, 0); } // Get the time value of the start of given date or year, month and day function dateValue() { switch (arguments.length) { case 0: return today(); case 1: return stripTime(arguments.length <= 0 ? undefined : arguments[0]); } // use setFullYear() to keep 2-digit year from being mapped to 1900-1999 var newDate = new Date(0); newDate.setFullYear.apply(newDate, arguments); return newDate.setHours(0, 0, 0, 0); } function addDays(date, amount) { var newDate = new Date(date); return newDate.setDate(newDate.getDate() + amount); } function addWeeks(date, amount) { return addDays(date, amount * 7); } function addMonths(date, amount) { // If the day of the date is not in the new month, the last day of the new // month will be returned. e.g. Jan 31 + 1 month → Feb 28 (not Mar 03) var newDate = new Date(date); var monthsToSet = newDate.getMonth() + amount; var expectedMonth = monthsToSet % 12; if (expectedMonth < 0) { expectedMonth += 12; } var time = newDate.setMonth(monthsToSet); return newDate.getMonth() !== expectedMonth ? newDate.setDate(0) : time; } function addYears(date, amount) { // If the date is Feb 29 and the new year is not a leap year, Feb 28 of the // new year will be returned. var newDate = new Date(date); var expectedMonth = newDate.getMonth(); var time = newDate.setFullYear(newDate.getFullYear() + amount); return expectedMonth === 1 && newDate.getMonth() === 2 ? newDate.setDate(0) : time; } // Calculate the distance bettwen 2 days of the week function dayDiff(day, from) { return (day - from + 7) % 7; } // Get the date of the specified day of the week of given base date function dayOfTheWeekOf(baseDate, dayOfWeek) { var weekStart = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 0; var baseDay = new Date(baseDate).getDay(); return addDays(baseDate, dayDiff(dayOfWeek, weekStart) - dayDiff(baseDay, weekStart)); } // Get the ISO week of a date function getWeek(date) { // start of ISO week is Monday var thuOfTheWeek = dayOfTheWeekOf(date, 4, 1); // 1st week == the week where the 4th of January is in var firstThu = dayOfTheWeekOf(new Date(thuOfTheWeek).setMonth(0, 4), 4, 1); return Math.round((thuOfTheWeek - firstThu) / 604800000) + 1; } // Get the start year of the period of years that includes given date // years: length of the year period function startOfYearPeriod(date, years) { /* @see https://en.wikipedia.org/wiki/Year_zero#ISO_8601 */ var year = new Date(date).getFullYear(); return Math.floor(year / years) * years; } // pattern for format parts var reFormatTokens = /dd?|DD?|mm?|MM?|yy?(?:yy)?/; // pattern for non date parts var reNonDateParts = /[\s!-/:-@[-`{-~年月日]+/; // cache for persed formats var knownFormats = {}; // parse funtions for date parts var parseFns = { y: function y(date, year) { return new Date(date).setFullYear(parseInt(year, 10)); }, m: function m(date, month, locale) { var newDate = new Date(date); var monthIndex = parseInt(month, 10) - 1; if (isNaN(monthIndex)) { if (!month) { return NaN; } var monthName = month.toLowerCase(); var compareNames = function compareNames(name) { return name.toLowerCase().startsWith(monthName); }; // compare with both short and full names because some locales have periods // in the short names (not equal to the first X letters of the full names) monthIndex = locale.monthsShort.findIndex(compareNames); if (monthIndex < 0) { monthIndex = locale.months.findIndex(compareNames); } if (monthIndex < 0) { return NaN; } } newDate.setMonth(monthIndex); return newDate.getMonth() !== normalizeMonth(monthIndex) ? newDate.setDate(0) : newDate.getTime(); }, d: function d(date, day) { return new Date(date).setDate(parseInt(day, 10)); } }; // format functions for date parts var formatFns = { d: function d(date) { return date.getDate(); }, dd: function dd(date) { return padZero(date.getDate(), 2); }, D: function D(date, locale) { return locale.daysShort[date.getDay()]; }, DD: function DD(date, locale) { return locale.days[date.getDay()]; }, m: function m(date) { return date.getMonth() + 1; }, mm: function mm(date) { return padZero(date.getMonth() + 1, 2); }, M: function M(date, locale) { return locale.monthsShort[date.getMonth()]; }, MM: function MM(date, locale) { return locale.months[date.getMonth()]; }, y: function y(date) { return date.getFullYear(); }, yy: function yy(date) { return padZero(date.getFullYear(), 2).slice(-2); }, yyyy: function yyyy(date) { return padZero(date.getFullYear(), 4); } }; // get month index in normal range (0 - 11) from any number function normalizeMonth(monthIndex) { return monthIndex > -1 ? monthIndex % 12 : normalizeMonth(monthIndex + 12); } function padZero(num, length) { return num.toString().padStart(length, '0'); } function parseFormatString(format) { if (typeof format !== 'string') { throw new Error("Invalid date format."); } if (format in knownFormats) { return knownFormats[format]; } // sprit the format string into parts and seprators var separators = format.split(reFormatTokens); var parts = format.match(new RegExp(reFormatTokens, 'g')); if (separators.length === 0 || !parts) { throw new Error("Invalid date format."); } // collect format functions used in the format var partFormatters = parts.map(function (token) { return formatFns[token]; }); // collect parse function keys used in the format // iterate over parseFns' keys in order to keep the order of the keys. var partParserKeys = Object.keys(parseFns).reduce(function (keys, key) { var token = parts.find(function (part) { return part[0] !== 'D' && part[0].toLowerCase() === key; }); if (token) { keys.push(key); } return keys; }, []); return knownFormats[format] = { parser: function parser(dateStr, locale) { var dateParts = dateStr.split(reNonDateParts).reduce(function (dtParts, part, index) { if (part.length > 0 && parts[index]) { var token = parts[index][0]; if (token === 'M') { dtParts.m = part; } else if (token !== 'D') { dtParts[token] = part; } } return dtParts; }, {}); // iterate over partParserkeys so that the parsing is made in the oder // of year, month and day to prevent the day parser from correcting last // day of month wrongly return partParserKeys.reduce(function (origDate, key) { var newDate = parseFns[key](origDate, dateParts[key], locale); // ingnore the part failed to parse return isNaN(newDate) ? origDate : newDate; }, today()); }, formatter: function formatter(date, locale) { var dateStr = partFormatters.reduce(function (str, fn, index) { return str += "".concat(separators[index]).concat(fn(date, locale)); }, ''); // separators' length is always parts' length + 1, return dateStr += lastItemOf(separators); } }; } function parseDate(dateStr, format, locale) { if (dateStr instanceof Date || typeof dateStr === 'number') { var date = stripTime(dateStr); return isNaN(date) ? undefined : date; } if (!dateStr) { return undefined; } if (dateStr === 'today') { return today(); } if (format && format.toValue) { var _date = format.toValue(dateStr, format, locale); return isNaN(_date) ? undefined : stripTime(_date); } return parseFormatString(format).parser(dateStr, locale); } function formatDate(date, format, locale) { if (isNaN(date) || !date && date !== 0) { return ''; } var dateObj = typeof date === 'number' ? new Date(date) : date; if (format.toDisplay) { return format.toDisplay(dateObj, format, locale); } return parseFormatString(format).formatter(dateObj, locale); } var listenerRegistry = new WeakMap(); var _EventTarget$prototyp = EventTarget.prototype, addEventListener = _EventTarget$prototyp.addEventListener, removeEventListener = _EventTarget$prototyp.removeEventListener; // Register event listeners to a key object // listeners: array of listener definitions; // - each definition must be a flat array of event target and the arguments // used to call addEventListener() on the target function registerListeners(keyObj, listeners) { var registered = listenerRegistry.get(keyObj); if (!registered) { registered = []; listenerRegistry.set(keyObj, registered); } listeners.forEach(function (listener) { addEventListener.call.apply(addEventListener, _toConsumableArray(listener)); registered.push(listener); }); } function unregisterListeners(keyObj) { var listeners = listenerRegistry.get(keyObj); if (!listeners) { return; } listeners.forEach(function (listener) { removeEventListener.call.apply(removeEventListener, _toConsumableArray(listener)); }); listenerRegistry["delete"](keyObj); } // Event.composedPath() polyfill for Edge // based on https://gist.github.com/kleinfreund/e9787d73776c0e3750dcfcdc89f100ec if (!Event.prototype.composedPath) { var getComposedPath = function getComposedPath(node) { var path = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : []; path.push(node); var parent; if (node.parentNode) { parent = node.parentNode; } else if (node.host) { // ShadowRoot parent = node.host; } else if (node.defaultView) { // Document parent = node.defaultView; } return parent ? getComposedPath(parent, path) : path; }; Event.prototype.composedPath = function () { return getComposedPath(this.target); }; } function findFromPath(path, criteria, currentTarget) { var index = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : 0; var el = path[index]; if (criteria(el)) { return el; } else if (el === currentTarget || !el.parentElement) { // stop when reaching currentTarget or return; } return findFromPath(path, criteria, currentTarget, index + 1); } // Search for the actual target of a delegated event function findElementInEventPath(ev, selector) { var criteria = typeof selector === 'function' ? selector : function (el) { return el.matches(selector); }; return findFromPath(ev.composedPath(), criteria, ev.currentTarget); } // default locales var locales = { en: { days: ["Sunday", "Monday", "Tuesday", "Wednesday", "Thursday", "Friday", "Saturday"], daysShort: ["Sun", "Mon", "Tue", "Wed", "Thu", "Fri", "Sat"], daysMin: ["Su", "Mo", "Tu", "We", "Th", "Fr", "Sa"], months: ["January", "February", "March", "April", "May", "June", "July", "August", "September", "October", "November", "December"], monthsShort: ["Jan", "Feb", "Mar", "Apr", "May", "Jun", "Jul", "Aug", "Sep", "Oct", "Nov", "Dec"], today: "Today", clear: "Clear", titleFormat: "MM y" } }; // config options updatable by setOptions() and their default values var defaultOptions = { autohide: false, beforeShowDay: null, beforeShowDecade: null, beforeShowMonth: null, beforeShowYear: null, calendarWeeks: false, clearBtn: false, dateDelimiter: ',', datesDisabled: [], daysOfWeekDisabled: [], daysOfWeekHighlighted: [], defaultViewDate: undefined, // placeholder, defaults to today() by the program disableTouchKeyboard: false, format: 'mm/dd/yyyy', language: 'en', maxDate: null, maxNumberOfDates: 1, maxView: 3, minDate: null, nextArrow: '', orientation: 'auto', pickLevel: 0, prevArrow: '', showDaysOfWeek: true, showOnClick: true, showOnFocus: true, startView: 0, title: '', todayBtn: false, todayBtnMode: 0, todayHighlight: false, updateOnBlur: true, weekStart: 0 }; var range = null; function parseHTML(html) { if (range == null) { range = document.createRange(); } return range.createContextualFragment(html); } function hideElement(el) { if (el.style.display === 'none') { return; } // back up the existing display setting in data-style-display if (el.style.display) { el.dataset.styleDisplay = el.style.display; } el.style.display = 'none'; } function showElement(el) { if (el.style.display !== 'none') { return; } if (el.dataset.styleDisplay) { // restore backed-up dispay property el.style.display = el.dataset.styleDisplay; delete el.dataset.styleDisplay; } else { el.style.display = ''; } } function emptyChildNodes(el) { if (el.firstChild) { el.removeChild(el.firstChild); emptyChildNodes(el); } } function replaceChildNodes(el, newChildNodes) { emptyChildNodes(el); if (newChildNodes instanceof DocumentFragment) { el.appendChild(newChildNodes); } else if (typeof newChildNodes === 'string') { el.appendChild(parseHTML(newChildNodes)); } else if (typeof newChildNodes.forEach === 'function') { newChildNodes.forEach(function (node) { el.appendChild(node); }); } } var defaultLang = defaultOptions.language, defaultFormat = defaultOptions.format, defaultWeekStart = defaultOptions.weekStart; // Reducer function to filter out invalid day-of-week from the input function sanitizeDOW(dow, day) { return dow.length < 6 && day >= 0 && day < 7 ? pushUnique(dow, day) : dow; } function calcEndOfWeek(startOfWeek) { return (startOfWeek + 6) % 7; } // validate input date. if invalid, fallback to the original value function validateDate(value, format, locale, origValue) { var date = parseDate(value, format, locale); return date !== undefined ? date : origValue; } // Validate viewId. if invalid, fallback to the original value function validateViewId(value, origValue) { var max = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 3; var viewId = parseInt(value, 10); return viewId >= 0 && viewId <= max ? viewId : origValue; } // Create Datepicker configuration to set function processOptions(options, datepicker) { var inOpts = Object.assign({}, options); var config = {}; var locales = datepicker.constructor.locales; var _ref = datepicker.config || {}, format = _ref.format, language = _ref.language, locale = _ref.locale, maxDate = _ref.maxDate, maxView = _ref.maxView, minDate = _ref.minDate, pickLevel = _ref.pickLevel, startView = _ref.startView, weekStart = _ref.weekStart; if (inOpts.language) { var lang; if (inOpts.language !== language) { if (locales[inOpts.language]) { lang = inOpts.language; } else { // Check if langauge + region tag can fallback to the one without // region (e.g. fr-CA → fr) lang = inOpts.language.split('-')[0]; if (locales[lang] === undefined) { lang = false; } } } delete inOpts.language; if (lang) { language = config.language = lang; // update locale as well when updating language var origLocale = locale || locales[defaultLang]; // use default language's properties for the fallback locale = Object.assign({ format: defaultFormat, weekStart: defaultWeekStart }, locales[defaultLang]); if (language !== defaultLang) { Object.assign(locale, locales[language]); } config.locale = locale; // if format and/or weekStart are the same as old locale's defaults, // update them to new locale's defaults if (format === origLocale.format) { format = config.format = locale.format; } if (weekStart === origLocale.weekStart) { weekStart = config.weekStart = locale.weekStart; config.weekEnd = calcEndOfWeek(locale.weekStart); } } } if (inOpts.format) { var hasToDisplay = typeof inOpts.format.toDisplay === 'function'; var hasToValue = typeof inOpts.format.toValue === 'function'; var validFormatString = reFormatTokens.test(inOpts.format); if (hasToDisplay && hasToValue || validFormatString) { format = config.format = inOpts.format; } delete inOpts.format; } //*** dates ***// // while min and maxDate for "no limit" in the options are better to be null // (especially when updating), the ones in the config have to be undefined // because null is treated as 0 (= unix epoch) when comparing with time value var minDt = minDate; var maxDt = maxDate; if (inOpts.minDate !== undefined) { minDt = inOpts.minDate === null ? dateValue(0, 0, 1) // set 0000-01-01 to prevent negative values for year : validateDate(inOpts.minDate, format, locale, minDt); delete inOpts.minDate; } if (inOpts.maxDate !== undefined) { maxDt = inOpts.maxDate === null ? undefined : validateDate(inOpts.maxDate, format, locale, maxDt); delete inOpts.maxDate; } if (maxDt < minDt) { minDate = config.minDate = maxDt; maxDate = config.maxDate = minDt; } else { if (minDate !== minDt) { minDate = config.minDate = minDt; } if (maxDate !== maxDt) { maxDate = config.maxDate = maxDt; } } if (inOpts.datesDisabled) { config.datesDisabled = inOpts.datesDisabled.reduce(function (dates, dt) { var date = parseDate(dt, format, locale); return date !== undefined ? pushUnique(dates, date) : dates; }, []); delete inOpts.datesDisabled; } if (inOpts.defaultViewDate !== undefined) { var viewDate = parseDate(inOpts.defaultViewDate, format, locale); if (viewDate !== undefined) { config.defaultViewDate = viewDate; } delete inOpts.defaultViewDate; } //*** days of week ***// if (inOpts.weekStart !== undefined) { var wkStart = Number(inOpts.weekStart) % 7; if (!isNaN(wkStart)) { weekStart = config.weekStart = wkStart; config.weekEnd = calcEndOfWeek(wkStart); } delete inOpts.weekStart; } if (inOpts.daysOfWeekDisabled) { config.daysOfWeekDisabled = inOpts.daysOfWeekDisabled.reduce(sanitizeDOW, []); delete inOpts.daysOfWeekDisabled; } if (inOpts.daysOfWeekHighlighted) { config.daysOfWeekHighlighted = inOpts.daysOfWeekHighlighted.reduce(sanitizeDOW, []); delete inOpts.daysOfWeekHighlighted; } //*** multi date ***// if (inOpts.maxNumberOfDates !== undefined) { var maxNumberOfDates = parseInt(inOpts.maxNumberOfDates, 10); if (maxNumberOfDates >= 0) { config.maxNumberOfDates = maxNumberOfDates; config.multidate = maxNumberOfDates !== 1; } delete inOpts.maxNumberOfDates; } if (inOpts.dateDelimiter) { config.dateDelimiter = String(inOpts.dateDelimiter); delete inOpts.dateDelimiter; } //*** pick level & view ***// var newPickLevel = pickLevel; if (inOpts.pickLevel !== undefined) { newPickLevel = validateViewId(inOpts.pickLevel, 2); delete inOpts.pickLevel; } if (newPickLevel !== pickLevel) { pickLevel = config.pickLevel = newPickLevel; } var newMaxView = maxView; if (inOpts.maxView !== undefined) { newMaxView = validateViewId(inOpts.maxView, maxView); delete inOpts.maxView; } // ensure max view >= pick level newMaxView = pickLevel > newMaxView ? pickLevel : newMaxView; if (newMaxView !== maxView) { maxView = config.maxView = newMaxView; } var newStartView = startView; if (inOpts.startView !== undefined) { newStartView = validateViewId(inOpts.startView, newStartView); delete inOpts.startView; } // ensure pick level <= start view <= max view if (newStartView < pickLevel) { newStartView = pickLevel; } else if (newStartView > maxView) { newStartView = maxView; } if (newStartView !== startView) { config.startView = newStartView; } //*** template ***// if (inOpts.prevArrow) { var prevArrow = parseHTML(inOpts.prevArrow); if (prevArrow.childNodes.length > 0) { config.prevArrow = prevArrow.childNodes; } delete inOpts.prevArrow; } if (inOpts.nextArrow) { var nextArrow = parseHTML(inOpts.nextArrow); if (nextArrow.childNodes.length > 0) { config.nextArrow = nextArrow.childNodes; } delete inOpts.nextArrow; } //*** misc ***// if (inOpts.disableTouchKeyboard !== undefined) { config.disableTouchKeyboard = 'ontouchstart' in document && !!inOpts.disableTouchKeyboard; delete inOpts.disableTouchKeyboard; } if (inOpts.orientation) { var orientation = inOpts.orientation.toLowerCase().split(/\s+/g); config.orientation = { x: orientation.find(function (x) { return x === 'left' || x === 'right'; }) || 'auto', y: orientation.find(function (y) { return y === 'top' || y === 'bottom'; }) || 'auto' }; delete inOpts.orientation; } if (inOpts.todayBtnMode !== undefined) { switch (inOpts.todayBtnMode) { case 0: case 1: config.todayBtnMode = inOpts.todayBtnMode; } delete inOpts.todayBtnMode; } //*** copy the rest ***// Object.keys(inOpts).forEach(function (key) { if (inOpts[key] !== undefined && hasProperty(defaultOptions, key)) { config[key] = inOpts[key]; } }); return config; } var pickerTemplate = optimizeTemplateHTML("