{"version":3,"file":"app-index.js","sources":["../node_modules/tslib/tslib.es6.js","../../webmodule-common/other/ui/global-state.ts","../../webmodule-common/other/api/user-security.ts","../../webmodule-common/other/api/current-user.ts","../../webmodule-common/other/async-constructor.ts","../node_modules/@lit/reactive-element/decorators/custom-element.js","../node_modules/@lit/reactive-element/css-tag.js","../node_modules/@lit/reactive-element/reactive-element.js","../node_modules/@lit/reactive-element/decorators/property.js","../node_modules/@lit/reactive-element/decorators/state.js","../node_modules/@lit/reactive-element/decorators/base.js","../node_modules/@lit/reactive-element/decorators/query.js","../../webmodule-common/other/dispose.ts","../node_modules/lit-html/lit-html.js","../node_modules/lit-element/lit-element.js","../../webmodule-common/other/ui/pages/meta-manager.ts","../../webmodule-common/other/language/technical-dictionary-data.ts","../../webmodule-common/other/language/lang.ts","../../webmodule-common/other/ui/show-error.ts","../../webmodule-common/other/development-error.ts","../node_modules/@vaadin/router/dist/vaadin-router.js","../../webmodule-common/other/ui/resource-resolver.ts","../node_modules/uuid/dist/esm-browser/rng.js","../node_modules/uuid/dist/esm-browser/stringify.js","../node_modules/uuid/dist/esm-browser/native.js","../node_modules/uuid/dist/esm-browser/v4.js","../../webmodule-common/other/api/guid.ts","../../webmodule-common/other/ui/string-helper-functions.ts","../../webmodule-common/other/debug.ts","../../webmodule-common/other/router.ts","../../webmodule-common/other/ui/pages/page-base.ts","../../scriptsLicenseServer/application/pages/helpers/page-base.ts","../../webmodule-common/components/src/common/lit-decorator-extended.ts","../webmodule-common/components/node_modules/@lit/reactive-element/css-tag.js","../webmodule-common/components/node_modules/@lit/reactive-element/reactive-element.js","../webmodule-common/components/node_modules/lit-html/lit-html.js","../webmodule-common/components/node_modules/lit-element/lit-element.js","../../webmodule-common/components/src/common/monitor.ts","../webmodule-common/components/node_modules/@lit/reactive-element/decorators/property.js","../webmodule-common/components/node_modules/@lit/reactive-element/decorators/state.js","../webmodule-common/components/node_modules/@lit/reactive-element/decorators/base.js","../webmodule-common/components/node_modules/@lit/reactive-element/decorators/query.js","../webmodule-common/components/node_modules/lit-html/directive.js","../webmodule-common/components/node_modules/lit-html/directives/style-map.js","../../webmodule-common/components/src/styles/component.styles.ts","../webmodule-common/components/node_modules/qr-creator/dist/qr-creator.es6.min.js","../../webmodule-common/components/src/components/qr-code/qr-code.styles.ts","../../webmodule-common/components/src/common/webmodule-element.ts","../../webmodule-common/components/src/components/qr-code/qr-code.ts","../webmodule-common/components/node_modules/lit-html/directives/class-map.js","../../webmodule-common/components/src/common/slot-controller.ts","../../webmodule-common/components/src/components/card/card.styles.ts","../../webmodule-common/components/src/components/card/card.ts","../../webmodule-common/components/src/components/icon/icon.default.lib.ts","../../webmodule-common/components/src/components/icon/library.ts","../webmodule-common/components/node_modules/lit-html/directive-helpers.js","../../webmodule-common/components/src/components/icon/icon.styles.ts","../../webmodule-common/components/src/components/icon/icon.ts","../../webmodule-common/components/src/components/divider/divider.styles.ts","../../webmodule-common/components/src/components/divider/divider.ts","../../webmodule-common/components/src/components/badge/badge.styles.ts","../../webmodule-common/components/src/components/badge/badge.ts","../../webmodule-common/components/src/components/placeholder/placeholder.styles.ts","../../webmodule-common/components/src/components/placeholder/placeholder.ts","../../webmodule-common/components/src/components/breadcrumb/breadcrumb.styles.ts","../../webmodule-common/components/src/components/breadcrumb/breadcrumb.ts","../webmodule-common/components/node_modules/lit-html/directives/if-defined.js","../../webmodule-common/components/src/components/breadcrumb-item/breadcrumb-item.styles.ts","../../webmodule-common/components/src/components/breadcrumb-item/breadcrumb-item.ts","../webmodule-common/components/node_modules/@floating-ui/utils/dist/floating-ui.utils.mjs","../webmodule-common/components/node_modules/@floating-ui/core/dist/floating-ui.core.mjs","../webmodule-common/components/node_modules/@floating-ui/utils/dist/floating-ui.utils.dom.mjs","../webmodule-common/components/node_modules/@floating-ui/dom/dist/floating-ui.dom.mjs","../webmodule-common/components/node_modules/composed-offset-position/dist/composed-offset-position.mjs","../../webmodule-common/components/src/components/popup/popup.styles.ts","../../webmodule-common/components/src/components/popup/popup.ts","../../webmodule-common/components/src/animations/attention_seekers/bounce.ts","../../webmodule-common/components/src/common/easings.ts","../../webmodule-common/components/src/animations/back_entrances/backInDown.ts","../../webmodule-common/components/src/animations/back_entrances/backInLeft.ts","../../webmodule-common/components/src/animations/back_entrances/backInRight.ts","../../webmodule-common/components/src/animations/back_entrances/backInUp.ts","../../webmodule-common/components/src/animations/back_exits/backOutDown.ts","../../webmodule-common/components/src/animations/back_exits/backOutLeft.ts","../../webmodule-common/components/src/animations/back_exits/backOutRight.ts","../../webmodule-common/components/src/animations/back_exits/backOutUp.ts","../../webmodule-common/components/src/animations/bouncing_entrances/bounceIn.ts","../../webmodule-common/components/src/animations/bouncing_entrances/bounceInDown.ts","../../webmodule-common/components/src/animations/bouncing_entrances/bounceInLeft.ts","../../webmodule-common/components/src/animations/bouncing_entrances/bounceInRight.ts","../../webmodule-common/components/src/animations/bouncing_entrances/bounceInUp.ts","../../webmodule-common/components/src/animations/bouncing_exits/bounceOut.ts","../../webmodule-common/components/src/animations/bouncing_exits/bounceOutDown.ts","../../webmodule-common/components/src/animations/bouncing_exits/bounceOutLeft.ts","../../webmodule-common/components/src/animations/bouncing_exits/bounceOutRight.ts","../../webmodule-common/components/src/animations/bouncing_exits/bounceOutUp.ts","../../webmodule-common/components/src/animations/fading_entrances/fadeIn.ts","../../webmodule-common/components/src/animations/fading_entrances/fadeInBottomLeft.ts","../../webmodule-common/components/src/animations/fading_entrances/fadeInBottomRight.ts","../../webmodule-common/components/src/animations/fading_entrances/fadeInDown.ts","../../webmodule-common/components/src/animations/fading_entrances/fadeInDownBig.ts","../../webmodule-common/components/src/animations/fading_entrances/fadeInLeft.ts","../../webmodule-common/components/src/animations/fading_entrances/fadeInLeftBig.ts","../../webmodule-common/components/src/animations/fading_entrances/fadeInRight.ts","../../webmodule-common/components/src/animations/fading_entrances/fadeInRightBig.ts","../../webmodule-common/components/src/animations/fading_entrances/fadeInTopLeft.ts","../../webmodule-common/components/src/animations/fading_entrances/fadeInTopRight.ts","../../webmodule-common/components/src/animations/fading_entrances/fadeInUp.ts","../../webmodule-common/components/src/animations/fading_entrances/fadeInUpBig.ts","../../webmodule-common/components/src/animations/fading_exits/fadeOut.ts","../../webmodule-common/components/src/animations/fading_exits/fadeOutBottomLeft.ts","../../webmodule-common/components/src/animations/fading_exits/fadeOutBottomRight.ts","../../webmodule-common/components/src/animations/fading_exits/fadeOutDown.ts","../../webmodule-common/components/src/animations/fading_exits/fadeOutDownBig.ts","../../webmodule-common/components/src/animations/fading_exits/fadeOutLeft.ts","../../webmodule-common/components/src/animations/fading_exits/fadeOutLeftBig.ts","../../webmodule-common/components/src/animations/fading_exits/fadeOutRight.ts","../../webmodule-common/components/src/animations/fading_exits/fadeOutRightBig.ts","../../webmodule-common/components/src/animations/fading_exits/fadeOutTopLeft.ts","../../webmodule-common/components/src/animations/fading_exits/fadeOutTopRight.ts","../../webmodule-common/components/src/animations/fading_exits/fadeOutUp.ts","../../webmodule-common/components/src/animations/fading_exits/fadeOutUpBig.ts","../../webmodule-common/components/src/animations/attention_seekers/flash.ts","../../webmodule-common/components/src/animations/flippers/flip.ts","../../webmodule-common/components/src/animations/flippers/flipInX.ts","../../webmodule-common/components/src/animations/flippers/flipInY.ts","../../webmodule-common/components/src/animations/flippers/flipOutX.ts","../../webmodule-common/components/src/animations/flippers/flipOutY.ts","../../webmodule-common/components/src/animations/attention_seekers/headShake.ts","../../webmodule-common/components/src/animations/attention_seekers/heartBeat.ts","../../webmodule-common/components/src/animations/specials/hinge.ts","../../webmodule-common/components/src/animations/specials/jackInTheBox.ts","../../webmodule-common/components/src/animations/attention_seekers/jello.ts","../../webmodule-common/components/src/animations/lightspeed/lightSpeedInLeft.ts","../../webmodule-common/components/src/animations/lightspeed/lightSpeedInRight.ts","../../webmodule-common/components/src/animations/lightspeed/lightSpeedOutLeft.ts","../../webmodule-common/components/src/animations/lightspeed/lightSpeedOutRight.ts","../../webmodule-common/components/src/animations/attention_seekers/pulse.ts","../../webmodule-common/components/src/animations/specials/rollIn.ts","../../webmodule-common/components/src/animations/specials/rollOut.ts","../../webmodule-common/components/src/animations/rotating_entrances/rotateIn.ts","../../webmodule-common/components/src/animations/rotating_entrances/rotateInDownLeft.ts","../../webmodule-common/components/src/animations/rotating_entrances/rotateInDownRight.ts","../../webmodule-common/components/src/animations/rotating_entrances/rotateInUpLeft.ts","../../webmodule-common/components/src/animations/rotating_entrances/rotateInUpRight.ts","../../webmodule-common/components/src/animations/rotating_exits/rotateOut.ts","../../webmodule-common/components/src/animations/rotating_exits/rotateOutDownLeft.ts","../../webmodule-common/components/src/animations/rotating_exits/rotateOutDownRight.ts","../../webmodule-common/components/src/animations/rotating_exits/rotateOutUpLeft.ts","../../webmodule-common/components/src/animations/rotating_exits/rotateOutUpRight.ts","../../webmodule-common/components/src/animations/attention_seekers/rubberBand.ts","../../webmodule-common/components/src/animations/attention_seekers/shake.ts","../../webmodule-common/components/src/animations/attention_seekers/shakeX.ts","../../webmodule-common/components/src/animations/attention_seekers/shakeY.ts","../../webmodule-common/components/src/animations/sliding_entrances/slideInDown.ts","../../webmodule-common/components/src/animations/sliding_entrances/slideInLeft.ts","../../webmodule-common/components/src/animations/sliding_entrances/slideInRight.ts","../../webmodule-common/components/src/animations/sliding_entrances/slideInUp.ts","../../webmodule-common/components/src/animations/sliding_exits/slideOutDown.ts","../../webmodule-common/components/src/animations/sliding_exits/slideOutLeft.ts","../../webmodule-common/components/src/animations/sliding_exits/slideOutRight.ts","../../webmodule-common/components/src/animations/sliding_exits/slideOutUp.ts","../../webmodule-common/components/src/animations/attention_seekers/swing.ts","../../webmodule-common/components/src/animations/attention_seekers/tada.ts","../../webmodule-common/components/src/animations/attention_seekers/wobble.ts","../../webmodule-common/components/src/animations/zooming_entrances/zoomIn.ts","../../webmodule-common/components/src/animations/zooming_entrances/zoomInDown.ts","../../webmodule-common/components/src/animations/zooming_entrances/zoomInLeft.ts","../../webmodule-common/components/src/animations/zooming_entrances/zoomInRight.ts","../../webmodule-common/components/src/animations/zooming_entrances/zoomInUp.ts","../../webmodule-common/components/src/animations/zooming_exits/zoomOut.ts","../../webmodule-common/components/src/animations/zooming_exits/zoomOutDown.ts","../../webmodule-common/components/src/animations/zooming_exits/zoomOutLeft.ts","../../webmodule-common/components/src/animations/zooming_exits/zoomOutRight.ts","../../webmodule-common/components/src/animations/zooming_exits/zoomOutUp.ts","../../webmodule-common/components/src/components/animate/animate.styles.ts","../../webmodule-common/components/src/components/animate/animate.ts","../webmodule-common/components/node_modules/@lit/reactive-element/decorators/query-async.js","../../webmodule-common/components/src/common/animation-common.ts","../../webmodule-common/components/src/events/events.ts","../../webmodule-common/components/src/components/tooltip/tooltip.styles.ts","../../webmodule-common/components/src/components/tooltip/tooltip.ts","../../webmodule-common/components/src/common/default-value.ts","../webmodule-common/components/node_modules/lit-html/directives/live.js","../../webmodule-common/components/src/styles/form-control.styles.ts","../../webmodule-common/components/src/components/toggle/toggle.styles.ts","../../webmodule-common/components/src/components/toggle/toggle.ts","../../webmodule-common/components/src/components/input/input.styles.ts","../../webmodule-common/components/src/components/input/input.ts","../webmodule-common/components/node_modules/lit-html/static.js","../../webmodule-common/components/src/components/icon-button/icon-button.styles.ts","../../webmodule-common/components/src/components/icon-button/icon-button.ts","../../webmodule-common/components/src/components/tag/tag.styles.ts","../../webmodule-common/components/src/components/tag/tag.ts","../../webmodule-common/components/src/components/button/button.styles.ts","../../webmodule-common/components/src/components/button/button.ts","../../webmodule-common/components/src/components/spinner/spinner.styles.ts","../../webmodule-common/components/src/components/spinner/spinner.ts","../../webmodule-common/components/src/components/button-group/button-group.styles.ts","../../webmodule-common/components/src/components/button-group/button-group.ts","../../webmodule-common/components/src/components/option/option.styles.ts","../../webmodule-common/components/src/components/option/option.ts","../../webmodule-common/components/src/common/scroll.ts","../webmodule-common/components/node_modules/lit-html/directives/unsafe-html.js","../../webmodule-common/components/src/components/select/select.styles.ts","../../webmodule-common/components/src/components/select/select.ts","../../webmodule-common/components/src/components/menu-label/menu-label.styles.ts","../../webmodule-common/components/src/components/menu-label/menu-label.ts","../webmodule-common/components/node_modules/lit-html/async-directive.js","../webmodule-common/components/node_modules/lit-html/directives/ref.js","../../webmodule-common/components/src/components/menu-item/submenu-controller.ts","../../webmodule-common/components/src/components/menu-item/menu-item.styles.ts","../../webmodule-common/components/src/components/menu-item/menu-item.ts","../../webmodule-common/components/src/components/menu/menu.styles.ts","../../webmodule-common/components/src/components/menu/menu.ts","../../webmodule-common/components/src/common/tabbable.ts","../../webmodule-common/components/src/components/dropdown/dropdown.styles.ts","../../webmodule-common/components/src/components/dropdown/dropdown.ts","../webmodule-common/components/node_modules/lit-html/directives/when.js","../../webmodule-common/components/src/components/tree-item/tree-item.styles.ts","../../webmodule-common/components/src/components/tree-item/tree-item.ts","../../webmodule-common/components/src/components/tree/tree.styles.ts","../../webmodule-common/components/src/components/tree/tree.ts","../../webmodule-common/components/src/components/checkbox/checkbox.styles.ts","../../webmodule-common/components/src/components/checkbox/checkbox.ts","../../webmodule-common/components/src/components/alert/alert.styles.ts","../../webmodule-common/components/src/components/alert/alert.ts","../../webmodule-common/components/src/components/textarea/textarea.styles.ts","../../webmodule-common/components/src/components/textarea/textarea.ts","../../webmodule-common/components/src/components/radio/radio.styles.ts","../../webmodule-common/components/src/components/radio/radio.ts","../../webmodule-common/components/src/components/radio-button/radio-button.styles.ts","../../webmodule-common/components/src/components/radio-button/radio-button.ts","../../webmodule-common/components/src/components/radio-group/radio-group.styles.ts","../../webmodule-common/components/src/components/radio-group/radio-group.ts","../../webmodule-common/components/src/common/helpers/modal-helper.ts","../../webmodule-common/components/src/components/modal/modal.styles.ts","../../webmodule-common/components/src/components/modal/modal.ts","../../webmodule-common/components/src/components/drawer/drawer.styles.ts","../../webmodule-common/components/src/components/drawer/drawer.ts","../../webmodule-common/components/src/components/tab-panel/tab-panel.styles.ts","../../webmodule-common/components/src/components/tab-panel/tab-panel.ts","../../webmodule-common/components/src/components/tab/tab.styles.ts","../../webmodule-common/components/src/components/tab/tab.ts","../../webmodule-common/components/src/components/tab-group/tab-group.styles.ts","../../webmodule-common/components/src/components/tab-group/tab-group.ts","../../webmodule-common/components/src/common/helpers/localization-helpers.ts","../../webmodule-common/components/src/common/localize-controller.ts","../../webmodule-common/components/src/components/input-money/input-money.styles.ts","../../webmodule-common/components/src/components/input-money/input-money.ts","../../webmodule-common/components/src/components/format-date/format-date.ts","../../webmodule-common/components/src/components/format-number/format-number.ts","../../webmodule-common/components/src/components/format-list/format-list.ts","../../webmodule-common/components/src/components/format-relative-time/format-relative-time.ts","../../webmodule-common/components/src/components/details/details.styles.ts","../../webmodule-common/components/src/components/details/details.ts","../../webmodule-common/components/src/components/avatar/avatar.styles.ts","../../webmodule-common/components/src/components/avatar/avatar.ts","../../webmodule-common/components/src/internal/ComponentApp.ts","../webmodule-common/components/node_modules/lit-html/directives/repeat.js","../webmodule-common/components/node_modules/lit-html/directives/private-async-helpers.js","../webmodule-common/components/node_modules/lit-html/directives/until.js","../../webmodule-common/components/src/components/table/lit-table.ts","../../webmodule-common/components/src/components/input-row/input-row.styles.ts","../../webmodule-common/components/src/components/input-row/input-row.ts","../../webmodule-common/components/src/components/testcomp/testcomp.styles.ts","../../webmodule-common/components/src/components/testcomp/testcomp.ts","../../webmodule-common/components/src/components/register-components.ts","../node_modules/marked/lib/marked.esm.js","../node_modules/lit-html/directive.js","../node_modules/lit-html/directives/unsafe-html.js","../../webmodule-common/other/general/markdown.ts","../../webmodule-common/other/common/assets.ts","../../webmodule-common/other/tooltip.ts","../node_modules/lit-html/directives/when.js","../../webmodule-common/other/ui/templateresult/form-input-assistant-base.ts","../../webmodule-common/other/ui/maps/map-helpers.ts","../../webmodule-common/other/ui/modal-footer-buttons.ts","../../webmodule-common/other/app-global-init.ts","../../webmodule-common/other/general/nothing.ts","../../webmodule-common/other/ui/modal/modal-factory-lit.ts","../../webmodule-common/other/ui/modal-confirmation.ts","../../webmodule-common/other/ui/modal-option.ts","../../webmodule-common/other/context/autoSaveNotifier.ts","../node_modules/@popperjs/core/lib/enums.js","../node_modules/@popperjs/core/lib/dom-utils/getNodeName.js","../node_modules/@popperjs/core/lib/dom-utils/getWindow.js","../node_modules/@popperjs/core/lib/dom-utils/instanceOf.js","../node_modules/@popperjs/core/lib/modifiers/applyStyles.js","../node_modules/@popperjs/core/lib/utils/getBasePlacement.js","../node_modules/@popperjs/core/lib/utils/math.js","../node_modules/@popperjs/core/lib/utils/userAgent.js","../node_modules/@popperjs/core/lib/dom-utils/isLayoutViewport.js","../node_modules/@popperjs/core/lib/dom-utils/getBoundingClientRect.js","../node_modules/@popperjs/core/lib/dom-utils/getLayoutRect.js","../node_modules/@popperjs/core/lib/dom-utils/contains.js","../node_modules/@popperjs/core/lib/dom-utils/getComputedStyle.js","../node_modules/@popperjs/core/lib/dom-utils/isTableElement.js","../node_modules/@popperjs/core/lib/dom-utils/getDocumentElement.js","../node_modules/@popperjs/core/lib/dom-utils/getParentNode.js","../node_modules/@popperjs/core/lib/dom-utils/getOffsetParent.js","../node_modules/@popperjs/core/lib/utils/getMainAxisFromPlacement.js","../node_modules/@popperjs/core/lib/utils/within.js","../node_modules/@popperjs/core/lib/utils/mergePaddingObject.js","../node_modules/@popperjs/core/lib/utils/getFreshSideObject.js","../node_modules/@popperjs/core/lib/utils/expandToHashMap.js","../node_modules/@popperjs/core/lib/modifiers/arrow.js","../node_modules/@popperjs/core/lib/utils/getVariation.js","../node_modules/@popperjs/core/lib/modifiers/computeStyles.js","../node_modules/@popperjs/core/lib/modifiers/eventListeners.js","../node_modules/@popperjs/core/lib/utils/getOppositePlacement.js","../node_modules/@popperjs/core/lib/utils/getOppositeVariationPlacement.js","../node_modules/@popperjs/core/lib/dom-utils/getWindowScroll.js","../node_modules/@popperjs/core/lib/dom-utils/getWindowScrollBarX.js","../node_modules/@popperjs/core/lib/dom-utils/isScrollParent.js","../node_modules/@popperjs/core/lib/dom-utils/getScrollParent.js","../node_modules/@popperjs/core/lib/dom-utils/listScrollParents.js","../node_modules/@popperjs/core/lib/utils/rectToClientRect.js","../node_modules/@popperjs/core/lib/dom-utils/getClippingRect.js","../node_modules/@popperjs/core/lib/dom-utils/getViewportRect.js","../node_modules/@popperjs/core/lib/dom-utils/getDocumentRect.js","../node_modules/@popperjs/core/lib/utils/computeOffsets.js","../node_modules/@popperjs/core/lib/utils/detectOverflow.js","../node_modules/@popperjs/core/lib/utils/computeAutoPlacement.js","../node_modules/@popperjs/core/lib/modifiers/flip.js","../node_modules/@popperjs/core/lib/modifiers/hide.js","../node_modules/@popperjs/core/lib/modifiers/offset.js","../node_modules/@popperjs/core/lib/modifiers/popperOffsets.js","../node_modules/@popperjs/core/lib/modifiers/preventOverflow.js","../node_modules/@popperjs/core/lib/utils/getAltAxis.js","../node_modules/@popperjs/core/lib/dom-utils/getCompositeRect.js","../node_modules/@popperjs/core/lib/dom-utils/getNodeScroll.js","../node_modules/@popperjs/core/lib/dom-utils/getHTMLElementScroll.js","../node_modules/@popperjs/core/lib/utils/orderModifiers.js","../node_modules/@popperjs/core/lib/createPopper.js","../node_modules/@popperjs/core/lib/utils/debounce.js","../node_modules/@popperjs/core/lib/utils/mergeByName.js","../node_modules/@popperjs/core/lib/popper-lite.js","../node_modules/@popperjs/core/lib/popper.js","../node_modules/bootstrap/dist/js/bootstrap.esm.js","../../webmodule-common/other/ui/modal-helper.ts","../../webmodule-common/other/ui-lock.ts","../../webmodule-common/other/currency-formatter.ts","../../webmodule-common/other/blob-converters.ts","../../webmodule-common/other/ui/databinding/databinding.ts","../../webmodule-common/interop/interfaces/service_response.ts","../../webmodule-common/other/toast-away.ts","../../webmodule-common/other/ui/modal-spinner.ts","../../webmodule-common/other/ui/modal-saving.ts","../../webmodule-common/other/ui/save-notifier.ts","../../webmodule-common/other/ui/information-dispatcher.ts","../../webmodule-common/other/general/time.ts","../../webmodule-common/other/ui/modal-validationhandler.ts","../../webmodule-common/other/save-workflow.ts","../../webmodule-common/other/ui/data-entry-screen-helpers.ts","../node_modules/lit-html/directive-helpers.js","../node_modules/lit-html/async-directive.js","../node_modules/lit-html/directives/private-async-helpers.js","../node_modules/lit-html/directives/until.js","../../webmodule-common/other/ui/template-processor.ts","../../webmodule-common/other/litelement-base.ts","../../webmodule-common/other/ui/view-base.ts","../../webmodule-common/other/ui/modal-base.ts","../../webmodule-common/other/general/multicast-promise.ts","../../webmodule-common/other/ui/data-entry-screen-base.ts","../../webmodule-common/other/ui/modal-base-original.ts","../../webmodule-common/other/ui/modal-factory.ts","../../scriptsLicenseServer/common/licenseserver-integration.ts","../../scriptsLicenseServer/dealers/view/cyncly-support-view.ts","../../webmodule-common/other/abort.ts","../../webmodule-common/other/ui/page-control.ts","../../scriptsLicenseServer/dealers/view/tentant-view.ts","../../scriptsLicenseServer/application/pages/app-dealer.ts","../node_modules/@lit/context/lib/context-request-event.js","../node_modules/@lit/context/lib/value-notifier.js","../node_modules/@lit/context/lib/controllers/context-provider.js","../node_modules/@lit/context/lib/decorators/provide.js","../../webmodule-common/other/context/imagePreview.ts","../../webmodule-common/other/context/UserSettingsContext.ts","../node_modules/luxon/src/errors.js","../node_modules/luxon/src/impl/formats.js","../node_modules/luxon/src/zone.js","../node_modules/luxon/src/zones/systemZone.js","../node_modules/luxon/src/zones/IANAZone.js","../node_modules/luxon/src/impl/locale.js","../node_modules/luxon/src/impl/english.js","../node_modules/luxon/src/zones/fixedOffsetZone.js","../node_modules/luxon/src/zones/invalidZone.js","../node_modules/luxon/src/impl/zoneUtil.js","../node_modules/luxon/src/impl/util.js","../node_modules/luxon/src/settings.js","../node_modules/luxon/src/impl/invalid.js","../node_modules/luxon/src/impl/conversions.js","../node_modules/luxon/src/impl/formatter.js","../node_modules/luxon/src/impl/regexParser.js","../node_modules/luxon/src/duration.js","../node_modules/luxon/src/interval.js","../node_modules/luxon/src/info.js","../node_modules/luxon/src/impl/diff.js","../node_modules/luxon/src/impl/digits.js","../node_modules/luxon/src/impl/tokenParser.js","../node_modules/luxon/src/datetime.js","../../webmodule-common/other/datetime-converter.ts","../../webmodule-common/other/ui/databinding/data-tracker.ts","../../webmodule-common/other/ui/icons/icon-checked.ts","../../webmodule-common/other/ui/icons/icon-copy.ts","../../webmodule-common/other/ui/icons/icon-delete.ts","../../webmodule-common/other/ui/icons/icon-notification-signal.ts","../../webmodule-common/other/ui/icons/icon-plus.ts","../../webmodule-common/other/ui/icons/icon-refresh.ts","../../webmodule-common/other/ui/icons/icon-save.ts","../../webmodule-common/other/ui/icons/icon-stale.ts","../../webmodule-common/other/ui/icons/register-icons.ts","../../webmodule-common/other/ui/maps/script-singleton-loader.ts","../../webmodule-common/other/ui/maps/google-maps-api.ts","../../webmodule-common/other/ui/maps/google-map.ts","../node_modules/lit-html/directives/class-map.js","../../webmodule-common/other/ui/maps/google-place-autocomplete.ts","../../webmodule-common/other/ui/templatecontrols/input-boolean.ts","../../webmodule-common/other/ui/templatecontrols/input-tri-check.ts","../../webmodule-common/other/ui/templatecontrols/component-registry.ts","../../webmodule-common/other/ui/templateresult/form-input-types.ts","../node_modules/lit-html/directives/if-defined.js","../../webmodule-common/other/ui/templateresult/form-input.ts","../node_modules/lit-html/directives/repeat.js","../node_modules/lit-html/directives/map.js","../../webmodule-common/other/ui/templateresult/form-select.ts","../../webmodule-common/other/ui/templateresult/form-input-assistant.ts","../../webmodule-common/other/ui/templateresult/form-radio-group.ts","../../webmodule-common/other/common/helpers/callbacks.ts","../../webmodule-common/other/clone.ts","../../webmodule-common/other/number-utilities.ts","../../webmodule-common/other/ui/address-editor.ts","../../webmodule-common/other/api/google-api.ts","../../webmodule-common/other/ui/button-switch.ts","../../webmodule-common/other/timed-trigger.ts","../../webmodule-common/other/ui/littable-view.ts","../../webmodule-common/other/ui/modal-factory-lit.ts","../../webmodule-common/interop/interfaces/frame-data.ts","../../webmodule-common/interop/interfaces/v6-config.ts","../../webmodule-common/other/ui/modal-errorhandler.ts","../node_modules/orderedmap/dist/index.js","../node_modules/prosemirror-model/dist/index.js","../node_modules/prosemirror-transform/dist/index.js","../node_modules/prosemirror-state/dist/index.js","../node_modules/prosemirror-view/dist/index.js","../node_modules/w3c-keyname/index.js","../node_modules/prosemirror-keymap/dist/index.js","../node_modules/prosemirror-commands/dist/index.js","../node_modules/prosemirror-inputrules/dist/index.js","../node_modules/rope-sequence/dist/index.js","../node_modules/prosemirror-history/dist/index.js","../node_modules/@toast-ui/editor/dist/esm/index.js","../../webmodule-common/other/ui/webcomponent-registry.ts","../../webmodule-common/other/ui/templateresult/FormInputView.ts","../../webmodule-common/other/api/api-injector.ts","../../webmodule-common/other/domain.ts","../../webmodule-common/other/currentuser-claims.ts","../../webmodule-common/other/api/network-consts.ts","../../webmodule-common/other/api/api-request.ts","../node_modules/lit-html/directives/live.js","../../webmodule-common/other/common/helpers/comparitives.ts","../../webmodule-common/other/ui/loginscreen/authenticate-modal-lit.ts","../../webmodule-common/other/app-index.ts","../../webmodule-common/other/common/web-cache.ts","../../webmodule-common/other/messages.ts","../../webmodule-common/other/user-session-verifier.ts","../../webmodule-common/other/general/event-source-client.ts","../../scriptsLicenseServer/application/pages/app-home.ts","../../scriptsLicenseServer/api/api-injector.ts","../../scriptsLicenseServer/application/pages/app-login.ts","../../scriptsLicenseServer/settings/view/settings-staff-view.ts","../../scriptsLicenseServer/common/user-permissions.ts","../../scriptsLicenseServer/api/licenseserver-credentials.ts","../../scriptsLicenseServer/api/api-interface-licenseserver.ts","../../scriptsLicenseServer/supplier/data-container.ts","../../webmodule-common/other/api/user-security-impl.ts","../../scriptsLicenseServer/settings/view/deployment-access-assignment-view.ts","../../scriptsLicenseServer/settings/view/settings-view.ts","../../scriptsLicenseServer/application/pages/app-settings.ts","../../scriptsLicenseServer/application/page-constants.ts","../../scriptsLicenseServer/application/pages/page-not-found.ts","../../scriptsLicenseServer/supplier/deployments-view.ts","../../scriptsLicenseServer/application/pages/app-deployments.ts","../../scriptsLicenseServer/application/app-config.ts","../../scriptsLicenseServer/application/debug.ts","../../webmodule-common/database/indexed-db.ts","../../webmodule-common/database/indexed-db-wrapper.ts","../../webmodule-common/database/no-sql-db.ts","../../webmodule-common/other/language/technical-dictionary.ts","../../webmodule-common/other/api/optimistic-user-lock.ts","../../scriptsLicenseServer/api/licenseserver-api.ts","../../webmodule-common/other/api/dealer-api-communications.ts","../../scriptsLicenseServer/application/application-initialization.ts","../../scriptsLicenseServer/api/dealer-pageload-verifications.ts","../../webmodule-common/other/bind-application-features.ts","../../webmodule-common/other/ui/modal/modal-factory.ts","../../webmodule-common/cache/data-cache-base.ts","../../scriptsLicenseServer/application/componentRegistry.ts","../../scriptsLicenseServer/application/app-index.ts"],"sourcesContent":["/******************************************************************************\r\nCopyright (c) Microsoft Corporation.\r\n\r\nPermission to use, copy, modify, and/or distribute this software for any\r\npurpose with or without fee is hereby granted.\r\n\r\nTHE SOFTWARE IS PROVIDED \"AS IS\" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH\r\nREGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY\r\nAND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,\r\nINDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM\r\nLOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR\r\nOTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR\r\nPERFORMANCE OF THIS SOFTWARE.\r\n***************************************************************************** */\r\n/* global Reflect, Promise, SuppressedError, Symbol */\r\n\r\nvar extendStatics = function(d, b) {\r\n extendStatics = Object.setPrototypeOf ||\r\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\r\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\r\n return extendStatics(d, b);\r\n};\r\n\r\nexport function __extends(d, b) {\r\n if (typeof b !== \"function\" && b !== null)\r\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\r\n extendStatics(d, b);\r\n function __() { this.constructor = d; }\r\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\r\n}\r\n\r\nexport var __assign = function() {\r\n __assign = Object.assign || function __assign(t) {\r\n for (var s, i = 1, n = arguments.length; i < n; i++) {\r\n s = arguments[i];\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];\r\n }\r\n return t;\r\n }\r\n return __assign.apply(this, arguments);\r\n}\r\n\r\nexport function __rest(s, e) {\r\n var t = {};\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)\r\n t[p] = s[p];\r\n if (s != null && typeof Object.getOwnPropertySymbols === \"function\")\r\n for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\r\n if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))\r\n t[p[i]] = s[p[i]];\r\n }\r\n return t;\r\n}\r\n\r\nexport function __decorate(decorators, target, key, desc) {\r\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\r\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\r\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\r\n return c > 3 && r && Object.defineProperty(target, key, r), r;\r\n}\r\n\r\nexport function __param(paramIndex, decorator) {\r\n return function (target, key) { decorator(target, key, paramIndex); }\r\n}\r\n\r\nexport function __esDecorate(ctor, descriptorIn, decorators, contextIn, initializers, extraInitializers) {\r\n function accept(f) { if (f !== void 0 && typeof f !== \"function\") throw new TypeError(\"Function expected\"); return f; }\r\n var kind = contextIn.kind, key = kind === \"getter\" ? \"get\" : kind === \"setter\" ? \"set\" : \"value\";\r\n var target = !descriptorIn && ctor ? contextIn[\"static\"] ? ctor : ctor.prototype : null;\r\n var descriptor = descriptorIn || (target ? Object.getOwnPropertyDescriptor(target, contextIn.name) : {});\r\n var _, done = false;\r\n for (var i = decorators.length - 1; i >= 0; i--) {\r\n var context = {};\r\n for (var p in contextIn) context[p] = p === \"access\" ? {} : contextIn[p];\r\n for (var p in contextIn.access) context.access[p] = contextIn.access[p];\r\n context.addInitializer = function (f) { if (done) throw new TypeError(\"Cannot add initializers after decoration has completed\"); extraInitializers.push(accept(f || null)); };\r\n var result = (0, decorators[i])(kind === \"accessor\" ? { get: descriptor.get, set: descriptor.set } : descriptor[key], context);\r\n if (kind === \"accessor\") {\r\n if (result === void 0) continue;\r\n if (result === null || typeof result !== \"object\") throw new TypeError(\"Object expected\");\r\n if (_ = accept(result.get)) descriptor.get = _;\r\n if (_ = accept(result.set)) descriptor.set = _;\r\n if (_ = accept(result.init)) initializers.unshift(_);\r\n }\r\n else if (_ = accept(result)) {\r\n if (kind === \"field\") initializers.unshift(_);\r\n else descriptor[key] = _;\r\n }\r\n }\r\n if (target) Object.defineProperty(target, contextIn.name, descriptor);\r\n done = true;\r\n};\r\n\r\nexport function __runInitializers(thisArg, initializers, value) {\r\n var useValue = arguments.length > 2;\r\n for (var i = 0; i < initializers.length; i++) {\r\n value = useValue ? initializers[i].call(thisArg, value) : initializers[i].call(thisArg);\r\n }\r\n return useValue ? value : void 0;\r\n};\r\n\r\nexport function __propKey(x) {\r\n return typeof x === \"symbol\" ? x : \"\".concat(x);\r\n};\r\n\r\nexport function __setFunctionName(f, name, prefix) {\r\n if (typeof name === \"symbol\") name = name.description ? \"[\".concat(name.description, \"]\") : \"\";\r\n return Object.defineProperty(f, \"name\", { configurable: true, value: prefix ? \"\".concat(prefix, \" \", name) : name });\r\n};\r\n\r\nexport function __metadata(metadataKey, metadataValue) {\r\n if (typeof Reflect === \"object\" && typeof Reflect.metadata === \"function\") return Reflect.metadata(metadataKey, metadataValue);\r\n}\r\n\r\nexport function __awaiter(thisArg, _arguments, P, generator) {\r\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\r\n return new (P || (P = Promise))(function (resolve, reject) {\r\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\r\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\r\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\r\n step((generator = generator.apply(thisArg, _arguments || [])).next());\r\n });\r\n}\r\n\r\nexport function __generator(thisArg, body) {\r\n var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;\r\n return g = { next: verb(0), \"throw\": verb(1), \"return\": verb(2) }, typeof Symbol === \"function\" && (g[Symbol.iterator] = function() { return this; }), g;\r\n function verb(n) { return function (v) { return step([n, v]); }; }\r\n function step(op) {\r\n if (f) throw new TypeError(\"Generator is already executing.\");\r\n while (g && (g = 0, op[0] && (_ = 0)), _) try {\r\n if (f = 1, y && (t = op[0] & 2 ? y[\"return\"] : op[0] ? y[\"throw\"] || ((t = y[\"return\"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;\r\n if (y = 0, t) op = [op[0] & 2, t.value];\r\n switch (op[0]) {\r\n case 0: case 1: t = op; break;\r\n case 4: _.label++; return { value: op[1], done: false };\r\n case 5: _.label++; y = op[1]; op = [0]; continue;\r\n case 7: op = _.ops.pop(); _.trys.pop(); continue;\r\n default:\r\n if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }\r\n if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }\r\n if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }\r\n if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }\r\n if (t[2]) _.ops.pop();\r\n _.trys.pop(); continue;\r\n }\r\n op = body.call(thisArg, _);\r\n } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }\r\n if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };\r\n }\r\n}\r\n\r\nexport var __createBinding = Object.create ? (function(o, m, k, k2) {\r\n if (k2 === undefined) k2 = k;\r\n var desc = Object.getOwnPropertyDescriptor(m, k);\r\n if (!desc || (\"get\" in desc ? !m.__esModule : desc.writable || desc.configurable)) {\r\n desc = { enumerable: true, get: function() { return m[k]; } };\r\n }\r\n Object.defineProperty(o, k2, desc);\r\n}) : (function(o, m, k, k2) {\r\n if (k2 === undefined) k2 = k;\r\n o[k2] = m[k];\r\n});\r\n\r\nexport function __exportStar(m, o) {\r\n for (var p in m) if (p !== \"default\" && !Object.prototype.hasOwnProperty.call(o, p)) __createBinding(o, m, p);\r\n}\r\n\r\nexport function __values(o) {\r\n var s = typeof Symbol === \"function\" && Symbol.iterator, m = s && o[s], i = 0;\r\n if (m) return m.call(o);\r\n if (o && typeof o.length === \"number\") return {\r\n next: function () {\r\n if (o && i >= o.length) o = void 0;\r\n return { value: o && o[i++], done: !o };\r\n }\r\n };\r\n throw new TypeError(s ? \"Object is not iterable.\" : \"Symbol.iterator is not defined.\");\r\n}\r\n\r\nexport function __read(o, n) {\r\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\r\n if (!m) return o;\r\n var i = m.call(o), r, ar = [], e;\r\n try {\r\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\r\n }\r\n catch (error) { e = { error: error }; }\r\n finally {\r\n try {\r\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\r\n }\r\n finally { if (e) throw e.error; }\r\n }\r\n return ar;\r\n}\r\n\r\n/** @deprecated */\r\nexport function __spread() {\r\n for (var ar = [], i = 0; i < arguments.length; i++)\r\n ar = ar.concat(__read(arguments[i]));\r\n return ar;\r\n}\r\n\r\n/** @deprecated */\r\nexport function __spreadArrays() {\r\n for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;\r\n for (var r = Array(s), k = 0, i = 0; i < il; i++)\r\n for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)\r\n r[k] = a[j];\r\n return r;\r\n}\r\n\r\nexport function __spreadArray(to, from, pack) {\r\n if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {\r\n if (ar || !(i in from)) {\r\n if (!ar) ar = Array.prototype.slice.call(from, 0, i);\r\n ar[i] = from[i];\r\n }\r\n }\r\n return to.concat(ar || Array.prototype.slice.call(from));\r\n}\r\n\r\nexport function __await(v) {\r\n return this instanceof __await ? (this.v = v, this) : new __await(v);\r\n}\r\n\r\nexport function __asyncGenerator(thisArg, _arguments, generator) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var g = generator.apply(thisArg, _arguments || []), i, q = [];\r\n return i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\", awaitReturn), i[Symbol.asyncIterator] = function () { return this; }, i;\r\n function awaitReturn(f) { return function (v) { return Promise.resolve(v).then(f, reject); }; }\r\n function verb(n, f) { if (g[n]) { i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; if (f) i[n] = f(i[n]); } }\r\n function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } }\r\n function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); }\r\n function fulfill(value) { resume(\"next\", value); }\r\n function reject(value) { resume(\"throw\", value); }\r\n function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); }\r\n}\r\n\r\nexport function __asyncDelegator(o) {\r\n var i, p;\r\n return i = {}, verb(\"next\"), verb(\"throw\", function (e) { throw e; }), verb(\"return\"), i[Symbol.iterator] = function () { return this; }, i;\r\n function verb(n, f) { i[n] = o[n] ? function (v) { return (p = !p) ? { value: __await(o[n](v)), done: false } : f ? f(v) : v; } : f; }\r\n}\r\n\r\nexport function __asyncValues(o) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var m = o[Symbol.asyncIterator], i;\r\n return m ? m.call(o) : (o = typeof __values === \"function\" ? __values(o) : o[Symbol.iterator](), i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i);\r\n function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; }\r\n function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); }\r\n}\r\n\r\nexport function __makeTemplateObject(cooked, raw) {\r\n if (Object.defineProperty) { Object.defineProperty(cooked, \"raw\", { value: raw }); } else { cooked.raw = raw; }\r\n return cooked;\r\n};\r\n\r\nvar __setModuleDefault = Object.create ? (function(o, v) {\r\n Object.defineProperty(o, \"default\", { enumerable: true, value: v });\r\n}) : function(o, v) {\r\n o[\"default\"] = v;\r\n};\r\n\r\nexport function __importStar(mod) {\r\n if (mod && mod.__esModule) return mod;\r\n var result = {};\r\n if (mod != null) for (var k in mod) if (k !== \"default\" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);\r\n __setModuleDefault(result, mod);\r\n return result;\r\n}\r\n\r\nexport function __importDefault(mod) {\r\n return (mod && mod.__esModule) ? mod : { default: mod };\r\n}\r\n\r\nexport function __classPrivateFieldGet(receiver, state, kind, f) {\r\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a getter\");\r\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot read private member from an object whose class did not declare it\");\r\n return kind === \"m\" ? f : kind === \"a\" ? f.call(receiver) : f ? f.value : state.get(receiver);\r\n}\r\n\r\nexport function __classPrivateFieldSet(receiver, state, value, kind, f) {\r\n if (kind === \"m\") throw new TypeError(\"Private method is not writable\");\r\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a setter\");\r\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot write private member to an object whose class did not declare it\");\r\n return (kind === \"a\" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;\r\n}\r\n\r\nexport function __classPrivateFieldIn(state, receiver) {\r\n if (receiver === null || (typeof receiver !== \"object\" && typeof receiver !== \"function\")) throw new TypeError(\"Cannot use 'in' operator on non-object\");\r\n return typeof state === \"function\" ? receiver === state : state.has(receiver);\r\n}\r\n\r\nexport function __addDisposableResource(env, value, async) {\r\n if (value !== null && value !== void 0) {\r\n if (typeof value !== \"object\" && typeof value !== \"function\") throw new TypeError(\"Object expected.\");\r\n var dispose, inner;\r\n if (async) {\r\n if (!Symbol.asyncDispose) throw new TypeError(\"Symbol.asyncDispose is not defined.\");\r\n dispose = value[Symbol.asyncDispose];\r\n }\r\n if (dispose === void 0) {\r\n if (!Symbol.dispose) throw new TypeError(\"Symbol.dispose is not defined.\");\r\n dispose = value[Symbol.dispose];\r\n if (async) inner = dispose;\r\n }\r\n if (typeof dispose !== \"function\") throw new TypeError(\"Object not disposable.\");\r\n if (inner) dispose = function() { try { inner.call(this); } catch (e) { return Promise.reject(e); } };\r\n env.stack.push({ value: value, dispose: dispose, async: async });\r\n }\r\n else if (async) {\r\n env.stack.push({ async: true });\r\n }\r\n return value;\r\n\r\n}\r\n\r\nvar _SuppressedError = typeof SuppressedError === \"function\" ? SuppressedError : function (error, suppressed, message) {\r\n var e = new Error(message);\r\n return e.name = \"SuppressedError\", e.error = error, e.suppressed = suppressed, e;\r\n};\r\n\r\nexport function __disposeResources(env) {\r\n function fail(e) {\r\n env.error = env.hasError ? new _SuppressedError(e, env.error, \"An error was suppressed during disposal.\") : e;\r\n env.hasError = true;\r\n }\r\n function next() {\r\n while (env.stack.length) {\r\n var rec = env.stack.pop();\r\n try {\r\n var result = rec.dispose && rec.dispose.call(rec.value);\r\n if (rec.async) return Promise.resolve(result).then(next, function(e) { fail(e); return next(); });\r\n }\r\n catch (e) {\r\n fail(e);\r\n }\r\n }\r\n if (env.hasError) throw env.error;\r\n }\r\n return next();\r\n}\r\n\r\nexport default {\r\n __extends: __extends,\r\n __assign: __assign,\r\n __rest: __rest,\r\n __decorate: __decorate,\r\n __param: __param,\r\n __metadata: __metadata,\r\n __awaiter: __awaiter,\r\n __generator: __generator,\r\n __createBinding: __createBinding,\r\n __exportStar: __exportStar,\r\n __values: __values,\r\n __read: __read,\r\n __spread: __spread,\r\n __spreadArrays: __spreadArrays,\r\n __spreadArray: __spreadArray,\r\n __await: __await,\r\n __asyncGenerator: __asyncGenerator,\r\n __asyncDelegator: __asyncDelegator,\r\n __asyncValues: __asyncValues,\r\n __makeTemplateObject: __makeTemplateObject,\r\n __importStar: __importStar,\r\n __importDefault: __importDefault,\r\n __classPrivateFieldGet: __classPrivateFieldGet,\r\n __classPrivateFieldSet: __classPrivateFieldSet,\r\n __classPrivateFieldIn: __classPrivateFieldIn,\r\n __addDisposableResource: __addDisposableResource,\r\n __disposeResources: __disposeResources,\r\n};\r\n","// @typescript-eslint/no-unsafe-return\r\nexport function globalState() {\r\n if (!globalThis.webmoduleComponents) globalThis.webmoduleComponents = {};\r\n return globalThis.webmoduleComponents;\r\n}\r\n","import { globalState } from '../ui/global-state';\r\n\r\nexport const claimIdentity = {\r\n true: 'true',\r\n /// \r\n /// claim added for a token that accesses a franchisee dealer db and wants to use a specific branch\r\n /// \r\n branchId: 'franchisee-branchid',\r\n allBranches: 'franchisee-allbranches',\r\n licenseServerAdmin: 'licenseserveradmin',\r\n branchAdmin: 'franchisee-branchadmin',\r\n primarycontact: 'primarycontact',\r\n supportTenantAllAccess: 'support-tenantallaccess',\r\n supportManager: 'support-manager',\r\n superAdmin: 'super-admin',\r\n\r\n /// \r\n /// claim identifies the user as being a login for a supplier nominated by the \"supplierId\" claim representing\r\n /// the \"id\" of a GlobalSupplier in the license server\r\n /// \r\n supplier: 'supplier',\r\n supplierId: 'supplierId',\r\n supplierGuid: 'supplierguid',\r\n frameConfigPowerUser: 'frameconfig-poweruser',\r\n /// \r\n /// represents that this token is created as a PAT on behalf of the tenant\r\n /// \r\n agent: 'agent-token',\r\n cynclyStaff: 'cynclystaff',\r\n\r\n /// \r\n /// this claim identifies the user as having admin rights on the license server on behalf of this tenant\r\n /// they have the ability to manage license allocations and user creation and maintenance\r\n /// \r\n admin: 'admin'\r\n};\r\n\r\nexport interface IUserSecurity {\r\n claimExists: (claimName: string) => boolean;\r\n claimIsTrue: (claimName: string) => boolean;\r\n claim: (claimName: string) => string;\r\n hasRole: (roleName: string) => boolean;\r\n isSupplier: () => boolean;\r\n isPowerUser: () => boolean;\r\n isAdmin: () => boolean;\r\n supplierId: () => number;\r\n supplierGuid: () => string;\r\n}\r\n\r\nconst defSecurity: IUserSecurity = {\r\n claimExists: () => false,\r\n claimIsTrue: () => false,\r\n claim: () => '',\r\n hasRole: () => false,\r\n isPowerUser: () => false,\r\n isSupplier: () => false,\r\n supplierId: () => 0,\r\n supplierGuid: () => '00000000-0000-0000-0000-000000000000',\r\n isAdmin: () => false\r\n};\r\n\r\nexport function setUserSecurity(newUserSecurity: IUserSecurity | null) {\r\n globalState().userSecurity = newUserSecurity ?? defSecurity;\r\n}\r\n\r\nexport function userSecurity(): IUserSecurity {\r\n return globalState().userSecurity ?? defSecurity;\r\n}\r\n","import { claimIdentity, setUserSecurity } from './user-security.js';\r\nimport type { IUserSecurity } from './user-security.js';\r\nimport { StringDictionary } from '../../interop/types/misc';\r\nimport { globalState } from '../ui/global-state';\r\n\r\nexport type EventNotify = () => void | Promise;\r\n\r\nexport interface UserPublicInfo {\r\n id: string;\r\n tenantId: number;\r\n userName: string;\r\n friendlyName: string;\r\n emailAddress: string;\r\n tokenDateExpires: string; // of date\r\n Is2FAEnabled?: boolean;\r\n}\r\n\r\nexport interface TenantLoginPasswordChangeRequired {\r\n token: string;\r\n}\r\n\r\nexport interface ResultTenantLogin {\r\n authenticationToken: string;\r\n publicInfo: UserPublicInfo;\r\n passwordChangeRequired?: TenantLoginPasswordChangeRequired;\r\n requires2FA: boolean;\r\n token2FA?: string;\r\n}\r\n\r\ninterface IUserInformation {\r\n profile: UserPublicInfo | null;\r\n claims: StringDictionary | null;\r\n eventApplyUser: EventNotify | null;\r\n}\r\n\r\nglobalState().userInformation = {\r\n profile: null,\r\n claims: null,\r\n eventApplyUser: null\r\n};\r\n\r\nfunction userInformation(): IUserInformation {\r\n return globalState().userInformation;\r\n}\r\n\r\nexport function setAfterApplyUserEvent(event: EventNotify | null) {\r\n userInformation().eventApplyUser = event;\r\n}\r\n\r\nexport function tenantId(): number {\r\n return getCurrentUser()?.tenantId ?? 0;\r\n}\r\n\r\nexport function getCurrentUser(force?: boolean): UserPublicInfo | null {\r\n if (!userInformation().profile || force) {\r\n const s = localStorage.getItem(apiUserName);\r\n if (!s) return null;\r\n userInformation().profile = JSON.parse(s) as UserPublicInfo;\r\n }\r\n return userInformation().profile;\r\n}\r\n\r\nexport type UserStateNotifierEvent = (user: UserPublicInfo | null) => void | Promise;\r\n\r\nexport interface CurrentUserStateNotifier {\r\n userStateChanged: (user: UserPublicInfo | null) => void | Promise;\r\n}\r\n\r\nlet callbackEvents: CurrentUserStateNotifier[] = [];\r\n\r\nexport function addCurrentUserEventListener(notifer: CurrentUserStateNotifier) {\r\n if (!callbackEvents.find(x => x === notifer)) {\r\n callbackEvents.push(notifer);\r\n //moving this to make the call in a timeout so that it is not happening in a constructor\r\n setTimeout(() => notifer.userStateChanged(getCurrentUser()), 5);\r\n }\r\n}\r\n\r\nexport function removeCurrentUserEventListener(notifer: CurrentUserStateNotifier) {\r\n if (callbackEvents.find(x => x === notifer)) {\r\n callbackEvents = callbackEvents.filter(x => x !== notifer);\r\n }\r\n}\r\n\r\nexport function setUserClaims(userClaims?: { [key: string]: string } | null) {\r\n userInformation().claims = userClaims ?? null;\r\n // Make a default implementation\r\n setUserSecurity(new DefaultUserSecuritySingleton());\r\n}\r\n\r\nexport async function setCurrentUser(user: UserPublicInfo | null, apiToken?: string): Promise {\r\n const userInfo = userInformation();\r\n userInfo.profile = user;\r\n\r\n if (userInfo.profile) {\r\n localStorage.setItem(apiUserName, JSON.stringify(userInfo.profile));\r\n if (apiToken) setApiToken(apiToken);\r\n } else {\r\n localStorage.removeItem(apiUserName);\r\n setApiToken(null);\r\n }\r\n await userInfo.eventApplyUser?.();\r\n callbackEvents.forEach(x => x.userStateChanged(user));\r\n}\r\n\r\nconst apiTokenName = 'webmodule:v1:authentication-token';\r\nconst apiUserName = 'webmodule:v1:user-profile';\r\n\r\n//Authentication is handled via an embedded inline authentication system which will apply any token recoved via authentication into\r\n//this local location.\r\nexport function setApiToken(token: string | null) {\r\n if (token) localStorage.setItem(apiTokenName, token);\r\n else localStorage.removeItem(apiTokenName);\r\n}\r\n\r\nexport function getApiToken(): string {\r\n //always load token to ensure responsiveness to cache deletions\r\n const token = localStorage.getItem(apiTokenName);\r\n return token ?? '';\r\n}\r\n\r\nclass DefaultUserSecuritySingleton implements IUserSecurity {\r\n private get userClaims(): { [key: string]: string } {\r\n return userInformation().claims ?? {};\r\n }\r\n\r\n public claimExists(claimName: string): boolean {\r\n return this.userClaims[claimName] !== undefined;\r\n }\r\n\r\n public claim(claimName: string): string {\r\n return this.userClaims[claimName] ?? '';\r\n }\r\n\r\n public claimIsTrue(claimName: string): boolean {\r\n return this.userClaims[claimName] === 'true';\r\n }\r\n\r\n public hasRole(roleName: string): boolean {\r\n return this.claimIsTrue(`role-${roleName}`);\r\n }\r\n\r\n public isSupplier() {\r\n return this.claimIsTrue(claimIdentity.supplier);\r\n }\r\n\r\n public isPowerUser(): boolean {\r\n return this.claimIsTrue(claimIdentity.frameConfigPowerUser);\r\n }\r\n\r\n public isAdmin(): boolean {\r\n return this.claimIsTrue(claimIdentity.admin);\r\n }\r\n\r\n supplierId() {\r\n return this.getUserSupplierId() ?? 0;\r\n }\r\n\r\n supplierGuid() {\r\n return this.getUserSupplierGuid() ?? '00000000-0000-0000-0000-000000000000';\r\n }\r\n\r\n public getUserSupplierId(): number | undefined {\r\n if (this.isSupplier()) {\r\n const val = parseInt(this.userClaims[claimIdentity.supplierId] ?? '0');\r\n\r\n return isNaN(val) ? undefined : val;\r\n }\r\n return undefined;\r\n }\r\n\r\n public getUserSupplierGuid(): string | undefined {\r\n if (this.isSupplier()) {\r\n return this.userClaims[claimIdentity.supplierId];\r\n }\r\n return undefined;\r\n }\r\n}\r\n","import { EventNotify } from '../interop/types/misc';\r\n\r\nexport interface AsyncConstructor {\r\n afterConstructionExecuted?: boolean;\r\n afterConstruction(): Promise;\r\n}\r\n\r\nlet onBefore: EventNotify | null = null;\r\nexport function setBeforeConstructionEvent(event: EventNotify) {\r\n onBefore = event;\r\n}\r\n\r\nexport async function constructAsync(obj: TResult): Promise {\r\n if (obj.afterConstructionExecuted) return obj;\r\n if (onBefore) await onBefore();\r\n await obj.afterConstruction();\r\n obj.afterConstructionExecuted = true;\r\n return obj;\r\n}\r\n","/**\n * @license\n * Copyright 2017 Google LLC\n * SPDX-License-Identifier: BSD-3-Clause\n */\nconst t=t=>(e,o)=>{void 0!==o?o.addInitializer((()=>{customElements.define(t,e)})):customElements.define(t,e)};export{t as customElement};\n//# sourceMappingURL=custom-element.js.map\n","/**\n * @license\n * Copyright 2019 Google LLC\n * SPDX-License-Identifier: BSD-3-Clause\n */\nconst t=globalThis,e=t.ShadowRoot&&(void 0===t.ShadyCSS||t.ShadyCSS.nativeShadow)&&\"adoptedStyleSheets\"in Document.prototype&&\"replace\"in CSSStyleSheet.prototype,s=Symbol(),o=new WeakMap;class n{constructor(t,e,o){if(this._$cssResult$=!0,o!==s)throw Error(\"CSSResult is not constructable. Use `unsafeCSS` or `css` instead.\");this.cssText=t,this.t=e}get styleSheet(){let t=this.o;const s=this.t;if(e&&void 0===t){const e=void 0!==s&&1===s.length;e&&(t=o.get(s)),void 0===t&&((this.o=t=new CSSStyleSheet).replaceSync(this.cssText),e&&o.set(s,t))}return t}toString(){return this.cssText}}const r=t=>new n(\"string\"==typeof t?t:t+\"\",void 0,s),i=(t,...e)=>{const o=1===t.length?t[0]:e.reduce(((e,s,o)=>e+(t=>{if(!0===t._$cssResult$)return t.cssText;if(\"number\"==typeof t)return t;throw Error(\"Value passed to 'css' function must be a 'css' function result: \"+t+\". Use 'unsafeCSS' to pass non-literal values, but take care to ensure page security.\")})(s)+t[o+1]),t[0]);return new n(o,t,s)},S=(s,o)=>{if(e)s.adoptedStyleSheets=o.map((t=>t instanceof CSSStyleSheet?t:t.styleSheet));else for(const e of o){const o=document.createElement(\"style\"),n=t.litNonce;void 0!==n&&o.setAttribute(\"nonce\",n),o.textContent=e.cssText,s.appendChild(o)}},c=e?t=>t:t=>t instanceof CSSStyleSheet?(t=>{let e=\"\";for(const s of t.cssRules)e+=s.cssText;return r(e)})(t):t;export{n as CSSResult,S as adoptStyles,i as css,c as getCompatibleStyle,e as supportsAdoptingStyleSheets,r as unsafeCSS};\n//# sourceMappingURL=css-tag.js.map\n","import{getCompatibleStyle as t,adoptStyles as s}from\"./css-tag.js\";export{CSSResult,adoptStyles,css,getCompatibleStyle,supportsAdoptingStyleSheets,unsafeCSS}from\"./css-tag.js\";\n/**\n * @license\n * Copyright 2017 Google LLC\n * SPDX-License-Identifier: BSD-3-Clause\n */const{is:i,defineProperty:e,getOwnPropertyDescriptor:r,getOwnPropertyNames:h,getOwnPropertySymbols:o,getPrototypeOf:n}=Object,a=globalThis,c=a.trustedTypes,l=c?c.emptyScript:\"\",p=a.reactiveElementPolyfillSupport,d=(t,s)=>t,u={toAttribute(t,s){switch(s){case Boolean:t=t?l:null;break;case Object:case Array:t=null==t?t:JSON.stringify(t)}return t},fromAttribute(t,s){let i=t;switch(s){case Boolean:i=null!==t;break;case Number:i=null===t?null:Number(t);break;case Object:case Array:try{i=JSON.parse(t)}catch(t){i=null}}return i}},f=(t,s)=>!i(t,s),y={attribute:!0,type:String,converter:u,reflect:!1,hasChanged:f};Symbol.metadata??=Symbol(\"metadata\"),a.litPropertyMetadata??=new WeakMap;class b extends HTMLElement{static addInitializer(t){this._$Ei(),(this.l??=[]).push(t)}static get observedAttributes(){return this.finalize(),this._$Eh&&[...this._$Eh.keys()]}static createProperty(t,s=y){if(s.state&&(s.attribute=!1),this._$Ei(),this.elementProperties.set(t,s),!s.noAccessor){const i=Symbol(),r=this.getPropertyDescriptor(t,i,s);void 0!==r&&e(this.prototype,t,r)}}static getPropertyDescriptor(t,s,i){const{get:e,set:h}=r(this.prototype,t)??{get(){return this[s]},set(t){this[s]=t}};return{get(){return e?.call(this)},set(s){const r=e?.call(this);h.call(this,s),this.requestUpdate(t,r,i)},configurable:!0,enumerable:!0}}static getPropertyOptions(t){return this.elementProperties.get(t)??y}static _$Ei(){if(this.hasOwnProperty(d(\"elementProperties\")))return;const t=n(this);t.finalize(),void 0!==t.l&&(this.l=[...t.l]),this.elementProperties=new Map(t.elementProperties)}static finalize(){if(this.hasOwnProperty(d(\"finalized\")))return;if(this.finalized=!0,this._$Ei(),this.hasOwnProperty(d(\"properties\"))){const t=this.properties,s=[...h(t),...o(t)];for(const i of s)this.createProperty(i,t[i])}const t=this[Symbol.metadata];if(null!==t){const s=litPropertyMetadata.get(t);if(void 0!==s)for(const[t,i]of s)this.elementProperties.set(t,i)}this._$Eh=new Map;for(const[t,s]of this.elementProperties){const i=this._$Eu(t,s);void 0!==i&&this._$Eh.set(i,t)}this.elementStyles=this.finalizeStyles(this.styles)}static finalizeStyles(s){const i=[];if(Array.isArray(s)){const e=new Set(s.flat(1/0).reverse());for(const s of e)i.unshift(t(s))}else void 0!==s&&i.push(t(s));return i}static _$Eu(t,s){const i=s.attribute;return!1===i?void 0:\"string\"==typeof i?i:\"string\"==typeof t?t.toLowerCase():void 0}constructor(){super(),this._$Ep=void 0,this.isUpdatePending=!1,this.hasUpdated=!1,this._$Em=null,this._$Ev()}_$Ev(){this._$ES=new Promise((t=>this.enableUpdating=t)),this._$AL=new Map,this._$E_(),this.requestUpdate(),this.constructor.l?.forEach((t=>t(this)))}addController(t){(this._$EO??=new Set).add(t),void 0!==this.renderRoot&&this.isConnected&&t.hostConnected?.()}removeController(t){this._$EO?.delete(t)}_$E_(){const t=new Map,s=this.constructor.elementProperties;for(const i of s.keys())this.hasOwnProperty(i)&&(t.set(i,this[i]),delete this[i]);t.size>0&&(this._$Ep=t)}createRenderRoot(){const t=this.shadowRoot??this.attachShadow(this.constructor.shadowRootOptions);return s(t,this.constructor.elementStyles),t}connectedCallback(){this.renderRoot??=this.createRenderRoot(),this.enableUpdating(!0),this._$EO?.forEach((t=>t.hostConnected?.()))}enableUpdating(t){}disconnectedCallback(){this._$EO?.forEach((t=>t.hostDisconnected?.()))}attributeChangedCallback(t,s,i){this._$AK(t,i)}_$EC(t,s){const i=this.constructor.elementProperties.get(t),e=this.constructor._$Eu(t,i);if(void 0!==e&&!0===i.reflect){const r=(void 0!==i.converter?.toAttribute?i.converter:u).toAttribute(s,i.type);this._$Em=t,null==r?this.removeAttribute(e):this.setAttribute(e,r),this._$Em=null}}_$AK(t,s){const i=this.constructor,e=i._$Eh.get(t);if(void 0!==e&&this._$Em!==e){const t=i.getPropertyOptions(e),r=\"function\"==typeof t.converter?{fromAttribute:t.converter}:void 0!==t.converter?.fromAttribute?t.converter:u;this._$Em=e,this[e]=r.fromAttribute(s,t.type),this._$Em=null}}requestUpdate(t,s,i){if(void 0!==t){if(i??=this.constructor.getPropertyOptions(t),!(i.hasChanged??f)(this[t],s))return;this.P(t,s,i)}!1===this.isUpdatePending&&(this._$ES=this._$ET())}P(t,s,i){this._$AL.has(t)||this._$AL.set(t,s),!0===i.reflect&&this._$Em!==t&&(this._$Ej??=new Set).add(t)}async _$ET(){this.isUpdatePending=!0;try{await this._$ES}catch(t){Promise.reject(t)}const t=this.scheduleUpdate();return null!=t&&await t,!this.isUpdatePending}scheduleUpdate(){return this.performUpdate()}performUpdate(){if(!this.isUpdatePending)return;if(!this.hasUpdated){if(this.renderRoot??=this.createRenderRoot(),this._$Ep){for(const[t,s]of this._$Ep)this[t]=s;this._$Ep=void 0}const t=this.constructor.elementProperties;if(t.size>0)for(const[s,i]of t)!0!==i.wrapped||this._$AL.has(s)||void 0===this[s]||this.P(s,this[s],i)}let t=!1;const s=this._$AL;try{t=this.shouldUpdate(s),t?(this.willUpdate(s),this._$EO?.forEach((t=>t.hostUpdate?.())),this.update(s)):this._$EU()}catch(s){throw t=!1,this._$EU(),s}t&&this._$AE(s)}willUpdate(t){}_$AE(t){this._$EO?.forEach((t=>t.hostUpdated?.())),this.hasUpdated||(this.hasUpdated=!0,this.firstUpdated(t)),this.updated(t)}_$EU(){this._$AL=new Map,this.isUpdatePending=!1}get updateComplete(){return this.getUpdateComplete()}getUpdateComplete(){return this._$ES}shouldUpdate(t){return!0}update(t){this._$Ej&&=this._$Ej.forEach((t=>this._$EC(t,this[t]))),this._$EU()}updated(t){}firstUpdated(t){}}b.elementStyles=[],b.shadowRootOptions={mode:\"open\"},b[d(\"elementProperties\")]=new Map,b[d(\"finalized\")]=new Map,p?.({ReactiveElement:b}),(a.reactiveElementVersions??=[]).push(\"2.0.4\");export{b as ReactiveElement,u as defaultConverter,f as notEqual};\n//# sourceMappingURL=reactive-element.js.map\n","import{defaultConverter as t,notEqual as e}from\"../reactive-element.js\";\n/**\n * @license\n * Copyright 2017 Google LLC\n * SPDX-License-Identifier: BSD-3-Clause\n */const o={attribute:!0,type:String,converter:t,reflect:!1,hasChanged:e},r=(t=o,e,r)=>{const{kind:n,metadata:i}=r;let s=globalThis.litPropertyMetadata.get(i);if(void 0===s&&globalThis.litPropertyMetadata.set(i,s=new Map),s.set(r.name,t),\"accessor\"===n){const{name:o}=r;return{set(r){const n=e.get.call(this);e.set.call(this,r),this.requestUpdate(o,n,t)},init(e){return void 0!==e&&this.P(o,void 0,t),e}}}if(\"setter\"===n){const{name:o}=r;return function(r){const n=this[o];e.call(this,r),this.requestUpdate(o,n,t)}}throw Error(\"Unsupported decorator location: \"+n)};function n(t){return(e,o)=>\"object\"==typeof o?r(t,e,o):((t,e,o)=>{const r=e.hasOwnProperty(o);return e.constructor.createProperty(o,r?{...t,wrapped:!0}:t),r?Object.getOwnPropertyDescriptor(e,o):void 0})(t,e,o)}export{n as property,r as standardProperty};\n//# sourceMappingURL=property.js.map\n","import{property as t}from\"./property.js\";\n/**\n * @license\n * Copyright 2017 Google LLC\n * SPDX-License-Identifier: BSD-3-Clause\n */function r(r){return t({...r,state:!0,attribute:!1})}export{r as state};\n//# sourceMappingURL=state.js.map\n","/**\n * @license\n * Copyright 2017 Google LLC\n * SPDX-License-Identifier: BSD-3-Clause\n */\nconst e=(e,t,c)=>(c.configurable=!0,c.enumerable=!0,Reflect.decorate&&\"object\"!=typeof t&&Object.defineProperty(e,t,c),c);export{e as desc};\n//# sourceMappingURL=base.js.map\n","import{desc as t}from\"./base.js\";\n/**\n * @license\n * Copyright 2017 Google LLC\n * SPDX-License-Identifier: BSD-3-Clause\n */function e(e,r){return(n,s,i)=>{const o=t=>t.renderRoot?.querySelector(e)??null;if(r){const{get:e,set:r}=\"object\"==typeof s?n:i??(()=>{const t=Symbol();return{get(){return this[t]},set(e){this[t]=e}}})();return t(n,s,{get(){let t=e.call(this);return void 0===t&&(t=o(this),(null!==t||this.hasUpdated)&&r.call(this,t)),t}})}return t(n,s,{get(){return o(this)}})}}export{e as query};\n//# sourceMappingURL=query.js.map\n","export interface IDispose {\r\n dispose: () => Promise;\r\n}\r\n\r\nexport async function disposeOf(disposable?: IDispose | null) {\r\n await disposable?.dispose();\r\n}\r\n","/**\n * @license\n * Copyright 2017 Google LLC\n * SPDX-License-Identifier: BSD-3-Clause\n */\nconst n=globalThis,c=n.trustedTypes,h=c?c.createPolicy(\"lit-html\",{createHTML:t=>t}):void 0,f=\"$lit$\",v=`lit$${Math.random().toFixed(9).slice(2)}$`,m=\"?\"+v,_=`<${m}>`,w=document,lt=()=>w.createComment(\"\"),st=t=>null===t||\"object\"!=typeof t&&\"function\"!=typeof t,g=Array.isArray,$=t=>g(t)||\"function\"==typeof t?.[Symbol.iterator],x=\"[ \\t\\n\\f\\r]\",T=/<(?:(!--|\\/[^a-zA-Z])|(\\/?[a-zA-Z][^>\\s]*)|(\\/?$))/g,E=/-->/g,k=/>/g,O=RegExp(`>|${x}(?:([^\\\\s\"'>=/]+)(${x}*=${x}*(?:[^ \\t\\n\\f\\r\"'\\`<>=]|(\"|')|))|$)`,\"g\"),S=/'/g,j=/\"/g,M=/^(?:script|style|textarea|title)$/i,P=t=>(i,...s)=>({_$litType$:t,strings:i,values:s}),ke=P(1),Oe=P(2),Se=P(3),R=Symbol.for(\"lit-noChange\"),D=Symbol.for(\"lit-nothing\"),V=new WeakMap,I=w.createTreeWalker(w,129);function N(t,i){if(!g(t)||!t.hasOwnProperty(\"raw\"))throw Error(\"invalid template strings array\");return void 0!==h?h.createHTML(i):i}const U=(t,i)=>{const s=t.length-1,e=[];let h,o=2===i?\"\":3===i?\"\":\"\",n=T;for(let i=0;i\"===l[0]?(n=h??T,c=-1):void 0===l[1]?c=-2:(c=n.lastIndex-l[2].length,r=l[1],n=void 0===l[3]?O:'\"'===l[3]?j:S):n===j||n===S?n=O:n===E||n===k?n=T:(n=O,h=void 0);const u=n===O&&t[i+1].startsWith(\"/>\")?\" \":\"\";o+=n===T?s+_:c>=0?(e.push(r),s.slice(0,c)+f+s.slice(c)+v+u):s+v+(-2===c?i:u)}return[N(t,o+(t[s]||\"\")+(2===i?\"\":3===i?\"\":\"\")),e]};class B{constructor({strings:t,_$litType$:i},s){let e;this.parts=[];let h=0,o=0;const n=t.length-1,r=this.parts,[l,a]=U(t,i);if(this.el=B.createElement(l,s),I.currentNode=this.el.content,2===i||3===i){const t=this.el.content.firstChild;t.replaceWith(...t.childNodes)}for(;null!==(e=I.nextNode())&&r.length0){e.textContent=c?c.emptyScript:\"\";for(let s=0;s2||\"\"!==s[0]||\"\"!==s[1]?(this._$AH=Array(s.length-1).fill(new String),this.strings=s):this._$AH=D}_$AI(t,i=this,s,e){const h=this.strings;let o=!1;if(void 0===h)t=z(this,t,i,0),o=!st(t)||t!==this._$AH&&t!==R,o&&(this._$AH=t);else{const e=t;let n,r;for(t=h[0],n=0;n{const e=s?.renderBefore??i;let h=e._$litPart$;if(void 0===h){const t=s?.renderBefore??null;e._$litPart$=h=new et(i.insertBefore(lt(),t),t,void 0,s??{})}return h._$AI(t),h};export{si as _$LH,ke as html,Se as mathml,R as noChange,D as nothing,Q as render,Oe as svg};\n//# sourceMappingURL=lit-html.js.map\n","import{ReactiveElement as e}from\"@lit/reactive-element\";export*from\"@lit/reactive-element\";import{render as n,noChange as l}from\"lit-html\";export*from\"lit-html\";\n/**\n * @license\n * Copyright 2017 Google LLC\n * SPDX-License-Identifier: BSD-3-Clause\n */class h extends e{constructor(){super(...arguments),this.renderOptions={host:this},this.o=void 0}createRenderRoot(){const t=super.createRenderRoot();return this.renderOptions.renderBefore??=t.firstChild,t}update(t){const e=this.render();this.hasUpdated||(this.renderOptions.isConnected=this.isConnected),super.update(t),this.o=n(e,this.renderRoot,this.renderOptions)}connectedCallback(){super.connectedCallback(),this.o?.setConnected(!0)}disconnectedCallback(){super.disconnectedCallback(),this.o?.setConnected(!1)}render(){return l}}h._$litElement$=!0,h[\"finalized\"]=!0,globalThis.litElementHydrateSupport?.({LitElement:h});const f=globalThis.litElementPolyfillSupport;f?.({LitElement:h});const x={_$AK:(t,e,s)=>{t._$AK(e,s)},_$AL:t=>t._$AL};(globalThis.litElementVersions??=[]).push(\"4.1.0\");export{h as LitElement,x as _$LE};\n//# sourceMappingURL=lit-element.js.map\n","export const setMetaTag = (attributeName: string, attributeValue: string, content: string) => {\r\n let element = document.head.querySelector(`meta[${attributeName}=\"${attributeValue}\"]`);\r\n\r\n if (!element) {\r\n element = document.createElement('meta');\r\n element.setAttribute(attributeName, attributeValue);\r\n document.head.appendChild(element);\r\n }\r\n\r\n element.setAttribute('content', content);\r\n};\r\n\r\nexport const removeMetaTag = (attributeName: string, attributeValue: string) => {\r\n const element = document.head.querySelector(`meta[${attributeName}=\"${attributeValue}\"]`);\r\n\r\n if (element) {\r\n document.head.removeChild(element);\r\n }\r\n};\r\n\r\nexport const setLinkTag = (rel: string, href: string) => {\r\n let element = document.head.querySelector(`link[rel=\"${rel}\"]`);\r\n\r\n if (!element) {\r\n element = document.createElement('link');\r\n element.setAttribute('rel', rel);\r\n document.head.appendChild(element);\r\n }\r\n\r\n element.setAttribute('href', href);\r\n};\r\n\r\nexport interface MetaOptions {\r\n title?: string;\r\n titleTemplate?: string | null;\r\n description?: string | null;\r\n url?: string;\r\n}\r\n\r\nexport const updateMeta = (options: MetaOptions) => {\r\n const { title, titleTemplate, description, url } = options;\r\n\r\n if (title) {\r\n document.title = titleTemplate ? titleTemplate.replace('%s', title) : title;\r\n }\r\n\r\n if (description) {\r\n setMetaTag('name', 'description', description);\r\n } else if (description === null) {\r\n setMetaTag('name', 'description', '');\r\n }\r\n\r\n if (url) {\r\n setLinkTag('canonical', url);\r\n }\r\n};\r\n","interface TechDict {\r\n [key: string]: DictionaryEntry;\r\n}\r\n\r\nexport function technicalDictionary(): TechDict {\r\n if (!globalThis.technicalDictionary) globalThis.technicalDictionary = {};\r\n\r\n return globalThis.technicalDictionary as TechDict;\r\n}\r\n\r\nexport type DictionaryEntryValue = () => string;\r\nexport interface DictionaryEntry {\r\n single: DictionaryEntryValue;\r\n plural: DictionaryEntryValue;\r\n}\r\n","//copyright Kyley Harris (2021) - all rights to reuse and change allowed\r\n\r\nimport { technicalDictionary } from './technical-dictionary-data.js';\r\n\r\nlet language = 'eng';\r\nconst supportedLang = ['eng', 'us'];\r\nlet event: ((language: string) => void) | null = null;\r\nexport function getLang() {\r\n return language;\r\n}\r\nexport function isLang(_language: string) {\r\n return language === _language;\r\n}\r\nexport function onLanguageChange(e: (language: string) => void) {\r\n event = e;\r\n}\r\nexport function setLang(name: string) {\r\n if (supportedLang.filter(x => x === name).length > 0) {\r\n language = name;\r\n if (event) event(name);\r\n } else throw new Error(`${name} is not a supported language yet`);\r\n}\r\n\r\nexport interface TranslatorMap {\r\n input?: string;\r\n output?: string;\r\n}\r\nexport interface LanguageFile {\r\n language: string;\r\n translations: { [key: string]: TranslatorMap } | null;\r\n}\r\n\r\nfunction langFile(): LanguageFile {\r\n if (!globalThis.langFile) globalThis.langFile = {};\r\n\r\n return globalThis.langFile as LanguageFile;\r\n}\r\n\r\nexport function registerLangFile(_langFile: LanguageFile) {\r\n globalThis.langFile = _langFile;\r\n}\r\n\r\n(function () {\r\n globalThis.registerLangFile = registerLangFile;\r\n})();\r\n\r\nexport function lang(text: string, namedResource?: string, doNotAddMissing?: boolean) {\r\n const languageTransform = langFile().translations ?? {};\r\n //if (language === \"eng\") return text;\r\n const finalText = (): string => {\r\n const newTextObj: TranslatorMap = languageTransform[namedResource ?? text];\r\n if (!newTextObj) {\r\n if (!doNotAddMissing) {\r\n languageTransform[namedResource ?? text] = {};\r\n if (namedResource) languageTransform[namedResource ?? text].input = text;\r\n }\r\n return text;\r\n } else {\r\n return newTextObj.output ?? newTextObj.input ?? text;\r\n }\r\n };\r\n\r\n let txt = finalText();\r\n\r\n const matches = txt.matchAll(/%%([\\w|-]+)%%/g);\r\n for (const match of matches) {\r\n const sKey = match[1].toLowerCase();\r\n const matchFunction = technicalDictionary()[sKey];\r\n if (!matchFunction) {\r\n alert(`${match[1]} is not a dictionary function`);\r\n } else txt = txt.replace(match[0], matchFunction.single());\r\n }\r\n\r\n const matchesPlural = txt.matchAll(/!!([\\w|-]+)!!/g);\r\n for (const match of matchesPlural) {\r\n const matchFunction = technicalDictionary()[match[1].toLowerCase()];\r\n if (!matchFunction) {\r\n alert(`${match[1]} is not a dictionary function`);\r\n } else txt = txt.replace(match[0], matchFunction.plural());\r\n }\r\n return txt;\r\n}\r\n\r\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\r\nexport function tlang(template: TemplateStringsArray, ...args: any[]) {\r\n let namedResource: string | undefined = undefined;\r\n if (args.length > 0) {\r\n // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment\r\n const arg1 = args[0];\r\n if (typeof arg1 === 'string') {\r\n if (arg1.startsWith('ref:')) {\r\n namedResource = arg1.toLowerCase();\r\n args.splice(0, 1);\r\n }\r\n }\r\n }\r\n let result = '';\r\n let i = 0;\r\n for (let loop = namedResource ? 1 : 0; loop < template.length; loop++) {\r\n result += `${template[loop]}` + (i < args.length ? `{${i++}}` : '');\r\n }\r\n let transformedResult = lang(result, namedResource);\r\n i = 0;\r\n args.forEach((value, index) => {\r\n // eslint-disable-next-line @typescript-eslint/no-unsafe-argument\r\n transformedResult = transformedResult.replace(`{${index}}`, value);\r\n });\r\n\r\n return transformedResult;\r\n}\r\n","import { EventSnippet, ServiceResponseInvalid, ShowErrorEvent } from '../../interop/webmodule-interop';\r\nimport { tlang } from '../language/lang';\r\n\r\nlet _handler: ShowErrorEvent | null = null;\r\n\r\nexport function setErrorDialogEventHandler(handler: ShowErrorEvent) {\r\n _handler = handler;\r\n}\r\n/**\r\n *\r\n * @param item abstracted show error removed from implementation details\r\n * @param title\r\n * @returns\r\n */\r\nexport async function showError(item: ServiceResponseInvalid | Error | string | null, title?: EventSnippet) {\r\n if (item === null) return;\r\n\r\n if (typeof item === 'string') item = new Error(item);\r\n\r\n if (!title) title = () => tlang`Exception Error`;\r\n\r\n await _handler?.(item, title);\r\n}\r\n","import { showError } from './ui/show-error';\r\nimport { tlang } from './language/lang';\r\n\r\nexport class DevelopmentError extends Error {\r\n constructor(message?: string) {\r\n const newMsg = tlang`${'ref:development:error'} Unexpected Development Error\r\n${message}\r\n`;\r\n super(newMsg);\r\n }\r\n}\r\n\r\nexport async function showDevelopmentError(message: string | Error) {\r\n await showError(message instanceof Error ? message : new DevelopmentError(message));\r\n}\r\n","function toArray(objectOrArray) {\n objectOrArray = objectOrArray || [];\n return Array.isArray(objectOrArray) ? objectOrArray : [objectOrArray];\n}\n\nfunction log(msg) {\n return `[Vaadin.Router] ${msg}`;\n}\n\nfunction logValue(value) {\n if (typeof value !== 'object') {\n return String(value);\n }\n\n const stringType = Object.prototype.toString.call(value).match(/ (.*)\\]$/)[1];\n if (stringType === 'Object' || stringType === 'Array') {\n return `${stringType} ${JSON.stringify(value)}`;\n } else {\n return stringType;\n }\n}\n\nconst MODULE = 'module';\nconst NOMODULE = 'nomodule';\nconst bundleKeys = [MODULE, NOMODULE];\n\nfunction ensureBundle(src) {\n if (!src.match(/.+\\.[m]?js$/)) {\n throw new Error(\n log(`Unsupported type for bundle \"${src}\": .js or .mjs expected.`)\n );\n }\n}\n\nfunction ensureRoute(route) {\n if (!route || !isString(route.path)) {\n throw new Error(\n log(`Expected route config to be an object with a \"path\" string property, or an array of such objects`)\n );\n }\n\n const bundle = route.bundle;\n\n const stringKeys = ['component', 'redirect', 'bundle'];\n if (\n !isFunction(route.action) &&\n !Array.isArray(route.children) &&\n !isFunction(route.children) &&\n !isObject(bundle) &&\n !stringKeys.some(key => isString(route[key]))\n ) {\n throw new Error(\n log(\n `Expected route config \"${route.path}\" to include either \"${stringKeys.join('\", \"')}\" ` +\n `or \"action\" function but none found.`\n )\n );\n }\n\n if (bundle) {\n if (isString(bundle)) {\n ensureBundle(bundle);\n } else if (!bundleKeys.some(key => key in bundle)) {\n throw new Error(\n log('Expected route bundle to include either \"' + NOMODULE + '\" or \"' + MODULE + '\" keys, or both')\n );\n } else {\n bundleKeys.forEach(key => key in bundle && ensureBundle(bundle[key]));\n }\n }\n\n if (route.redirect) {\n ['bundle', 'component'].forEach(overriddenProp => {\n if (overriddenProp in route) {\n console.warn(\n log(\n `Route config \"${route.path}\" has both \"redirect\" and \"${overriddenProp}\" properties, ` +\n `and \"redirect\" will always override the latter. Did you mean to only use \"${overriddenProp}\"?`\n )\n );\n }\n });\n }\n}\n\nfunction ensureRoutes(routes) {\n toArray(routes).forEach(route => ensureRoute(route));\n}\n\nfunction loadScript(src, key) {\n let script = document.head.querySelector('script[src=\"' + src + '\"][async]');\n if (!script) {\n script = document.createElement('script');\n script.setAttribute('src', src);\n if (key === MODULE) {\n script.setAttribute('type', MODULE);\n } else if (key === NOMODULE) {\n script.setAttribute(NOMODULE, '');\n }\n script.async = true;\n }\n return new Promise((resolve, reject) => {\n script.onreadystatechange = script.onload = e => {\n script.__dynamicImportLoaded = true;\n resolve(e);\n };\n script.onerror = e => {\n if (script.parentNode) {\n script.parentNode.removeChild(script);\n }\n reject(e);\n };\n if (script.parentNode === null) {\n document.head.appendChild(script);\n } else if (script.__dynamicImportLoaded) {\n resolve();\n }\n });\n}\n\nfunction loadBundle(bundle) {\n if (isString(bundle)) {\n return loadScript(bundle);\n } else {\n return Promise.race(\n bundleKeys\n .filter(key => key in bundle)\n .map(key => loadScript(bundle[key], key))\n );\n }\n}\n\nfunction fireRouterEvent(type, detail) {\n return !window.dispatchEvent(new CustomEvent(\n `vaadin-router-${type}`,\n {cancelable: type === 'go', detail}\n ));\n}\n\nfunction isObject(o) {\n // guard against null passing the typeof check\n return typeof o === 'object' && !!o;\n}\n\nfunction isFunction(f) {\n return typeof f === 'function';\n}\n\nfunction isString(s) {\n return typeof s === 'string';\n}\n\nfunction getNotFoundError(context) {\n const error = new Error(log(`Page not found (${context.pathname})`));\n error.context = context;\n error.code = 404;\n return error;\n}\n\nconst notFoundResult = new (class NotFoundResult {})();\n\n/* istanbul ignore next: coverage is calculated in Chrome, this code is for IE */\nfunction getAnchorOrigin(anchor) {\n // IE11: on HTTP and HTTPS the default port is not included into\n // window.location.origin, so won't include it here either.\n const port = anchor.port;\n const protocol = anchor.protocol;\n const defaultHttp = protocol === 'http:' && port === '80';\n const defaultHttps = protocol === 'https:' && port === '443';\n const host = (defaultHttp || defaultHttps)\n ? anchor.hostname // does not include the port number (e.g. www.example.org)\n : anchor.host; // does include the port number (e.g. www.example.org:80)\n return `${protocol}//${host}`;\n}\n\n// The list of checks is not complete:\n// - SVG support is missing\n// - the 'rel' attribute is not considered\nfunction vaadinRouterGlobalClickHandler(event) {\n // ignore the click if the default action is prevented\n if (event.defaultPrevented) {\n return;\n }\n\n // ignore the click if not with the primary mouse button\n if (event.button !== 0) {\n return;\n }\n\n // ignore the click if a modifier key is pressed\n if (event.shiftKey || event.ctrlKey || event.altKey || event.metaKey) {\n return;\n }\n\n // find the element that the click is at (or within)\n let anchor = event.target;\n const path = event.composedPath\n ? event.composedPath()\n : (event.path || []);\n\n // FIXME(web-padawan): `Symbol.iterator` used by webcomponentsjs is broken for arrays\n // example to check: `for...of` loop here throws the \"Not yet implemented\" error\n for (let i = 0; i < path.length; i++) {\n const target = path[i];\n if (target.nodeName && target.nodeName.toLowerCase() === 'a') {\n anchor = target;\n break;\n }\n }\n\n while (anchor && anchor.nodeName.toLowerCase() !== 'a') {\n anchor = anchor.parentNode;\n }\n\n // ignore the click if not at an element\n if (!anchor || anchor.nodeName.toLowerCase() !== 'a') {\n return;\n }\n\n // ignore the click if the element has a non-default target\n if (anchor.target && anchor.target.toLowerCase() !== '_self') {\n return;\n }\n\n // ignore the click if the element has the 'download' attribute\n if (anchor.hasAttribute('download')) {\n return;\n }\n\n // ignore the click if the element has the 'router-ignore' attribute\n if (anchor.hasAttribute('router-ignore')) {\n return;\n }\n\n // ignore the click if the target URL is a fragment on the current page\n if (anchor.pathname === window.location.pathname && anchor.hash !== '') {\n return;\n }\n\n // ignore the click if the target is external to the app\n // In IE11 HTMLAnchorElement does not have the `origin` property\n const origin = anchor.origin || getAnchorOrigin(anchor);\n if (origin !== window.location.origin) {\n return;\n }\n\n // if none of the above, convert the click into a navigation event\n const {pathname, search, hash} = anchor;\n if (fireRouterEvent('go', {pathname, search, hash})) {\n event.preventDefault();\n // for a click event, the scroll is reset to the top position.\n if (event && event.type === 'click') {\n window.scrollTo(0, 0);\n }\n }\n}\n\n/**\n * A navigation trigger for Vaadin Router that translated clicks on `` links\n * into Vaadin Router navigation events.\n *\n * Only regular clicks on in-app links are translated (primary mouse button, no\n * modifier keys, the target href is within the app's URL space).\n *\n * @memberOf Router.NavigationTrigger\n * @type {NavigationTrigger}\n */\nconst CLICK = {\n activate() {\n window.document.addEventListener('click', vaadinRouterGlobalClickHandler);\n },\n\n inactivate() {\n window.document.removeEventListener('click', vaadinRouterGlobalClickHandler);\n }\n};\n\n// PopStateEvent constructor shim\nconst isIE = /Trident/.test(navigator.userAgent);\n\n/* istanbul ignore next: coverage is calculated in Chrome, this code is for IE */\nif (isIE && !isFunction(window.PopStateEvent)) {\n window.PopStateEvent = function(inType, params) {\n params = params || {};\n var e = document.createEvent('Event');\n e.initEvent(inType, Boolean(params.bubbles), Boolean(params.cancelable));\n e.state = params.state || null;\n return e;\n };\n window.PopStateEvent.prototype = window.Event.prototype;\n}\n\nfunction vaadinRouterGlobalPopstateHandler(event) {\n if (event.state === 'vaadin-router-ignore') {\n return;\n }\n const {pathname, search, hash} = window.location;\n fireRouterEvent('go', {pathname, search, hash});\n}\n\n/**\n * A navigation trigger for Vaadin Router that translates popstate events into\n * Vaadin Router navigation events.\n *\n * @memberOf Router.NavigationTrigger\n * @type {NavigationTrigger}\n */\nconst POPSTATE = {\n activate() {\n window.addEventListener('popstate', vaadinRouterGlobalPopstateHandler);\n },\n\n inactivate() {\n window.removeEventListener('popstate', vaadinRouterGlobalPopstateHandler);\n }\n};\n\n/**\n * Expose `pathToRegexp`.\n */\nvar pathToRegexp_1 = pathToRegexp$1;\nvar parse_1 = parse;\nvar compile_1 = compile;\nvar tokensToFunction_1 = tokensToFunction;\nvar tokensToRegExp_1 = tokensToRegExp;\n\n/**\n * Default configs.\n */\nvar DEFAULT_DELIMITER = '/';\nvar DEFAULT_DELIMITERS = './';\n\n/**\n * The main path matching regexp utility.\n *\n * @type {RegExp}\n */\nvar PATH_REGEXP = new RegExp([\n // Match escaped characters that would otherwise appear in future matches.\n // This allows the user to escape special characters that won't transform.\n '(\\\\\\\\.)',\n // Match Express-style parameters and un-named parameters with a prefix\n // and optional suffixes. Matches appear as:\n //\n // \":test(\\\\d+)?\" => [\"test\", \"\\d+\", undefined, \"?\"]\n // \"(\\\\d+)\" => [undefined, undefined, \"\\d+\", undefined]\n '(?:\\\\:(\\\\w+)(?:\\\\(((?:\\\\\\\\.|[^\\\\\\\\()])+)\\\\))?|\\\\(((?:\\\\\\\\.|[^\\\\\\\\()])+)\\\\))([+*?])?'\n].join('|'), 'g');\n\n/**\n * Parse a string for the raw tokens.\n *\n * @param {string} str\n * @param {Object=} options\n * @return {!Array}\n */\nfunction parse (str, options) {\n var tokens = [];\n var key = 0;\n var index = 0;\n var path = '';\n var defaultDelimiter = (options && options.delimiter) || DEFAULT_DELIMITER;\n var delimiters = (options && options.delimiters) || DEFAULT_DELIMITERS;\n var pathEscaped = false;\n var res;\n\n while ((res = PATH_REGEXP.exec(str)) !== null) {\n var m = res[0];\n var escaped = res[1];\n var offset = res.index;\n path += str.slice(index, offset);\n index = offset + m.length;\n\n // Ignore already escaped sequences.\n if (escaped) {\n path += escaped[1];\n pathEscaped = true;\n continue\n }\n\n var prev = '';\n var next = str[index];\n var name = res[2];\n var capture = res[3];\n var group = res[4];\n var modifier = res[5];\n\n if (!pathEscaped && path.length) {\n var k = path.length - 1;\n\n if (delimiters.indexOf(path[k]) > -1) {\n prev = path[k];\n path = path.slice(0, k);\n }\n }\n\n // Push the current path onto the tokens.\n if (path) {\n tokens.push(path);\n path = '';\n pathEscaped = false;\n }\n\n var partial = prev !== '' && next !== undefined && next !== prev;\n var repeat = modifier === '+' || modifier === '*';\n var optional = modifier === '?' || modifier === '*';\n var delimiter = prev || defaultDelimiter;\n var pattern = capture || group;\n\n tokens.push({\n name: name || key++,\n prefix: prev,\n delimiter: delimiter,\n optional: optional,\n repeat: repeat,\n partial: partial,\n pattern: pattern ? escapeGroup(pattern) : '[^' + escapeString(delimiter) + ']+?'\n });\n }\n\n // Push any remaining characters.\n if (path || index < str.length) {\n tokens.push(path + str.substr(index));\n }\n\n return tokens\n}\n\n/**\n * Compile a string to a template function for the path.\n *\n * @param {string} str\n * @param {Object=} options\n * @return {!function(Object=, Object=)}\n */\nfunction compile (str, options) {\n return tokensToFunction(parse(str, options))\n}\n\n/**\n * Expose a method for transforming tokens into the path function.\n */\nfunction tokensToFunction (tokens) {\n // Compile all the tokens into regexps.\n var matches = new Array(tokens.length);\n\n // Compile all the patterns before compilation.\n for (var i = 0; i < tokens.length; i++) {\n if (typeof tokens[i] === 'object') {\n matches[i] = new RegExp('^(?:' + tokens[i].pattern + ')$');\n }\n }\n\n return function (data, options) {\n var path = '';\n var encode = (options && options.encode) || encodeURIComponent;\n\n for (var i = 0; i < tokens.length; i++) {\n var token = tokens[i];\n\n if (typeof token === 'string') {\n path += token;\n continue\n }\n\n var value = data ? data[token.name] : undefined;\n var segment;\n\n if (Array.isArray(value)) {\n if (!token.repeat) {\n throw new TypeError('Expected \"' + token.name + '\" to not repeat, but got array')\n }\n\n if (value.length === 0) {\n if (token.optional) continue\n\n throw new TypeError('Expected \"' + token.name + '\" to not be empty')\n }\n\n for (var j = 0; j < value.length; j++) {\n segment = encode(value[j], token);\n\n if (!matches[i].test(segment)) {\n throw new TypeError('Expected all \"' + token.name + '\" to match \"' + token.pattern + '\"')\n }\n\n path += (j === 0 ? token.prefix : token.delimiter) + segment;\n }\n\n continue\n }\n\n if (typeof value === 'string' || typeof value === 'number' || typeof value === 'boolean') {\n segment = encode(String(value), token);\n\n if (!matches[i].test(segment)) {\n throw new TypeError('Expected \"' + token.name + '\" to match \"' + token.pattern + '\", but got \"' + segment + '\"')\n }\n\n path += token.prefix + segment;\n continue\n }\n\n if (token.optional) {\n // Prepend partial segment prefixes.\n if (token.partial) path += token.prefix;\n\n continue\n }\n\n throw new TypeError('Expected \"' + token.name + '\" to be ' + (token.repeat ? 'an array' : 'a string'))\n }\n\n return path\n }\n}\n\n/**\n * Escape a regular expression string.\n *\n * @param {string} str\n * @return {string}\n */\nfunction escapeString (str) {\n return str.replace(/([.+*?=^!:${}()[\\]|/\\\\])/g, '\\\\$1')\n}\n\n/**\n * Escape the capturing group by escaping special characters and meaning.\n *\n * @param {string} group\n * @return {string}\n */\nfunction escapeGroup (group) {\n return group.replace(/([=!:$/()])/g, '\\\\$1')\n}\n\n/**\n * Get the flags for a regexp from the options.\n *\n * @param {Object} options\n * @return {string}\n */\nfunction flags (options) {\n return options && options.sensitive ? '' : 'i'\n}\n\n/**\n * Pull out keys from a regexp.\n *\n * @param {!RegExp} path\n * @param {Array=} keys\n * @return {!RegExp}\n */\nfunction regexpToRegexp (path, keys) {\n if (!keys) return path\n\n // Use a negative lookahead to match only capturing groups.\n var groups = path.source.match(/\\((?!\\?)/g);\n\n if (groups) {\n for (var i = 0; i < groups.length; i++) {\n keys.push({\n name: i,\n prefix: null,\n delimiter: null,\n optional: false,\n repeat: false,\n partial: false,\n pattern: null\n });\n }\n }\n\n return path\n}\n\n/**\n * Transform an array into a regexp.\n *\n * @param {!Array} path\n * @param {Array=} keys\n * @param {Object=} options\n * @return {!RegExp}\n */\nfunction arrayToRegexp (path, keys, options) {\n var parts = [];\n\n for (var i = 0; i < path.length; i++) {\n parts.push(pathToRegexp$1(path[i], keys, options).source);\n }\n\n return new RegExp('(?:' + parts.join('|') + ')', flags(options))\n}\n\n/**\n * Create a path regexp from string input.\n *\n * @param {string} path\n * @param {Array=} keys\n * @param {Object=} options\n * @return {!RegExp}\n */\nfunction stringToRegexp (path, keys, options) {\n return tokensToRegExp(parse(path, options), keys, options)\n}\n\n/**\n * Expose a function for taking tokens and returning a RegExp.\n *\n * @param {!Array} tokens\n * @param {Array=} keys\n * @param {Object=} options\n * @return {!RegExp}\n */\nfunction tokensToRegExp (tokens, keys, options) {\n options = options || {};\n\n var strict = options.strict;\n var start = options.start !== false;\n var end = options.end !== false;\n var delimiter = escapeString(options.delimiter || DEFAULT_DELIMITER);\n var delimiters = options.delimiters || DEFAULT_DELIMITERS;\n var endsWith = [].concat(options.endsWith || []).map(escapeString).concat('$').join('|');\n var route = start ? '^' : '';\n var isEndDelimited = tokens.length === 0;\n\n // Iterate over the tokens and create our regexp string.\n for (var i = 0; i < tokens.length; i++) {\n var token = tokens[i];\n\n if (typeof token === 'string') {\n route += escapeString(token);\n isEndDelimited = i === tokens.length - 1 && delimiters.indexOf(token[token.length - 1]) > -1;\n } else {\n var capture = token.repeat\n ? '(?:' + token.pattern + ')(?:' + escapeString(token.delimiter) + '(?:' + token.pattern + '))*'\n : token.pattern;\n\n if (keys) keys.push(token);\n\n if (token.optional) {\n if (token.partial) {\n route += escapeString(token.prefix) + '(' + capture + ')?';\n } else {\n route += '(?:' + escapeString(token.prefix) + '(' + capture + '))?';\n }\n } else {\n route += escapeString(token.prefix) + '(' + capture + ')';\n }\n }\n }\n\n if (end) {\n if (!strict) route += '(?:' + delimiter + ')?';\n\n route += endsWith === '$' ? '$' : '(?=' + endsWith + ')';\n } else {\n if (!strict) route += '(?:' + delimiter + '(?=' + endsWith + '))?';\n if (!isEndDelimited) route += '(?=' + delimiter + '|' + endsWith + ')';\n }\n\n return new RegExp(route, flags(options))\n}\n\n/**\n * Normalize the given path string, returning a regular expression.\n *\n * An empty array can be passed in for the keys, which will hold the\n * placeholder key descriptions. For example, using `/user/:id`, `keys` will\n * contain `[{ name: 'id', delimiter: '/', optional: false, repeat: false }]`.\n *\n * @param {(string|RegExp|Array)} path\n * @param {Array=} keys\n * @param {Object=} options\n * @return {!RegExp}\n */\nfunction pathToRegexp$1 (path, keys, options) {\n if (path instanceof RegExp) {\n return regexpToRegexp(path, keys)\n }\n\n if (Array.isArray(path)) {\n return arrayToRegexp(/** @type {!Array} */ (path), keys, options)\n }\n\n return stringToRegexp(/** @type {string} */ (path), keys, options)\n}\npathToRegexp_1.parse = parse_1;\npathToRegexp_1.compile = compile_1;\npathToRegexp_1.tokensToFunction = tokensToFunction_1;\npathToRegexp_1.tokensToRegExp = tokensToRegExp_1;\n\n/**\n * Universal Router (https://www.kriasoft.com/universal-router/)\n *\n * Copyright (c) 2015-present Kriasoft.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE.txt file in the root directory of this source tree.\n */\n\nconst {hasOwnProperty} = Object.prototype;\nconst cache$1 = new Map();\n// see https://github.com/pillarjs/path-to-regexp/issues/148\ncache$1.set('|false', {\n keys: [],\n pattern: /(?:)/\n});\n\nfunction decodeParam(val) {\n try {\n return decodeURIComponent(val);\n } catch (err) {\n return val;\n }\n}\n\nfunction matchPath(routepath, path, exact, parentKeys, parentParams) {\n exact = !!exact;\n const cacheKey = `${routepath}|${exact}`;\n let regexp = cache$1.get(cacheKey);\n\n if (!regexp) {\n const keys = [];\n regexp = {\n keys,\n pattern: pathToRegexp_1(routepath, keys, {\n end: exact,\n strict: routepath === ''\n }),\n };\n cache$1.set(cacheKey, regexp);\n }\n\n const m = regexp.pattern.exec(path);\n if (!m) {\n return null;\n }\n\n const params = Object.assign({}, parentParams);\n\n for (let i = 1; i < m.length; i++) {\n const key = regexp.keys[i - 1];\n const prop = key.name;\n const value = m[i];\n if (value !== undefined || !hasOwnProperty.call(params, prop)) {\n if (key.repeat) {\n params[prop] = value ? value.split(key.delimiter).map(decodeParam) : [];\n } else {\n params[prop] = value ? decodeParam(value) : value;\n }\n }\n }\n\n return {\n path: m[0],\n keys: (parentKeys || []).concat(regexp.keys),\n params,\n };\n}\n\n/**\n * Universal Router (https://www.kriasoft.com/universal-router/)\n *\n * Copyright (c) 2015-present Kriasoft.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE.txt file in the root directory of this source tree.\n */\n\n/**\n * Traverses the routes tree and matches its nodes to the given pathname from\n * the root down to the leaves. Each match consumes a part of the pathname and\n * the matching process continues for as long as there is a matching child\n * route for the remaining part of the pathname.\n *\n * The returned value is a lazily evaluated iterator.\n *\n * The leading \"/\" in a route path matters only for the root of the routes\n * tree (or if all parent routes are \"\"). In all other cases a leading \"/\" in\n * a child route path has no significance.\n *\n * The trailing \"/\" in a _route path_ matters only for the leaves of the\n * routes tree. A leaf route with a trailing \"/\" matches only a pathname that\n * also has a trailing \"/\".\n *\n * The trailing \"/\" in a route path does not affect matching of child routes\n * in any way.\n *\n * The trailing \"/\" in a _pathname_ generally does not matter (except for\n * the case of leaf nodes described above).\n *\n * The \"\" and \"/\" routes have special treatment:\n * 1. as a single route\n * the \"\" and \"/\" routes match only the \"\" and \"/\" pathnames respectively\n * 2. as a parent in the routes tree\n * the \"\" route matches any pathname without consuming any part of it\n * the \"/\" route matches any absolute pathname consuming its leading \"/\"\n * 3. as a leaf in the routes tree\n * the \"\" and \"/\" routes match only if the entire pathname is consumed by\n * the parent routes chain. In this case \"\" and \"/\" are equivalent.\n * 4. several directly nested \"\" or \"/\" routes\n * - directly nested \"\" or \"/\" routes are 'squashed' (i.e. nesting two\n * \"/\" routes does not require a double \"/\" in the pathname to match)\n * - if there are only \"\" in the parent routes chain, no part of the\n * pathname is consumed, and the leading \"/\" in the child routes' paths\n * remains significant\n *\n * Side effect:\n * - the routes tree { path: '' } matches only the '' pathname\n * - the routes tree { path: '', children: [ { path: '' } ] } matches any\n * pathname (for the tree root)\n *\n * Prefix matching can be enabled also by `children: true`.\n */\nfunction matchRoute(route, pathname, ignoreLeadingSlash, parentKeys, parentParams) {\n let match;\n let childMatches;\n let childIndex = 0;\n let routepath = route.path || '';\n if (routepath.charAt(0) === '/') {\n if (ignoreLeadingSlash) {\n routepath = routepath.substr(1);\n }\n ignoreLeadingSlash = true;\n }\n\n return {\n next(routeToSkip) {\n if (route === routeToSkip) {\n return {done: true};\n }\n\n const children = route.__children = route.__children || route.children;\n\n if (!match) {\n match = matchPath(routepath, pathname, !children, parentKeys, parentParams);\n\n if (match) {\n return {\n done: false,\n value: {\n route,\n keys: match.keys,\n params: match.params,\n path: match.path\n },\n };\n }\n }\n\n if (match && children) {\n while (childIndex < children.length) {\n if (!childMatches) {\n const childRoute = children[childIndex];\n childRoute.parent = route;\n\n let matchedLength = match.path.length;\n if (matchedLength > 0 && pathname.charAt(matchedLength) === '/') {\n matchedLength += 1;\n }\n\n childMatches = matchRoute(\n childRoute,\n pathname.substr(matchedLength),\n ignoreLeadingSlash,\n match.keys,\n match.params\n );\n }\n\n const childMatch = childMatches.next(routeToSkip);\n if (!childMatch.done) {\n return {\n done: false,\n value: childMatch.value,\n };\n }\n\n childMatches = null;\n childIndex++;\n }\n }\n\n return {done: true};\n },\n };\n}\n\n/**\n * Universal Router (https://www.kriasoft.com/universal-router/)\n *\n * Copyright (c) 2015-present Kriasoft.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE.txt file in the root directory of this source tree.\n */\n\nfunction resolveRoute(context) {\n if (isFunction(context.route.action)) {\n return context.route.action(context);\n }\n return undefined;\n}\n\n/**\n * Universal Router (https://www.kriasoft.com/universal-router/)\n *\n * Copyright (c) 2015-present Kriasoft.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE.txt file in the root directory of this source tree.\n */\n\nfunction isChildRoute(parentRoute, childRoute) {\n let route = childRoute;\n while (route) {\n route = route.parent;\n if (route === parentRoute) {\n return true;\n }\n }\n return false;\n}\n\nfunction generateErrorMessage(currentContext) {\n let errorMessage = `Path '${currentContext.pathname}' is not properly resolved due to an error.`;\n const routePath = (currentContext.route || {}).path;\n if (routePath) {\n errorMessage += ` Resolution had failed on route: '${routePath}'`;\n }\n return errorMessage;\n}\n\nfunction updateChainForRoute(context, match) {\n const {route, path} = match;\n\n if (route && !route.__synthetic) {\n const item = {path, route};\n if (!context.chain) {\n context.chain = [];\n } else {\n // Discard old items\n if (route.parent) {\n let i = context.chain.length;\n while (i-- && context.chain[i].route && context.chain[i].route !== route.parent) {\n context.chain.pop();\n }\n }\n }\n context.chain.push(item);\n }\n}\n\n/**\n */\nclass Resolver {\n constructor(routes, options = {}) {\n if (Object(routes) !== routes) {\n throw new TypeError('Invalid routes');\n }\n\n this.baseUrl = options.baseUrl || '';\n this.errorHandler = options.errorHandler;\n this.resolveRoute = options.resolveRoute || resolveRoute;\n this.context = Object.assign({resolver: this}, options.context);\n this.root = Array.isArray(routes) ? {path: '', __children: routes, parent: null, __synthetic: true} : routes;\n this.root.parent = null;\n }\n\n /**\n * Returns the current list of routes (as a shallow copy). Adding / removing\n * routes to / from the returned array does not affect the routing config,\n * but modifying the route objects does.\n *\n * @return {!Array}\n */\n getRoutes() {\n return [...this.root.__children];\n }\n\n /**\n * Sets the routing config (replacing the existing one).\n *\n * @param {!Array|!Router.Route} routes a single route or an array of those\n * (the array is shallow copied)\n */\n setRoutes(routes) {\n ensureRoutes(routes);\n const newRoutes = [...toArray(routes)];\n this.root.__children = newRoutes;\n }\n\n /**\n * Appends one or several routes to the routing config and returns the\n * effective routing config after the operation.\n *\n * @param {!Array|!Router.Route} routes a single route or an array of those\n * (the array is shallow copied)\n * @return {!Array}\n * @protected\n */\n addRoutes(routes) {\n ensureRoutes(routes);\n this.root.__children.push(...toArray(routes));\n return this.getRoutes();\n }\n\n /**\n * Removes all existing routes from the routing config.\n */\n removeRoutes() {\n this.setRoutes([]);\n }\n\n /**\n * Asynchronously resolves the given pathname, i.e. finds all routes matching\n * the pathname and tries resolving them one after another in the order they\n * are listed in the routes config until the first non-null result.\n *\n * Returns a promise that is fulfilled with the return value of an object that consists of the first\n * route handler result that returns something other than `null` or `undefined` and context used to get this result.\n *\n * If no route handlers return a non-null result, or if no route matches the\n * given pathname the returned promise is rejected with a 'page not found'\n * `Error`.\n *\n * @param {!string|!{pathname: !string}} pathnameOrContext the pathname to\n * resolve or a context object with a `pathname` property and other\n * properties to pass to the route resolver functions.\n * @return {!Promise}\n */\n resolve(pathnameOrContext) {\n const context = Object.assign(\n {},\n this.context,\n isString(pathnameOrContext) ? {pathname: pathnameOrContext} : pathnameOrContext\n );\n const match = matchRoute(\n this.root,\n this.__normalizePathname(context.pathname),\n this.baseUrl\n );\n const resolve = this.resolveRoute;\n let matches = null;\n let nextMatches = null;\n let currentContext = context;\n\n function next(resume, parent = matches.value.route, prevResult) {\n const routeToSkip = prevResult === null && matches.value.route;\n matches = nextMatches || match.next(routeToSkip);\n nextMatches = null;\n\n if (!resume) {\n if (matches.done || !isChildRoute(parent, matches.value.route)) {\n nextMatches = matches;\n return Promise.resolve(notFoundResult);\n }\n }\n\n if (matches.done) {\n return Promise.reject(getNotFoundError(context));\n }\n\n currentContext = Object.assign(\n currentContext\n ? {chain: (currentContext.chain ? currentContext.chain.slice(0) : [])}\n : {},\n context,\n matches.value\n );\n updateChainForRoute(currentContext, matches.value);\n\n return Promise.resolve(resolve(currentContext)).then(resolution => {\n if (resolution !== null && resolution !== undefined && resolution !== notFoundResult) {\n currentContext.result = resolution.result || resolution;\n return currentContext;\n }\n return next(resume, parent, resolution);\n });\n }\n\n context.next = next;\n\n return Promise.resolve()\n .then(() => next(true, this.root))\n .catch((error) => {\n const errorMessage = generateErrorMessage(currentContext);\n if (!error) {\n error = new Error(errorMessage);\n } else {\n console.warn(errorMessage);\n }\n error.context = error.context || currentContext;\n // DOMException has its own code which is read-only\n if (!(error instanceof DOMException)) {\n error.code = error.code || 500;\n }\n if (this.errorHandler) {\n currentContext.result = this.errorHandler(error);\n return currentContext;\n }\n throw error;\n });\n }\n\n /**\n * URL constructor polyfill hook. Creates and returns an URL instance.\n */\n static __createUrl(url, base) {\n return new URL(url, base);\n }\n\n /**\n * If the baseUrl property is set, transforms the baseUrl and returns the full\n * actual `base` string for using in the `new URL(path, base);` and for\n * prepernding the paths with. The returned base ends with a trailing slash.\n *\n * Otherwise, returns empty string.\n */\n get __effectiveBaseUrl() {\n return this.baseUrl\n ? this.constructor.__createUrl(\n this.baseUrl,\n document.baseURI || document.URL\n ).href.replace(/[^\\/]*$/, '')\n : '';\n }\n\n /**\n * If the baseUrl is set, matches the pathname with the router’s baseUrl,\n * and returns the local pathname with the baseUrl stripped out.\n *\n * If the pathname does not match the baseUrl, returns undefined.\n *\n * If the `baseUrl` is not set, returns the unmodified pathname argument.\n */\n __normalizePathname(pathname) {\n if (!this.baseUrl) {\n // No base URL, no need to transform the pathname.\n return pathname;\n }\n\n const base = this.__effectiveBaseUrl;\n const normalizedUrl = this.constructor.__createUrl(pathname, base).href;\n if (normalizedUrl.slice(0, base.length) === base) {\n return normalizedUrl.slice(base.length);\n }\n }\n}\n\nResolver.pathToRegexp = pathToRegexp_1;\n\n/**\n * Universal Router (https://www.kriasoft.com/universal-router/)\n *\n * Copyright (c) 2015-present Kriasoft.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE.txt file in the root directory of this source tree.\n */\n\nconst {pathToRegexp} = Resolver;\nconst cache = new Map();\n\nfunction cacheRoutes(routesByName, route, routes) {\n const name = route.name || route.component;\n if (name) {\n if (routesByName.has(name)) {\n routesByName.get(name).push(route);\n } else {\n routesByName.set(name, [route]);\n }\n }\n\n if (Array.isArray(routes)) {\n for (let i = 0; i < routes.length; i++) {\n const childRoute = routes[i];\n childRoute.parent = route;\n cacheRoutes(routesByName, childRoute, childRoute.__children || childRoute.children);\n }\n }\n}\n\nfunction getRouteByName(routesByName, routeName) {\n const routes = routesByName.get(routeName);\n if (routes && routes.length > 1) {\n throw new Error(\n `Duplicate route with name \"${routeName}\".`\n + ` Try seting unique 'name' route properties.`\n );\n }\n return routes && routes[0];\n}\n\nfunction getRoutePath(route) {\n let path = route.path;\n path = Array.isArray(path) ? path[0] : path;\n return path !== undefined ? path : '';\n}\n\nfunction generateUrls(router, options = {}) {\n if (!(router instanceof Resolver)) {\n throw new TypeError('An instance of Resolver is expected');\n }\n\n const routesByName = new Map();\n\n return (routeName, params) => {\n let route = getRouteByName(routesByName, routeName);\n if (!route) {\n routesByName.clear(); // clear cache\n cacheRoutes(routesByName, router.root, router.root.__children);\n\n route = getRouteByName(routesByName, routeName);\n if (!route) {\n throw new Error(`Route \"${routeName}\" not found`);\n }\n }\n\n let regexp = cache.get(route.fullPath);\n if (!regexp) {\n let fullPath = getRoutePath(route);\n let rt = route.parent;\n while (rt) {\n const path = getRoutePath(rt);\n if (path) {\n fullPath = path.replace(/\\/$/, '') + '/' + fullPath.replace(/^\\//, '');\n }\n rt = rt.parent;\n }\n const tokens = pathToRegexp.parse(fullPath);\n const toPath = pathToRegexp.tokensToFunction(tokens);\n const keys = Object.create(null);\n for (let i = 0; i < tokens.length; i++) {\n if (!isString(tokens[i])) {\n keys[tokens[i].name] = true;\n }\n }\n regexp = {toPath, keys};\n cache.set(fullPath, regexp);\n route.fullPath = fullPath;\n }\n\n let url = regexp.toPath(params, options) || '/';\n\n if (options.stringifyQueryParams && params) {\n const queryParams = {};\n const keys = Object.keys(params);\n for (let i = 0; i < keys.length; i++) {\n const key = keys[i];\n if (!regexp.keys[key]) {\n queryParams[key] = params[key];\n }\n }\n const query = options.stringifyQueryParams(queryParams);\n if (query) {\n url += query.charAt(0) === '?' ? query : `?${query}`;\n }\n }\n\n return url;\n };\n}\n\n/**\n * @typedef NavigationTrigger\n * @type {object}\n * @property {function()} activate\n * @property {function()} inactivate\n */\n\n/** @type {Array} */\nlet triggers = [];\n\nfunction setNavigationTriggers(newTriggers) {\n triggers.forEach(trigger => trigger.inactivate());\n\n newTriggers.forEach(trigger => trigger.activate());\n\n triggers = newTriggers;\n}\n\nconst willAnimate = elem => {\n const name = getComputedStyle(elem).getPropertyValue('animation-name');\n return name && name !== 'none';\n};\n\nconst waitForAnimation = (elem, cb) => {\n const listener = () => {\n elem.removeEventListener('animationend', listener);\n cb();\n };\n elem.addEventListener('animationend', listener);\n};\n\nfunction animate(elem, className) {\n elem.classList.add(className);\n\n return new Promise(resolve => {\n if (willAnimate(elem)) {\n const rect = elem.getBoundingClientRect();\n const size = `height: ${rect.bottom - rect.top}px; width: ${rect.right - rect.left}px`;\n elem.setAttribute('style', `position: absolute; ${size}`);\n waitForAnimation(elem, () => {\n elem.classList.remove(className);\n elem.removeAttribute('style');\n resolve();\n });\n } else {\n elem.classList.remove(className);\n resolve();\n }\n });\n}\n\nconst MAX_REDIRECT_COUNT = 256;\n\nfunction isResultNotEmpty(result) {\n return result !== null && result !== undefined;\n}\n\nfunction copyContextWithoutNext(context) {\n const copy = Object.assign({}, context);\n delete copy.next;\n return copy;\n}\n\nfunction createLocation({pathname = '', search = '', hash = '', chain = [], params = {}, redirectFrom, resolver}, route) {\n const routes = chain.map(item => item.route);\n return {\n baseUrl: resolver && resolver.baseUrl || '',\n pathname,\n search,\n hash,\n routes,\n route: route || routes.length && routes[routes.length - 1] || null,\n params,\n redirectFrom,\n getUrl: (userParams = {}) => getPathnameForRouter(\n Router.pathToRegexp.compile(\n getMatchedPath(routes)\n )(Object.assign({}, params, userParams)),\n resolver\n )\n };\n}\n\nfunction createRedirect(context, pathname) {\n const params = Object.assign({}, context.params);\n return {\n redirect: {\n pathname,\n from: context.pathname,\n params\n }\n };\n}\n\nfunction renderElement(context, element) {\n element.location = createLocation(context);\n const index = context.chain.map(item => item.route).indexOf(context.route);\n context.chain[index].element = element;\n return element;\n}\n\nfunction runCallbackIfPossible(callback, args, thisArg) {\n if (isFunction(callback)) {\n return callback.apply(thisArg, args);\n }\n}\n\nfunction amend(amendmentFunction, args, element) {\n return amendmentResult => {\n if (amendmentResult && (amendmentResult.cancel || amendmentResult.redirect)) {\n return amendmentResult;\n }\n\n if (element) {\n return runCallbackIfPossible(element[amendmentFunction], args, element);\n }\n };\n}\n\nfunction processNewChildren(newChildren, route) {\n if (!Array.isArray(newChildren) && !isObject(newChildren)) {\n throw new Error(\n log(\n `Incorrect \"children\" value for the route ${route.path}: expected array or object, but got ${newChildren}`\n )\n );\n }\n\n route.__children = [];\n const childRoutes = toArray(newChildren);\n for (let i = 0; i < childRoutes.length; i++) {\n ensureRoute(childRoutes[i]);\n route.__children.push(childRoutes[i]);\n }\n}\n\nfunction removeDomNodes(nodes) {\n if (nodes && nodes.length) {\n const parent = nodes[0].parentNode;\n for (let i = 0; i < nodes.length; i++) {\n parent.removeChild(nodes[i]);\n }\n }\n}\n\nfunction getPathnameForRouter(pathname, router) {\n const base = router.__effectiveBaseUrl;\n return base\n ? router.constructor.__createUrl(pathname.replace(/^\\//, ''), base).pathname\n : pathname;\n}\n\nfunction getMatchedPath(chain) {\n return chain.map(item => item.path).reduce((a, b) => {\n if (b.length) {\n return a.replace(/\\/$/, '') + '/' + b.replace(/^\\//, '');\n }\n return a;\n }, '');\n}\n\n/**\n * A simple client-side router for single-page applications. It uses\n * express-style middleware and has a first-class support for Web Components and\n * lazy-loading. Works great in Polymer and non-Polymer apps.\n *\n * Use `new Router(outlet, options)` to create a new Router instance.\n *\n * * The `outlet` parameter is a reference to the DOM node to render\n * the content into.\n *\n * * The `options` parameter is an optional object with options. The following\n * keys are supported:\n * * `baseUrl` — the initial value for [\n * the `baseUrl` property\n * ](#/classes/Router#property-baseUrl)\n *\n * The Router instance is automatically subscribed to navigation events\n * on `window`.\n *\n * See [Live Examples](#/classes/Router/demos/demo/index.html) for the detailed usage demo and code snippets.\n *\n * See also detailed API docs for the following methods, for the advanced usage:\n *\n * * [setOutlet](#/classes/Router#method-setOutlet) – should be used to configure the outlet.\n * * [setTriggers](#/classes/Router#method-setTriggers) – should be used to configure the navigation events.\n * * [setRoutes](#/classes/Router#method-setRoutes) – should be used to configure the routes.\n *\n * Only `setRoutes` has to be called manually, others are automatically invoked when creating a new instance.\n *\n * @extends Resolver\n * @demo demo/index.html\n * @summary JavaScript class that renders different DOM content depending on\n * a given path. It can re-render when triggered or automatically on\n * 'popstate' and / or 'click' events.\n */\nclass Router extends Resolver {\n\n /**\n * Creates a new Router instance with a given outlet, and\n * automatically subscribes it to navigation events on the `window`.\n * Using a constructor argument or a setter for outlet is equivalent:\n *\n * ```\n * const router = new Router();\n * router.setOutlet(outlet);\n * ```\n * @param {?Node=} outlet\n * @param {?RouterOptions=} options\n */\n constructor(outlet, options) {\n const baseElement = document.head.querySelector('base');\n const baseHref = baseElement && baseElement.getAttribute('href');\n super([], Object.assign({\n // Default options\n baseUrl: baseHref && Resolver.__createUrl(baseHref, document.URL).pathname.replace(/[^\\/]*$/, '')\n }, options));\n\n this.resolveRoute = context => this.__resolveRoute(context);\n\n const triggers = Router.NavigationTrigger;\n Router.setTriggers.apply(Router, Object.keys(triggers).map(key => triggers[key]));\n\n /**\n * The base URL for all routes in the router instance. By default,\n * if the base element exists in the ``, vaadin-router\n * takes the `` attribute value, resolves against current `document.URL`\n * and gets the `pathname` from the result.\n *\n * @public\n * @type {string}\n */\n this.baseUrl;\n\n /**\n * A promise that is settled after the current render cycle completes. If\n * there is no render cycle in progress the promise is immediately settled\n * with the last render cycle result.\n *\n * @public\n * @type {!Promise}\n */\n this.ready;\n this.ready = Promise.resolve(outlet);\n\n /**\n * Contains read-only information about the current router location:\n * pathname, active routes, parameters. See the\n * [Location type declaration](#/classes/RouterLocation)\n * for more details.\n *\n * @public\n * @type {!RouterLocation}\n */\n this.location;\n this.location = createLocation({resolver: this});\n\n this.__lastStartedRenderId = 0;\n this.__navigationEventHandler = this.__onNavigationEvent.bind(this);\n this.setOutlet(outlet);\n this.subscribe();\n // Using WeakMap instead of WeakSet because WeakSet is not supported by IE11\n this.__createdByRouter = new WeakMap();\n this.__addedByRouter = new WeakMap();\n }\n\n __resolveRoute(context) {\n const route = context.route;\n\n let callbacks = Promise.resolve();\n\n if (isFunction(route.children)) {\n callbacks = callbacks\n .then(() => route.children(copyContextWithoutNext(context)))\n .then(children => {\n // The route.children() callback might have re-written the\n // route.children property instead of returning a value\n if (!isResultNotEmpty(children) && !isFunction(route.children)) {\n children = route.children;\n }\n processNewChildren(children, route);\n });\n }\n\n const commands = {\n redirect: path => createRedirect(context, path),\n component: (component) => {\n const element = document.createElement(component);\n this.__createdByRouter.set(element, true);\n return element;\n }\n };\n\n return callbacks\n .then(() => {\n if (this.__isLatestRender(context)) {\n return runCallbackIfPossible(route.action, [context, commands], route);\n }\n })\n .then(result => {\n if (isResultNotEmpty(result)) {\n // Actions like `() => import('my-view.js')` are not expected to\n // end the resolution, despite the result is not empty. Checking\n // the result with a whitelist of values that end the resolution.\n if (result instanceof HTMLElement ||\n result.redirect ||\n result === notFoundResult) {\n return result;\n }\n }\n\n if (isString(route.redirect)) {\n return commands.redirect(route.redirect);\n }\n\n if (route.bundle) {\n return loadBundle(route.bundle)\n .then(() => {}, () => {\n throw new Error(log(`Bundle not found: ${route.bundle}. Check if the file name is correct`));\n });\n }\n })\n .then(result => {\n if (isResultNotEmpty(result)) {\n return result;\n }\n if (isString(route.component)) {\n return commands.component(route.component);\n }\n });\n }\n\n /**\n * Sets the router outlet (the DOM node where the content for the current\n * route is inserted). Any content pre-existing in the router outlet is\n * removed at the end of each render pass.\n *\n * NOTE: this method is automatically invoked first time when creating a new Router instance.\n *\n * @param {?Node} outlet the DOM node where the content for the current route\n * is inserted.\n */\n setOutlet(outlet) {\n if (outlet) {\n this.__ensureOutlet(outlet);\n }\n this.__outlet = outlet;\n }\n\n /**\n * Returns the current router outlet. The initial value is `undefined`.\n *\n * @return {?Node} the current router outlet (or `undefined`)\n */\n getOutlet() {\n return this.__outlet;\n }\n\n /**\n * Sets the routing config (replacing the existing one) and triggers a\n * navigation event so that the router outlet is refreshed according to the\n * current `window.location` and the new routing config.\n *\n * Each route object may have the following properties, listed here in the processing order:\n * * `path` – the route path (relative to the parent route if any) in the\n * [express.js syntax](https://expressjs.com/en/guide/routing.html#route-paths\").\n *\n * * `children` – an array of nested routes or a function that provides this\n * array at the render time. The function can be synchronous or asynchronous:\n * in the latter case the render is delayed until the returned promise is\n * resolved. The `children` function is executed every time when this route is\n * being rendered. This allows for dynamic route structures (e.g. backend-defined),\n * but it might have a performance impact as well. In order to avoid calling\n * the function on subsequent renders, you can override the `children` property\n * of the route object and save the calculated array there\n * (via `context.route.children = [ route1, route2, ...];`).\n * Parent routes are fully resolved before resolving the children. Children\n * 'path' values are relative to the parent ones.\n *\n * * `action` – the action that is executed before the route is resolved.\n * The value for this property should be a function, accepting `context`\n * and `commands` parameters described below. If present, this function is\n * always invoked first, disregarding of the other properties' presence.\n * The action can return a result directly or within a `Promise`, which\n * resolves to the result. If the action result is an `HTMLElement` instance,\n * a `commands.component(name)` result, a `commands.redirect(path)` result,\n * or a `context.next()` result, the current route resolution is finished,\n * and other route config properties are ignored.\n * See also **Route Actions** section in [Live Examples](#/classes/Router/demos/demo/index.html).\n *\n * * `redirect` – other route's path to redirect to. Passes all route parameters to the redirect target.\n * The target route should also be defined.\n * See also **Redirects** section in [Live Examples](#/classes/Router/demos/demo/index.html).\n *\n * * `bundle` – string containing the path to `.js` or `.mjs` bundle to load before resolving the route,\n * or the object with \"module\" and \"nomodule\" keys referring to different bundles.\n * Each bundle is only loaded once. If \"module\" and \"nomodule\" are set, only one bundle is loaded,\n * depending on whether the browser supports ES modules or not.\n * The property is ignored when either an `action` returns the result or `redirect` property is present.\n * Any error, e.g. 404 while loading bundle will cause route resolution to throw.\n * See also **Code Splitting** section in [Live Examples](#/classes/Router/demos/demo/index.html).\n *\n * * `component` – the tag name of the Web Component to resolve the route to.\n * The property is ignored when either an `action` returns the result or `redirect` property is present.\n * If route contains the `component` property (or an action that return a component)\n * and its child route also contains the `component` property, child route's component\n * will be rendered as a light dom child of a parent component.\n *\n * * `name` – the string name of the route to use in the\n * [`router.urlForName(name, params)`](#/classes/Router#method-urlForName)\n * navigation helper method.\n *\n * For any route function (`action`, `children`) defined, the corresponding `route` object is available inside the callback\n * through the `this` reference. If you need to access it, make sure you define the callback as a non-arrow function\n * because arrow functions do not have their own `this` reference.\n *\n * `context` object that is passed to `action` function holds the following properties:\n * * `context.pathname` – string with the pathname being resolved\n *\n * * `context.search` – search query string\n *\n * * `context.hash` – hash string\n *\n * * `context.params` – object with route parameters\n *\n * * `context.route` – object that holds the route that is currently being rendered.\n *\n * * `context.next()` – function for asynchronously getting the next route\n * contents from the resolution chain (if any)\n *\n * `commands` object that is passed to `action` function has\n * the following methods:\n *\n * * `commands.redirect(path)` – function that creates a redirect data\n * for the path specified.\n *\n * * `commands.component(component)` – function that creates a new HTMLElement\n * with current context. Note: the component created by this function is reused if visiting the same path twice in row.\n *\n *\n * @param {!Array|!Route} routes a single route or an array of those\n * @param {?boolean} skipRender configure the router but skip rendering the\n * route corresponding to the current `window.location` values\n *\n * @return {!Promise}\n */\n setRoutes(routes, skipRender = false) {\n this.__previousContext = undefined;\n this.__urlForName = undefined;\n super.setRoutes(routes);\n if (!skipRender) {\n this.__onNavigationEvent();\n }\n return this.ready;\n }\n\n /**\n * Asynchronously resolves the given pathname and renders the resolved route\n * component into the router outlet. If no router outlet is set at the time of\n * calling this method, or at the time when the route resolution is completed,\n * a `TypeError` is thrown.\n *\n * Returns a promise that is fulfilled with the router outlet DOM Node after\n * the route component is created and inserted into the router outlet, or\n * rejected if no route matches the given path.\n *\n * If another render pass is started before the previous one is completed, the\n * result of the previous render pass is ignored.\n *\n * @param {!string|!{pathname: !string, search: ?string, hash: ?string}} pathnameOrContext\n * the pathname to render or a context object with a `pathname` property,\n * optional `search` and `hash` properties, and other properties\n * to pass to the resolver.\n * @param {boolean=} shouldUpdateHistory\n * update browser history with the rendered location\n * @return {!Promise}\n */\n render(pathnameOrContext, shouldUpdateHistory) {\n const renderId = ++this.__lastStartedRenderId;\n const context = Object.assign(\n {\n search: '',\n hash: ''\n },\n isString(pathnameOrContext)\n ? {pathname: pathnameOrContext}\n : pathnameOrContext,\n {\n __renderId: renderId\n }\n );\n\n // Find the first route that resolves to a non-empty result\n this.ready = this.resolve(context)\n\n // Process the result of this.resolve() and handle all special commands:\n // (redirect / prevent / component). If the result is a 'component',\n // then go deeper and build the entire chain of nested components matching\n // the pathname. Also call all 'on before' callbacks along the way.\n .then(context => this.__fullyResolveChain(context))\n\n .then(context => {\n if (this.__isLatestRender(context)) {\n const previousContext = this.__previousContext;\n\n // Check if the render was prevented and make an early return in that case\n if (context === previousContext) {\n // Replace the history with the previous context\n // to make sure the URL stays the same.\n this.__updateBrowserHistory(previousContext, true);\n return this.location;\n }\n\n this.location = createLocation(context);\n\n if (shouldUpdateHistory) {\n // Replace only if first render redirects, so that we don’t leave\n // the redirecting record in the history\n this.__updateBrowserHistory(context, renderId === 1);\n }\n\n fireRouterEvent('location-changed', {router: this, location: this.location});\n\n // Skip detaching/re-attaching there are no render changes\n if (context.__skipAttach) {\n this.__copyUnchangedElements(context, previousContext);\n this.__previousContext = context;\n return this.location;\n }\n\n this.__addAppearingContent(context, previousContext);\n const animationDone = this.__animateIfNeeded(context);\n\n this.__runOnAfterEnterCallbacks(context);\n this.__runOnAfterLeaveCallbacks(context, previousContext);\n\n return animationDone.then(() => {\n if (this.__isLatestRender(context)) {\n // If there is another render pass started after this one,\n // the 'disappearing content' would be removed when the other\n // render pass calls `this.__addAppearingContent()`\n this.__removeDisappearingContent();\n\n this.__previousContext = context;\n return this.location;\n }\n });\n }\n })\n .catch(error => {\n if (renderId === this.__lastStartedRenderId) {\n if (shouldUpdateHistory) {\n this.__updateBrowserHistory(context);\n }\n removeDomNodes(this.__outlet && this.__outlet.children);\n this.location = createLocation(Object.assign(context, {resolver: this}));\n fireRouterEvent('error', Object.assign({router: this, error}, context));\n throw error;\n }\n });\n return this.ready;\n }\n\n // `topOfTheChainContextBeforeRedirects` is a context coming from Resolver.resolve().\n // It would contain a 'redirect' route or the first 'component' route that\n // matched the pathname. There might be more child 'component' routes to be\n // resolved and added into the chain. This method would find and add them.\n // `contextBeforeRedirects` is the context containing such a child component\n // route. It's only necessary when this method is called recursively (otherwise\n // it's the same as the 'top of the chain' context).\n //\n // Apart from building the chain of child components, this method would also\n // handle 'redirect' routes, call 'onBefore' callbacks and handle 'prevent'\n // and 'redirect' callback results.\n __fullyResolveChain(topOfTheChainContextBeforeRedirects,\n contextBeforeRedirects = topOfTheChainContextBeforeRedirects) {\n return this.__findComponentContextAfterAllRedirects(contextBeforeRedirects)\n // `contextAfterRedirects` is always a context with an `HTMLElement` result\n // In other cases the promise gets rejected and .then() is not called\n .then(contextAfterRedirects => {\n const redirectsHappened = contextAfterRedirects !== contextBeforeRedirects;\n const topOfTheChainContextAfterRedirects =\n redirectsHappened ? contextAfterRedirects : topOfTheChainContextBeforeRedirects;\n\n const matchedPath = getPathnameForRouter(\n getMatchedPath(contextAfterRedirects.chain),\n contextAfterRedirects.resolver\n );\n const isFound = (matchedPath === contextAfterRedirects.pathname);\n\n // Recursive method to try matching more child and sibling routes\n const findNextContextIfAny = (context, parent = context.route, prevResult) => {\n return context.next(undefined, parent, prevResult).then(nextContext => {\n if (nextContext === null || nextContext === notFoundResult) {\n // Next context is not found in children, ...\n if (isFound) {\n // ...but original context is already fully matching - use it\n return context;\n } else if (parent.parent !== null) {\n // ...and there is no full match yet - step up to check siblings\n return findNextContextIfAny(context, parent.parent, nextContext);\n } else {\n return nextContext;\n }\n }\n\n return nextContext;\n });\n };\n\n return findNextContextIfAny(contextAfterRedirects).then(nextContext => {\n if (nextContext === null || nextContext === notFoundResult) {\n throw getNotFoundError(topOfTheChainContextAfterRedirects);\n }\n\n return nextContext\n && nextContext !== notFoundResult\n && nextContext !== contextAfterRedirects\n ? this.__fullyResolveChain(topOfTheChainContextAfterRedirects, nextContext)\n : this.__amendWithOnBeforeCallbacks(contextAfterRedirects);\n });\n });\n }\n\n __findComponentContextAfterAllRedirects(context) {\n const result = context.result;\n if (result instanceof HTMLElement) {\n renderElement(context, result);\n return Promise.resolve(context);\n } else if (result.redirect) {\n return this.__redirect(result.redirect, context.__redirectCount, context.__renderId)\n .then(context => this.__findComponentContextAfterAllRedirects(context));\n } else if (result instanceof Error) {\n return Promise.reject(result);\n } else {\n return Promise.reject(\n new Error(\n log(\n `Invalid route resolution result for path \"${context.pathname}\". ` +\n `Expected redirect object or HTML element, but got: \"${logValue(result)}\". ` +\n `Double check the action return value for the route.`\n )\n ));\n }\n }\n\n __amendWithOnBeforeCallbacks(contextWithFullChain) {\n return this.__runOnBeforeCallbacks(contextWithFullChain).then(amendedContext => {\n if (amendedContext === this.__previousContext || amendedContext === contextWithFullChain) {\n return amendedContext;\n }\n return this.__fullyResolveChain(amendedContext);\n });\n }\n\n __runOnBeforeCallbacks(newContext) {\n const previousContext = this.__previousContext || {};\n const previousChain = previousContext.chain || [];\n const newChain = newContext.chain;\n\n let callbacks = Promise.resolve();\n const prevent = () => ({cancel: true});\n const redirect = (pathname) => createRedirect(newContext, pathname);\n\n newContext.__divergedChainIndex = 0;\n newContext.__skipAttach = false;\n if (previousChain.length) {\n for (let i = 0; i < Math.min(previousChain.length, newChain.length); i = ++newContext.__divergedChainIndex) {\n if (previousChain[i].route !== newChain[i].route\n || previousChain[i].path !== newChain[i].path && previousChain[i].element !== newChain[i].element\n || !this.__isReusableElement(previousChain[i].element, newChain[i].element)) {\n break;\n }\n }\n\n // Skip re-attaching and notifications if element and chain do not change\n newContext.__skipAttach =\n // Same route chain\n newChain.length === previousChain.length && newContext.__divergedChainIndex == newChain.length &&\n // Same element\n this.__isReusableElement(newContext.result, previousContext.result);\n\n if (newContext.__skipAttach) {\n // execute onBeforeLeave for changed segment element when skipping attach\n for (let i = newChain.length - 1; i >= 0; i--) {\n callbacks = this.__runOnBeforeLeaveCallbacks(callbacks, newContext, {prevent}, previousChain[i]);\n }\n // execute onBeforeEnter for changed segment element when skipping attach\n for (let i = 0; i < newChain.length; i++) {\n callbacks = this.__runOnBeforeEnterCallbacks(callbacks, newContext, {prevent, redirect}, newChain[i]);\n previousChain[i].element.location = createLocation(newContext, previousChain[i].route);\n }\n\n } else {\n // execute onBeforeLeave when NOT skipping attach\n for (let i = previousChain.length - 1; i >= newContext.__divergedChainIndex; i--) {\n callbacks = this.__runOnBeforeLeaveCallbacks(callbacks, newContext, {prevent}, previousChain[i]);\n }\n }\n }\n // execute onBeforeEnter when NOT skipping attach\n if (!newContext.__skipAttach) {\n for (let i = 0; i < newChain.length; i++) {\n if (i < newContext.__divergedChainIndex) {\n if (i < previousChain.length && previousChain[i].element) {\n previousChain[i].element.location = createLocation(newContext, previousChain[i].route);\n }\n } else {\n callbacks = this.__runOnBeforeEnterCallbacks(callbacks, newContext, {prevent, redirect}, newChain[i]);\n if (newChain[i].element) {\n newChain[i].element.location = createLocation(newContext, newChain[i].route);\n }\n }\n }\n }\n return callbacks.then(amendmentResult => {\n if (amendmentResult) {\n if (amendmentResult.cancel) {\n this.__previousContext.__renderId = newContext.__renderId;\n return this.__previousContext;\n }\n if (amendmentResult.redirect) {\n return this.__redirect(amendmentResult.redirect, newContext.__redirectCount, newContext.__renderId);\n }\n }\n return newContext;\n });\n }\n\n __runOnBeforeLeaveCallbacks(callbacks, newContext, commands, chainElement) {\n const location = createLocation(newContext);\n return callbacks.then(result => {\n if (this.__isLatestRender(newContext)) {\n const afterLeaveFunction = amend('onBeforeLeave', [location, commands, this], chainElement.element);\n return afterLeaveFunction(result);\n }\n }).then(result => {\n if (!(result || {}).redirect) {\n return result;\n }\n });\n }\n\n __runOnBeforeEnterCallbacks(callbacks, newContext, commands, chainElement) {\n const location = createLocation(newContext, chainElement.route);\n return callbacks.then(result => {\n if (this.__isLatestRender(newContext)) {\n const beforeEnterFunction = amend('onBeforeEnter', [location, commands, this], chainElement.element);\n return beforeEnterFunction(result);\n }\n });\n }\n\n __isReusableElement(element, otherElement) {\n if (element && otherElement) {\n return this.__createdByRouter.get(element) && this.__createdByRouter.get(otherElement)\n ? element.localName === otherElement.localName\n : element === otherElement;\n }\n return false;\n }\n\n __isLatestRender(context) {\n return context.__renderId === this.__lastStartedRenderId;\n }\n\n __redirect(redirectData, counter, renderId) {\n if (counter > MAX_REDIRECT_COUNT) {\n throw new Error(log(`Too many redirects when rendering ${redirectData.from}`));\n }\n\n return this.resolve({\n pathname: this.urlForPath(\n redirectData.pathname,\n redirectData.params\n ),\n redirectFrom: redirectData.from,\n __redirectCount: (counter || 0) + 1,\n __renderId: renderId\n });\n }\n\n __ensureOutlet(outlet = this.__outlet) {\n if (!(outlet instanceof Node)) {\n throw new TypeError(log(`Expected router outlet to be a valid DOM Node (but got ${outlet})`));\n }\n }\n\n __updateBrowserHistory({pathname, search = '', hash = ''}, replace) {\n if (window.location.pathname !== pathname\n || window.location.search !== search\n || window.location.hash !== hash\n ) {\n const changeState = replace ? 'replaceState' : 'pushState';\n window.history[changeState](null, document.title, pathname + search + hash);\n window.dispatchEvent(new PopStateEvent('popstate', {state: 'vaadin-router-ignore'}));\n }\n }\n\n __copyUnchangedElements(context, previousContext) {\n // Find the deepest common parent between the last and the new component\n // chains. Update references for the unchanged elements in the new chain\n let deepestCommonParent = this.__outlet;\n for (let i = 0; i < context.__divergedChainIndex; i++) {\n const unchangedElement = previousContext && previousContext.chain[i].element;\n if (unchangedElement) {\n if (unchangedElement.parentNode === deepestCommonParent) {\n context.chain[i].element = unchangedElement;\n deepestCommonParent = unchangedElement;\n } else {\n break;\n }\n }\n }\n return deepestCommonParent;\n }\n\n __addAppearingContent(context, previousContext) {\n this.__ensureOutlet();\n\n // If the previous 'entering' animation has not completed yet,\n // stop it and remove that content from the DOM before adding new one.\n this.__removeAppearingContent();\n\n // Copy reusable elements from the previousContext to current\n const deepestCommonParent = this.__copyUnchangedElements(context, previousContext);\n\n // Keep two lists of DOM elements:\n // - those that should be removed once the transition animation is over\n // - and those that should remain\n this.__appearingContent = [];\n this.__disappearingContent = Array\n .from(deepestCommonParent.children)\n .filter(\n // Only remove layout content that was added by router\n e => this.__addedByRouter.get(e) &&\n // Do not remove the result element to avoid flickering\n e !== context.result);\n\n // Add new elements (starting after the deepest common parent) to the DOM.\n // That way only the components that are actually different between the two\n // locations are added to the DOM (and those that are common remain in the\n // DOM without first removing and then adding them again).\n let parentElement = deepestCommonParent;\n for (let i = context.__divergedChainIndex; i < context.chain.length; i++) {\n const elementToAdd = context.chain[i].element;\n if (elementToAdd) {\n parentElement.appendChild(elementToAdd);\n this.__addedByRouter.set(elementToAdd, true);\n if (parentElement === deepestCommonParent) {\n this.__appearingContent.push(elementToAdd);\n }\n parentElement = elementToAdd;\n }\n }\n }\n\n __removeDisappearingContent() {\n if (this.__disappearingContent) {\n removeDomNodes(this.__disappearingContent);\n }\n this.__disappearingContent = null;\n this.__appearingContent = null;\n }\n\n __removeAppearingContent() {\n if (this.__disappearingContent && this.__appearingContent) {\n removeDomNodes(this.__appearingContent);\n this.__disappearingContent = null;\n this.__appearingContent = null;\n }\n }\n\n __runOnAfterLeaveCallbacks(currentContext, targetContext) {\n if (!targetContext) {\n return;\n }\n\n // REVERSE iteration: from Z to A\n for (let i = targetContext.chain.length - 1; i >= currentContext.__divergedChainIndex; i--) {\n if (!this.__isLatestRender(currentContext)) {\n break;\n }\n const currentComponent = targetContext.chain[i].element;\n if (!currentComponent) {\n continue;\n }\n try {\n const location = createLocation(currentContext);\n runCallbackIfPossible(\n currentComponent.onAfterLeave,\n [location, {}, targetContext.resolver],\n currentComponent);\n } finally {\n if (this.__disappearingContent.indexOf(currentComponent) > -1) {\n removeDomNodes(currentComponent.children);\n }\n }\n }\n }\n\n __runOnAfterEnterCallbacks(currentContext) {\n // forward iteration: from A to Z\n for (let i = currentContext.__divergedChainIndex; i < currentContext.chain.length; i++) {\n if (!this.__isLatestRender(currentContext)) {\n break;\n }\n const currentComponent = currentContext.chain[i].element || {};\n const location = createLocation(currentContext, currentContext.chain[i].route);\n runCallbackIfPossible(\n currentComponent.onAfterEnter,\n [location, {}, currentContext.resolver],\n currentComponent);\n }\n }\n\n __animateIfNeeded(context) {\n const from = (this.__disappearingContent || [])[0];\n const to = (this.__appearingContent || [])[0];\n const promises = [];\n\n const chain = context.chain;\n let config;\n for (let i = chain.length; i > 0; i--) {\n if (chain[i - 1].route.animate) {\n config = chain[i - 1].route.animate;\n break;\n }\n }\n\n if (from && to && config) {\n const leave = isObject(config) && config.leave || 'leaving';\n const enter = isObject(config) && config.enter || 'entering';\n promises.push(animate(from, leave));\n promises.push(animate(to, enter));\n }\n\n return Promise.all(promises).then(() => context);\n }\n\n /**\n * Subscribes this instance to navigation events on the `window`.\n *\n * NOTE: beware of resource leaks. For as long as a router instance is\n * subscribed to navigation events, it won't be garbage collected.\n */\n subscribe() {\n window.addEventListener('vaadin-router-go', this.__navigationEventHandler);\n }\n\n /**\n * Removes the subscription to navigation events created in the `subscribe()`\n * method.\n */\n unsubscribe() {\n window.removeEventListener('vaadin-router-go', this.__navigationEventHandler);\n }\n\n __onNavigationEvent(event) {\n const {pathname, search, hash} = event ? event.detail : window.location;\n if (isString(this.__normalizePathname(pathname))) {\n if (event && event.preventDefault) {\n event.preventDefault();\n }\n this.render({pathname, search, hash}, true);\n }\n }\n\n /**\n * Configures what triggers Router navigation events:\n * - `POPSTATE`: popstate events on the current `window`\n * - `CLICK`: click events on `` links leading to the current page\n *\n * This method is invoked with the pre-configured values when creating a new Router instance.\n * By default, both `POPSTATE` and `CLICK` are enabled. This setup is expected to cover most of the use cases.\n *\n * See the `router-config.js` for the default navigation triggers config. Based on it, you can\n * create the own one and only import the triggers you need, instead of pulling in all the code,\n * e.g. if you want to handle `click` differently.\n *\n * See also **Navigation Triggers** section in [Live Examples](#/classes/Router/demos/demo/index.html).\n *\n * @param {...NavigationTrigger} triggers\n */\n static setTriggers(...triggers) {\n setNavigationTriggers(triggers);\n }\n\n /**\n * Generates a URL for the route with the given name, optionally performing\n * substitution of parameters.\n *\n * The route is searched in all the Router instances subscribed to\n * navigation events.\n *\n * **Note:** For child route names, only array children are considered.\n * It is not possible to generate URLs using a name for routes set with\n * a children function.\n *\n * @function urlForName\n * @param {!string} name the route name or the route’s `component` name.\n * @param {Params=} params Optional object with route path parameters.\n * Named parameters are passed by name (`params[name] = value`), unnamed\n * parameters are passed by index (`params[index] = value`).\n *\n * @return {string}\n */\n urlForName(name, params) {\n if (!this.__urlForName) {\n this.__urlForName = generateUrls(this);\n }\n return getPathnameForRouter(\n this.__urlForName(name, params),\n this\n );\n }\n\n /**\n * Generates a URL for the given route path, optionally performing\n * substitution of parameters.\n *\n * @param {!string} path string route path declared in [express.js syntax](https://expressjs.com/en/guide/routing.html#route-paths\").\n * @param {Params=} params Optional object with route path parameters.\n * Named parameters are passed by name (`params[name] = value`), unnamed\n * parameters are passed by index (`params[index] = value`).\n *\n * @return {string}\n */\n urlForPath(path, params) {\n return getPathnameForRouter(\n Router.pathToRegexp.compile(path)(params),\n this\n );\n }\n\n /**\n * Triggers navigation to a new path. Returns a boolean without waiting until\n * the navigation is complete. Returns `true` if at least one `Router`\n * has handled the navigation (was subscribed and had `baseUrl` matching\n * the `path` argument), otherwise returns `false`.\n *\n * @param {!string|!{pathname: !string, search: (string|undefined), hash: (string|undefined)}} path\n * a new in-app path string, or an URL-like object with `pathname`\n * string property, and optional `search` and `hash` string properties.\n * @return {boolean}\n */\n static go(path) {\n const {pathname, search, hash} = isString(path)\n ? this.__createUrl(path, 'http://a') // some base to omit origin\n : path;\n return fireRouterEvent('go', {pathname, search, hash});\n }\n}\n\nconst DEV_MODE_CODE_REGEXP =\n /\\/\\*[\\*!]\\s+vaadin-dev-mode:start([\\s\\S]*)vaadin-dev-mode:end\\s+\\*\\*\\//i;\n\nconst FlowClients = window.Vaadin && window.Vaadin.Flow && window.Vaadin.Flow.clients;\n\nfunction isMinified() {\n function test() {\n /** vaadin-dev-mode:start\n return false;\n vaadin-dev-mode:end **/\n return true;\n }\n return uncommentAndRun(test);\n}\n\nfunction isDevelopmentMode() {\n try {\n if (isForcedDevelopmentMode()) {\n return true;\n }\n\n if (!isLocalhost()) {\n return false;\n }\n\n if (FlowClients) {\n return !isFlowProductionMode();\n }\n\n return !isMinified();\n } catch (e) {\n // Some error in this code, assume production so no further actions will be taken\n return false;\n }\n}\n\nfunction isForcedDevelopmentMode() {\n return localStorage.getItem(\"vaadin.developmentmode.force\");\n}\n\nfunction isLocalhost() {\n return ([\"localhost\",\"127.0.0.1\"].indexOf(window.location.hostname) >= 0);\n}\n\nfunction isFlowProductionMode() {\n if (FlowClients) {\n const productionModeApps = Object.keys(FlowClients)\n .map(key => FlowClients[key])\n .filter(client => client.productionMode);\n if (productionModeApps.length > 0) {\n return true;\n }\n }\n return false;\n}\n\nfunction uncommentAndRun(callback, args) {\n if (typeof callback !== 'function') {\n return;\n }\n\n const match = DEV_MODE_CODE_REGEXP.exec(callback.toString());\n if (match) {\n try {\n // requires CSP: script-src 'unsafe-eval'\n callback = new Function(match[1]);\n } catch (e) {\n // eat the exception\n console.log('vaadin-development-mode-detector: uncommentAndRun() failed', e);\n }\n }\n\n return callback(args);\n}\n\n// A guard against polymer-modulizer removing the window.Vaadin\n// initialization above.\nwindow['Vaadin'] = window['Vaadin'] || {};\n\n/**\n * Inspects the source code of the given `callback` function for\n * specially-marked _commented_ code. If such commented code is found in the\n * callback source, uncomments and runs that code instead of the callback\n * itself. Otherwise runs the callback as is.\n *\n * The optional arguments are passed into the callback / uncommented code,\n * the result is returned.\n *\n * See the `isMinified()` function source code in this file for an example.\n *\n */\nconst runIfDevelopmentMode = function(callback, args) {\n if (window.Vaadin.developmentMode) {\n return uncommentAndRun(callback, args);\n }\n};\n\nif (window.Vaadin.developmentMode === undefined) {\n window.Vaadin.developmentMode = isDevelopmentMode();\n}\n\n/* This file is autogenerated from src/vaadin-usage-statistics.tpl.html */\n\nfunction maybeGatherAndSendStats() {\n /** vaadin-dev-mode:start\n (function () {\n'use strict';\n\nvar _typeof = typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\" ? function (obj) {\n return typeof obj;\n} : function (obj) {\n return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj;\n};\n\nvar classCallCheck = function (instance, Constructor) {\n if (!(instance instanceof Constructor)) {\n throw new TypeError(\"Cannot call a class as a function\");\n }\n};\n\nvar createClass = function () {\n function defineProperties(target, props) {\n for (var i = 0; i < props.length; i++) {\n var descriptor = props[i];\n descriptor.enumerable = descriptor.enumerable || false;\n descriptor.configurable = true;\n if (\"value\" in descriptor) descriptor.writable = true;\n Object.defineProperty(target, descriptor.key, descriptor);\n }\n }\n\n return function (Constructor, protoProps, staticProps) {\n if (protoProps) defineProperties(Constructor.prototype, protoProps);\n if (staticProps) defineProperties(Constructor, staticProps);\n return Constructor;\n };\n}();\n\nvar getPolymerVersion = function getPolymerVersion() {\n return window.Polymer && window.Polymer.version;\n};\n\nvar StatisticsGatherer = function () {\n function StatisticsGatherer(logger) {\n classCallCheck(this, StatisticsGatherer);\n\n this.now = new Date().getTime();\n this.logger = logger;\n }\n\n createClass(StatisticsGatherer, [{\n key: 'frameworkVersionDetectors',\n value: function frameworkVersionDetectors() {\n return {\n 'Flow': function Flow() {\n if (window.Vaadin && window.Vaadin.Flow && window.Vaadin.Flow.clients) {\n var flowVersions = Object.keys(window.Vaadin.Flow.clients).map(function (key) {\n return window.Vaadin.Flow.clients[key];\n }).filter(function (client) {\n return client.getVersionInfo;\n }).map(function (client) {\n return client.getVersionInfo().flow;\n });\n if (flowVersions.length > 0) {\n return flowVersions[0];\n }\n }\n },\n 'Vaadin Framework': function VaadinFramework() {\n if (window.vaadin && window.vaadin.clients) {\n var frameworkVersions = Object.values(window.vaadin.clients).filter(function (client) {\n return client.getVersionInfo;\n }).map(function (client) {\n return client.getVersionInfo().vaadinVersion;\n });\n if (frameworkVersions.length > 0) {\n return frameworkVersions[0];\n }\n }\n },\n 'AngularJs': function AngularJs() {\n if (window.angular && window.angular.version && window.angular.version) {\n return window.angular.version.full;\n }\n },\n 'Angular': function Angular() {\n if (window.ng) {\n var tags = document.querySelectorAll(\"[ng-version]\");\n if (tags.length > 0) {\n return tags[0].getAttribute(\"ng-version\");\n }\n return \"Unknown\";\n }\n },\n 'Backbone.js': function BackboneJs() {\n if (window.Backbone) {\n return window.Backbone.VERSION;\n }\n },\n 'React': function React() {\n var reactSelector = '[data-reactroot], [data-reactid]';\n if (!!document.querySelector(reactSelector)) {\n // React does not publish the version by default\n return \"unknown\";\n }\n },\n 'Ember': function Ember() {\n if (window.Em && window.Em.VERSION) {\n return window.Em.VERSION;\n } else if (window.Ember && window.Ember.VERSION) {\n return window.Ember.VERSION;\n }\n },\n 'jQuery': function (_jQuery) {\n function jQuery() {\n return _jQuery.apply(this, arguments);\n }\n\n jQuery.toString = function () {\n return _jQuery.toString();\n };\n\n return jQuery;\n }(function () {\n if (typeof jQuery === 'function' && jQuery.prototype.jquery !== undefined) {\n return jQuery.prototype.jquery;\n }\n }),\n 'Polymer': function Polymer() {\n var version = getPolymerVersion();\n if (version) {\n return version;\n }\n },\n 'LitElement': function LitElement() {\n var version = window.litElementVersions && window.litElementVersions[0];\n if (version) {\n return version;\n }\n },\n 'LitHtml': function LitHtml() {\n var version = window.litHtmlVersions && window.litHtmlVersions[0];\n if (version) {\n return version;\n }\n },\n 'Vue.js': function VueJs() {\n if (window.Vue) {\n return window.Vue.version;\n }\n }\n };\n }\n }, {\n key: 'getUsedVaadinElements',\n value: function getUsedVaadinElements(elements) {\n var version = getPolymerVersion();\n var elementClasses = void 0;\n // NOTE: In case you edit the code here, YOU MUST UPDATE any statistics reporting code in Flow.\n // Check all locations calling the method getEntries() in\n // https://github.com/vaadin/flow/blob/master/flow-server/src/main/java/com/vaadin/flow/internal/UsageStatistics.java#L106\n // Currently it is only used by BootstrapHandler.\n if (version && version.indexOf('2') === 0) {\n // Polymer 2: components classes are stored in window.Vaadin\n elementClasses = Object.keys(window.Vaadin).map(function (c) {\n return window.Vaadin[c];\n }).filter(function (c) {\n return c.is;\n });\n } else {\n // Polymer 3: components classes are stored in window.Vaadin.registrations\n elementClasses = window.Vaadin.registrations || [];\n }\n elementClasses.forEach(function (klass) {\n var version = klass.version ? klass.version : \"0.0.0\";\n elements[klass.is] = { version: version };\n });\n }\n }, {\n key: 'getUsedVaadinThemes',\n value: function getUsedVaadinThemes(themes) {\n ['Lumo', 'Material'].forEach(function (themeName) {\n var theme;\n var version = getPolymerVersion();\n if (version && version.indexOf('2') === 0) {\n // Polymer 2: themes are stored in window.Vaadin\n theme = window.Vaadin[themeName];\n } else {\n // Polymer 3: themes are stored in custom element registry\n theme = customElements.get('vaadin-' + themeName.toLowerCase() + '-styles');\n }\n if (theme && theme.version) {\n themes[themeName] = { version: theme.version };\n }\n });\n }\n }, {\n key: 'getFrameworks',\n value: function getFrameworks(frameworks) {\n var detectors = this.frameworkVersionDetectors();\n Object.keys(detectors).forEach(function (framework) {\n var detector = detectors[framework];\n try {\n var version = detector();\n if (version) {\n frameworks[framework] = { version: version };\n }\n } catch (e) {}\n });\n }\n }, {\n key: 'gather',\n value: function gather(storage) {\n var storedStats = storage.read();\n var gatheredStats = {};\n var types = [\"elements\", \"frameworks\", \"themes\"];\n\n types.forEach(function (type) {\n gatheredStats[type] = {};\n if (!storedStats[type]) {\n storedStats[type] = {};\n }\n });\n\n var previousStats = JSON.stringify(storedStats);\n\n this.getUsedVaadinElements(gatheredStats.elements);\n this.getFrameworks(gatheredStats.frameworks);\n this.getUsedVaadinThemes(gatheredStats.themes);\n\n var now = this.now;\n types.forEach(function (type) {\n var keys = Object.keys(gatheredStats[type]);\n keys.forEach(function (key) {\n if (!storedStats[type][key] || _typeof(storedStats[type][key]) != _typeof({})) {\n storedStats[type][key] = { firstUsed: now };\n }\n // Discards any previously logged version number\n storedStats[type][key].version = gatheredStats[type][key].version;\n storedStats[type][key].lastUsed = now;\n });\n });\n\n var newStats = JSON.stringify(storedStats);\n storage.write(newStats);\n if (newStats != previousStats && Object.keys(storedStats).length > 0) {\n this.logger.debug(\"New stats: \" + newStats);\n }\n }\n }]);\n return StatisticsGatherer;\n}();\n\nvar StatisticsStorage = function () {\n function StatisticsStorage(key) {\n classCallCheck(this, StatisticsStorage);\n\n this.key = key;\n }\n\n createClass(StatisticsStorage, [{\n key: 'read',\n value: function read() {\n var localStorageStatsString = localStorage.getItem(this.key);\n try {\n return JSON.parse(localStorageStatsString ? localStorageStatsString : '{}');\n } catch (e) {\n return {};\n }\n }\n }, {\n key: 'write',\n value: function write(data) {\n localStorage.setItem(this.key, data);\n }\n }, {\n key: 'clear',\n value: function clear() {\n localStorage.removeItem(this.key);\n }\n }, {\n key: 'isEmpty',\n value: function isEmpty() {\n var storedStats = this.read();\n var empty = true;\n Object.keys(storedStats).forEach(function (key) {\n if (Object.keys(storedStats[key]).length > 0) {\n empty = false;\n }\n });\n\n return empty;\n }\n }]);\n return StatisticsStorage;\n}();\n\nvar StatisticsSender = function () {\n function StatisticsSender(url, logger) {\n classCallCheck(this, StatisticsSender);\n\n this.url = url;\n this.logger = logger;\n }\n\n createClass(StatisticsSender, [{\n key: 'send',\n value: function send(data, errorHandler) {\n var logger = this.logger;\n\n if (navigator.onLine === false) {\n logger.debug(\"Offline, can't send\");\n errorHandler();\n return;\n }\n logger.debug(\"Sending data to \" + this.url);\n\n var req = new XMLHttpRequest();\n req.withCredentials = true;\n req.addEventListener(\"load\", function () {\n // Stats sent, nothing more to do\n logger.debug(\"Response: \" + req.responseText);\n });\n req.addEventListener(\"error\", function () {\n logger.debug(\"Send failed\");\n errorHandler();\n });\n req.addEventListener(\"abort\", function () {\n logger.debug(\"Send aborted\");\n errorHandler();\n });\n req.open(\"POST\", this.url);\n req.setRequestHeader(\"Content-Type\", \"application/json\");\n req.send(data);\n }\n }]);\n return StatisticsSender;\n}();\n\nvar StatisticsLogger = function () {\n function StatisticsLogger(id) {\n classCallCheck(this, StatisticsLogger);\n\n this.id = id;\n }\n\n createClass(StatisticsLogger, [{\n key: '_isDebug',\n value: function _isDebug() {\n return localStorage.getItem(\"vaadin.\" + this.id + \".debug\");\n }\n }, {\n key: 'debug',\n value: function debug(msg) {\n if (this._isDebug()) {\n console.info(this.id + \": \" + msg);\n }\n }\n }]);\n return StatisticsLogger;\n}();\n\nvar UsageStatistics = function () {\n function UsageStatistics() {\n classCallCheck(this, UsageStatistics);\n\n this.now = new Date();\n this.timeNow = this.now.getTime();\n this.gatherDelay = 10; // Delay between loading this file and gathering stats\n this.initialDelay = 24 * 60 * 60;\n\n this.logger = new StatisticsLogger(\"statistics\");\n this.storage = new StatisticsStorage(\"vaadin.statistics.basket\");\n this.gatherer = new StatisticsGatherer(this.logger);\n this.sender = new StatisticsSender(\"https://tools.vaadin.com/usage-stats/submit\", this.logger);\n }\n\n createClass(UsageStatistics, [{\n key: 'maybeGatherAndSend',\n value: function maybeGatherAndSend() {\n var _this = this;\n\n if (localStorage.getItem(UsageStatistics.optOutKey)) {\n return;\n }\n this.gatherer.gather(this.storage);\n setTimeout(function () {\n _this.maybeSend();\n }, this.gatherDelay * 1000);\n }\n }, {\n key: 'lottery',\n value: function lottery() {\n return true;\n }\n }, {\n key: 'currentMonth',\n value: function currentMonth() {\n return this.now.getYear() * 12 + this.now.getMonth();\n }\n }, {\n key: 'maybeSend',\n value: function maybeSend() {\n var firstUse = Number(localStorage.getItem(UsageStatistics.firstUseKey));\n var monthProcessed = Number(localStorage.getItem(UsageStatistics.monthProcessedKey));\n\n if (!firstUse) {\n // Use a grace period to avoid interfering with tests, incognito mode etc\n firstUse = this.timeNow;\n localStorage.setItem(UsageStatistics.firstUseKey, firstUse);\n }\n\n if (this.timeNow < firstUse + this.initialDelay * 1000) {\n this.logger.debug(\"No statistics will be sent until the initial delay of \" + this.initialDelay + \"s has passed\");\n return;\n }\n if (this.currentMonth() <= monthProcessed) {\n this.logger.debug(\"This month has already been processed\");\n return;\n }\n localStorage.setItem(UsageStatistics.monthProcessedKey, this.currentMonth());\n // Use random sampling\n if (this.lottery()) {\n this.logger.debug(\"Congratulations, we have a winner!\");\n } else {\n this.logger.debug(\"Sorry, no stats from you this time\");\n return;\n }\n\n this.send();\n }\n }, {\n key: 'send',\n value: function send() {\n // Ensure we have the latest data\n this.gatherer.gather(this.storage);\n\n // Read, send and clean up\n var data = this.storage.read();\n data[\"firstUse\"] = Number(localStorage.getItem(UsageStatistics.firstUseKey));\n data[\"usageStatisticsVersion\"] = UsageStatistics.version;\n var info = 'This request contains usage statistics gathered from the application running in development mode. \\n\\nStatistics gathering is automatically disabled and excluded from production builds.\\n\\nFor details and to opt-out, see https://github.com/vaadin/vaadin-usage-statistics.\\n\\n\\n\\n';\n var self = this;\n this.sender.send(info + JSON.stringify(data), function () {\n // Revert the 'month processed' flag\n localStorage.setItem(UsageStatistics.monthProcessedKey, self.currentMonth() - 1);\n });\n }\n }], [{\n key: 'version',\n get: function get$1() {\n return '2.1.2';\n }\n }, {\n key: 'firstUseKey',\n get: function get$1() {\n return 'vaadin.statistics.firstuse';\n }\n }, {\n key: 'monthProcessedKey',\n get: function get$1() {\n return 'vaadin.statistics.monthProcessed';\n }\n }, {\n key: 'optOutKey',\n get: function get$1() {\n return 'vaadin.statistics.optout';\n }\n }]);\n return UsageStatistics;\n}();\n\ntry {\n window.Vaadin = window.Vaadin || {};\n window.Vaadin.usageStatsChecker = window.Vaadin.usageStatsChecker || new UsageStatistics();\n window.Vaadin.usageStatsChecker.maybeGatherAndSend();\n} catch (e) {\n // Intentionally ignored as this is not a problem in the app being developed\n}\n\n}());\n\n vaadin-dev-mode:end **/\n}\n\nconst usageStatistics = function() {\n if (typeof runIfDevelopmentMode === 'function') {\n return runIfDevelopmentMode(maybeGatherAndSendStats);\n }\n};\n\nwindow.Vaadin = window.Vaadin || {};\nwindow.Vaadin.registrations = window.Vaadin.registrations || [];\n\nwindow.Vaadin.registrations.push({\n is: '@vaadin/router',\n version: '1.7.4',\n});\n\nusageStatistics();\n\nRouter.NavigationTrigger = {POPSTATE, CLICK};\n\nexport { Resolver, Router };\n//# sourceMappingURL=vaadin-router.js.map\n","import { DevelopmentError } from '../development-error';\r\nimport { Router } from '@vaadin/router';\r\n\r\nexport interface ResolveURLEntry {\r\n type: string;\r\n resolver: (id: string) => string;\r\n}\r\n\r\nconst _resolveList: ResolveURLEntry[] = [];\r\n\r\nexport function addURLResolvers(resolvers: ResolveURLEntry[]) {\r\n _resolveList.push(...resolvers);\r\n}\r\n\r\nexport function resolveURL(type: string, id: string, pageFragment?: string | null): string {\r\n const entry = _resolveList.find(item => item.type === type);\r\n if (!entry) throw new DevelopmentError(`not resolver found for \"${type}\"`);\r\n return pageFragment ? `${entry.resolver(id)}#${pageFragment}` : entry.resolver(id);\r\n}\r\n\r\nexport function goURL(type: string, id: string, pageFragment?: string | null) {\r\n const url = resolveURL(type, id, pageFragment);\r\n Router.go(url);\r\n}\r\n\r\nexport function goStaticURL(url: string) {\r\n Router.go(url);\r\n}\r\n\r\nexport function pageReload() {\r\n window.location.reload();\r\n}\r\n","// Unique ID creation requires a high quality random # generator. In the browser we therefore\n// require the crypto API and do not support built-in fallback to lower quality random number\n// generators (like Math.random()).\nlet getRandomValues;\nconst rnds8 = new Uint8Array(16);\nexport default function rng() {\n // lazy load so that environments that need to polyfill have a chance to do so\n if (!getRandomValues) {\n // getRandomValues needs to be invoked in a context where \"this\" is a Crypto implementation.\n getRandomValues = typeof crypto !== 'undefined' && crypto.getRandomValues && crypto.getRandomValues.bind(crypto);\n\n if (!getRandomValues) {\n throw new Error('crypto.getRandomValues() not supported. See https://github.com/uuidjs/uuid#getrandomvalues-not-supported');\n }\n }\n\n return getRandomValues(rnds8);\n}","import validate from './validate.js';\n/**\n * Convert array of 16 byte values to UUID string format of the form:\n * XXXXXXXX-XXXX-XXXX-XXXX-XXXXXXXXXXXX\n */\n\nconst byteToHex = [];\n\nfor (let i = 0; i < 256; ++i) {\n byteToHex.push((i + 0x100).toString(16).slice(1));\n}\n\nexport function unsafeStringify(arr, offset = 0) {\n // Note: Be careful editing this code! It's been tuned for performance\n // and works in ways you may not expect. See https://github.com/uuidjs/uuid/pull/434\n return byteToHex[arr[offset + 0]] + byteToHex[arr[offset + 1]] + byteToHex[arr[offset + 2]] + byteToHex[arr[offset + 3]] + '-' + byteToHex[arr[offset + 4]] + byteToHex[arr[offset + 5]] + '-' + byteToHex[arr[offset + 6]] + byteToHex[arr[offset + 7]] + '-' + byteToHex[arr[offset + 8]] + byteToHex[arr[offset + 9]] + '-' + byteToHex[arr[offset + 10]] + byteToHex[arr[offset + 11]] + byteToHex[arr[offset + 12]] + byteToHex[arr[offset + 13]] + byteToHex[arr[offset + 14]] + byteToHex[arr[offset + 15]];\n}\n\nfunction stringify(arr, offset = 0) {\n const uuid = unsafeStringify(arr, offset); // Consistency check for valid UUID. If this throws, it's likely due to one\n // of the following:\n // - One or more input array values don't map to a hex octet (leading to\n // \"undefined\" in the uuid)\n // - Invalid input values for the RFC `version` or `variant` fields\n\n if (!validate(uuid)) {\n throw TypeError('Stringified UUID is invalid');\n }\n\n return uuid;\n}\n\nexport default stringify;","const randomUUID = typeof crypto !== 'undefined' && crypto.randomUUID && crypto.randomUUID.bind(crypto);\nexport default {\n randomUUID\n};","import native from './native.js';\nimport rng from './rng.js';\nimport { unsafeStringify } from './stringify.js';\n\nfunction v4(options, buf, offset) {\n if (native.randomUUID && !buf && !options) {\n return native.randomUUID();\n }\n\n options = options || {};\n const rnds = options.random || (options.rng || rng)(); // Per 4.4, set bits for version and `clock_seq_hi_and_reserved`\n\n rnds[6] = rnds[6] & 0x0f | 0x40;\n rnds[8] = rnds[8] & 0x3f | 0x80; // Copy bytes to buffer, if provided\n\n if (buf) {\n offset = offset || 0;\n\n for (let i = 0; i < 16; ++i) {\n buf[offset + i] = rnds[i];\n }\n\n return buf;\n }\n\n return unsafeStringify(rnds);\n}\n\nexport default v4;","import * as uuid from 'uuid';\r\n\r\nexport const emptyGuid = '00000000-0000-0000-0000-000000000000';\r\n\r\nexport const newGuid: () => string =\r\n self.crypto && (self.crypto as any).randomUUID\r\n ? (): string => {\r\n return (self.crypto as any).randomUUID();\r\n }\r\n : (): string => {\r\n return uuid.v4();\r\n };\r\n\r\nexport function guidEquals(a?: string | null, b?: string | null) {\r\n return a?.toLowerCase() === b?.toLowerCase();\r\n}\r\n","import { emptyGuid } from '../api/guid.js';\r\nimport { tlang } from '../language/lang.js';\r\n\r\nexport function validId(value: string | null | undefined): boolean {\r\n return !isEmptyOrSpace(value);\r\n}\r\n\r\nexport function removeDuplicatIds(arr: string[]): string[] {\r\n return [...new Set(arr)];\r\n}\r\n\r\nexport function sameText(a: string | undefined, ...b: (string | undefined)[]): boolean {\r\n for (const item of b) {\r\n if (a?.toLowerCase() === item?.toLowerCase()) return true;\r\n }\r\n return false;\r\n}\r\n\r\nexport function containsText(value: string, searchTerm: string): boolean {\r\n return value.toLocaleLowerCase().includes(searchTerm.toLocaleLowerCase());\r\n}\r\n\r\nexport function sameAs(a: any, ...b: any[]): boolean {\r\n return b.some(item => item === a);\r\n}\r\n\r\nexport function isEmptyOrSpace(value: string | null | undefined): boolean {\r\n return value === null || value === undefined || value.trim() === '' || value.trim() == emptyGuid;\r\n}\r\n\r\nexport function hasContent(value: string | null | undefined): boolean {\r\n return !isEmptyOrSpace(value);\r\n}\r\n\r\nexport function joinWithCommaAnd(array: string[]) {\r\n if (array && array.length > 1) {\r\n const last = array.pop();\r\n return `${array.join(', ')} and ${last}`;\r\n } else {\r\n return array[0] || '';\r\n }\r\n}\r\n\r\nexport function isValidEmail(mail: string): boolean {\r\n return /^\\w+([\\.-]?\\w+)*@\\w+([\\.-]?\\w+)*(\\.\\w{2,3})+$/.test(mail);\r\n}\r\n\r\nexport function concatStrings(\r\n options: {\r\n split?: string;\r\n excludeEmpty?: boolean;\r\n },\r\n ...strings: (string | undefined)[]\r\n): string {\r\n const seperator = options.split ?? '-';\r\n let result = '';\r\n strings.forEach(s => {\r\n if ((options.excludeEmpty ?? true) && isEmptyOrSpace(s)) return;\r\n const part = s ?? '';\r\n result = isEmptyOrSpace(result) ? part : `${result}${seperator}${part}`;\r\n });\r\n return result.trimEnd();\r\n}\r\n\r\nexport function concatNotes(...args) {\r\n return args.filter(str => str && !isEmptyOrSpace(str.toString())).join('\\r\\n----------\\r\\n');\r\n}\r\n\r\nfunction displayBoolean(yes: string, no: string, value?: boolean) {\r\n return value ? yes : no;\r\n}\r\n\r\nexport function displayYesNo(value?: boolean) {\r\n return displayBoolean(tlang`Yes`, tlang`No`, value);\r\n}\r\n\r\nexport function bsFormRadioGroupYesNoOptions() {\r\n return [\r\n { value: 'Yes', text: 'Yes' },\r\n { value: 'No', text: 'No' }\r\n ];\r\n}\r\n\r\nexport function firstValidString(...args) {\r\n for (let i = 0; i < args.length; i++) if (!isEmptyOrSpace(args[i])) return args[i];\r\n return '';\r\n}\r\n\r\nexport function flagInSet(flag: number, flagSet: number): boolean {\r\n // eslint-disable-next-line no-bitwise\r\n return (flag & flagSet) !== 0;\r\n}\r\n\r\nexport function isFlagInFilterSet(flag: number, flagSet?: number | null): boolean {\r\n return flagSet === undefined || flagSet === null || flagInSet(flag, flagSet);\r\n}\r\n\r\nexport function getInitials(fullName: string): string {\r\n // Split the full name into individual words, excluding extra spaces\r\n const nameParts = fullName.trim().split(/\\s+/);\r\n\r\n if (nameParts.length === 1) {\r\n // For single-word names, return the first initial\r\n return nameParts[0].charAt(0).toUpperCase();\r\n }\r\n\r\n // For multi-word names, use the first letter of the first and last name parts\r\n return nameParts[0].charAt(0).toUpperCase() + nameParts[nameParts.length - 1].charAt(0).toUpperCase();\r\n}\r\n\r\n/**\r\n * NOTE: This is a work-around what appears to be a bug in Chrome :https://bugs.chromium.org/p/chromium/issues/detail?id=920069\r\n */\r\nexport function getOffset(element: HTMLElement, parent: HTMLElement) {\r\n return {\r\n top: Math.round(element.getBoundingClientRect().top - parent.getBoundingClientRect().top),\r\n left: Math.round(element.getBoundingClientRect().left - parent.getBoundingClientRect().left)\r\n };\r\n}\r\n\r\n/*\r\n(function () {\r\n let prefix: string | undefined = undefined;\r\n let main: string | undefined = 'test';\r\n let suffix: string | undefined = undefined;\r\n console.log(concatStrings({ split: ' - ', excludeEmpty: true }, prefix, main, suffix));\r\n prefix = 'AAA';\r\n main = 'test';\r\n suffix = undefined;\r\n console.log(concatStrings({ split: ' - ', excludeEmpty: true }, prefix, main, suffix));\r\n prefix = 'AAA';\r\n main = 'test';\r\n suffix = 'BBB';\r\n console.log(concatStrings({ split: ' - ', excludeEmpty: true }, prefix, main, suffix));\r\n prefix = 'AAA';\r\n main = undefined;\r\n suffix = 'BBB';\r\n console.log(concatStrings({ split: ' - ', excludeEmpty: true }, prefix, main, suffix));\r\n})();\r\n*/\r\n","import { pageReload } from './ui/resource-resolver';\r\nimport { sameText } from './ui/string-helper-functions';\r\n\r\n// eslint-disable-next-line no-var -- var declared as it is replaced by\r\n\r\nlet usedebugv6 = 'false';\r\nlet isv6Debugging = usedebugv6 == 'true';\r\nlet localBuildNumber = '';\r\nlet isDebugging = sameText('local', localBuildNumber);\r\n\r\nexport function setDebugInformation(alocalBuildNumber: string, localDebugV6: string) {\r\n usedebugv6 = localDebugV6;\r\n isv6Debugging = usedebugv6 == 'true';\r\n localBuildNumber = alocalBuildNumber;\r\n isDebugging = sameText('local', localBuildNumber);\r\n globalThis.localBuildNumber = localBuildNumber;\r\n}\r\n\r\nexport function isDebugMode(): boolean {\r\n return isDebugging;\r\n}\r\n\r\nexport function isv6DebugMode(): boolean {\r\n return isv6Debugging;\r\n}\r\n\r\nexport function getLocalBuildNumber(): string {\r\n return localBuildNumber;\r\n}\r\n\r\nlet debugOutofdate = false;\r\n\r\nexport function isDebugForcedOutOfDate(): boolean {\r\n return debugOutofdate;\r\n}\r\n\r\nexport function appOutOfDate(buildNumber?: string): boolean {\r\n if (debugOutofdate) {\r\n return true;\r\n }\r\n return (\r\n !sameText(getLocalBuildNumber(), buildNumber ?? globalThis.dealerConfiguration?.apiBuildNumberDisplay) &&\r\n !isDebugMode()\r\n );\r\n}\r\n\r\nexport function getServerBuildNumberDisplay() {\r\n return globalThis.dealerConfiguration?.apiBuildNumberDisplay ?? '';\r\n}\r\n\r\nexport async function checkAppOutOfDate() {\r\n await globalThis.dealerRefreshApiDetails?.();\r\n}\r\n\r\nexport const outOfDateURL = '/outofdate';\r\nglobalThis.forceOutOfDate = (value = true, reRoute = true) => {\r\n debugOutofdate = value;\r\n if (reRoute) pageReload();\r\n};\r\n\r\nglobalThis.isAppOutOfDate = (buildNumber?: string) => {\r\n return appOutOfDate(buildNumber);\r\n};\r\n","//this should be a generic unit. unbound from routes. routes is an implementation specific\r\n\r\nimport { Router } from '@vaadin/router';\r\nimport type { Params, Route } from '@vaadin/router';\r\n\r\nglobalThis.__vaadinRouter = globalThis.__vaadinRouter ?? new Router();\r\nexport const router = globalThis.__vaadinRouter;\r\n\r\nexport function setRoutes(routes: Route[]) {\r\n router.setRoutes([\r\n // Redirect to URL without trailing slash\r\n {\r\n path: '(.*)/',\r\n action: (context, commands) => {\r\n const newPath = context.pathname.slice(0, -1);\r\n return commands.redirect(newPath);\r\n }\r\n },\r\n ...routes\r\n ]);\r\n}\r\nexport const attachRouter = (outlet: HTMLElement) => {\r\n router.setOutlet(outlet);\r\n};\r\n\r\nexport const urlForName = (name: string, params?: Params) => {\r\n return router.urlForName(name, params);\r\n};\r\n","import { LitElement, PropertyValues } from 'lit';\r\nimport { PreventAndRedirectCommands, PreventCommands, Router, RouterLocation } from '@vaadin/router';\r\nimport { property, state } from 'lit/decorators.js';\r\nimport { MetaOptions, updateMeta } from './meta-manager';\r\nimport { appOutOfDate, outOfDateURL } from '../../debug';\r\nimport {\r\n addCurrentUserEventListener,\r\n CurrentUserStateNotifier,\r\n getCurrentUser,\r\n removeCurrentUserEventListener,\r\n UserPublicInfo\r\n} from '../../api/current-user';\r\nimport { IDispose } from '../../dispose';\r\nimport { router } from '../../router';\r\nimport { NullPromise } from '../events';\r\n\r\nexport interface IPageController {\r\n pagesCanClose: () => Promise;\r\n\r\n disposeAndRefresh();\r\n\r\n disposeAll();\r\n}\r\n\r\ninterface IPageRefresh {\r\n disposeAndRefresh: () => Promise;\r\n dispose: () => Promise;\r\n pageCanClose: () => Promise;\r\n}\r\n\r\nclass PageController implements IPageController {\r\n pages: IPageRefresh[] = [];\r\n\r\n addPage(page: IPageRefresh) {\r\n if (!this.pages.find(x => x == page)) this.pages.push(page);\r\n }\r\n\r\n remPage(page: IPageRefresh) {\r\n this.pages = this.pages.filter(x => x !== page);\r\n }\r\n\r\n async disposeAndRefresh() {\r\n for (let i = 0; i < this.pages.length; i++) await this.pages[i].disposeAndRefresh();\r\n }\r\n\r\n async disposeAll() {\r\n for (let i = 0; i < this.pages.length; i++) await this.pages[i].dispose();\r\n }\r\n\r\n async pagesCanClose(): Promise {\r\n let canClose = true;\r\n for (let i = 0; i < this.pages.length; i++) canClose = (await this.pages[i].pageCanClose()) && canClose;\r\n return canClose;\r\n }\r\n}\r\n\r\nconst pageController = new PageController();\r\n\r\nexport function getPageController(): IPageController {\r\n return pageController;\r\n //allow refreshing\r\n}\r\n\r\nexport class PageBaseInternal extends LitElement implements CurrentUserStateNotifier, IPageRefresh, IDispose {\r\n @property({ type: Object })\r\n protected location = router.location;\r\n @state()\r\n protected loggedIn = false;\r\n protected defaultTitleTemplate = `%s | Dealer Module`;\r\n\r\n protected get defaultMeta() {\r\n return {\r\n url: window.location.href,\r\n titleTemplate: this.defaultTitleTemplate\r\n };\r\n }\r\n\r\n async onBeforeEnter(_location: RouterLocation, commands: PreventAndRedirectCommands, _router: Router): Promise {\r\n this.loggedIn = getCurrentUser() !== null;\r\n if (appOutOfDate() && this.divertToOutOfDate()) {\r\n window.location.reload();\r\n return commands.redirect(outOfDateURL);\r\n }\r\n if (!this.loggedIn && this.divertToLogin()) {\r\n return commands.redirect('/login');\r\n }\r\n\r\n const allowEnter = await this.allowEnter();\r\n if (!allowEnter) {\r\n const r = await this.redirectPath();\r\n if (r) return commands.redirect(r);\r\n return commands.prevent();\r\n }\r\n pageController.addPage(this);\r\n }\r\n\r\n async redirectPath(): NullPromise {\r\n return null;\r\n }\r\n\r\n async pageCanClose(): Promise {\r\n if (this.loggedIn) return await this.canLeavePage();\r\n return true;\r\n }\r\n\r\n async onBeforeLeave(_location: RouterLocation, commands: PreventCommands, _router: Router) {\r\n if (appOutOfDate()) return true;\r\n if (this.loggedIn)\r\n if (!(await this.canLeavePage())) {\r\n //if not logged in, we cant do anything, we are trying to exit cleanly\r\n return commands.prevent();\r\n }\r\n pageController.remPage(this);\r\n return true;\r\n }\r\n\r\n public async onAfterEnter(\r\n _location: RouterLocation,\r\n _commands: PreventAndRedirectCommands,\r\n _router: Router\r\n ): Promise {\r\n const event = new CustomEvent('webmodule-page-navigation', {\r\n bubbles: true,\r\n composed: true,\r\n detail: { name: _location.route?.name, path: _location.route?.path }\r\n });\r\n this.dispatchEvent(event);\r\n await this.awaken();\r\n }\r\n\r\n public async onAfterLeave(\r\n _location: RouterLocation,\r\n _commands: PreventAndRedirectCommands,\r\n _router: Router\r\n ): Promise {\r\n if (this.loggedIn) {\r\n //if we are not logged in, then anything we do here is probably going to fail as we are doing a page reload.\r\n await this.dispose();\r\n }\r\n }\r\n\r\n public async disposeAndRefresh() {\r\n await this.dispose();\r\n await this.afterUserConnected();\r\n }\r\n\r\n public async dispose() {\r\n //do shutdown stuff\r\n }\r\n\r\n async userReset() {\r\n await this.dispose();\r\n }\r\n\r\n async loadUserCoreDetails() {\r\n throw new Error('loadUserCoreDetails');\r\n }\r\n\r\n async userStateChanged(user: UserPublicInfo | null): Promise {\r\n if (appOutOfDate()) return;\r\n this.loggedIn = user !== null;\r\n if (user !== null) {\r\n await this.loadUserCoreDetails();\r\n\r\n await this.afterUserConnected();\r\n } else {\r\n await this.userReset();\r\n }\r\n this.requestUpdate();\r\n }\r\n\r\n connectedCallback(): void {\r\n super.connectedCallback();\r\n this.addEventListener('ui-changed', this.eventChildUIChanged);\r\n addCurrentUserEventListener(this);\r\n }\r\n\r\n disconnectedCallback(): void {\r\n super.disconnectedCallback();\r\n this.removeEventListener('ui-changed', this.eventChildUIChanged);\r\n removeCurrentUserEventListener(this);\r\n }\r\n\r\n updated(changedProperties: PropertyValues) {\r\n super.updated(changedProperties);\r\n\r\n const meta = this.meta();\r\n\r\n if (meta) {\r\n updateMeta({\r\n ...this.defaultMeta,\r\n ...((meta.titleTemplate || meta.titleTemplate === null) && {\r\n titleTemplate: meta.titleTemplate\r\n }),\r\n ...meta\r\n });\r\n }\r\n }\r\n\r\n protected createRenderRoot(): HTMLElement | DocumentFragment {\r\n return this;\r\n }\r\n\r\n protected divertToLogin(): boolean {\r\n return true;\r\n }\r\n\r\n protected divertToOutOfDate(): boolean {\r\n return true;\r\n }\r\n\r\n /***\r\n * overriding this can be used as a preconstruction technique that can fail if for some reason the page\r\n * cannot be accessed.. or redirected.\r\n */\r\n protected async allowEnter(): Promise {\r\n return true;\r\n }\r\n\r\n protected async canLeavePage(): Promise {\r\n return true;\r\n }\r\n\r\n protected async awaken() {\r\n //do stuff as preload.\r\n }\r\n\r\n /**\r\n * The page must override this method to customize the meta\r\n */\r\n protected meta(): MetaOptions | undefined {\r\n return;\r\n }\r\n\r\n protected async afterUserConnected() {\r\n //\r\n }\r\n\r\n protected eventChildUIChanged = (_e: Event) => this.requestUpdate();\r\n}\r\n","import { PageBaseInternal } from '../../../../webmodule-common/other/ui/pages/page-base';\r\n\r\nexport class PageBase extends PageBaseInternal {\r\n protected defaultTitleTemplate = `%s | License Server Module`;\r\n\r\n async loadUserCoreDetails() {\r\n //no details\r\n }\r\n}\r\n","/* eslint-disable */\r\n\r\n/**\r\n * @license\r\n * Copyright 2017 Google LLC\r\n * SPDX-License-Identifier: BSD-3-Clause\r\n *\r\n * ADAPTED TO TRY AND REGISTER A COMPONENT TO EXCLUDE DUPLICATES\r\n */\r\n\r\n/*\r\n * IMPORTANT: For compatibility with tsickle and the Closure JS compiler, all\r\n * property decorators (but not class decorators) in this file that have\r\n * an @ExportDecoratedItems annotation must be defined as a regular function,\r\n * not an arrow function.\r\n */\r\n\r\n/**\r\n * Allow for custom element classes with private constructors\r\n */\r\ntype CustomElementClass = Omit;\r\n\r\nconst legacyCustomElement = (tagName: string, clazz: CustomElementClass) => {\r\n try {\r\n customElements.define(tagName, clazz as CustomElementConstructor);\r\n } catch (e) {\r\n console.log(e);\r\n }\r\n // Cast as any because TS doesn't recognize the return type as being a\r\n // subtype of the decorated class when clazz is typed as\r\n // `Constructor` for some reason.\r\n // `Constructor` is helpful to make sure the decorator is\r\n // applied to elements however.\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n return clazz as any;\r\n};\r\n\r\ntype Constructor = {\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n new (...args: any[]): T;\r\n};\r\n\r\ninterface ClassElement {\r\n kind: 'field' | 'method';\r\n key: PropertyKey;\r\n placement: 'static' | 'prototype' | 'own';\r\n initializer?: Function;\r\n extras?: ClassElement[];\r\n finisher?: (clazz: Constructor) => void | Constructor;\r\n descriptor?: PropertyDescriptor;\r\n}\r\n\r\n// From the TC39 Decorators proposal\r\ninterface ClassDescriptor {\r\n kind: 'class';\r\n elements: ClassElement[];\r\n finisher?: (clazz: Constructor) => void | Constructor;\r\n}\r\n\r\nconst standardCustomElement = (tagName: string, descriptor: ClassDescriptor) => {\r\n const { kind, elements } = descriptor;\r\n\r\n return {\r\n kind,\r\n elements,\r\n // This callback is called once the class is otherwise fully defined\r\n finisher(clazz: Constructor) {\r\n try {\r\n customElements.define(tagName, clazz);\r\n } catch (e) {\r\n console.log(e);\r\n }\r\n }\r\n };\r\n};\r\n\r\n/**\r\n * Class decorator factory that defines the decorated class as a custom element.\r\n *\r\n * ```js\r\n * @customElementTry('my-element')\r\n * class MyElement extends LitElement {\r\n * render() {\r\n * return html``;\r\n * }\r\n * }\r\n * ```\r\n * @category Decorator\r\n * @param tagName The tag name of the custom element to define.\r\n */\r\nexport const customElementTry = (tagName: string) => (classOrDescriptor: CustomElementClass | ClassDescriptor) => {\r\n return typeof classOrDescriptor === 'function'\r\n ? legacyCustomElement(tagName, classOrDescriptor)\r\n : standardCustomElement(tagName, classOrDescriptor as ClassDescriptor);\r\n};\r\n\r\nexport const autoElement = () => (classOrDescriptor: CustomElementClass | ClassDescriptor) => {\r\n if (typeof classOrDescriptor === 'function') {\r\n const classname = (classOrDescriptor as Function).name;\r\n return legacyCustomElement(`wm-${classname.toLowerCase()}`, classOrDescriptor);\r\n } else {\r\n return standardCustomElement('', classOrDescriptor as ClassDescriptor);\r\n } //\r\n};\r\n","/**\n * @license\n * Copyright 2019 Google LLC\n * SPDX-License-Identifier: BSD-3-Clause\n */\nconst t=globalThis,e=t.ShadowRoot&&(void 0===t.ShadyCSS||t.ShadyCSS.nativeShadow)&&\"adoptedStyleSheets\"in Document.prototype&&\"replace\"in CSSStyleSheet.prototype,s=Symbol(),o=new WeakMap;class n{constructor(t,e,o){if(this._$cssResult$=!0,o!==s)throw Error(\"CSSResult is not constructable. Use `unsafeCSS` or `css` instead.\");this.cssText=t,this.t=e}get styleSheet(){let t=this.o;const s=this.t;if(e&&void 0===t){const e=void 0!==s&&1===s.length;e&&(t=o.get(s)),void 0===t&&((this.o=t=new CSSStyleSheet).replaceSync(this.cssText),e&&o.set(s,t))}return t}toString(){return this.cssText}}const r=t=>new n(\"string\"==typeof t?t:t+\"\",void 0,s),i=(t,...e)=>{const o=1===t.length?t[0]:e.reduce(((e,s,o)=>e+(t=>{if(!0===t._$cssResult$)return t.cssText;if(\"number\"==typeof t)return t;throw Error(\"Value passed to 'css' function must be a 'css' function result: \"+t+\". Use 'unsafeCSS' to pass non-literal values, but take care to ensure page security.\")})(s)+t[o+1]),t[0]);return new n(o,t,s)},S=(s,o)=>{if(e)s.adoptedStyleSheets=o.map((t=>t instanceof CSSStyleSheet?t:t.styleSheet));else for(const e of o){const o=document.createElement(\"style\"),n=t.litNonce;void 0!==n&&o.setAttribute(\"nonce\",n),o.textContent=e.cssText,s.appendChild(o)}},c=e?t=>t:t=>t instanceof CSSStyleSheet?(t=>{let e=\"\";for(const s of t.cssRules)e+=s.cssText;return r(e)})(t):t;export{n as CSSResult,S as adoptStyles,i as css,c as getCompatibleStyle,e as supportsAdoptingStyleSheets,r as unsafeCSS};\n//# sourceMappingURL=css-tag.js.map\n","import{getCompatibleStyle as t,adoptStyles as s}from\"./css-tag.js\";export{CSSResult,adoptStyles,css,getCompatibleStyle,supportsAdoptingStyleSheets,unsafeCSS}from\"./css-tag.js\";\n/**\n * @license\n * Copyright 2017 Google LLC\n * SPDX-License-Identifier: BSD-3-Clause\n */const{is:i,defineProperty:e,getOwnPropertyDescriptor:r,getOwnPropertyNames:h,getOwnPropertySymbols:o,getPrototypeOf:n}=Object,a=globalThis,c=a.trustedTypes,l=c?c.emptyScript:\"\",p=a.reactiveElementPolyfillSupport,d=(t,s)=>t,u={toAttribute(t,s){switch(s){case Boolean:t=t?l:null;break;case Object:case Array:t=null==t?t:JSON.stringify(t)}return t},fromAttribute(t,s){let i=t;switch(s){case Boolean:i=null!==t;break;case Number:i=null===t?null:Number(t);break;case Object:case Array:try{i=JSON.parse(t)}catch(t){i=null}}return i}},f=(t,s)=>!i(t,s),y={attribute:!0,type:String,converter:u,reflect:!1,hasChanged:f};Symbol.metadata??=Symbol(\"metadata\"),a.litPropertyMetadata??=new WeakMap;class b extends HTMLElement{static addInitializer(t){this._$Ei(),(this.l??=[]).push(t)}static get observedAttributes(){return this.finalize(),this._$Eh&&[...this._$Eh.keys()]}static createProperty(t,s=y){if(s.state&&(s.attribute=!1),this._$Ei(),this.elementProperties.set(t,s),!s.noAccessor){const i=Symbol(),r=this.getPropertyDescriptor(t,i,s);void 0!==r&&e(this.prototype,t,r)}}static getPropertyDescriptor(t,s,i){const{get:e,set:h}=r(this.prototype,t)??{get(){return this[s]},set(t){this[s]=t}};return{get(){return e?.call(this)},set(s){const r=e?.call(this);h.call(this,s),this.requestUpdate(t,r,i)},configurable:!0,enumerable:!0}}static getPropertyOptions(t){return this.elementProperties.get(t)??y}static _$Ei(){if(this.hasOwnProperty(d(\"elementProperties\")))return;const t=n(this);t.finalize(),void 0!==t.l&&(this.l=[...t.l]),this.elementProperties=new Map(t.elementProperties)}static finalize(){if(this.hasOwnProperty(d(\"finalized\")))return;if(this.finalized=!0,this._$Ei(),this.hasOwnProperty(d(\"properties\"))){const t=this.properties,s=[...h(t),...o(t)];for(const i of s)this.createProperty(i,t[i])}const t=this[Symbol.metadata];if(null!==t){const s=litPropertyMetadata.get(t);if(void 0!==s)for(const[t,i]of s)this.elementProperties.set(t,i)}this._$Eh=new Map;for(const[t,s]of this.elementProperties){const i=this._$Eu(t,s);void 0!==i&&this._$Eh.set(i,t)}this.elementStyles=this.finalizeStyles(this.styles)}static finalizeStyles(s){const i=[];if(Array.isArray(s)){const e=new Set(s.flat(1/0).reverse());for(const s of e)i.unshift(t(s))}else void 0!==s&&i.push(t(s));return i}static _$Eu(t,s){const i=s.attribute;return!1===i?void 0:\"string\"==typeof i?i:\"string\"==typeof t?t.toLowerCase():void 0}constructor(){super(),this._$Ep=void 0,this.isUpdatePending=!1,this.hasUpdated=!1,this._$Em=null,this._$Ev()}_$Ev(){this._$ES=new Promise((t=>this.enableUpdating=t)),this._$AL=new Map,this._$E_(),this.requestUpdate(),this.constructor.l?.forEach((t=>t(this)))}addController(t){(this._$EO??=new Set).add(t),void 0!==this.renderRoot&&this.isConnected&&t.hostConnected?.()}removeController(t){this._$EO?.delete(t)}_$E_(){const t=new Map,s=this.constructor.elementProperties;for(const i of s.keys())this.hasOwnProperty(i)&&(t.set(i,this[i]),delete this[i]);t.size>0&&(this._$Ep=t)}createRenderRoot(){const t=this.shadowRoot??this.attachShadow(this.constructor.shadowRootOptions);return s(t,this.constructor.elementStyles),t}connectedCallback(){this.renderRoot??=this.createRenderRoot(),this.enableUpdating(!0),this._$EO?.forEach((t=>t.hostConnected?.()))}enableUpdating(t){}disconnectedCallback(){this._$EO?.forEach((t=>t.hostDisconnected?.()))}attributeChangedCallback(t,s,i){this._$AK(t,i)}_$EC(t,s){const i=this.constructor.elementProperties.get(t),e=this.constructor._$Eu(t,i);if(void 0!==e&&!0===i.reflect){const r=(void 0!==i.converter?.toAttribute?i.converter:u).toAttribute(s,i.type);this._$Em=t,null==r?this.removeAttribute(e):this.setAttribute(e,r),this._$Em=null}}_$AK(t,s){const i=this.constructor,e=i._$Eh.get(t);if(void 0!==e&&this._$Em!==e){const t=i.getPropertyOptions(e),r=\"function\"==typeof t.converter?{fromAttribute:t.converter}:void 0!==t.converter?.fromAttribute?t.converter:u;this._$Em=e,this[e]=r.fromAttribute(s,t.type),this._$Em=null}}requestUpdate(t,s,i){if(void 0!==t){if(i??=this.constructor.getPropertyOptions(t),!(i.hasChanged??f)(this[t],s))return;this.P(t,s,i)}!1===this.isUpdatePending&&(this._$ES=this._$ET())}P(t,s,i){this._$AL.has(t)||this._$AL.set(t,s),!0===i.reflect&&this._$Em!==t&&(this._$Ej??=new Set).add(t)}async _$ET(){this.isUpdatePending=!0;try{await this._$ES}catch(t){Promise.reject(t)}const t=this.scheduleUpdate();return null!=t&&await t,!this.isUpdatePending}scheduleUpdate(){return this.performUpdate()}performUpdate(){if(!this.isUpdatePending)return;if(!this.hasUpdated){if(this.renderRoot??=this.createRenderRoot(),this._$Ep){for(const[t,s]of this._$Ep)this[t]=s;this._$Ep=void 0}const t=this.constructor.elementProperties;if(t.size>0)for(const[s,i]of t)!0!==i.wrapped||this._$AL.has(s)||void 0===this[s]||this.P(s,this[s],i)}let t=!1;const s=this._$AL;try{t=this.shouldUpdate(s),t?(this.willUpdate(s),this._$EO?.forEach((t=>t.hostUpdate?.())),this.update(s)):this._$EU()}catch(s){throw t=!1,this._$EU(),s}t&&this._$AE(s)}willUpdate(t){}_$AE(t){this._$EO?.forEach((t=>t.hostUpdated?.())),this.hasUpdated||(this.hasUpdated=!0,this.firstUpdated(t)),this.updated(t)}_$EU(){this._$AL=new Map,this.isUpdatePending=!1}get updateComplete(){return this.getUpdateComplete()}getUpdateComplete(){return this._$ES}shouldUpdate(t){return!0}update(t){this._$Ej&&=this._$Ej.forEach((t=>this._$EC(t,this[t]))),this._$EU()}updated(t){}firstUpdated(t){}}b.elementStyles=[],b.shadowRootOptions={mode:\"open\"},b[d(\"elementProperties\")]=new Map,b[d(\"finalized\")]=new Map,p?.({ReactiveElement:b}),(a.reactiveElementVersions??=[]).push(\"2.0.4\");export{b as ReactiveElement,u as defaultConverter,f as notEqual};\n//# sourceMappingURL=reactive-element.js.map\n","/**\n * @license\n * Copyright 2017 Google LLC\n * SPDX-License-Identifier: BSD-3-Clause\n */\nconst n=globalThis,c=n.trustedTypes,h=c?c.createPolicy(\"lit-html\",{createHTML:t=>t}):void 0,f=\"$lit$\",v=`lit$${Math.random().toFixed(9).slice(2)}$`,m=\"?\"+v,_=`<${m}>`,w=document,lt=()=>w.createComment(\"\"),st=t=>null===t||\"object\"!=typeof t&&\"function\"!=typeof t,g=Array.isArray,$=t=>g(t)||\"function\"==typeof t?.[Symbol.iterator],x=\"[ \\t\\n\\f\\r]\",T=/<(?:(!--|\\/[^a-zA-Z])|(\\/?[a-zA-Z][^>\\s]*)|(\\/?$))/g,E=/-->/g,k=/>/g,O=RegExp(`>|${x}(?:([^\\\\s\"'>=/]+)(${x}*=${x}*(?:[^ \\t\\n\\f\\r\"'\\`<>=]|(\"|')|))|$)`,\"g\"),S=/'/g,j=/\"/g,M=/^(?:script|style|textarea|title)$/i,P=t=>(i,...s)=>({_$litType$:t,strings:i,values:s}),ke=P(1),Oe=P(2),Se=P(3),R=Symbol.for(\"lit-noChange\"),D=Symbol.for(\"lit-nothing\"),V=new WeakMap,I=w.createTreeWalker(w,129);function N(t,i){if(!g(t)||!t.hasOwnProperty(\"raw\"))throw Error(\"invalid template strings array\");return void 0!==h?h.createHTML(i):i}const U=(t,i)=>{const s=t.length-1,e=[];let h,o=2===i?\"\":3===i?\"\":\"\",n=T;for(let i=0;i\"===l[0]?(n=h??T,c=-1):void 0===l[1]?c=-2:(c=n.lastIndex-l[2].length,r=l[1],n=void 0===l[3]?O:'\"'===l[3]?j:S):n===j||n===S?n=O:n===E||n===k?n=T:(n=O,h=void 0);const u=n===O&&t[i+1].startsWith(\"/>\")?\" \":\"\";o+=n===T?s+_:c>=0?(e.push(r),s.slice(0,c)+f+s.slice(c)+v+u):s+v+(-2===c?i:u)}return[N(t,o+(t[s]||\"\")+(2===i?\"\":3===i?\"\":\"\")),e]};class B{constructor({strings:t,_$litType$:i},s){let e;this.parts=[];let h=0,o=0;const n=t.length-1,r=this.parts,[l,a]=U(t,i);if(this.el=B.createElement(l,s),I.currentNode=this.el.content,2===i||3===i){const t=this.el.content.firstChild;t.replaceWith(...t.childNodes)}for(;null!==(e=I.nextNode())&&r.length0){e.textContent=c?c.emptyScript:\"\";for(let s=0;s2||\"\"!==s[0]||\"\"!==s[1]?(this._$AH=Array(s.length-1).fill(new String),this.strings=s):this._$AH=D}_$AI(t,i=this,s,e){const h=this.strings;let o=!1;if(void 0===h)t=z(this,t,i,0),o=!st(t)||t!==this._$AH&&t!==R,o&&(this._$AH=t);else{const e=t;let n,r;for(t=h[0],n=0;n{const e=s?.renderBefore??i;let h=e._$litPart$;if(void 0===h){const t=s?.renderBefore??null;e._$litPart$=h=new et(i.insertBefore(lt(),t),t,void 0,s??{})}return h._$AI(t),h};export{si as _$LH,ke as html,Se as mathml,R as noChange,D as nothing,Q as render,Oe as svg};\n//# sourceMappingURL=lit-html.js.map\n","import{ReactiveElement as e}from\"@lit/reactive-element\";export*from\"@lit/reactive-element\";import{render as n,noChange as l}from\"lit-html\";export*from\"lit-html\";\n/**\n * @license\n * Copyright 2017 Google LLC\n * SPDX-License-Identifier: BSD-3-Clause\n */class h extends e{constructor(){super(...arguments),this.renderOptions={host:this},this.o=void 0}createRenderRoot(){const t=super.createRenderRoot();return this.renderOptions.renderBefore??=t.firstChild,t}update(t){const e=this.render();this.hasUpdated||(this.renderOptions.isConnected=this.isConnected),super.update(t),this.o=n(e,this.renderRoot,this.renderOptions)}connectedCallback(){super.connectedCallback(),this.o?.setConnected(!0)}disconnectedCallback(){super.disconnectedCallback(),this.o?.setConnected(!1)}render(){return l}}h._$litElement$=!0,h[\"finalized\"]=!0,globalThis.litElementHydrateSupport?.({LitElement:h});const f=globalThis.litElementPolyfillSupport;f?.({LitElement:h});const x={_$AK:(t,e,s)=>{t._$AK(e,s)},_$AL:t=>t._$AL};(globalThis.litElementVersions??=[]).push(\"4.1.0\");export{h as LitElement,x as _$LE};\n//# sourceMappingURL=lit-element.js.map\n","import type { ReactiveElement } from 'lit';\r\n\r\ninterface MonitorOptions {\r\n delayMonitorUntilFirstUpdate?: boolean;\r\n}\r\n\r\ninterface Observer {\r\n method: (...args: unknown[]) => void;\r\n keys: PropertyKey[];\r\n options: MonitorOptions;\r\n}\r\n\r\nexport const observersForClass = new WeakMap<\r\n // eslint-disable-next-line @typescript-eslint/ban-types\r\n Function,\r\n Observer[]\r\n>();\r\n\r\nexport function monitor(properties: keyof T | (keyof T)[], monitorOptions?: MonitorOptions) {\r\n const options: Required = {\r\n delayMonitorUntilFirstUpdate: false,\r\n ...monitorOptions\r\n };\r\n\r\n const monitoredProperties = Array.isArray(properties) ? properties : [properties];\r\n\r\n return function (\r\n target: T,\r\n _propertyKey: string | symbol,\r\n descriptor: TypedPropertyDescriptor<(...args: unknown[]) => void>\r\n ) {\r\n let observers = observersForClass.get(target.constructor);\r\n if (observers === undefined) {\r\n observersForClass.set(target.constructor, (observers = []));\r\n }\r\n observers.push({ keys: monitoredProperties, method: descriptor.value!, options });\r\n };\r\n}\r\n","import{defaultConverter as t,notEqual as e}from\"../reactive-element.js\";\n/**\n * @license\n * Copyright 2017 Google LLC\n * SPDX-License-Identifier: BSD-3-Clause\n */const o={attribute:!0,type:String,converter:t,reflect:!1,hasChanged:e},r=(t=o,e,r)=>{const{kind:n,metadata:i}=r;let s=globalThis.litPropertyMetadata.get(i);if(void 0===s&&globalThis.litPropertyMetadata.set(i,s=new Map),s.set(r.name,t),\"accessor\"===n){const{name:o}=r;return{set(r){const n=e.get.call(this);e.set.call(this,r),this.requestUpdate(o,n,t)},init(e){return void 0!==e&&this.P(o,void 0,t),e}}}if(\"setter\"===n){const{name:o}=r;return function(r){const n=this[o];e.call(this,r),this.requestUpdate(o,n,t)}}throw Error(\"Unsupported decorator location: \"+n)};function n(t){return(e,o)=>\"object\"==typeof o?r(t,e,o):((t,e,o)=>{const r=e.hasOwnProperty(o);return e.constructor.createProperty(o,r?{...t,wrapped:!0}:t),r?Object.getOwnPropertyDescriptor(e,o):void 0})(t,e,o)}export{n as property,r as standardProperty};\n//# sourceMappingURL=property.js.map\n","import{property as t}from\"./property.js\";\n/**\n * @license\n * Copyright 2017 Google LLC\n * SPDX-License-Identifier: BSD-3-Clause\n */function r(r){return t({...r,state:!0,attribute:!1})}export{r as state};\n//# sourceMappingURL=state.js.map\n","/**\n * @license\n * Copyright 2017 Google LLC\n * SPDX-License-Identifier: BSD-3-Clause\n */\nconst e=(e,t,c)=>(c.configurable=!0,c.enumerable=!0,Reflect.decorate&&\"object\"!=typeof t&&Object.defineProperty(e,t,c),c);export{e as desc};\n//# sourceMappingURL=base.js.map\n","import{desc as t}from\"./base.js\";\n/**\n * @license\n * Copyright 2017 Google LLC\n * SPDX-License-Identifier: BSD-3-Clause\n */function e(e,r){return(n,s,i)=>{const o=t=>t.renderRoot?.querySelector(e)??null;if(r){const{get:e,set:r}=\"object\"==typeof s?n:i??(()=>{const t=Symbol();return{get(){return this[t]},set(e){this[t]=e}}})();return t(n,s,{get(){let t=e.call(this);return void 0===t&&(t=o(this),(null!==t||this.hasUpdated)&&r.call(this,t)),t}})}return t(n,s,{get(){return o(this)}})}}export{e as query};\n//# sourceMappingURL=query.js.map\n","/**\n * @license\n * Copyright 2017 Google LLC\n * SPDX-License-Identifier: BSD-3-Clause\n */\nconst t={ATTRIBUTE:1,CHILD:2,PROPERTY:3,BOOLEAN_ATTRIBUTE:4,EVENT:5,ELEMENT:6},e=t=>(...e)=>({_$litDirective$:t,values:e});class i{constructor(t){}get _$AU(){return this._$AM._$AU}_$AT(t,e,i){this.t=t,this._$AM=e,this.i=i}_$AS(t,e){return this.update(t,e)}update(t,e){return this.render(...e)}}export{i as Directive,t as PartType,e as directive};\n//# sourceMappingURL=directive.js.map\n","import{noChange as R}from\"../lit-html.js\";import{directive as e,Directive as i,PartType as t}from\"../directive.js\";\n/**\n * @license\n * Copyright 2018 Google LLC\n * SPDX-License-Identifier: BSD-3-Clause\n */const ee=\"important\",ie=\" !\"+ee,se=e(class extends i{constructor(e){if(super(e),e.type!==t.ATTRIBUTE||\"style\"!==e.name||e.strings?.length>2)throw Error(\"The `styleMap` directive must be used in the `style` attribute and must be the only part in the attribute.\")}render(t){return Object.keys(t).reduce(((e,r)=>{const s=t[r];return null==s?e:e+`${r=r.includes(\"-\")?r:r.replace(/(?:^(webkit|moz|ms|o)|)(?=[A-Z])/g,\"-$&\").toLowerCase()}:${s};`}),\"\")}update(t,[e]){const{style:r}=t.element;if(void 0===this.ft)return this.ft=new Set(Object.keys(e)),this.render(e);for(const t of this.ft)null==e[t]&&(this.ft.delete(t),t.includes(\"-\")?r.removeProperty(t):r[t]=null);for(const t in e){const s=e[t];if(null!=s){this.ft.add(t);const e=\"string\"==typeof s&&s.endsWith(ie);t.includes(\"-\")||e?r.setProperty(t,e?s.slice(0,-11):s,e?ee:\"\"):r[t]=s}}return R}});export{se as styleMap};\n//# sourceMappingURL=style-map.js.map\n","import { css } from 'lit';\r\n\r\nexport default css`\r\n :host {\r\n box-sizing: border-box;\r\n }\r\n\r\n :host *,\r\n :host *::before,\r\n :host *::after {\r\n box-sizing: inherit;\r\n }\r\n\r\n [hidden] {\r\n display: none !important;\r\n }\r\n`;\r\n","/*\n jquery-qrcode v0.14.0 - https://larsjung.de/jquery-qrcode/ */\n'use strict';let G=null;class H{}H.render=function(w,B){G(w,B)};self.QrCreator=H;\n(function(w){function B(t,c,a,e){var b={},h=w(a,c);h.u(t);h.J();e=e||0;var r=h.h(),d=h.h()+2*e;b.text=t;b.level=c;b.version=a;b.O=d;b.a=function(b,a){b-=e;a-=e;return 0>b||b>=r||0>a||a>=r?!1:h.a(b,a)};return b}function C(t,c,a,e,b,h,r,d,g,x){function u(b,a,f,c,d,r,g){b?(t.lineTo(a+r,f+g),t.arcTo(a,f,c,d,h)):t.lineTo(a,f)}r?t.moveTo(c+h,a):t.moveTo(c,a);u(d,e,a,e,b,-h,0);u(g,e,b,c,b,0,-h);u(x,c,b,c,a,h,0);u(r,c,a,e,a,0,h)}function z(t,c,a,e,b,h,r,d,g,x){function u(b,a,c,d){t.moveTo(b+c,a);t.lineTo(b,\na);t.lineTo(b,a+d);t.arcTo(b,a,b+c,a,h)}r&&u(c,a,h,h);d&&u(e,a,-h,h);g&&u(e,b,-h,-h);x&&u(c,b,h,-h)}function A(t,c){var a=c.fill;if(\"string\"===typeof a)t.fillStyle=a;else{var e=a.type,b=a.colorStops;a=a.position.map((b)=>Math.round(b*c.size));if(\"linear-gradient\"===e)var h=t.createLinearGradient.apply(t,a);else if(\"radial-gradient\"===e)h=t.createRadialGradient.apply(t,a);else throw Error(\"Unsupported fill\");b.forEach(([b,a])=>{h.addColorStop(b,a)});t.fillStyle=h}}function y(t,c){a:{var a=c.text,e=\nc.v,b=c.N,h=c.K,r=c.P;b=Math.max(1,b||1);for(h=Math.min(40,h||40);b<=h;b+=1)try{var d=B(a,e,b,r);break a}catch(J){}d=void 0}if(!d)return null;a=t.getContext(\"2d\");c.background&&(a.fillStyle=c.background,a.fillRect(c.left,c.top,c.size,c.size));e=d.O;h=c.size/e;a.beginPath();for(r=0;r>>7-b%8&1)},put:function(b,h){for(var a=0;a>>h-a-1&1))},f:function(){return a},m:function(b){var h=Math.floor(a/8);c.length<=h&&c.push(0);b&&(c[h]|=128>>>a%8);a+=1}};return e}function C(c,a){function e(b,h){for(var a=-1;7>=a;a+=1)if(!(-1>=b+a||d<=b+a))for(var c=-1;7>=c;c+=1)-1>=h+c||d<=h+c||(r[b+a][h+c]=0<=a&&6>=a&&(0==c||6==c)||0<=c&&6>=c&&(0==a||6==a)||2<=a&&4>=a&&2<=c&&4>=c?!0:!1)}function b(b,a){for(var f=d=4*c+17,k=Array(f),m=0;m<\nf;m+=1){k[m]=Array(f);for(var p=0;p=n;n+=1)for(var l=-2;2>=l;l+=1)r[p+n][q+l]=-2==n||2==n||-2==l||2==l||0==n&&0==l}for(f=8;fk;k+=1)m=!b&&1==(f>>k&1),r[6>k?k:8>k?k+1:d-15+k][8]=m,r[8][8>k?d-k-1:9>k?15-k:14-k]=m;r[d-8][8]=!b;if(7<=\nc){f=y.A(c);for(k=0;18>k;k+=1)m=!b&&1==(f>>k&1),r[Math.floor(k/3)][k%3+d-8-3]=m;for(k=0;18>k;k+=1)m=!b&&1==(f>>k&1),r[k%3+d-8-3][Math.floor(k/3)]=m}if(null==g){b=t.I(c,h);f=B();for(k=0;k8*m)throw Error(\"code length overflow. (\"+f.f()+\">\"+8*m+\")\");for(f.f()+4<=8*m&&f.put(0,4);0!=f.f()%8;)f.m(!1);for(;!(f.f()>=8*m);){f.put(236,8);if(f.f()>=8*m)break;f.put(17,8)}var u=0;m=k=0;p=Array(b.length);\nq=Array(b.length);for(n=0;nn;n+=1)null==r[k][q-n]&&(l=!1,p>>m&1)),a(k,q-n)&&(l=!l),r[k][q-n]=l,--m,-1==m&&(p+=1,m=7));k+=f;if(0>k||d<=k){k-=f;f=-f;break}}}var h=A[a],r=null,d=0,g=null,x=[],u={u:function(b){b=w(b);x.push(b);g=null},a:function(b,a){if(0>b||d<=b||0>a||d<=a)throw Error(b+\",\"+a);return r[b][a]},h:function(){return d},J:function(){for(var a=0,h=0,c=0;8>c;c+=1){b(!0,c);var d=y.D(u);if(0==c||a>d)a=d,h=c}b(!1,h)}};return u}\nfunction z(c,a){if(\"undefined\"==typeof c.length)throw Error(c.length+\"/\"+a);var e=function(){for(var b=0;bb.b()-a.b())return b;for(var c=v.g(b.c(0))-v.g(a.c(0)),h=Array(b.b()),\ng=0;gb?a.push(b):2048>b?a.push(192|b>>6,128|b&63):55296>b||57344<=b?a.push(224|b>>12,128|b>>6&63,128|b&63):(e++,b=65536+((b&1023)<<10|c.charCodeAt(e)&1023),a.push(240|b>>18,128|b>>12&63,128|b>>6&63,128|b&63))}return a};var A={L:1,M:0,Q:3,H:2},y=function(){function c(b){for(var a=0;0!=b;)a+=1,b>>>=1;return a}var a=[[],[6,18],\n[6,22],[6,26],[6,30],[6,34],[6,22,38],[6,24,42],[6,26,46],[6,28,50],[6,30,54],[6,32,58],[6,34,62],[6,26,46,66],[6,26,48,70],[6,26,50,74],[6,30,54,78],[6,30,56,82],[6,30,58,86],[6,34,62,90],[6,28,50,72,94],[6,26,50,74,98],[6,30,54,78,102],[6,28,54,80,106],[6,32,58,84,110],[6,30,58,86,114],[6,34,62,90,118],[6,26,50,74,98,122],[6,30,54,78,102,126],[6,26,52,78,104,130],[6,30,56,82,108,134],[6,34,60,86,112,138],[6,30,58,86,114,142],[6,34,62,90,118,146],[6,30,54,78,102,126,150],[6,24,50,76,102,128,154],\n[6,28,54,80,106,132,158],[6,32,58,84,110,136,162],[6,26,54,82,110,138,166],[6,30,58,86,114,142,170]],e={w:function(b){for(var a=b<<10;0<=c(a)-c(1335);)a^=1335<a||40a?8:16},D:function(b){for(var a=b.h(),c=0,\nd=0;d=p;p+=1)if(!(0>d+p||a<=d+p))for(var q=-1;1>=q;q+=1)0>g+q||a<=g+q||(0!=p||0!=q)&&t==b.a(d+p,g+q)&&(e+=1);5e;e+=1)c[e]=1<e;e+=1)c[e]=c[e-4]^c[e-5]^c[e-6]^c[e-8];for(e=0;255>e;e+=1)a[c[e]]=e;return{g:function(b){if(1>b)throw Error(\"glog(\"+b+\")\");return a[b]},i:function(b){for(;0>b;)b+=255;for(;256<=b;)b-=255;return c[b]}}}(),t=function(){function c(b,c){switch(c){case A.L:return a[4*\n(b-1)];case A.M:return a[4*(b-1)+1];case A.Q:return a[4*(b-1)+2];case A.H:return a[4*(b-1)+3]}}var a=[[1,26,19],[1,26,16],[1,26,13],[1,26,9],[1,44,34],[1,44,28],[1,44,22],[1,44,16],[1,70,55],[1,70,44],[2,35,17],[2,35,13],[1,100,80],[2,50,32],[2,50,24],[4,25,9],[1,134,108],[2,67,43],[2,33,15,2,34,16],[2,33,11,2,34,12],[2,86,68],[4,43,27],[4,43,19],[4,43,15],[2,98,78],[4,49,31],[2,32,14,4,33,15],[4,39,13,1,40,14],[2,121,97],[2,60,38,2,61,39],[4,40,18,2,41,19],[4,40,14,2,41,15],[2,146,116],[3,58,36,\n2,59,37],[4,36,16,4,37,17],[4,36,12,4,37,13],[2,86,68,2,87,69],[4,69,43,1,70,44],[6,43,19,2,44,20],[6,43,15,2,44,16],[4,101,81],[1,80,50,4,81,51],[4,50,22,4,51,23],[3,36,12,8,37,13],[2,116,92,2,117,93],[6,58,36,2,59,37],[4,46,20,6,47,21],[7,42,14,4,43,15],[4,133,107],[8,59,37,1,60,38],[8,44,20,4,45,21],[12,33,11,4,34,12],[3,145,115,1,146,116],[4,64,40,5,65,41],[11,36,16,5,37,17],[11,36,12,5,37,13],[5,109,87,1,110,88],[5,65,41,5,66,42],[5,54,24,7,55,25],[11,36,12,7,37,13],[5,122,98,1,123,99],[7,73,\n45,3,74,46],[15,43,19,2,44,20],[3,45,15,13,46,16],[1,135,107,5,136,108],[10,74,46,1,75,47],[1,50,22,15,51,23],[2,42,14,17,43,15],[5,150,120,1,151,121],[9,69,43,4,70,44],[17,50,22,1,51,23],[2,42,14,19,43,15],[3,141,113,4,142,114],[3,70,44,11,71,45],[17,47,21,4,48,22],[9,39,13,16,40,14],[3,135,107,5,136,108],[3,67,41,13,68,42],[15,54,24,5,55,25],[15,43,15,10,44,16],[4,144,116,4,145,117],[17,68,42],[17,50,22,6,51,23],[19,46,16,6,47,17],[2,139,111,7,140,112],[17,74,46],[7,54,24,16,55,25],[34,37,13],[4,\n151,121,5,152,122],[4,75,47,14,76,48],[11,54,24,14,55,25],[16,45,15,14,46,16],[6,147,117,4,148,118],[6,73,45,14,74,46],[11,54,24,16,55,25],[30,46,16,2,47,17],[8,132,106,4,133,107],[8,75,47,13,76,48],[7,54,24,22,55,25],[22,45,15,13,46,16],[10,142,114,2,143,115],[19,74,46,4,75,47],[28,50,22,6,51,23],[33,46,16,4,47,17],[8,152,122,4,153,123],[22,73,45,3,74,46],[8,53,23,26,54,24],[12,45,15,28,46,16],[3,147,117,10,148,118],[3,73,45,23,74,46],[4,54,24,31,55,25],[11,45,15,31,46,16],[7,146,116,7,147,117],\n[21,73,45,7,74,46],[1,53,23,37,54,24],[19,45,15,26,46,16],[5,145,115,10,146,116],[19,75,47,10,76,48],[15,54,24,25,55,25],[23,45,15,25,46,16],[13,145,115,3,146,116],[2,74,46,29,75,47],[42,54,24,1,55,25],[23,45,15,28,46,16],[17,145,115],[10,74,46,23,75,47],[10,54,24,35,55,25],[19,45,15,35,46,16],[17,145,115,1,146,116],[14,74,46,21,75,47],[29,54,24,19,55,25],[11,45,15,46,46,16],[13,145,115,6,146,116],[14,74,46,23,75,47],[44,54,24,7,55,25],[59,46,16,1,47,17],[12,151,121,7,152,122],[12,75,47,26,76,48],\n[39,54,24,14,55,25],[22,45,15,41,46,16],[6,151,121,14,152,122],[6,75,47,34,76,48],[46,54,24,10,55,25],[2,45,15,64,46,16],[17,152,122,4,153,123],[29,74,46,14,75,47],[49,54,24,10,55,25],[24,45,15,46,46,16],[4,152,122,18,153,123],[13,74,46,32,75,47],[48,54,24,14,55,25],[42,45,15,32,46,16],[20,147,117,4,148,118],[40,75,47,7,76,48],[43,54,24,22,55,25],[10,45,15,67,46,16],[19,148,118,6,149,119],[18,75,47,31,76,48],[34,54,24,34,55,25],[20,45,15,61,46,16]],e={I:function(b,a){var e=c(b,a);if(\"undefined\"==\ntypeof e)throw Error(\"bad rs block @ typeNumber:\"+b+\"/errorCorrectLevel:\"+a);b=e.length/3;a=[];for(var d=0;d = T extends keyof GlobalEventHandlersEventMap\r\n ? // ...where the event detail is an object...\r\n GlobalEventHandlersEventMap[T] extends CustomEvent>\r\n ? // ...that is non-empty...\r\n GlobalEventHandlersEventMap[T] extends CustomEvent>\r\n ? never\r\n : // ...and has at least one non-optional property\r\n Partial extends GlobalEventHandlersEventMap[T]['detail']\r\n ? never\r\n : T\r\n : never\r\n : never;\r\n\r\n// The inverse of the above (match any type that doesn't match EventTypeRequiresDetail)\r\ntype EventTypeDoesNotRequireDetail = T extends keyof GlobalEventHandlersEventMap\r\n ? GlobalEventHandlersEventMap[T] extends CustomEvent>\r\n ? GlobalEventHandlersEventMap[T] extends CustomEvent>\r\n ? T\r\n : Partial extends GlobalEventHandlersEventMap[T]['detail']\r\n ? T\r\n : never\r\n : T\r\n : T;\r\n\r\n// `keyof EventTypesWithRequiredDetail` lists all registered event types that require detail\r\ntype EventTypesWithRequiredDetail = {\r\n [EventType in keyof GlobalEventHandlersEventMap as EventTypeRequiresDetail]: true;\r\n};\r\n\r\n// `keyof EventTypesWithoutRequiredDetail` lists all registered event types that do NOT require detail\r\ntype EventTypesWithoutRequiredDetail = {\r\n [EventType in keyof GlobalEventHandlersEventMap as EventTypeDoesNotRequireDetail]: true;\r\n};\r\n\r\n// Helper to make a specific property of an object non-optional\r\ntype WithRequired = T & { [P in K]-?: T[P] };\r\n\r\n// Given an event name, get a valid type for the options to initialize the event that is more restrictive than\r\n// just CustomEventInit when appropriate (validate the type of the event detail, and require it to be provided if the\r\n// event requires it)\r\ntype WebModuleEventInit = T extends keyof GlobalEventHandlersEventMap\r\n ? GlobalEventHandlersEventMap[T] extends CustomEvent>\r\n ? GlobalEventHandlersEventMap[T] extends CustomEvent>\r\n ? CustomEventInit\r\n : Partial extends GlobalEventHandlersEventMap[T]['detail']\r\n ? CustomEventInit\r\n : WithRequired, 'detail'>\r\n : CustomEventInit\r\n : CustomEventInit;\r\n\r\n// Given an event name string, get the type of the event\r\ntype GetCustomEventType = T extends keyof GlobalEventHandlersEventMap\r\n ? GlobalEventHandlersEventMap[T] extends CustomEvent\r\n ? GlobalEventHandlersEventMap[T]\r\n : CustomEvent\r\n : CustomEvent;\r\n\r\n// `keyof ValidEventTypeMap` is equivalent to `keyof GlobalEventHandlersEventMap` but gives a nicer error message\r\ntype ValidEventTypeMap = EventTypesWithRequiredDetail | EventTypesWithoutRequiredDetail;\r\n\r\n// noinspection JSUnusedGlobalSymbols\r\nexport default class WebModuleElement extends LitElement {\r\n constructor() {\r\n super();\r\n }\r\n\r\n // Emits a custom event with more convenient defaults.\r\n emit(\r\n name: EventTypeDoesNotRequireDetail,\r\n options?: WebModuleEventInit | undefined\r\n ): GetCustomEventType;\r\n emit(\r\n name: EventTypeRequiresDetail,\r\n options: WebModuleEventInit\r\n ): GetCustomEventType;\r\n emit(\r\n name: T,\r\n options?: WebModuleEventInit | undefined\r\n ): GetCustomEventType {\r\n const event = new CustomEvent(name, {\r\n bubbles: true,\r\n cancelable: false,\r\n composed: true,\r\n detail: {},\r\n ...options\r\n });\r\n\r\n this.dispatchEvent(event);\r\n\r\n return event as GetCustomEventType;\r\n }\r\n\r\n override update(changedProperties: PropertyValues) {\r\n const observers = observersForClass.get(this.constructor);\r\n\r\n if (observers !== undefined) {\r\n for (const { keys, method, options } of observers) {\r\n if (keys.some(p => changedProperties.has(p))) {\r\n if (!options.delayMonitorUntilFirstUpdate || this.hasUpdated) {\r\n // eslint-disable-next-line @typescript-eslint/no-unsafe-return\r\n const oldValues = keys.map(p => changedProperties.get(p));\r\n method.apply(this, oldValues);\r\n }\r\n }\r\n }\r\n }\r\n\r\n super.update(changedProperties);\r\n }\r\n}\r\n","import { html } from 'lit';\r\nimport { monitor } from '../../common/monitor.js';\r\nimport { property, query } from 'lit/decorators.js';\r\nimport { styleMap } from 'lit/directives/style-map.js';\r\nimport componentStyles from '../../styles/component.styles.js';\r\nimport QrCreator from 'qr-creator';\r\nimport styles from './qr-code.styles.js';\r\nimport WebModuleElement from '../../common/webmodule-element.js';\r\nimport type { CSSResultGroup } from 'lit';\r\n\r\n/**\r\n * @summary Generates a [QR code](https://www.qrcode.com/) and renders it using the [Canvas API](https://developer.mozilla.org/en-US/docs/Web/API/Canvas_API).\r\n *\r\n * @csspart base - The component's base wrapper.\r\n *\r\n * @tag webmodule-qr-code\r\n */\r\nexport default class WebmoduleQrCode extends WebModuleElement {\r\n static styles: CSSResultGroup = [componentStyles, styles];\r\n\r\n @query('canvas') canvas: HTMLElement;\r\n\r\n /** The QR code's value. */\r\n @property() value = '';\r\n\r\n /** The label for assistive devices to announce. If unspecified, the value will be used instead. */\r\n @property() label = '';\r\n\r\n /** The size of the QR code, in pixels. */\r\n @property({ type: Number }) size = 128;\r\n\r\n /** The fill color. This can be any valid CSS color, but not a CSS custom property. */\r\n @property() fill = 'black';\r\n\r\n /** The background color. This can be any valid CSS color or `transparent`. It cannot be a CSS custom property. */\r\n @property() background = 'transparent';\r\n\r\n /** The edge radius of each module. Must be between 0 and 0.5. */\r\n @property({ type: Number }) radius = 0;\r\n\r\n /** The level of error correction to use. [Learn more](https://www.qrcode.com/en/about/error_correction.html) */\r\n @property({ attribute: 'error-correction' }) errorCorrection: 'L' | 'M' | 'Q' | 'H' = 'H';\r\n\r\n firstUpdated() {\r\n this.generate();\r\n }\r\n\r\n @monitor(['background', 'errorCorrection', 'fill', 'radius', 'size', 'value'])\r\n generate() {\r\n if (!this.hasUpdated) {\r\n return;\r\n }\r\n\r\n // For some reason, when changing to \"NodeNext\", it has the wrong type for QrCreator.\r\n (QrCreator as unknown as typeof QrCreator.default).render(\r\n {\r\n text: this.value,\r\n radius: this.radius,\r\n ecLevel: this.errorCorrection,\r\n fill: this.fill,\r\n background: this.background,\r\n // We draw the canvas larger and scale its container down to avoid blurring on high-density displays\r\n size: this.size * 2\r\n },\r\n this.canvas\r\n );\r\n }\r\n\r\n render() {\r\n return html`\r\n 0 ? this.label : this.value}\r\n style=${styleMap({\r\n width: `${this.size}px`,\r\n height: `${this.size}px`\r\n })}\r\n >\r\n `;\r\n }\r\n}\r\n\r\ndeclare global {\r\n interface HTMLElementTagNameMap {\r\n 'webmodule-qr-code': WebmoduleQrCode;\r\n }\r\n}\r\n","import{noChange as R}from\"../lit-html.js\";import{directive as e,Directive as i,PartType as t}from\"../directive.js\";\n/**\n * @license\n * Copyright 2018 Google LLC\n * SPDX-License-Identifier: BSD-3-Clause\n */const Rt=e(class extends i{constructor(s){if(super(s),s.type!==t.ATTRIBUTE||\"class\"!==s.name||s.strings?.length>2)throw Error(\"`classMap()` can only be used in the `class` attribute and must be the only part in the attribute.\")}render(t){return\" \"+Object.keys(t).filter((s=>t[s])).join(\" \")+\" \"}update(t,[s]){if(void 0===this.st){this.st=new Set,void 0!==t.strings&&(this.nt=new Set(t.strings.join(\" \").split(/\\s/).filter((t=>\"\"!==t))));for(const t in s)s[t]&&!this.nt?.has(t)&&this.st.add(t);return this.render(s)}const i=t.element.classList;for(const t of this.st)t in s||(i.remove(t),this.st.delete(t));for(const t in s){const r=!!s[t];r===this.st.has(t)||this.nt?.has(t)||(r?(i.add(t),this.st.add(t)):(i.remove(t),this.st.delete(t)))}return R}});export{Rt as classMap};\n//# sourceMappingURL=class-map.js.map\n","import type { ReactiveController, ReactiveControllerHost } from 'lit';\r\n\r\n/**\r\n * Given a slot, this function iterates over all of its assigned element and text nodes and returns the concatenated\r\n * HTML as a string.\r\n */\r\nexport function getInnerHTML(slot: HTMLSlotElement): string {\r\n const nodes = slot.assignedNodes({ flatten: true });\r\n let html = '';\r\n\r\n [...nodes].forEach(node => {\r\n if (node.nodeType === Node.ELEMENT_NODE) {\r\n html += (node as HTMLElement).outerHTML;\r\n }\r\n\r\n if (node.nodeType === Node.TEXT_NODE) {\r\n html += node.textContent;\r\n }\r\n });\r\n\r\n return html;\r\n}\r\n\r\n/**\r\n * Given a slot, this function iterates over all of its assigned text nodes and returns the concatenated text as a\r\n * string.\r\n */\r\nexport function getTextContent(slot: HTMLSlotElement | undefined | null): string {\r\n if (!slot) {\r\n return '';\r\n }\r\n const nodes = slot.assignedNodes({ flatten: true });\r\n let text = '';\r\n\r\n [...nodes].forEach(node => {\r\n if (node.nodeType === Node.TEXT_NODE) {\r\n text += node.textContent;\r\n }\r\n });\r\n\r\n return text;\r\n}\r\n\r\n/** A reactive controller that determines if slots exist. */\r\nexport class HasSlotController implements ReactiveController {\r\n host: ReactiveControllerHost & Element;\r\n slotNames: string[] = [];\r\n\r\n constructor(host: ReactiveControllerHost & Element, ...slotNames: string[]) {\r\n (this.host = host).addController(this);\r\n this.slotNames = slotNames;\r\n this.handleSlotChange = this.handleSlotChange.bind(this);\r\n }\r\n\r\n hostConnected() {\r\n this.host.shadowRoot!.addEventListener('slotchange', this.handleSlotChange);\r\n }\r\n\r\n hostDisconnected() {\r\n this.host.shadowRoot!.removeEventListener('slotchange', this.handleSlotChange);\r\n }\r\n\r\n handleSlotChange(event: Event) {\r\n const slot = event.target as HTMLSlotElement;\r\n\r\n //If any slot changes, request an update on the host element.\r\n if ((this.slotNames.includes('[default]') && !slot.name) || (slot.name && this.slotNames.includes(slot.name))) {\r\n this.host.requestUpdate();\r\n }\r\n }\r\n\r\n // Check if a slot has been defined\r\n checkFor(slotName: string) {\r\n return slotName === '[default]' ? this.hasDefaultSlot() : this.hasNamedSlot(slotName);\r\n }\r\n\r\n private hasDefaultSlot() {\r\n return [...this.host.childNodes].some(node => {\r\n if (node.nodeType === node.TEXT_NODE && node.textContent!.trim() !== '') {\r\n return true;\r\n }\r\n\r\n if (node.nodeType === node.ELEMENT_NODE) {\r\n const el = node as HTMLElement;\r\n\r\n // If it doesn't have a slot attribute, it's part of the default slot for the element\r\n if (!el.hasAttribute('slot')) {\r\n return true;\r\n }\r\n }\r\n\r\n return false;\r\n });\r\n }\r\n\r\n private hasNamedSlot(name: string) {\r\n return this.host.querySelector(`:scope > [slot=\"${name}\"]`) !== null;\r\n }\r\n}\r\n","import { css } from 'lit';\r\n\r\nexport default css`\r\n :host {\r\n --border-color: var(--webmodule-color-neutral-200);\r\n --border-radius: var(--webmodule-border-radius-medium);\r\n --border-width: 1px;\r\n --padding: var(--webmodule-spacing-large);\r\n\r\n display: inline-block;\r\n }\r\n\r\n .card {\r\n display: flex;\r\n flex-direction: column;\r\n background-color: var(--webmodule-panel-background-color);\r\n box-shadow: var(--webmodule-shadow-x-small);\r\n border: solid var(--border-width) var(--border-color);\r\n border-radius: var(--border-radius);\r\n }\r\n\r\n .card__image {\r\n display: flex;\r\n border-top-left-radius: var(--border-radius);\r\n border-top-right-radius: var(--border-radius);\r\n margin: calc(-1 * var(--border-width));\r\n overflow: hidden;\r\n }\r\n\r\n .card__image::slotted(img) {\r\n display: block;\r\n width: 100%;\r\n }\r\n\r\n .card:not(.card--has-image) .card__image {\r\n display: none;\r\n }\r\n\r\n .card__header {\r\n display: block;\r\n border-bottom: solid var(--border-width) var(--border-color);\r\n padding: calc(var(--padding) / 2) var(--padding);\r\n }\r\n\r\n .card:not(.card--has-header) .card__header {\r\n display: none;\r\n }\r\n\r\n .card:not(.card--has-image) .card__header {\r\n border-top-left-radius: var(--border-radius);\r\n border-top-right-radius: var(--border-radius);\r\n }\r\n\r\n .card__body {\r\n display: block;\r\n padding: var(--padding);\r\n }\r\n\r\n .card--has-footer .card__footer {\r\n display: block;\r\n border-top: solid var(--border-width) var(--border-color);\r\n padding: var(--padding);\r\n }\r\n\r\n .card:not(.card--has-footer) .card__footer {\r\n display: none;\r\n }\r\n`;\r\n","import { classMap } from 'lit/directives/class-map.js';\r\nimport { HasSlotController } from '../../common/slot-controller.js';\r\nimport { html } from 'lit';\r\nimport componentStyles from '../../styles/component.styles.js';\r\nimport styles from './card.styles.js';\r\nimport WebModuleElement from '../../common/webmodule-element.js';\r\nimport type { CSSResultGroup } from 'lit';\r\n\r\n/**\r\n * @summary Container to group elements.\r\n *\r\n * @slot - Card's body.\r\n * @slot header - An optional header.\r\n * @slot footer - An optional footer.\r\n * @slot image - An optional image.\r\n *\r\n * @csspart base\r\n * @csspart image - Image container.\r\n * @csspart header - header container\r\n * @csspart body - Body container\r\n * @csspart footer - Footer container\r\n *\r\n * @cssproperty --border-color - Color of the border\r\n * @cssproperty --border-radius - Card's corner radius\r\n * @cssproperty --border-width - Card's border with\r\n * @cssproperty --padding - The padding to use for the card's sections (slots).\r\n *\r\n * @tag webmodule-card\r\n */\r\nexport default class WebmoduleCard extends WebModuleElement {\r\n static styles: CSSResultGroup = [componentStyles, styles];\r\n\r\n private readonly hasSlot = new HasSlotController(this, 'footer', 'header', 'image');\r\n\r\n render() {\r\n return html`\r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n `;\r\n }\r\n}\r\n\r\ndeclare global {\r\n interface HTMLElementTagNameMap {\r\n 'webmodule-card': WebmoduleCard;\r\n }\r\n}\r\n","import type { IconLibrary } from './library.js';\r\n\r\nconst icons = {\r\n adjust: `\r\n \r\n \r\n \r\n `,\r\n bin: `\r\n \r\n \r\n \r\n `,\r\n 'chevron-down': `\r\n \r\n \r\n \r\n `,\r\n 'chevron-up': `\r\n \r\n \r\n \r\n `,\r\n 'chevron-right': `\r\n \r\n \r\n \r\n `,\r\n 'chevron-left': `\r\n \r\n \r\n \r\n `,\r\n copy: `\r\n \r\n \r\n \r\n `,\r\n edit: `\r\n \r\n \r\n \r\n `,\r\n 'x-circle-fill': `\r\n \r\n \r\n \r\n `,\r\n 'eye-slash': `\r\n \r\n \r\n \r\n \r\n \r\n `,\r\n eye: `\r\n \r\n \r\n \r\n \r\n `,\r\n caret: `\r\n \r\n \r\n \r\n `,\r\n 'caret-up': `\r\n \r\n \r\n \r\n `,\r\n check: `\r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n `,\r\n 'x-lg': `\r\n \r\n \r\n \r\n `,\r\n indeterminate: `\r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n `,\r\n radio: `\r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n `,\r\n 'no-tax': `\r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n `,\r\n person: `\r\n \r\n \r\n \r\n `\r\n};\r\n\r\nconst defaultLibrary: IconLibrary = {\r\n name: 'default',\r\n resolver: (name: keyof typeof icons) => {\r\n if (name in icons) {\r\n return `data:image/svg+xml, ${encodeURIComponent(icons[name])}`;\r\n }\r\n return '';\r\n }\r\n};\r\n\r\nexport default defaultLibrary;\r\n","import defaultLibrary from './icon.default.lib.js';\r\nimport type WebmoduleIcon from '../icon/icon.js';\r\n\r\nexport type IconLibraryResolver = (name: string) => string;\r\nexport type IconLibraryMutator = (svg: SVGElement) => void;\r\nexport interface IconLibrary {\r\n name: string;\r\n resolver: IconLibraryResolver;\r\n mutator?: IconLibraryMutator;\r\n spriteSheet?: boolean;\r\n}\r\n\r\nlet registry: IconLibrary[] = [defaultLibrary];\r\nlet watchedIcons: WebmoduleIcon[] = [];\r\n\r\n/** Adds an icon to the list of watched icons. */\r\nexport function watchIcon(icon: WebmoduleIcon) {\r\n watchedIcons.push(icon);\r\n}\r\n\r\n/** Removes an icon from the list of watched icons. */\r\nexport function unwatchIcon(icon: WebmoduleIcon) {\r\n watchedIcons = watchedIcons.filter(el => el !== icon);\r\n}\r\n\r\n/** Returns a library from the registry. */\r\nexport function getIconLibrary(name?: string) {\r\n return registry.find(lib => lib.name === name);\r\n}\r\n\r\n/** Adds an icon library to the registry, or overrides an existing one. */\r\nexport function registerIconLibrary(name: string, options: Omit) {\r\n unregisterIconLibrary(name);\r\n registry.push({\r\n name,\r\n resolver: options.resolver,\r\n mutator: options.mutator,\r\n spriteSheet: options.spriteSheet\r\n });\r\n\r\n // Redraw watched icons\r\n watchedIcons.forEach(icon => {\r\n if (icon.library === name) {\r\n icon.setIcon();\r\n }\r\n });\r\n}\r\n\r\n/** Removes an icon library from the registry. */\r\nexport function unregisterIconLibrary(name: string) {\r\n registry = registry.filter(lib => lib.name !== name);\r\n}\r\n","import{_$LH as io}from\"./lit-html.js\";\n/**\n * @license\n * Copyright 2020 Google LLC\n * SPDX-License-Identifier: BSD-3-Clause\n */const{I:et}=io,st=o=>null===o||\"object\"!=typeof o&&\"function\"!=typeof o,no={HTML:1,SVG:2,MATHML:3},nt=(o,t)=>void 0===t?void 0!==o?._$litType$:o?._$litType$===t,ot=o=>null!=o?._$litType$?.h,eo=o=>void 0!==o?._$litDirective$,lo=o=>o?._$litDirective$,rt=o=>void 0===o.strings,lt=()=>document.createComment(\"\"),at=(o,t,i)=>{const n=o._$AA.parentNode,e=void 0===t?o._$AB:t._$AA;if(void 0===i){const t=n.insertBefore(lt(),e),l=n.insertBefore(lt(),e);i=new et(t,l,o,o.options)}else{const t=i._$AB.nextSibling,l=i._$AM,c=l!==o;if(c){let t;i._$AQ?.(o),i._$AM=o,void 0!==i._$AP&&(t=o._$AU)!==l._$AU&&i._$AP(t)}if(t!==e||c){let o=i._$AA;for(;o!==t;){const t=o.nextSibling;n.insertBefore(o,e),o=t}}}return i},ct=(o,t,i=o)=>(o._$AI(t,i),o),ht={},dt=(o,t=ht)=>o._$AH=t,ut=o=>o._$AH,pt=o=>{o._$AP?.(!1,!0);let t=o._$AA;const i=o._$AB.nextSibling;for(;t!==i;){const o=t.nextSibling;t.remove(),t=o}},ft=o=>{o._$AR()};export{no as TemplateResultType,ft as clearPart,ut as getCommittedValue,lo as getDirectiveClass,at as insertPart,ot as isCompiledTemplateResult,eo as isDirectiveResult,st as isPrimitive,rt as isSingleExpression,nt as isTemplateResult,pt as removePart,ct as setChildPartValue,dt as setCommittedValue};\n//# sourceMappingURL=directive-helpers.js.map\n","import { css } from 'lit';\r\n\r\nexport default css`\r\n :host {\r\n display: inline-block;\r\n width: 1em;\r\n height: 1em;\r\n box-sizing: content-box !important;\r\n }\r\n\r\n svg {\r\n display: block;\r\n height: 100%;\r\n width: 100%;\r\n }\r\n`;\r\n","import { type CSSResultGroup, html, type HTMLTemplateResult } from 'lit';\r\nimport { getIconLibrary, type IconLibrary, unwatchIcon, watchIcon } from './library.js';\r\nimport { isTemplateResult } from 'lit/directive-helpers.js';\r\nimport { monitor } from '../../common/monitor.js';\r\nimport { property, state } from 'lit/decorators.js';\r\nimport componentStyles from '../../styles/component.styles.js';\r\nimport styles from './icon.styles.js';\r\nimport WebModuleElement from '../../common/webmodule-element.js';\r\n\r\nconst CACHEABLE_ERROR = Symbol();\r\nconst RETRYABLE_ERROR = Symbol();\r\ntype SVGResult = HTMLTemplateResult | SVGSVGElement | typeof RETRYABLE_ERROR | typeof CACHEABLE_ERROR;\r\n\r\nlet parser: DOMParser;\r\nconst iconCache = new Map>();\r\n\r\ninterface IconSource {\r\n url?: string;\r\n fromLibrary: boolean;\r\n}\r\n\r\n/**\r\n * @summary Icon component for presentation\r\n *\r\n * @event webmodule-load - Emitted wehn icon has loaded.\r\n * @event webmodule-error - Emitted when icon fails to load.\r\n *\r\n * @csspart svg - Internal SVG element.\r\n * @csspart use - The element generated when using `spriteSheet: true`\r\n *\r\n * @tag webmodule-icon\r\n */\r\nexport default class WebmoduleIcon extends WebModuleElement {\r\n static styles: CSSResultGroup = [componentStyles, styles];\r\n\r\n private initialRender = false;\r\n\r\n /** Given a URL, this function returns the resulting SVG element or an appropriate error symbol. */\r\n private async resolveIcon(url: string, library?: IconLibrary): Promise {\r\n let fileData: Response;\r\n\r\n if (library?.spriteSheet) {\r\n this.svg = html` \r\n \r\n `;\r\n\r\n // Using a templateResult requires the SVG to be written to the DOM first before we can grab the SVGElement\r\n // to be passed to the library's mutator function.\r\n await this.updateComplete;\r\n\r\n const svg = this.shadowRoot!.querySelector(\"[part='svg']\")!;\r\n\r\n if (typeof library.mutator === 'function') {\r\n library.mutator(svg as SVGElement);\r\n }\r\n\r\n return this.svg;\r\n }\r\n\r\n try {\r\n fileData = await fetch(url, { mode: 'cors' });\r\n if (!fileData.ok) return fileData.status === 410 ? CACHEABLE_ERROR : RETRYABLE_ERROR;\r\n } catch {\r\n return RETRYABLE_ERROR;\r\n }\r\n\r\n try {\r\n const div = document.createElement('div');\r\n div.innerHTML = await fileData.text();\r\n\r\n const svg = div.firstElementChild;\r\n if (svg?.tagName?.toLowerCase() !== 'svg') return CACHEABLE_ERROR;\r\n\r\n if (!parser) parser = new DOMParser();\r\n const doc = parser.parseFromString(svg.outerHTML, 'text/html');\r\n\r\n const svgEl = doc.body.querySelector('svg');\r\n if (!svgEl) return CACHEABLE_ERROR;\r\n\r\n svgEl.part.add('svg');\r\n return document.adoptNode(svgEl);\r\n } catch {\r\n return CACHEABLE_ERROR;\r\n }\r\n }\r\n\r\n @state() private svg: SVGElement | HTMLTemplateResult | null = null;\r\n\r\n /** The name of the icon to draw. Available names depend on the icon library being used. */\r\n @property({ reflect: true }) name?: string;\r\n\r\n /**\r\n * An external URL of an SVG file. Be sure you trust the content you are including, as it will be executed as code and\r\n * can result in XSS attacks.\r\n */\r\n @property() src?: string;\r\n\r\n /**\r\n * An alternate description to use for assistive devices. If omitted, the icon will be considered presentational and\r\n * ignored by assistive devices.\r\n */\r\n @property() label = '';\r\n\r\n /** The name of a registered custom icon library. */\r\n @property({ reflect: true }) library = 'default';\r\n\r\n connectedCallback() {\r\n super.connectedCallback();\r\n watchIcon(this);\r\n }\r\n\r\n firstUpdated() {\r\n this.initialRender = true;\r\n this.setIcon();\r\n }\r\n\r\n disconnectedCallback() {\r\n super.disconnectedCallback();\r\n unwatchIcon(this);\r\n }\r\n\r\n private getIconSource(): IconSource {\r\n const library = getIconLibrary(this.library);\r\n if (this.name && library) {\r\n return {\r\n url: library.resolver(this.name),\r\n fromLibrary: true\r\n };\r\n }\r\n\r\n return {\r\n url: this.src,\r\n fromLibrary: false\r\n };\r\n }\r\n\r\n @monitor(['name', 'src', 'library'])\r\n async setIcon() {\r\n const { url, fromLibrary } = this.getIconSource();\r\n const library = fromLibrary ? getIconLibrary(this.library) : undefined;\r\n\r\n if (!url) {\r\n this.svg = null;\r\n return;\r\n }\r\n\r\n let iconResolver = iconCache.get(url);\r\n if (!iconResolver) {\r\n iconResolver = this.resolveIcon(url, library);\r\n iconCache.set(url, iconResolver);\r\n }\r\n\r\n // If we haven't rendered yet, exit early. This avoids unnecessary work due to watching multiple props.\r\n if (!this.initialRender) {\r\n return;\r\n }\r\n\r\n const svg = await iconResolver;\r\n\r\n if (svg === RETRYABLE_ERROR) {\r\n iconCache.delete(url);\r\n }\r\n\r\n if (url !== this.getIconSource().url) {\r\n // If the url has changed while fetching the icon, ignore this request\r\n return;\r\n }\r\n\r\n if (isTemplateResult(svg)) {\r\n this.svg = svg;\r\n return;\r\n }\r\n\r\n switch (svg) {\r\n case RETRYABLE_ERROR:\r\n case CACHEABLE_ERROR:\r\n this.svg = null;\r\n this.emit('webmodule-error');\r\n break;\r\n default:\r\n this.svg = svg.cloneNode(true) as SVGElement;\r\n library?.mutator?.(this.svg);\r\n this.emit('webmodule-load');\r\n }\r\n }\r\n\r\n render() {\r\n return this.svg;\r\n }\r\n}\r\n\r\ndeclare global {\r\n interface HTMLElementTagNameMap {\r\n 'webmodule-icon': WebmoduleIcon;\r\n }\r\n}\r\n","import { css } from 'lit';\r\n\r\nexport default css`\r\n :host {\r\n --color: var(--webmodule-panel-border-color);\r\n --width: var(--webmodule-panel-border-width);\r\n --spacing: var(--webmodule-spacing-medium);\r\n }\r\n\r\n :host(:not([vertical])) {\r\n display: block;\r\n border-top: solid var(--width) var(--color);\r\n margin: var(--spacing) 0;\r\n }\r\n\r\n :host([vertical]) {\r\n display: inline-block;\r\n height: 100%;\r\n border-left: solid var(--width) var(--color);\r\n margin: 0 var(--spacing);\r\n }\r\n`;\r\n","import { monitor } from '../../common/monitor.js';\r\nimport { property } from 'lit/decorators.js';\r\nimport componentStyles from '../../styles/component.styles.js';\r\nimport styles from './divider.styles.js';\r\nimport WebModuleElement from '../../common/webmodule-element.js';\r\nimport type { CSSResultGroup } from 'lit';\r\n\r\n/**\r\n * @summary Element to visually separate elements.\r\n *\r\n * @cssproperty --color - The color of the divider.\r\n * @cssproperty --width - The width of the divider.\r\n * @cssproperty --spacing - The spacing of the divider.\r\n *\r\n * @tag webmodule-divider\r\n */\r\nexport default class WebmoduleDivider extends WebModuleElement {\r\n static styles: CSSResultGroup = [componentStyles, styles];\r\n\r\n @property({ type: Boolean, reflect: true }) vertical = false;\r\n\r\n connectedCallback() {\r\n super.connectedCallback();\r\n this.setAttribute('role', 'separator');\r\n }\r\n\r\n @monitor('vertical')\r\n handleVerticalChange() {\r\n this.setAttribute('aria-orientation', this.vertical ? 'vertical' : 'horizontal');\r\n }\r\n}\r\n\r\ndeclare global {\r\n interface HTMLElementTagNameMap {\r\n 'webmodule-divider': WebmoduleDivider;\r\n }\r\n}\r\n","import { css } from 'lit';\r\n\r\nexport default css`\r\n :host {\r\n display: inline-flex;\r\n }\r\n\r\n .badge {\r\n display: inline-flex;\r\n align-items: center;\r\n justify-content: center;\r\n font-size: max(12px, 0.75em);\r\n font-weight: var(--webmodule-font-weight-semibold);\r\n letter-spacing: var(--webmodule-letter-spacing-normal);\r\n line-height: 1;\r\n border-radius: var(--webmodule-border-radius-medium);\r\n border: solid 1px var(--webmodule-color-neutral-0);\r\n white-space: nowrap;\r\n padding: var(--webmodule-spacing-2x-small) var(--webmodule-spacing-small)\r\n calc(var(--webmodule-spacing-x-small) - 2px) var(--webmodule-spacing-small);\r\n user-select: none;\r\n cursor: inherit;\r\n }\r\n\r\n /* Variant modifiers */\r\n .badge--primary {\r\n background-color: var(--webmodule-color-primary);\r\n color: var(--webmodule-color-neutral-0);\r\n }\r\n\r\n .badge--success {\r\n background-color: var(--webmodule-color-success);\r\n color: var(--webmodule-color-neutral-0);\r\n }\r\n\r\n .badge--neutral {\r\n background-color: var(--webmodule-color-neutral-600);\r\n color: var(--webmodule-color-neutral-0);\r\n }\r\n\r\n .badge--warning {\r\n background-color: var(--webmodule-color-warning);\r\n color: var(--webmodule-color-neutral-0);\r\n }\r\n\r\n .badge--danger {\r\n background-color: var(--webmodule-color-danger);\r\n color: var(--webmodule-color-neutral-0);\r\n }\r\n\r\n .badge--pill {\r\n border-radius: var(--webmodule-border-radius-pill);\r\n }\r\n\r\n .badge--pulse {\r\n animation: pulse 1.5s infinite;\r\n }\r\n\r\n .badge--pulse.badge--primary {\r\n --pulse-color: var(--webmodule-color-primary);\r\n }\r\n\r\n .badge--pulse.badge--success {\r\n --pulse-color: var(--webmodule-color-success);\r\n }\r\n\r\n .badge--pulse.badge--neutral {\r\n --pulse-color: var(--webmodule-color-neutral-600);\r\n }\r\n\r\n .badge--pulse.badge--warning {\r\n --pulse-color: var(--webmodule-color-warning);\r\n }\r\n\r\n .badge--pulse.badge--danger {\r\n --pulse-color: var(--webmodule-color-danger);\r\n }\r\n\r\n @keyframes pulse {\r\n 0% {\r\n box-shadow: 0 0 0 0 var(--pulse-color);\r\n }\r\n 70% {\r\n box-shadow: 0 0 0 0.5rem transparent;\r\n }\r\n 100% {\r\n box-shadow: 0 0 0 0 transparent;\r\n }\r\n }\r\n`;\r\n","import { classMap } from 'lit/directives/class-map.js';\r\nimport { html } from 'lit';\r\nimport { property } from 'lit/decorators.js';\r\nimport componentStyles from '../../styles/component.styles.js';\r\nimport styles from './badge.styles.js';\r\nimport WebModuleElement from '../../common/webmodule-element.js';\r\nimport type { CSSResultGroup } from 'lit';\r\n\r\n/**\r\n * @summary Badges are used to draw attention and display statuses or counts.\r\n *\r\n * @slot - Content of the badge.\r\n *\r\n * @csspart base - Component's base wrapper.\r\n *\r\n * @tag webmodule-badge\r\n */\r\nexport default class WebmoduleBadge extends WebModuleElement {\r\n static styles: CSSResultGroup = [componentStyles, styles];\r\n\r\n /** The badge's theme variant. */\r\n @property({ reflect: true })\r\n variant: 'primary' | 'success' | 'neutral' | 'warning' | 'danger' = 'primary';\r\n\r\n /** Draws a pill-style badge with rounded edges. */\r\n @property({ type: Boolean, reflect: true })\r\n pill = false;\r\n\r\n /** Makes the badge pulsate to draw attention. */\r\n @property({ type: Boolean, reflect: true })\r\n pulse = false;\r\n\r\n render() {\r\n return html`\r\n \r\n `;\r\n }\r\n}\r\n\r\ndeclare global {\r\n interface HTMLElementTagNameMap {\r\n 'webmodule-badge': WebmoduleBadge;\r\n }\r\n}\r\n","import { css } from 'lit';\r\n\r\nexport default css`\r\n :host {\r\n --border-raduis: var(--webmodule-border-radius-pill);\r\n --color: var(--webmodule-color-neutral-200);\r\n --shimmer-color: var(--webmodule-color-neutral-300);\r\n\r\n display: block;\r\n position: relative;\r\n }\r\n\r\n .placeholder {\r\n display: flex;\r\n width: 100%;\r\n height: 100%;\r\n min-height: 1rem;\r\n }\r\n\r\n .placeholder--display {\r\n flex: 1 1 auto;\r\n background: var(--color);\r\n border-radius: var(--border-raduis);\r\n }\r\n\r\n .placeholder--shimmer .placeholder--display {\r\n background: linear-gradient(270deg, var(--shimmer-color), var(--color), var(--color), var(--shimmer-color));\r\n background-size: 400% 100%;\r\n animation: shimmer 8s ease-in-out infinite;\r\n }\r\n\r\n @keyframes shimmer {\r\n 0% {\r\n background-position: 200% 0;\r\n }\r\n to {\r\n background-position: -200% 0;\r\n }\r\n }\r\n`;\r\n","import { classMap } from 'lit/directives/class-map.js';\r\nimport { html } from 'lit';\r\nimport { property } from 'lit/decorators.js';\r\nimport componentStyles from '../../styles/component.styles.js';\r\nimport styles from './placeholder.styles.js';\r\nimport WebModuleElement from '../../common/webmodule-element.js';\r\nimport type { CSSResultGroup } from 'lit';\r\n\r\n/**\r\n * @summary A placeholder component to visually show where content will be rendered\r\n *\r\n * @csspart base - The component's base wrapper.\r\n * @csspart display - The display element\r\n *\r\n * @cssproperty --border-radius - The border radius of the display element.\r\n * @cssproperty --color - The color of the display element.\r\n * @cssproperty --shimmer-color - The shimmer color of the display element.\r\n *\r\n * @tag webmodule-placeholder\r\n */\r\nexport default class WebmodulePlaceholder extends WebModuleElement {\r\n static styles: CSSResultGroup = [componentStyles, styles];\r\n\r\n /** Flag indicating if the shimmer animation should be applied. */\r\n @property({ type: Boolean, reflect: true })\r\n shimmer = false;\r\n\r\n render() {\r\n return html`\r\n \r\n
\r\n \r\n `;\r\n }\r\n}\r\n\r\ndeclare global {\r\n interface HTMLElementTagNameMap {\r\n 'webmodule-placeholder': WebmodulePlaceholder;\r\n }\r\n}\r\n","import { css } from 'lit';\r\n\r\nexport default css`\r\n .breadcrumb {\r\n display: flex;\r\n align-items: center;\r\n flex-wrap: wrap;\r\n }\r\n`;\r\n","import '../icon/icon.js';\r\nimport { html } from 'lit';\r\nimport { query } from 'lit/decorators.js';\r\nimport componentStyles from '../../styles/component.styles.js';\r\nimport styles from './breadcrumb.styles.js';\r\nimport WebModuleElement from '../../common/webmodule-element.js';\r\nimport type { CSSResultGroup } from 'lit';\r\nimport type WebmoduleBreadcrumbItem from '../breadcrumb-item/breadcrumb-item.js';\r\n\r\n/**\r\n * @summary Breadcrumbs provide links so users can navigate a hierarchy.\r\n *\r\n * @dependency webmodule-icon\r\n *\r\n * @slot - The default slot for breadcrumb-item.\r\n * @slot separator - Rendered element to separate breadcrumb-item\r\n *\r\n * @csspart base - The component's base wrapper.\r\n *\r\n * @tag webmodule-breadcrumb\r\n */\r\nexport default class WebmoduleBreadcrumb extends WebModuleElement {\r\n static styles: CSSResultGroup = [componentStyles, styles];\r\n\r\n @query('slot')\r\n defaultSlot: HTMLSlotElement;\r\n\r\n @query('slot[name=\"separator\"]')\r\n separatorSlot: HTMLSlotElement;\r\n\r\n private getSeparator() {\r\n const separator = this.separatorSlot.assignedElements({ flatten: true })[0] as HTMLElement;\r\n\r\n const clone = separator.cloneNode(true) as HTMLElement;\r\n [clone, ...clone.querySelectorAll('[id]')].forEach(el => el.removeAttribute('id'));\r\n clone.setAttribute('data-default', '');\r\n clone.slot = 'separator';\r\n\r\n return clone;\r\n }\r\n\r\n private slotChangeHandler() {\r\n const items = [...this.defaultSlot.assignedElements({ flatten: true })].filter(\r\n item => item.tagName.toLowerCase() === 'webmodule-breadcrumb-item'\r\n ) as WebmoduleBreadcrumbItem[];\r\n\r\n items.forEach(item => {\r\n const separator = item.querySelector('[slot=\"separator\"]');\r\n if (separator === null) {\r\n // No separator exists, add one\r\n item.append(this.getSeparator());\r\n } else if (separator.hasAttribute('data-default')) {\r\n // A default separator exists, replace it\r\n separator.replaceWith(this.getSeparator());\r\n } else {\r\n // The user provided a custom separator, leave it alone\r\n }\r\n });\r\n }\r\n\r\n render() {\r\n return html`\r\n \r\n\r\n \r\n `;\r\n }\r\n}\r\n\r\ndeclare global {\r\n interface HTMLElementTagNameMap {\r\n 'webmodule-breadcrumb': WebmoduleBreadcrumb;\r\n }\r\n}\r\n","import{nothing as D}from\"../lit-html.js\";\n/**\n * @license\n * Copyright 2018 Google LLC\n * SPDX-License-Identifier: BSD-3-Clause\n */const to=t=>t??D;export{to as ifDefined};\n//# sourceMappingURL=if-defined.js.map\n","import { css } from 'lit';\r\n\r\nexport default css`\r\n :host {\r\n display: inline-flex;\r\n }\r\n\r\n .breadcrumb-item {\r\n display: inline-flex;\r\n align-items: center;\r\n font-family: var(--webmodule-font-sans);\r\n font-size: var(--webmodule-font-size-small);\r\n font-weight: var(--webmodule-font-weight-semibold);\r\n color: var(--webmodule-color-neutral-600);\r\n line-height: var(--webmodule-line-height-normal);\r\n white-space: nowrap;\r\n }\r\n\r\n .breadcrumb-item__label {\r\n display: inline-block;\r\n font-family: inherit;\r\n font-size: inherit;\r\n font-weight: inherit;\r\n line-height: inherit;\r\n text-decoration: none;\r\n color: inherit;\r\n background: none;\r\n border: none;\r\n border-radius: var(--webmodule-border-radius-medium);\r\n padding: 0;\r\n margin: 0;\r\n cursor: pointer;\r\n transition: var(--webmodule-animate-fast) --color;\r\n }\r\n\r\n :host(:not(:last-of-type)) .breadcrumb-item__label {\r\n color: var(--webmodule-color-primary-600);\r\n }\r\n\r\n :host(:not(:last-of-type)) .breadcrumb-item__label:hover {\r\n color: var(--webmodule-color-primary-500);\r\n }\r\n\r\n :host(:not(:last-of-type)) .breadcrumb-item__label:active {\r\n color: var(--webmodule-color-primary-600);\r\n }\r\n\r\n .breadcrumb-item__label:focus {\r\n outline: none;\r\n }\r\n\r\n .breadcrumb-item__label:focus-visible {\r\n outline: var(--webmodule-focus-border);\r\n outline-offset: var(--webmodule-focus-border-offset);\r\n }\r\n\r\n .breadcrumb-item__prefix,\r\n .breadcrumb-item__suffix {\r\n display: none;\r\n flex: 0 0 auto;\r\n display: flex;\r\n align-items: center;\r\n }\r\n\r\n .breadcrumb-item--has-prefix .breadcrumb-item__prefix {\r\n display: inline-flex;\r\n margin-inline-end: var(--webmodule-spacing-x-small);\r\n }\r\n\r\n .breadcrumb-item--has-suffix .breadcrumb-item__suffix {\r\n display: inline-flex;\r\n margin-inline-start: var(--webmodule-spacing-x-small);\r\n }\r\n\r\n :host(:last-of-type) .breadcrumb-item__separator {\r\n display: none;\r\n }\r\n\r\n .breadcrumb-item__separator {\r\n display: inline-flex;\r\n align-items: center;\r\n margin: 0 var(--webmodule-spacing-x-small);\r\n user-select: none;\r\n -webkit-user-select: none;\r\n }\r\n`;\r\n","import { classMap } from 'lit/directives/class-map.js';\r\nimport { HasSlotController } from '../../common/slot-controller.js';\r\nimport { html } from 'lit';\r\nimport { ifDefined } from 'lit/directives/if-defined.js';\r\nimport { property } from 'lit/decorators.js';\r\nimport componentStyles from '../../styles/component.styles.js';\r\nimport styles from './breadcrumb-item.styles.js';\r\nimport WebModuleElement from '../../common/webmodule-element.js';\r\nimport type { CSSResultGroup } from 'lit';\r\n\r\n/**\r\n * @summary Breadcrumb item, for use inside a Breadcrumb component\r\n *\r\n * @slot - Default content.\r\n * @slot prefix - An optional prefix, usually an icon or icon button.\r\n * @slot suffix - An optional suffix, usually an icon or icon button.\r\n * @slot separator - Separator to use with this item only.\r\n *\r\n * @csspart base - The component's base wrapper.\r\n * @csspart content - The breadcrumb item's content.\r\n *\r\n * @tag webmodule-breadcrumb-item\r\n */\r\nexport default class WebmoduleBreadcrumbItem extends WebModuleElement {\r\n static styles: CSSResultGroup = [componentStyles, styles];\r\n\r\n /**\r\n * Optional URL to direct the user to when the breadcrumb item is activated. When set, a link will be rendered\r\n * internally. When unset, a button will be rendered instead.\r\n */\r\n @property() href?: string;\r\n\r\n /** Tells the browser where to open the link. Only used when `href` is set. */\r\n @property() target?: '_blank' | '_parent' | '_self' | '_top';\r\n\r\n /** The `rel` attribute to use on the link. Only used when `href` is set. */\r\n @property() rel = 'noreferrer noopener';\r\n\r\n private readonly hasSlotController = new HasSlotController(this, 'prefix', 'suffix');\r\n\r\n render() {\r\n const isLink = this.href ? true : false;\r\n\r\n return html`\r\n \r\n \r\n \r\n \r\n\r\n ${isLink\r\n ? html`\r\n \r\n \r\n
\r\n `\r\n : html`\r\n \r\n `}\r\n\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n \r\n `;\r\n }\r\n}\r\n\r\ndeclare global {\r\n interface HTMLElementTagNameMap {\r\n 'webmodule-breadcrumb-item': WebmoduleBreadcrumbItem;\r\n }\r\n}\r\n","/**\n * Custom positioning reference element.\n * @see https://floating-ui.com/docs/virtual-elements\n */\n\nconst sides = ['top', 'right', 'bottom', 'left'];\nconst alignments = ['start', 'end'];\nconst placements = /*#__PURE__*/sides.reduce((acc, side) => acc.concat(side, side + \"-\" + alignments[0], side + \"-\" + alignments[1]), []);\nconst min = Math.min;\nconst max = Math.max;\nconst round = Math.round;\nconst floor = Math.floor;\nconst createCoords = v => ({\n x: v,\n y: v\n});\nconst oppositeSideMap = {\n left: 'right',\n right: 'left',\n bottom: 'top',\n top: 'bottom'\n};\nconst oppositeAlignmentMap = {\n start: 'end',\n end: 'start'\n};\nfunction clamp(start, value, end) {\n return max(start, min(value, end));\n}\nfunction evaluate(value, param) {\n return typeof value === 'function' ? value(param) : value;\n}\nfunction getSide(placement) {\n return placement.split('-')[0];\n}\nfunction getAlignment(placement) {\n return placement.split('-')[1];\n}\nfunction getOppositeAxis(axis) {\n return axis === 'x' ? 'y' : 'x';\n}\nfunction getAxisLength(axis) {\n return axis === 'y' ? 'height' : 'width';\n}\nfunction getSideAxis(placement) {\n return ['top', 'bottom'].includes(getSide(placement)) ? 'y' : 'x';\n}\nfunction getAlignmentAxis(placement) {\n return getOppositeAxis(getSideAxis(placement));\n}\nfunction getAlignmentSides(placement, rects, rtl) {\n if (rtl === void 0) {\n rtl = false;\n }\n const alignment = getAlignment(placement);\n const alignmentAxis = getAlignmentAxis(placement);\n const length = getAxisLength(alignmentAxis);\n let mainAlignmentSide = alignmentAxis === 'x' ? alignment === (rtl ? 'end' : 'start') ? 'right' : 'left' : alignment === 'start' ? 'bottom' : 'top';\n if (rects.reference[length] > rects.floating[length]) {\n mainAlignmentSide = getOppositePlacement(mainAlignmentSide);\n }\n return [mainAlignmentSide, getOppositePlacement(mainAlignmentSide)];\n}\nfunction getExpandedPlacements(placement) {\n const oppositePlacement = getOppositePlacement(placement);\n return [getOppositeAlignmentPlacement(placement), oppositePlacement, getOppositeAlignmentPlacement(oppositePlacement)];\n}\nfunction getOppositeAlignmentPlacement(placement) {\n return placement.replace(/start|end/g, alignment => oppositeAlignmentMap[alignment]);\n}\nfunction getSideList(side, isStart, rtl) {\n const lr = ['left', 'right'];\n const rl = ['right', 'left'];\n const tb = ['top', 'bottom'];\n const bt = ['bottom', 'top'];\n switch (side) {\n case 'top':\n case 'bottom':\n if (rtl) return isStart ? rl : lr;\n return isStart ? lr : rl;\n case 'left':\n case 'right':\n return isStart ? tb : bt;\n default:\n return [];\n }\n}\nfunction getOppositeAxisPlacements(placement, flipAlignment, direction, rtl) {\n const alignment = getAlignment(placement);\n let list = getSideList(getSide(placement), direction === 'start', rtl);\n if (alignment) {\n list = list.map(side => side + \"-\" + alignment);\n if (flipAlignment) {\n list = list.concat(list.map(getOppositeAlignmentPlacement));\n }\n }\n return list;\n}\nfunction getOppositePlacement(placement) {\n return placement.replace(/left|right|bottom|top/g, side => oppositeSideMap[side]);\n}\nfunction expandPaddingObject(padding) {\n return {\n top: 0,\n right: 0,\n bottom: 0,\n left: 0,\n ...padding\n };\n}\nfunction getPaddingObject(padding) {\n return typeof padding !== 'number' ? expandPaddingObject(padding) : {\n top: padding,\n right: padding,\n bottom: padding,\n left: padding\n };\n}\nfunction rectToClientRect(rect) {\n const {\n x,\n y,\n width,\n height\n } = rect;\n return {\n width,\n height,\n top: y,\n left: x,\n right: x + width,\n bottom: y + height,\n x,\n y\n };\n}\n\nexport { alignments, clamp, createCoords, evaluate, expandPaddingObject, floor, getAlignment, getAlignmentAxis, getAlignmentSides, getAxisLength, getExpandedPlacements, getOppositeAlignmentPlacement, getOppositeAxis, getOppositeAxisPlacements, getOppositePlacement, getPaddingObject, getSide, getSideAxis, max, min, placements, rectToClientRect, round, sides };\n","import { getSideAxis, getAlignmentAxis, getAxisLength, getSide, getAlignment, evaluate, getPaddingObject, rectToClientRect, min, clamp, placements, getAlignmentSides, getOppositeAlignmentPlacement, getOppositePlacement, getExpandedPlacements, getOppositeAxisPlacements, sides, max, getOppositeAxis } from '@floating-ui/utils';\nexport { rectToClientRect } from '@floating-ui/utils';\n\nfunction computeCoordsFromPlacement(_ref, placement, rtl) {\n let {\n reference,\n floating\n } = _ref;\n const sideAxis = getSideAxis(placement);\n const alignmentAxis = getAlignmentAxis(placement);\n const alignLength = getAxisLength(alignmentAxis);\n const side = getSide(placement);\n const isVertical = sideAxis === 'y';\n const commonX = reference.x + reference.width / 2 - floating.width / 2;\n const commonY = reference.y + reference.height / 2 - floating.height / 2;\n const commonAlign = reference[alignLength] / 2 - floating[alignLength] / 2;\n let coords;\n switch (side) {\n case 'top':\n coords = {\n x: commonX,\n y: reference.y - floating.height\n };\n break;\n case 'bottom':\n coords = {\n x: commonX,\n y: reference.y + reference.height\n };\n break;\n case 'right':\n coords = {\n x: reference.x + reference.width,\n y: commonY\n };\n break;\n case 'left':\n coords = {\n x: reference.x - floating.width,\n y: commonY\n };\n break;\n default:\n coords = {\n x: reference.x,\n y: reference.y\n };\n }\n switch (getAlignment(placement)) {\n case 'start':\n coords[alignmentAxis] -= commonAlign * (rtl && isVertical ? -1 : 1);\n break;\n case 'end':\n coords[alignmentAxis] += commonAlign * (rtl && isVertical ? -1 : 1);\n break;\n }\n return coords;\n}\n\n/**\n * Computes the `x` and `y` coordinates that will place the floating element\n * next to a given reference element.\n *\n * This export does not have any `platform` interface logic. You will need to\n * write one for the platform you are using Floating UI with.\n */\nconst computePosition = async (reference, floating, config) => {\n const {\n placement = 'bottom',\n strategy = 'absolute',\n middleware = [],\n platform\n } = config;\n const validMiddleware = middleware.filter(Boolean);\n const rtl = await (platform.isRTL == null ? void 0 : platform.isRTL(floating));\n let rects = await platform.getElementRects({\n reference,\n floating,\n strategy\n });\n let {\n x,\n y\n } = computeCoordsFromPlacement(rects, placement, rtl);\n let statefulPlacement = placement;\n let middlewareData = {};\n let resetCount = 0;\n for (let i = 0; i < validMiddleware.length; i++) {\n const {\n name,\n fn\n } = validMiddleware[i];\n const {\n x: nextX,\n y: nextY,\n data,\n reset\n } = await fn({\n x,\n y,\n initialPlacement: placement,\n placement: statefulPlacement,\n strategy,\n middlewareData,\n rects,\n platform,\n elements: {\n reference,\n floating\n }\n });\n x = nextX != null ? nextX : x;\n y = nextY != null ? nextY : y;\n middlewareData = {\n ...middlewareData,\n [name]: {\n ...middlewareData[name],\n ...data\n }\n };\n if (reset && resetCount <= 50) {\n resetCount++;\n if (typeof reset === 'object') {\n if (reset.placement) {\n statefulPlacement = reset.placement;\n }\n if (reset.rects) {\n rects = reset.rects === true ? await platform.getElementRects({\n reference,\n floating,\n strategy\n }) : reset.rects;\n }\n ({\n x,\n y\n } = computeCoordsFromPlacement(rects, statefulPlacement, rtl));\n }\n i = -1;\n }\n }\n return {\n x,\n y,\n placement: statefulPlacement,\n strategy,\n middlewareData\n };\n};\n\n/**\n * Resolves with an object of overflow side offsets that determine how much the\n * element is overflowing a given clipping boundary on each side.\n * - positive = overflowing the boundary by that number of pixels\n * - negative = how many pixels left before it will overflow\n * - 0 = lies flush with the boundary\n * @see https://floating-ui.com/docs/detectOverflow\n */\nasync function detectOverflow(state, options) {\n var _await$platform$isEle;\n if (options === void 0) {\n options = {};\n }\n const {\n x,\n y,\n platform,\n rects,\n elements,\n strategy\n } = state;\n const {\n boundary = 'clippingAncestors',\n rootBoundary = 'viewport',\n elementContext = 'floating',\n altBoundary = false,\n padding = 0\n } = evaluate(options, state);\n const paddingObject = getPaddingObject(padding);\n const altContext = elementContext === 'floating' ? 'reference' : 'floating';\n const element = elements[altBoundary ? altContext : elementContext];\n const clippingClientRect = rectToClientRect(await platform.getClippingRect({\n element: ((_await$platform$isEle = await (platform.isElement == null ? void 0 : platform.isElement(element))) != null ? _await$platform$isEle : true) ? element : element.contextElement || (await (platform.getDocumentElement == null ? void 0 : platform.getDocumentElement(elements.floating))),\n boundary,\n rootBoundary,\n strategy\n }));\n const rect = elementContext === 'floating' ? {\n x,\n y,\n width: rects.floating.width,\n height: rects.floating.height\n } : rects.reference;\n const offsetParent = await (platform.getOffsetParent == null ? void 0 : platform.getOffsetParent(elements.floating));\n const offsetScale = (await (platform.isElement == null ? void 0 : platform.isElement(offsetParent))) ? (await (platform.getScale == null ? void 0 : platform.getScale(offsetParent))) || {\n x: 1,\n y: 1\n } : {\n x: 1,\n y: 1\n };\n const elementClientRect = rectToClientRect(platform.convertOffsetParentRelativeRectToViewportRelativeRect ? await platform.convertOffsetParentRelativeRectToViewportRelativeRect({\n elements,\n rect,\n offsetParent,\n strategy\n }) : rect);\n return {\n top: (clippingClientRect.top - elementClientRect.top + paddingObject.top) / offsetScale.y,\n bottom: (elementClientRect.bottom - clippingClientRect.bottom + paddingObject.bottom) / offsetScale.y,\n left: (clippingClientRect.left - elementClientRect.left + paddingObject.left) / offsetScale.x,\n right: (elementClientRect.right - clippingClientRect.right + paddingObject.right) / offsetScale.x\n };\n}\n\n/**\n * Provides data to position an inner element of the floating element so that it\n * appears centered to the reference element.\n * @see https://floating-ui.com/docs/arrow\n */\nconst arrow = options => ({\n name: 'arrow',\n options,\n async fn(state) {\n const {\n x,\n y,\n placement,\n rects,\n platform,\n elements,\n middlewareData\n } = state;\n // Since `element` is required, we don't Partial<> the type.\n const {\n element,\n padding = 0\n } = evaluate(options, state) || {};\n if (element == null) {\n return {};\n }\n const paddingObject = getPaddingObject(padding);\n const coords = {\n x,\n y\n };\n const axis = getAlignmentAxis(placement);\n const length = getAxisLength(axis);\n const arrowDimensions = await platform.getDimensions(element);\n const isYAxis = axis === 'y';\n const minProp = isYAxis ? 'top' : 'left';\n const maxProp = isYAxis ? 'bottom' : 'right';\n const clientProp = isYAxis ? 'clientHeight' : 'clientWidth';\n const endDiff = rects.reference[length] + rects.reference[axis] - coords[axis] - rects.floating[length];\n const startDiff = coords[axis] - rects.reference[axis];\n const arrowOffsetParent = await (platform.getOffsetParent == null ? void 0 : platform.getOffsetParent(element));\n let clientSize = arrowOffsetParent ? arrowOffsetParent[clientProp] : 0;\n\n // DOM platform can return `window` as the `offsetParent`.\n if (!clientSize || !(await (platform.isElement == null ? void 0 : platform.isElement(arrowOffsetParent)))) {\n clientSize = elements.floating[clientProp] || rects.floating[length];\n }\n const centerToReference = endDiff / 2 - startDiff / 2;\n\n // If the padding is large enough that it causes the arrow to no longer be\n // centered, modify the padding so that it is centered.\n const largestPossiblePadding = clientSize / 2 - arrowDimensions[length] / 2 - 1;\n const minPadding = min(paddingObject[minProp], largestPossiblePadding);\n const maxPadding = min(paddingObject[maxProp], largestPossiblePadding);\n\n // Make sure the arrow doesn't overflow the floating element if the center\n // point is outside the floating element's bounds.\n const min$1 = minPadding;\n const max = clientSize - arrowDimensions[length] - maxPadding;\n const center = clientSize / 2 - arrowDimensions[length] / 2 + centerToReference;\n const offset = clamp(min$1, center, max);\n\n // If the reference is small enough that the arrow's padding causes it to\n // to point to nothing for an aligned placement, adjust the offset of the\n // floating element itself. To ensure `shift()` continues to take action,\n // a single reset is performed when this is true.\n const shouldAddOffset = !middlewareData.arrow && getAlignment(placement) != null && center !== offset && rects.reference[length] / 2 - (center < min$1 ? minPadding : maxPadding) - arrowDimensions[length] / 2 < 0;\n const alignmentOffset = shouldAddOffset ? center < min$1 ? center - min$1 : center - max : 0;\n return {\n [axis]: coords[axis] + alignmentOffset,\n data: {\n [axis]: offset,\n centerOffset: center - offset - alignmentOffset,\n ...(shouldAddOffset && {\n alignmentOffset\n })\n },\n reset: shouldAddOffset\n };\n }\n});\n\nfunction getPlacementList(alignment, autoAlignment, allowedPlacements) {\n const allowedPlacementsSortedByAlignment = alignment ? [...allowedPlacements.filter(placement => getAlignment(placement) === alignment), ...allowedPlacements.filter(placement => getAlignment(placement) !== alignment)] : allowedPlacements.filter(placement => getSide(placement) === placement);\n return allowedPlacementsSortedByAlignment.filter(placement => {\n if (alignment) {\n return getAlignment(placement) === alignment || (autoAlignment ? getOppositeAlignmentPlacement(placement) !== placement : false);\n }\n return true;\n });\n}\n/**\n * Optimizes the visibility of the floating element by choosing the placement\n * that has the most space available automatically, without needing to specify a\n * preferred placement. Alternative to `flip`.\n * @see https://floating-ui.com/docs/autoPlacement\n */\nconst autoPlacement = function (options) {\n if (options === void 0) {\n options = {};\n }\n return {\n name: 'autoPlacement',\n options,\n async fn(state) {\n var _middlewareData$autoP, _middlewareData$autoP2, _placementsThatFitOnE;\n const {\n rects,\n middlewareData,\n placement,\n platform,\n elements\n } = state;\n const {\n crossAxis = false,\n alignment,\n allowedPlacements = placements,\n autoAlignment = true,\n ...detectOverflowOptions\n } = evaluate(options, state);\n const placements$1 = alignment !== undefined || allowedPlacements === placements ? getPlacementList(alignment || null, autoAlignment, allowedPlacements) : allowedPlacements;\n const overflow = await detectOverflow(state, detectOverflowOptions);\n const currentIndex = ((_middlewareData$autoP = middlewareData.autoPlacement) == null ? void 0 : _middlewareData$autoP.index) || 0;\n const currentPlacement = placements$1[currentIndex];\n if (currentPlacement == null) {\n return {};\n }\n const alignmentSides = getAlignmentSides(currentPlacement, rects, await (platform.isRTL == null ? void 0 : platform.isRTL(elements.floating)));\n\n // Make `computeCoords` start from the right place.\n if (placement !== currentPlacement) {\n return {\n reset: {\n placement: placements$1[0]\n }\n };\n }\n const currentOverflows = [overflow[getSide(currentPlacement)], overflow[alignmentSides[0]], overflow[alignmentSides[1]]];\n const allOverflows = [...(((_middlewareData$autoP2 = middlewareData.autoPlacement) == null ? void 0 : _middlewareData$autoP2.overflows) || []), {\n placement: currentPlacement,\n overflows: currentOverflows\n }];\n const nextPlacement = placements$1[currentIndex + 1];\n\n // There are more placements to check.\n if (nextPlacement) {\n return {\n data: {\n index: currentIndex + 1,\n overflows: allOverflows\n },\n reset: {\n placement: nextPlacement\n }\n };\n }\n const placementsSortedByMostSpace = allOverflows.map(d => {\n const alignment = getAlignment(d.placement);\n return [d.placement, alignment && crossAxis ?\n // Check along the mainAxis and main crossAxis side.\n d.overflows.slice(0, 2).reduce((acc, v) => acc + v, 0) :\n // Check only the mainAxis.\n d.overflows[0], d.overflows];\n }).sort((a, b) => a[1] - b[1]);\n const placementsThatFitOnEachSide = placementsSortedByMostSpace.filter(d => d[2].slice(0,\n // Aligned placements should not check their opposite crossAxis\n // side.\n getAlignment(d[0]) ? 2 : 3).every(v => v <= 0));\n const resetPlacement = ((_placementsThatFitOnE = placementsThatFitOnEachSide[0]) == null ? void 0 : _placementsThatFitOnE[0]) || placementsSortedByMostSpace[0][0];\n if (resetPlacement !== placement) {\n return {\n data: {\n index: currentIndex + 1,\n overflows: allOverflows\n },\n reset: {\n placement: resetPlacement\n }\n };\n }\n return {};\n }\n };\n};\n\n/**\n * Optimizes the visibility of the floating element by flipping the `placement`\n * in order to keep it in view when the preferred placement(s) will overflow the\n * clipping boundary. Alternative to `autoPlacement`.\n * @see https://floating-ui.com/docs/flip\n */\nconst flip = function (options) {\n if (options === void 0) {\n options = {};\n }\n return {\n name: 'flip',\n options,\n async fn(state) {\n var _middlewareData$arrow, _middlewareData$flip;\n const {\n placement,\n middlewareData,\n rects,\n initialPlacement,\n platform,\n elements\n } = state;\n const {\n mainAxis: checkMainAxis = true,\n crossAxis: checkCrossAxis = true,\n fallbackPlacements: specifiedFallbackPlacements,\n fallbackStrategy = 'bestFit',\n fallbackAxisSideDirection = 'none',\n flipAlignment = true,\n ...detectOverflowOptions\n } = evaluate(options, state);\n\n // If a reset by the arrow was caused due to an alignment offset being\n // added, we should skip any logic now since `flip()` has already done its\n // work.\n // https://github.com/floating-ui/floating-ui/issues/2549#issuecomment-1719601643\n if ((_middlewareData$arrow = middlewareData.arrow) != null && _middlewareData$arrow.alignmentOffset) {\n return {};\n }\n const side = getSide(placement);\n const isBasePlacement = getSide(initialPlacement) === initialPlacement;\n const rtl = await (platform.isRTL == null ? void 0 : platform.isRTL(elements.floating));\n const fallbackPlacements = specifiedFallbackPlacements || (isBasePlacement || !flipAlignment ? [getOppositePlacement(initialPlacement)] : getExpandedPlacements(initialPlacement));\n if (!specifiedFallbackPlacements && fallbackAxisSideDirection !== 'none') {\n fallbackPlacements.push(...getOppositeAxisPlacements(initialPlacement, flipAlignment, fallbackAxisSideDirection, rtl));\n }\n const placements = [initialPlacement, ...fallbackPlacements];\n const overflow = await detectOverflow(state, detectOverflowOptions);\n const overflows = [];\n let overflowsData = ((_middlewareData$flip = middlewareData.flip) == null ? void 0 : _middlewareData$flip.overflows) || [];\n if (checkMainAxis) {\n overflows.push(overflow[side]);\n }\n if (checkCrossAxis) {\n const sides = getAlignmentSides(placement, rects, rtl);\n overflows.push(overflow[sides[0]], overflow[sides[1]]);\n }\n overflowsData = [...overflowsData, {\n placement,\n overflows\n }];\n\n // One or more sides is overflowing.\n if (!overflows.every(side => side <= 0)) {\n var _middlewareData$flip2, _overflowsData$filter;\n const nextIndex = (((_middlewareData$flip2 = middlewareData.flip) == null ? void 0 : _middlewareData$flip2.index) || 0) + 1;\n const nextPlacement = placements[nextIndex];\n if (nextPlacement) {\n // Try next placement and re-run the lifecycle.\n return {\n data: {\n index: nextIndex,\n overflows: overflowsData\n },\n reset: {\n placement: nextPlacement\n }\n };\n }\n\n // First, find the candidates that fit on the mainAxis side of overflow,\n // then find the placement that fits the best on the main crossAxis side.\n let resetPlacement = (_overflowsData$filter = overflowsData.filter(d => d.overflows[0] <= 0).sort((a, b) => a.overflows[1] - b.overflows[1])[0]) == null ? void 0 : _overflowsData$filter.placement;\n\n // Otherwise fallback.\n if (!resetPlacement) {\n switch (fallbackStrategy) {\n case 'bestFit':\n {\n var _overflowsData$map$so;\n const placement = (_overflowsData$map$so = overflowsData.map(d => [d.placement, d.overflows.filter(overflow => overflow > 0).reduce((acc, overflow) => acc + overflow, 0)]).sort((a, b) => a[1] - b[1])[0]) == null ? void 0 : _overflowsData$map$so[0];\n if (placement) {\n resetPlacement = placement;\n }\n break;\n }\n case 'initialPlacement':\n resetPlacement = initialPlacement;\n break;\n }\n }\n if (placement !== resetPlacement) {\n return {\n reset: {\n placement: resetPlacement\n }\n };\n }\n }\n return {};\n }\n };\n};\n\nfunction getSideOffsets(overflow, rect) {\n return {\n top: overflow.top - rect.height,\n right: overflow.right - rect.width,\n bottom: overflow.bottom - rect.height,\n left: overflow.left - rect.width\n };\n}\nfunction isAnySideFullyClipped(overflow) {\n return sides.some(side => overflow[side] >= 0);\n}\n/**\n * Provides data to hide the floating element in applicable situations, such as\n * when it is not in the same clipping context as the reference element.\n * @see https://floating-ui.com/docs/hide\n */\nconst hide = function (options) {\n if (options === void 0) {\n options = {};\n }\n return {\n name: 'hide',\n options,\n async fn(state) {\n const {\n rects\n } = state;\n const {\n strategy = 'referenceHidden',\n ...detectOverflowOptions\n } = evaluate(options, state);\n switch (strategy) {\n case 'referenceHidden':\n {\n const overflow = await detectOverflow(state, {\n ...detectOverflowOptions,\n elementContext: 'reference'\n });\n const offsets = getSideOffsets(overflow, rects.reference);\n return {\n data: {\n referenceHiddenOffsets: offsets,\n referenceHidden: isAnySideFullyClipped(offsets)\n }\n };\n }\n case 'escaped':\n {\n const overflow = await detectOverflow(state, {\n ...detectOverflowOptions,\n altBoundary: true\n });\n const offsets = getSideOffsets(overflow, rects.floating);\n return {\n data: {\n escapedOffsets: offsets,\n escaped: isAnySideFullyClipped(offsets)\n }\n };\n }\n default:\n {\n return {};\n }\n }\n }\n };\n};\n\nfunction getBoundingRect(rects) {\n const minX = min(...rects.map(rect => rect.left));\n const minY = min(...rects.map(rect => rect.top));\n const maxX = max(...rects.map(rect => rect.right));\n const maxY = max(...rects.map(rect => rect.bottom));\n return {\n x: minX,\n y: minY,\n width: maxX - minX,\n height: maxY - minY\n };\n}\nfunction getRectsByLine(rects) {\n const sortedRects = rects.slice().sort((a, b) => a.y - b.y);\n const groups = [];\n let prevRect = null;\n for (let i = 0; i < sortedRects.length; i++) {\n const rect = sortedRects[i];\n if (!prevRect || rect.y - prevRect.y > prevRect.height / 2) {\n groups.push([rect]);\n } else {\n groups[groups.length - 1].push(rect);\n }\n prevRect = rect;\n }\n return groups.map(rect => rectToClientRect(getBoundingRect(rect)));\n}\n/**\n * Provides improved positioning for inline reference elements that can span\n * over multiple lines, such as hyperlinks or range selections.\n * @see https://floating-ui.com/docs/inline\n */\nconst inline = function (options) {\n if (options === void 0) {\n options = {};\n }\n return {\n name: 'inline',\n options,\n async fn(state) {\n const {\n placement,\n elements,\n rects,\n platform,\n strategy\n } = state;\n // A MouseEvent's client{X,Y} coords can be up to 2 pixels off a\n // ClientRect's bounds, despite the event listener being triggered. A\n // padding of 2 seems to handle this issue.\n const {\n padding = 2,\n x,\n y\n } = evaluate(options, state);\n const nativeClientRects = Array.from((await (platform.getClientRects == null ? void 0 : platform.getClientRects(elements.reference))) || []);\n const clientRects = getRectsByLine(nativeClientRects);\n const fallback = rectToClientRect(getBoundingRect(nativeClientRects));\n const paddingObject = getPaddingObject(padding);\n function getBoundingClientRect() {\n // There are two rects and they are disjoined.\n if (clientRects.length === 2 && clientRects[0].left > clientRects[1].right && x != null && y != null) {\n // Find the first rect in which the point is fully inside.\n return clientRects.find(rect => x > rect.left - paddingObject.left && x < rect.right + paddingObject.right && y > rect.top - paddingObject.top && y < rect.bottom + paddingObject.bottom) || fallback;\n }\n\n // There are 2 or more connected rects.\n if (clientRects.length >= 2) {\n if (getSideAxis(placement) === 'y') {\n const firstRect = clientRects[0];\n const lastRect = clientRects[clientRects.length - 1];\n const isTop = getSide(placement) === 'top';\n const top = firstRect.top;\n const bottom = lastRect.bottom;\n const left = isTop ? firstRect.left : lastRect.left;\n const right = isTop ? firstRect.right : lastRect.right;\n const width = right - left;\n const height = bottom - top;\n return {\n top,\n bottom,\n left,\n right,\n width,\n height,\n x: left,\n y: top\n };\n }\n const isLeftSide = getSide(placement) === 'left';\n const maxRight = max(...clientRects.map(rect => rect.right));\n const minLeft = min(...clientRects.map(rect => rect.left));\n const measureRects = clientRects.filter(rect => isLeftSide ? rect.left === minLeft : rect.right === maxRight);\n const top = measureRects[0].top;\n const bottom = measureRects[measureRects.length - 1].bottom;\n const left = minLeft;\n const right = maxRight;\n const width = right - left;\n const height = bottom - top;\n return {\n top,\n bottom,\n left,\n right,\n width,\n height,\n x: left,\n y: top\n };\n }\n return fallback;\n }\n const resetRects = await platform.getElementRects({\n reference: {\n getBoundingClientRect\n },\n floating: elements.floating,\n strategy\n });\n if (rects.reference.x !== resetRects.reference.x || rects.reference.y !== resetRects.reference.y || rects.reference.width !== resetRects.reference.width || rects.reference.height !== resetRects.reference.height) {\n return {\n reset: {\n rects: resetRects\n }\n };\n }\n return {};\n }\n };\n};\n\n// For type backwards-compatibility, the `OffsetOptions` type was also\n// Derivable.\n\nasync function convertValueToCoords(state, options) {\n const {\n placement,\n platform,\n elements\n } = state;\n const rtl = await (platform.isRTL == null ? void 0 : platform.isRTL(elements.floating));\n const side = getSide(placement);\n const alignment = getAlignment(placement);\n const isVertical = getSideAxis(placement) === 'y';\n const mainAxisMulti = ['left', 'top'].includes(side) ? -1 : 1;\n const crossAxisMulti = rtl && isVertical ? -1 : 1;\n const rawValue = evaluate(options, state);\n\n // eslint-disable-next-line prefer-const\n let {\n mainAxis,\n crossAxis,\n alignmentAxis\n } = typeof rawValue === 'number' ? {\n mainAxis: rawValue,\n crossAxis: 0,\n alignmentAxis: null\n } : {\n mainAxis: 0,\n crossAxis: 0,\n alignmentAxis: null,\n ...rawValue\n };\n if (alignment && typeof alignmentAxis === 'number') {\n crossAxis = alignment === 'end' ? alignmentAxis * -1 : alignmentAxis;\n }\n return isVertical ? {\n x: crossAxis * crossAxisMulti,\n y: mainAxis * mainAxisMulti\n } : {\n x: mainAxis * mainAxisMulti,\n y: crossAxis * crossAxisMulti\n };\n}\n\n/**\n * Modifies the placement by translating the floating element along the\n * specified axes.\n * A number (shorthand for `mainAxis` or distance), or an axes configuration\n * object may be passed.\n * @see https://floating-ui.com/docs/offset\n */\nconst offset = function (options) {\n if (options === void 0) {\n options = 0;\n }\n return {\n name: 'offset',\n options,\n async fn(state) {\n var _middlewareData$offse, _middlewareData$arrow;\n const {\n x,\n y,\n placement,\n middlewareData\n } = state;\n const diffCoords = await convertValueToCoords(state, options);\n\n // If the placement is the same and the arrow caused an alignment offset\n // then we don't need to change the positioning coordinates.\n if (placement === ((_middlewareData$offse = middlewareData.offset) == null ? void 0 : _middlewareData$offse.placement) && (_middlewareData$arrow = middlewareData.arrow) != null && _middlewareData$arrow.alignmentOffset) {\n return {};\n }\n return {\n x: x + diffCoords.x,\n y: y + diffCoords.y,\n data: {\n ...diffCoords,\n placement\n }\n };\n }\n };\n};\n\n/**\n * Optimizes the visibility of the floating element by shifting it in order to\n * keep it in view when it will overflow the clipping boundary.\n * @see https://floating-ui.com/docs/shift\n */\nconst shift = function (options) {\n if (options === void 0) {\n options = {};\n }\n return {\n name: 'shift',\n options,\n async fn(state) {\n const {\n x,\n y,\n placement\n } = state;\n const {\n mainAxis: checkMainAxis = true,\n crossAxis: checkCrossAxis = false,\n limiter = {\n fn: _ref => {\n let {\n x,\n y\n } = _ref;\n return {\n x,\n y\n };\n }\n },\n ...detectOverflowOptions\n } = evaluate(options, state);\n const coords = {\n x,\n y\n };\n const overflow = await detectOverflow(state, detectOverflowOptions);\n const crossAxis = getSideAxis(getSide(placement));\n const mainAxis = getOppositeAxis(crossAxis);\n let mainAxisCoord = coords[mainAxis];\n let crossAxisCoord = coords[crossAxis];\n if (checkMainAxis) {\n const minSide = mainAxis === 'y' ? 'top' : 'left';\n const maxSide = mainAxis === 'y' ? 'bottom' : 'right';\n const min = mainAxisCoord + overflow[minSide];\n const max = mainAxisCoord - overflow[maxSide];\n mainAxisCoord = clamp(min, mainAxisCoord, max);\n }\n if (checkCrossAxis) {\n const minSide = crossAxis === 'y' ? 'top' : 'left';\n const maxSide = crossAxis === 'y' ? 'bottom' : 'right';\n const min = crossAxisCoord + overflow[minSide];\n const max = crossAxisCoord - overflow[maxSide];\n crossAxisCoord = clamp(min, crossAxisCoord, max);\n }\n const limitedCoords = limiter.fn({\n ...state,\n [mainAxis]: mainAxisCoord,\n [crossAxis]: crossAxisCoord\n });\n return {\n ...limitedCoords,\n data: {\n x: limitedCoords.x - x,\n y: limitedCoords.y - y\n }\n };\n }\n };\n};\n/**\n * Built-in `limiter` that will stop `shift()` at a certain point.\n */\nconst limitShift = function (options) {\n if (options === void 0) {\n options = {};\n }\n return {\n options,\n fn(state) {\n const {\n x,\n y,\n placement,\n rects,\n middlewareData\n } = state;\n const {\n offset = 0,\n mainAxis: checkMainAxis = true,\n crossAxis: checkCrossAxis = true\n } = evaluate(options, state);\n const coords = {\n x,\n y\n };\n const crossAxis = getSideAxis(placement);\n const mainAxis = getOppositeAxis(crossAxis);\n let mainAxisCoord = coords[mainAxis];\n let crossAxisCoord = coords[crossAxis];\n const rawOffset = evaluate(offset, state);\n const computedOffset = typeof rawOffset === 'number' ? {\n mainAxis: rawOffset,\n crossAxis: 0\n } : {\n mainAxis: 0,\n crossAxis: 0,\n ...rawOffset\n };\n if (checkMainAxis) {\n const len = mainAxis === 'y' ? 'height' : 'width';\n const limitMin = rects.reference[mainAxis] - rects.floating[len] + computedOffset.mainAxis;\n const limitMax = rects.reference[mainAxis] + rects.reference[len] - computedOffset.mainAxis;\n if (mainAxisCoord < limitMin) {\n mainAxisCoord = limitMin;\n } else if (mainAxisCoord > limitMax) {\n mainAxisCoord = limitMax;\n }\n }\n if (checkCrossAxis) {\n var _middlewareData$offse, _middlewareData$offse2;\n const len = mainAxis === 'y' ? 'width' : 'height';\n const isOriginSide = ['top', 'left'].includes(getSide(placement));\n const limitMin = rects.reference[crossAxis] - rects.floating[len] + (isOriginSide ? ((_middlewareData$offse = middlewareData.offset) == null ? void 0 : _middlewareData$offse[crossAxis]) || 0 : 0) + (isOriginSide ? 0 : computedOffset.crossAxis);\n const limitMax = rects.reference[crossAxis] + rects.reference[len] + (isOriginSide ? 0 : ((_middlewareData$offse2 = middlewareData.offset) == null ? void 0 : _middlewareData$offse2[crossAxis]) || 0) - (isOriginSide ? computedOffset.crossAxis : 0);\n if (crossAxisCoord < limitMin) {\n crossAxisCoord = limitMin;\n } else if (crossAxisCoord > limitMax) {\n crossAxisCoord = limitMax;\n }\n }\n return {\n [mainAxis]: mainAxisCoord,\n [crossAxis]: crossAxisCoord\n };\n }\n };\n};\n\n/**\n * Provides data that allows you to change the size of the floating element —\n * for instance, prevent it from overflowing the clipping boundary or match the\n * width of the reference element.\n * @see https://floating-ui.com/docs/size\n */\nconst size = function (options) {\n if (options === void 0) {\n options = {};\n }\n return {\n name: 'size',\n options,\n async fn(state) {\n const {\n placement,\n rects,\n platform,\n elements\n } = state;\n const {\n apply = () => {},\n ...detectOverflowOptions\n } = evaluate(options, state);\n const overflow = await detectOverflow(state, detectOverflowOptions);\n const side = getSide(placement);\n const alignment = getAlignment(placement);\n const isYAxis = getSideAxis(placement) === 'y';\n const {\n width,\n height\n } = rects.floating;\n let heightSide;\n let widthSide;\n if (side === 'top' || side === 'bottom') {\n heightSide = side;\n widthSide = alignment === ((await (platform.isRTL == null ? void 0 : platform.isRTL(elements.floating))) ? 'start' : 'end') ? 'left' : 'right';\n } else {\n widthSide = side;\n heightSide = alignment === 'end' ? 'top' : 'bottom';\n }\n const maximumClippingHeight = height - overflow.top - overflow.bottom;\n const maximumClippingWidth = width - overflow.left - overflow.right;\n const overflowAvailableHeight = min(height - overflow[heightSide], maximumClippingHeight);\n const overflowAvailableWidth = min(width - overflow[widthSide], maximumClippingWidth);\n const noShift = !state.middlewareData.shift;\n let availableHeight = overflowAvailableHeight;\n let availableWidth = overflowAvailableWidth;\n if (isYAxis) {\n availableWidth = alignment || noShift ? min(overflowAvailableWidth, maximumClippingWidth) : maximumClippingWidth;\n } else {\n availableHeight = alignment || noShift ? min(overflowAvailableHeight, maximumClippingHeight) : maximumClippingHeight;\n }\n if (noShift && !alignment) {\n const xMin = max(overflow.left, 0);\n const xMax = max(overflow.right, 0);\n const yMin = max(overflow.top, 0);\n const yMax = max(overflow.bottom, 0);\n if (isYAxis) {\n availableWidth = width - 2 * (xMin !== 0 || xMax !== 0 ? xMin + xMax : max(overflow.left, overflow.right));\n } else {\n availableHeight = height - 2 * (yMin !== 0 || yMax !== 0 ? yMin + yMax : max(overflow.top, overflow.bottom));\n }\n }\n await apply({\n ...state,\n availableWidth,\n availableHeight\n });\n const nextDimensions = await platform.getDimensions(elements.floating);\n if (width !== nextDimensions.width || height !== nextDimensions.height) {\n return {\n reset: {\n rects: true\n }\n };\n }\n return {};\n }\n };\n};\n\nexport { arrow, autoPlacement, computePosition, detectOverflow, flip, hide, inline, limitShift, offset, shift, size };\n","function getNodeName(node) {\n if (isNode(node)) {\n return (node.nodeName || '').toLowerCase();\n }\n // Mocked nodes in testing environments may not be instances of Node. By\n // returning `#document` an infinite loop won't occur.\n // https://github.com/floating-ui/floating-ui/issues/2317\n return '#document';\n}\nfunction getWindow(node) {\n var _node$ownerDocument;\n return (node == null || (_node$ownerDocument = node.ownerDocument) == null ? void 0 : _node$ownerDocument.defaultView) || window;\n}\nfunction getDocumentElement(node) {\n var _ref;\n return (_ref = (isNode(node) ? node.ownerDocument : node.document) || window.document) == null ? void 0 : _ref.documentElement;\n}\nfunction isNode(value) {\n return value instanceof Node || value instanceof getWindow(value).Node;\n}\nfunction isElement(value) {\n return value instanceof Element || value instanceof getWindow(value).Element;\n}\nfunction isHTMLElement(value) {\n return value instanceof HTMLElement || value instanceof getWindow(value).HTMLElement;\n}\nfunction isShadowRoot(value) {\n // Browsers without `ShadowRoot` support.\n if (typeof ShadowRoot === 'undefined') {\n return false;\n }\n return value instanceof ShadowRoot || value instanceof getWindow(value).ShadowRoot;\n}\nfunction isOverflowElement(element) {\n const {\n overflow,\n overflowX,\n overflowY,\n display\n } = getComputedStyle(element);\n return /auto|scroll|overlay|hidden|clip/.test(overflow + overflowY + overflowX) && !['inline', 'contents'].includes(display);\n}\nfunction isTableElement(element) {\n return ['table', 'td', 'th'].includes(getNodeName(element));\n}\nfunction isTopLayer(element) {\n return [':popover-open', ':modal'].some(selector => {\n try {\n return element.matches(selector);\n } catch (e) {\n return false;\n }\n });\n}\nfunction isContainingBlock(elementOrCss) {\n const webkit = isWebKit();\n const css = isElement(elementOrCss) ? getComputedStyle(elementOrCss) : elementOrCss;\n\n // https://developer.mozilla.org/en-US/docs/Web/CSS/Containing_block#identifying_the_containing_block\n return css.transform !== 'none' || css.perspective !== 'none' || (css.containerType ? css.containerType !== 'normal' : false) || !webkit && (css.backdropFilter ? css.backdropFilter !== 'none' : false) || !webkit && (css.filter ? css.filter !== 'none' : false) || ['transform', 'perspective', 'filter'].some(value => (css.willChange || '').includes(value)) || ['paint', 'layout', 'strict', 'content'].some(value => (css.contain || '').includes(value));\n}\nfunction getContainingBlock(element) {\n let currentNode = getParentNode(element);\n while (isHTMLElement(currentNode) && !isLastTraversableNode(currentNode)) {\n if (isContainingBlock(currentNode)) {\n return currentNode;\n } else if (isTopLayer(currentNode)) {\n return null;\n }\n currentNode = getParentNode(currentNode);\n }\n return null;\n}\nfunction isWebKit() {\n if (typeof CSS === 'undefined' || !CSS.supports) return false;\n return CSS.supports('-webkit-backdrop-filter', 'none');\n}\nfunction isLastTraversableNode(node) {\n return ['html', 'body', '#document'].includes(getNodeName(node));\n}\nfunction getComputedStyle(element) {\n return getWindow(element).getComputedStyle(element);\n}\nfunction getNodeScroll(element) {\n if (isElement(element)) {\n return {\n scrollLeft: element.scrollLeft,\n scrollTop: element.scrollTop\n };\n }\n return {\n scrollLeft: element.scrollX,\n scrollTop: element.scrollY\n };\n}\nfunction getParentNode(node) {\n if (getNodeName(node) === 'html') {\n return node;\n }\n const result =\n // Step into the shadow DOM of the parent of a slotted node.\n node.assignedSlot ||\n // DOM Element detected.\n node.parentNode ||\n // ShadowRoot detected.\n isShadowRoot(node) && node.host ||\n // Fallback.\n getDocumentElement(node);\n return isShadowRoot(result) ? result.host : result;\n}\nfunction getNearestOverflowAncestor(node) {\n const parentNode = getParentNode(node);\n if (isLastTraversableNode(parentNode)) {\n return node.ownerDocument ? node.ownerDocument.body : node.body;\n }\n if (isHTMLElement(parentNode) && isOverflowElement(parentNode)) {\n return parentNode;\n }\n return getNearestOverflowAncestor(parentNode);\n}\nfunction getOverflowAncestors(node, list, traverseIframes) {\n var _node$ownerDocument2;\n if (list === void 0) {\n list = [];\n }\n if (traverseIframes === void 0) {\n traverseIframes = true;\n }\n const scrollableAncestor = getNearestOverflowAncestor(node);\n const isBody = scrollableAncestor === ((_node$ownerDocument2 = node.ownerDocument) == null ? void 0 : _node$ownerDocument2.body);\n const win = getWindow(scrollableAncestor);\n if (isBody) {\n const frameElement = getFrameElement(win);\n return list.concat(win, win.visualViewport || [], isOverflowElement(scrollableAncestor) ? scrollableAncestor : [], frameElement && traverseIframes ? getOverflowAncestors(frameElement) : []);\n }\n return list.concat(scrollableAncestor, getOverflowAncestors(scrollableAncestor, [], traverseIframes));\n}\nfunction getFrameElement(win) {\n return win.parent && Object.getPrototypeOf(win.parent) ? win.frameElement : null;\n}\n\nexport { getComputedStyle, getContainingBlock, getDocumentElement, getFrameElement, getNearestOverflowAncestor, getNodeName, getNodeScroll, getOverflowAncestors, getParentNode, getWindow, isContainingBlock, isElement, isHTMLElement, isLastTraversableNode, isNode, isOverflowElement, isShadowRoot, isTableElement, isTopLayer, isWebKit };\n","import { rectToClientRect, detectOverflow as detectOverflow$1, offset as offset$1, autoPlacement as autoPlacement$1, shift as shift$1, flip as flip$1, size as size$1, hide as hide$1, arrow as arrow$1, inline as inline$1, limitShift as limitShift$1, computePosition as computePosition$1 } from '@floating-ui/core';\nimport { round, createCoords, max, min, floor } from '@floating-ui/utils';\nimport { getComputedStyle, isHTMLElement, isElement, getWindow, isWebKit, getFrameElement, getDocumentElement, isTopLayer, getNodeName, isOverflowElement, getNodeScroll, getOverflowAncestors, getParentNode, isLastTraversableNode, isContainingBlock, isTableElement, getContainingBlock } from '@floating-ui/utils/dom';\nexport { getOverflowAncestors } from '@floating-ui/utils/dom';\n\nfunction getCssDimensions(element) {\n const css = getComputedStyle(element);\n // In testing environments, the `width` and `height` properties are empty\n // strings for SVG elements, returning NaN. Fallback to `0` in this case.\n let width = parseFloat(css.width) || 0;\n let height = parseFloat(css.height) || 0;\n const hasOffset = isHTMLElement(element);\n const offsetWidth = hasOffset ? element.offsetWidth : width;\n const offsetHeight = hasOffset ? element.offsetHeight : height;\n const shouldFallback = round(width) !== offsetWidth || round(height) !== offsetHeight;\n if (shouldFallback) {\n width = offsetWidth;\n height = offsetHeight;\n }\n return {\n width,\n height,\n $: shouldFallback\n };\n}\n\nfunction unwrapElement(element) {\n return !isElement(element) ? element.contextElement : element;\n}\n\nfunction getScale(element) {\n const domElement = unwrapElement(element);\n if (!isHTMLElement(domElement)) {\n return createCoords(1);\n }\n const rect = domElement.getBoundingClientRect();\n const {\n width,\n height,\n $\n } = getCssDimensions(domElement);\n let x = ($ ? round(rect.width) : rect.width) / width;\n let y = ($ ? round(rect.height) : rect.height) / height;\n\n // 0, NaN, or Infinity should always fallback to 1.\n\n if (!x || !Number.isFinite(x)) {\n x = 1;\n }\n if (!y || !Number.isFinite(y)) {\n y = 1;\n }\n return {\n x,\n y\n };\n}\n\nconst noOffsets = /*#__PURE__*/createCoords(0);\nfunction getVisualOffsets(element) {\n const win = getWindow(element);\n if (!isWebKit() || !win.visualViewport) {\n return noOffsets;\n }\n return {\n x: win.visualViewport.offsetLeft,\n y: win.visualViewport.offsetTop\n };\n}\nfunction shouldAddVisualOffsets(element, isFixed, floatingOffsetParent) {\n if (isFixed === void 0) {\n isFixed = false;\n }\n if (!floatingOffsetParent || isFixed && floatingOffsetParent !== getWindow(element)) {\n return false;\n }\n return isFixed;\n}\n\nfunction getBoundingClientRect(element, includeScale, isFixedStrategy, offsetParent) {\n if (includeScale === void 0) {\n includeScale = false;\n }\n if (isFixedStrategy === void 0) {\n isFixedStrategy = false;\n }\n const clientRect = element.getBoundingClientRect();\n const domElement = unwrapElement(element);\n let scale = createCoords(1);\n if (includeScale) {\n if (offsetParent) {\n if (isElement(offsetParent)) {\n scale = getScale(offsetParent);\n }\n } else {\n scale = getScale(element);\n }\n }\n const visualOffsets = shouldAddVisualOffsets(domElement, isFixedStrategy, offsetParent) ? getVisualOffsets(domElement) : createCoords(0);\n let x = (clientRect.left + visualOffsets.x) / scale.x;\n let y = (clientRect.top + visualOffsets.y) / scale.y;\n let width = clientRect.width / scale.x;\n let height = clientRect.height / scale.y;\n if (domElement) {\n const win = getWindow(domElement);\n const offsetWin = offsetParent && isElement(offsetParent) ? getWindow(offsetParent) : offsetParent;\n let currentWin = win;\n let currentIFrame = getFrameElement(currentWin);\n while (currentIFrame && offsetParent && offsetWin !== currentWin) {\n const iframeScale = getScale(currentIFrame);\n const iframeRect = currentIFrame.getBoundingClientRect();\n const css = getComputedStyle(currentIFrame);\n const left = iframeRect.left + (currentIFrame.clientLeft + parseFloat(css.paddingLeft)) * iframeScale.x;\n const top = iframeRect.top + (currentIFrame.clientTop + parseFloat(css.paddingTop)) * iframeScale.y;\n x *= iframeScale.x;\n y *= iframeScale.y;\n width *= iframeScale.x;\n height *= iframeScale.y;\n x += left;\n y += top;\n currentWin = getWindow(currentIFrame);\n currentIFrame = getFrameElement(currentWin);\n }\n }\n return rectToClientRect({\n width,\n height,\n x,\n y\n });\n}\n\nfunction convertOffsetParentRelativeRectToViewportRelativeRect(_ref) {\n let {\n elements,\n rect,\n offsetParent,\n strategy\n } = _ref;\n const isFixed = strategy === 'fixed';\n const documentElement = getDocumentElement(offsetParent);\n const topLayer = elements ? isTopLayer(elements.floating) : false;\n if (offsetParent === documentElement || topLayer && isFixed) {\n return rect;\n }\n let scroll = {\n scrollLeft: 0,\n scrollTop: 0\n };\n let scale = createCoords(1);\n const offsets = createCoords(0);\n const isOffsetParentAnElement = isHTMLElement(offsetParent);\n if (isOffsetParentAnElement || !isOffsetParentAnElement && !isFixed) {\n if (getNodeName(offsetParent) !== 'body' || isOverflowElement(documentElement)) {\n scroll = getNodeScroll(offsetParent);\n }\n if (isHTMLElement(offsetParent)) {\n const offsetRect = getBoundingClientRect(offsetParent);\n scale = getScale(offsetParent);\n offsets.x = offsetRect.x + offsetParent.clientLeft;\n offsets.y = offsetRect.y + offsetParent.clientTop;\n }\n }\n return {\n width: rect.width * scale.x,\n height: rect.height * scale.y,\n x: rect.x * scale.x - scroll.scrollLeft * scale.x + offsets.x,\n y: rect.y * scale.y - scroll.scrollTop * scale.y + offsets.y\n };\n}\n\nfunction getClientRects(element) {\n return Array.from(element.getClientRects());\n}\n\nfunction getWindowScrollBarX(element) {\n // If has a CSS width greater than the viewport, then this will be\n // incorrect for RTL.\n return getBoundingClientRect(getDocumentElement(element)).left + getNodeScroll(element).scrollLeft;\n}\n\n// Gets the entire size of the scrollable document area, even extending outside\n// of the `` and `` rect bounds if horizontally scrollable.\nfunction getDocumentRect(element) {\n const html = getDocumentElement(element);\n const scroll = getNodeScroll(element);\n const body = element.ownerDocument.body;\n const width = max(html.scrollWidth, html.clientWidth, body.scrollWidth, body.clientWidth);\n const height = max(html.scrollHeight, html.clientHeight, body.scrollHeight, body.clientHeight);\n let x = -scroll.scrollLeft + getWindowScrollBarX(element);\n const y = -scroll.scrollTop;\n if (getComputedStyle(body).direction === 'rtl') {\n x += max(html.clientWidth, body.clientWidth) - width;\n }\n return {\n width,\n height,\n x,\n y\n };\n}\n\nfunction getViewportRect(element, strategy) {\n const win = getWindow(element);\n const html = getDocumentElement(element);\n const visualViewport = win.visualViewport;\n let width = html.clientWidth;\n let height = html.clientHeight;\n let x = 0;\n let y = 0;\n if (visualViewport) {\n width = visualViewport.width;\n height = visualViewport.height;\n const visualViewportBased = isWebKit();\n if (!visualViewportBased || visualViewportBased && strategy === 'fixed') {\n x = visualViewport.offsetLeft;\n y = visualViewport.offsetTop;\n }\n }\n return {\n width,\n height,\n x,\n y\n };\n}\n\n// Returns the inner client rect, subtracting scrollbars if present.\nfunction getInnerBoundingClientRect(element, strategy) {\n const clientRect = getBoundingClientRect(element, true, strategy === 'fixed');\n const top = clientRect.top + element.clientTop;\n const left = clientRect.left + element.clientLeft;\n const scale = isHTMLElement(element) ? getScale(element) : createCoords(1);\n const width = element.clientWidth * scale.x;\n const height = element.clientHeight * scale.y;\n const x = left * scale.x;\n const y = top * scale.y;\n return {\n width,\n height,\n x,\n y\n };\n}\nfunction getClientRectFromClippingAncestor(element, clippingAncestor, strategy) {\n let rect;\n if (clippingAncestor === 'viewport') {\n rect = getViewportRect(element, strategy);\n } else if (clippingAncestor === 'document') {\n rect = getDocumentRect(getDocumentElement(element));\n } else if (isElement(clippingAncestor)) {\n rect = getInnerBoundingClientRect(clippingAncestor, strategy);\n } else {\n const visualOffsets = getVisualOffsets(element);\n rect = {\n ...clippingAncestor,\n x: clippingAncestor.x - visualOffsets.x,\n y: clippingAncestor.y - visualOffsets.y\n };\n }\n return rectToClientRect(rect);\n}\nfunction hasFixedPositionAncestor(element, stopNode) {\n const parentNode = getParentNode(element);\n if (parentNode === stopNode || !isElement(parentNode) || isLastTraversableNode(parentNode)) {\n return false;\n }\n return getComputedStyle(parentNode).position === 'fixed' || hasFixedPositionAncestor(parentNode, stopNode);\n}\n\n// A \"clipping ancestor\" is an `overflow` element with the characteristic of\n// clipping (or hiding) child elements. This returns all clipping ancestors\n// of the given element up the tree.\nfunction getClippingElementAncestors(element, cache) {\n const cachedResult = cache.get(element);\n if (cachedResult) {\n return cachedResult;\n }\n let result = getOverflowAncestors(element, [], false).filter(el => isElement(el) && getNodeName(el) !== 'body');\n let currentContainingBlockComputedStyle = null;\n const elementIsFixed = getComputedStyle(element).position === 'fixed';\n let currentNode = elementIsFixed ? getParentNode(element) : element;\n\n // https://developer.mozilla.org/en-US/docs/Web/CSS/Containing_block#identifying_the_containing_block\n while (isElement(currentNode) && !isLastTraversableNode(currentNode)) {\n const computedStyle = getComputedStyle(currentNode);\n const currentNodeIsContaining = isContainingBlock(currentNode);\n if (!currentNodeIsContaining && computedStyle.position === 'fixed') {\n currentContainingBlockComputedStyle = null;\n }\n const shouldDropCurrentNode = elementIsFixed ? !currentNodeIsContaining && !currentContainingBlockComputedStyle : !currentNodeIsContaining && computedStyle.position === 'static' && !!currentContainingBlockComputedStyle && ['absolute', 'fixed'].includes(currentContainingBlockComputedStyle.position) || isOverflowElement(currentNode) && !currentNodeIsContaining && hasFixedPositionAncestor(element, currentNode);\n if (shouldDropCurrentNode) {\n // Drop non-containing blocks.\n result = result.filter(ancestor => ancestor !== currentNode);\n } else {\n // Record last containing block for next iteration.\n currentContainingBlockComputedStyle = computedStyle;\n }\n currentNode = getParentNode(currentNode);\n }\n cache.set(element, result);\n return result;\n}\n\n// Gets the maximum area that the element is visible in due to any number of\n// clipping ancestors.\nfunction getClippingRect(_ref) {\n let {\n element,\n boundary,\n rootBoundary,\n strategy\n } = _ref;\n const elementClippingAncestors = boundary === 'clippingAncestors' ? isTopLayer(element) ? [] : getClippingElementAncestors(element, this._c) : [].concat(boundary);\n const clippingAncestors = [...elementClippingAncestors, rootBoundary];\n const firstClippingAncestor = clippingAncestors[0];\n const clippingRect = clippingAncestors.reduce((accRect, clippingAncestor) => {\n const rect = getClientRectFromClippingAncestor(element, clippingAncestor, strategy);\n accRect.top = max(rect.top, accRect.top);\n accRect.right = min(rect.right, accRect.right);\n accRect.bottom = min(rect.bottom, accRect.bottom);\n accRect.left = max(rect.left, accRect.left);\n return accRect;\n }, getClientRectFromClippingAncestor(element, firstClippingAncestor, strategy));\n return {\n width: clippingRect.right - clippingRect.left,\n height: clippingRect.bottom - clippingRect.top,\n x: clippingRect.left,\n y: clippingRect.top\n };\n}\n\nfunction getDimensions(element) {\n const {\n width,\n height\n } = getCssDimensions(element);\n return {\n width,\n height\n };\n}\n\nfunction getRectRelativeToOffsetParent(element, offsetParent, strategy) {\n const isOffsetParentAnElement = isHTMLElement(offsetParent);\n const documentElement = getDocumentElement(offsetParent);\n const isFixed = strategy === 'fixed';\n const rect = getBoundingClientRect(element, true, isFixed, offsetParent);\n let scroll = {\n scrollLeft: 0,\n scrollTop: 0\n };\n const offsets = createCoords(0);\n if (isOffsetParentAnElement || !isOffsetParentAnElement && !isFixed) {\n if (getNodeName(offsetParent) !== 'body' || isOverflowElement(documentElement)) {\n scroll = getNodeScroll(offsetParent);\n }\n if (isOffsetParentAnElement) {\n const offsetRect = getBoundingClientRect(offsetParent, true, isFixed, offsetParent);\n offsets.x = offsetRect.x + offsetParent.clientLeft;\n offsets.y = offsetRect.y + offsetParent.clientTop;\n } else if (documentElement) {\n offsets.x = getWindowScrollBarX(documentElement);\n }\n }\n const x = rect.left + scroll.scrollLeft - offsets.x;\n const y = rect.top + scroll.scrollTop - offsets.y;\n return {\n x,\n y,\n width: rect.width,\n height: rect.height\n };\n}\n\nfunction isStaticPositioned(element) {\n return getComputedStyle(element).position === 'static';\n}\n\nfunction getTrueOffsetParent(element, polyfill) {\n if (!isHTMLElement(element) || getComputedStyle(element).position === 'fixed') {\n return null;\n }\n if (polyfill) {\n return polyfill(element);\n }\n return element.offsetParent;\n}\n\n// Gets the closest ancestor positioned element. Handles some edge cases,\n// such as table ancestors and cross browser bugs.\nfunction getOffsetParent(element, polyfill) {\n const win = getWindow(element);\n if (isTopLayer(element)) {\n return win;\n }\n if (!isHTMLElement(element)) {\n let svgOffsetParent = getParentNode(element);\n while (svgOffsetParent && !isLastTraversableNode(svgOffsetParent)) {\n if (isElement(svgOffsetParent) && !isStaticPositioned(svgOffsetParent)) {\n return svgOffsetParent;\n }\n svgOffsetParent = getParentNode(svgOffsetParent);\n }\n return win;\n }\n let offsetParent = getTrueOffsetParent(element, polyfill);\n while (offsetParent && isTableElement(offsetParent) && isStaticPositioned(offsetParent)) {\n offsetParent = getTrueOffsetParent(offsetParent, polyfill);\n }\n if (offsetParent && isLastTraversableNode(offsetParent) && isStaticPositioned(offsetParent) && !isContainingBlock(offsetParent)) {\n return win;\n }\n return offsetParent || getContainingBlock(element) || win;\n}\n\nconst getElementRects = async function (data) {\n const getOffsetParentFn = this.getOffsetParent || getOffsetParent;\n const getDimensionsFn = this.getDimensions;\n const floatingDimensions = await getDimensionsFn(data.floating);\n return {\n reference: getRectRelativeToOffsetParent(data.reference, await getOffsetParentFn(data.floating), data.strategy),\n floating: {\n x: 0,\n y: 0,\n width: floatingDimensions.width,\n height: floatingDimensions.height\n }\n };\n};\n\nfunction isRTL(element) {\n return getComputedStyle(element).direction === 'rtl';\n}\n\nconst platform = {\n convertOffsetParentRelativeRectToViewportRelativeRect,\n getDocumentElement,\n getClippingRect,\n getOffsetParent,\n getElementRects,\n getClientRects,\n getDimensions,\n getScale,\n isElement,\n isRTL\n};\n\n// https://samthor.au/2021/observing-dom/\nfunction observeMove(element, onMove) {\n let io = null;\n let timeoutId;\n const root = getDocumentElement(element);\n function cleanup() {\n var _io;\n clearTimeout(timeoutId);\n (_io = io) == null || _io.disconnect();\n io = null;\n }\n function refresh(skip, threshold) {\n if (skip === void 0) {\n skip = false;\n }\n if (threshold === void 0) {\n threshold = 1;\n }\n cleanup();\n const {\n left,\n top,\n width,\n height\n } = element.getBoundingClientRect();\n if (!skip) {\n onMove();\n }\n if (!width || !height) {\n return;\n }\n const insetTop = floor(top);\n const insetRight = floor(root.clientWidth - (left + width));\n const insetBottom = floor(root.clientHeight - (top + height));\n const insetLeft = floor(left);\n const rootMargin = -insetTop + \"px \" + -insetRight + \"px \" + -insetBottom + \"px \" + -insetLeft + \"px\";\n const options = {\n rootMargin,\n threshold: max(0, min(1, threshold)) || 1\n };\n let isFirstUpdate = true;\n function handleObserve(entries) {\n const ratio = entries[0].intersectionRatio;\n if (ratio !== threshold) {\n if (!isFirstUpdate) {\n return refresh();\n }\n if (!ratio) {\n // If the reference is clipped, the ratio is 0. Throttle the refresh\n // to prevent an infinite loop of updates.\n timeoutId = setTimeout(() => {\n refresh(false, 1e-7);\n }, 1000);\n } else {\n refresh(false, ratio);\n }\n }\n isFirstUpdate = false;\n }\n\n // Older browsers don't support a `document` as the root and will throw an\n // error.\n try {\n io = new IntersectionObserver(handleObserve, {\n ...options,\n // Handle