@public-ui/components 3.0.2-4633c75bfe6e8436d102c316ead90b0a2b4974ef.0 → 3.0.2-4d9d73e6b2febbdb23cf92ad1926eb0ccb66d12c.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/custom-elements.json +279 -14
- package/dist/cjs/Alert-Ci6Z1mEi.js +4 -0
- package/dist/cjs/Alert-Ci6Z1mEi.js.map +1 -0
- package/dist/cjs/Collapsible-BlQc7nSm.js +4 -0
- package/dist/cjs/Collapsible-BlQc7nSm.js.map +1 -0
- package/dist/cjs/CustomSuggestionsOptionsGroup-BKXb-lJV.js +4 -0
- package/dist/cjs/CustomSuggestionsOptionsGroup-BKXb-lJV.js.map +1 -0
- package/dist/cjs/FieldControlStateWrapper-CST5Yhui.js +4 -0
- package/dist/cjs/FieldControlStateWrapper-CST5Yhui.js.map +1 -0
- package/dist/cjs/Heading-CgMClZ8F.js +4 -0
- package/dist/cjs/Heading-CgMClZ8F.js.map +1 -0
- package/dist/cjs/Icon-DyK7k8JC.js +4 -0
- package/dist/cjs/Icon-DyK7k8JC.js.map +1 -0
- package/dist/cjs/Input-DyExf_C0.js +4 -0
- package/dist/cjs/Input-DyExf_C0.js.map +1 -0
- package/dist/cjs/InputStateWrapper-DebleKhC.js +4 -0
- package/dist/cjs/InputStateWrapper-DebleKhC.js.map +1 -0
- package/dist/cjs/InternalUnderlinedBadgeText-BD4HDB2z.js +4 -0
- package/dist/cjs/InternalUnderlinedBadgeText-BD4HDB2z.js.map +1 -0
- package/dist/cjs/Span-B7WqADKN.js +4 -0
- package/dist/cjs/Span-B7WqADKN.js.map +1 -0
- package/dist/cjs/access-and-short-key-CLBDRHjl.js +4 -0
- package/dist/cjs/access-and-short-key-CLBDRHjl.js.map +1 -0
- package/dist/cjs/align-BO18xcUR.js +4 -0
- package/dist/cjs/align-BO18xcUR.js.map +1 -0
- package/dist/cjs/align-floating-elements-DZR8PUzH.js +4 -0
- package/dist/cjs/align-floating-elements-DZR8PUzH.js.map +1 -0
- package/dist/cjs/app-globals-Ch1CxVvY.js +4 -0
- package/dist/cjs/app-globals-Ch1CxVvY.js.map +1 -0
- package/dist/cjs/ariaCurrentService-3051l6MI.js.map +1 -0
- package/dist/cjs/associated.controller-B6s4BBc5.js +4 -0
- package/dist/cjs/associated.controller-B6s4BBc5.js.map +1 -0
- package/dist/cjs/auto-complete-DmgsTAsU.js +4 -0
- package/dist/cjs/auto-complete-DmgsTAsU.js.map +1 -0
- package/dist/cjs/bem-BJH7Pd5N.js +4 -0
- package/dist/cjs/bem-BJH7Pd5N.js.map +1 -0
- package/dist/cjs/bem-C_jCpzb9.js +4 -0
- package/dist/cjs/bem-C_jCpzb9.js.map +1 -0
- package/dist/cjs/bootstrap-Bu2_7K9K.js +4 -0
- package/dist/cjs/bootstrap-Bu2_7K9K.js.map +1 -0
- package/dist/cjs/browser-D6KVhibU.js +4 -0
- package/dist/cjs/browser-D6KVhibU.js.map +1 -0
- package/dist/cjs/clsx-CkZlkaek.js.map +1 -0
- package/dist/cjs/color-BW_T-Uqc.js +4 -0
- package/dist/cjs/color-BW_T-Uqc.js.map +1 -0
- package/dist/cjs/component-names-D7MwtuB7.js.map +1 -0
- package/dist/cjs/controller-BYV8oxkv.js +4 -0
- package/dist/cjs/controller-BYV8oxkv.js.map +1 -0
- package/dist/cjs/controller-CB8G2ntb.js +4 -0
- package/dist/cjs/controller-CB8G2ntb.js.map +1 -0
- package/dist/cjs/controller-CCrgS9Qj.js +4 -0
- package/dist/cjs/controller-CCrgS9Qj.js.map +1 -0
- package/dist/cjs/controller-D_5kjpv5.js +4 -0
- package/dist/cjs/controller-D_5kjpv5.js.map +1 -0
- package/dist/cjs/controller-icon-M_N93506.js +4 -0
- package/dist/cjs/controller-icon-M_N93506.js.map +1 -0
- package/dist/cjs/custom-class-BnO7qPZb.js +4 -0
- package/dist/cjs/custom-class-BnO7qPZb.js.map +1 -0
- package/dist/cjs/dev.utils-DjNbUbz6.js +4 -0
- package/dist/cjs/dev.utils-DjNbUbz6.js.map +1 -0
- package/dist/cjs/devtools-DxyFvQK3.js +4 -0
- package/dist/cjs/devtools-DxyFvQK3.js.map +1 -0
- package/dist/cjs/disabled-CE0Rprxv.js +4 -0
- package/dist/cjs/disabled-CE0Rprxv.js.map +1 -0
- package/dist/cjs/events-DDhO-Ns8.js.map +1 -0
- package/dist/cjs/getRenderStates-BVwH-CtZ.js +4 -0
- package/dist/cjs/getRenderStates-BVwH-CtZ.js.map +1 -0
- package/dist/cjs/has-closer-CqMc7f53.js +4 -0
- package/dist/cjs/has-closer-CqMc7f53.js.map +1 -0
- package/dist/cjs/hide-label-Cb5Cfuxn.js +4 -0
- package/dist/cjs/hide-label-Cb5Cfuxn.js.map +1 -0
- package/dist/cjs/href-CyD1Zh08.js +4 -0
- package/dist/cjs/href-CyD1Zh08.js.map +1 -0
- package/dist/cjs/i18n-BLEJ-_9m.js +4 -0
- package/dist/cjs/i18n-BLEJ-_9m.js.map +1 -0
- package/dist/cjs/i18n-FoT8aNyf.js +4 -0
- package/dist/cjs/i18n-FoT8aNyf.js.map +1 -0
- package/dist/cjs/icons-DxjGyJie.js +4 -0
- package/dist/cjs/icons-DxjGyJie.js.map +1 -0
- package/dist/cjs/image-source-2aBPRVw-.js +4 -0
- package/dist/cjs/image-source-2aBPRVw-.js.map +1 -0
- package/dist/cjs/index-D1fnlL55.js +4 -0
- package/dist/cjs/index-D1fnlL55.js.map +1 -0
- package/dist/cjs/index.cjs.js +1 -1
- package/dist/cjs/index.cjs.js.map +1 -1
- package/dist/cjs/isObject-DMA85Fq4.js +4 -0
- package/dist/cjs/isObject-DMA85Fq4.js.map +1 -0
- package/dist/cjs/keyboard-C096g_BV.js.map +1 -0
- package/dist/cjs/kol-abbr.cjs.entry.js +1 -1
- package/dist/cjs/kol-abbr.cjs.entry.js.map +1 -1
- package/dist/cjs/kol-abbr.entry.cjs.js.map +1 -0
- package/dist/cjs/kol-accordion.cjs.entry.js +1 -1
- package/dist/cjs/kol-accordion.cjs.entry.js.map +1 -1
- package/dist/cjs/kol-accordion.entry.cjs.js.map +1 -0
- package/dist/cjs/kol-alert-wc.cjs.entry.js +1 -1
- package/dist/cjs/kol-alert-wc.cjs.entry.js.map +1 -1
- package/dist/cjs/kol-alert-wc.entry.cjs.js.map +1 -0
- package/dist/cjs/kol-alert.cjs.entry.js +1 -1
- package/dist/cjs/kol-alert.cjs.entry.js.map +1 -1
- package/dist/cjs/kol-alert.entry.cjs.js.map +1 -0
- package/dist/cjs/kol-avatar-wc.cjs.entry.js +1 -1
- package/dist/cjs/kol-avatar-wc.cjs.entry.js.map +1 -1
- package/dist/cjs/kol-avatar-wc.entry.cjs.js.map +1 -0
- package/dist/cjs/kol-avatar.cjs.entry.js +1 -1
- package/dist/cjs/kol-avatar.cjs.entry.js.map +1 -1
- package/dist/cjs/kol-avatar.entry.cjs.js.map +1 -0
- package/dist/cjs/kol-badge.cjs.entry.js +1 -1
- package/dist/cjs/kol-badge.cjs.entry.js.map +1 -1
- package/dist/cjs/kol-badge.entry.cjs.js.map +1 -0
- package/dist/cjs/kol-breadcrumb.cjs.entry.js +1 -1
- package/dist/cjs/kol-breadcrumb.cjs.entry.js.map +1 -1
- package/dist/cjs/kol-breadcrumb.entry.cjs.js.map +1 -0
- package/dist/cjs/kol-button-link.cjs.entry.js +1 -1
- package/dist/cjs/kol-button-link.cjs.entry.js.map +1 -1
- package/dist/cjs/kol-button-link.entry.cjs.js.map +1 -0
- package/dist/cjs/kol-button-wc.cjs.entry.js +1 -1
- package/dist/cjs/kol-button-wc.cjs.entry.js.map +1 -1
- package/dist/cjs/kol-button-wc.entry.cjs.js.map +1 -0
- package/dist/cjs/kol-button.cjs.entry.js +1 -1
- package/dist/cjs/kol-button.cjs.entry.js.map +1 -1
- package/dist/cjs/kol-button.entry.cjs.js.map +1 -0
- package/dist/cjs/kol-card-wc.cjs.entry.js +1 -1
- package/dist/cjs/kol-card-wc.cjs.entry.js.map +1 -1
- package/dist/cjs/kol-card-wc.entry.cjs.js.map +1 -0
- package/dist/cjs/kol-card.cjs.entry.js +1 -1
- package/dist/cjs/kol-card.cjs.entry.js.map +1 -1
- package/dist/cjs/kol-card.entry.cjs.js.map +1 -0
- package/dist/cjs/kol-combobox.cjs.entry.js +1 -1
- package/dist/cjs/kol-combobox.cjs.entry.js.map +1 -1
- package/dist/cjs/kol-combobox.entry.cjs.js.map +1 -0
- package/dist/cjs/kol-details.cjs.entry.js +1 -1
- package/dist/cjs/kol-details.cjs.entry.js.map +1 -1
- package/dist/cjs/kol-details.entry.cjs.js.map +1 -0
- package/dist/cjs/kol-drawer.cjs.entry.js +1 -1
- package/dist/cjs/kol-drawer.cjs.entry.js.map +1 -1
- package/dist/cjs/kol-drawer.entry.cjs.js.map +1 -0
- package/dist/cjs/kol-form.cjs.entry.js +1 -1
- package/dist/cjs/kol-form.cjs.entry.js.map +1 -1
- package/dist/cjs/kol-form.entry.cjs.js.map +1 -0
- package/dist/cjs/kol-heading.cjs.entry.js +1 -1
- package/dist/cjs/kol-heading.cjs.entry.js.map +1 -1
- package/dist/cjs/kol-heading.entry.cjs.js.map +1 -0
- package/dist/cjs/kol-icon.cjs.entry.js +1 -1
- package/dist/cjs/kol-icon.cjs.entry.js.map +1 -1
- package/dist/cjs/kol-icon.entry.cjs.js.map +1 -0
- package/dist/cjs/kol-image.cjs.entry.js +1 -1
- package/dist/cjs/kol-image.cjs.entry.js.map +1 -1
- package/dist/cjs/kol-image.entry.cjs.js.map +1 -0
- package/dist/cjs/kol-input-checkbox.cjs.entry.js +1 -1
- package/dist/cjs/kol-input-checkbox.cjs.entry.js.map +1 -1
- package/dist/cjs/kol-input-checkbox.entry.cjs.js.map +1 -0
- package/dist/cjs/kol-input-color.cjs.entry.js +1 -1
- package/dist/cjs/kol-input-color.cjs.entry.js.map +1 -1
- package/dist/cjs/kol-input-color.entry.cjs.js.map +1 -0
- package/dist/cjs/kol-input-date.cjs.entry.js +1 -1
- package/dist/cjs/kol-input-date.cjs.entry.js.map +1 -1
- package/dist/cjs/kol-input-date.entry.cjs.js.map +1 -0
- package/dist/cjs/kol-input-email.cjs.entry.js +1 -1
- package/dist/cjs/kol-input-email.cjs.entry.js.map +1 -1
- package/dist/cjs/kol-input-email.entry.cjs.js.map +1 -0
- package/dist/cjs/kol-input-file.cjs.entry.js +1 -1
- package/dist/cjs/kol-input-file.cjs.entry.js.map +1 -1
- package/dist/cjs/kol-input-file.entry.cjs.js.map +1 -0
- package/dist/cjs/kol-input-number.cjs.entry.js +1 -1
- package/dist/cjs/kol-input-number.cjs.entry.js.map +1 -1
- package/dist/cjs/kol-input-number.entry.cjs.js.map +1 -0
- package/dist/cjs/kol-input-password.cjs.entry.js +1 -1
- package/dist/cjs/kol-input-password.cjs.entry.js.map +1 -1
- package/dist/cjs/kol-input-password.entry.cjs.js.map +1 -0
- package/dist/cjs/kol-input-radio.cjs.entry.js +1 -1
- package/dist/cjs/kol-input-radio.cjs.entry.js.map +1 -1
- package/dist/cjs/kol-input-radio.entry.cjs.js.map +1 -0
- package/dist/cjs/kol-input-range.cjs.entry.js +1 -1
- package/dist/cjs/kol-input-range.cjs.entry.js.map +1 -1
- package/dist/cjs/kol-input-range.entry.cjs.js.map +1 -0
- package/dist/cjs/kol-input-text.cjs.entry.js +1 -1
- package/dist/cjs/kol-input-text.cjs.entry.js.map +1 -1
- package/dist/cjs/kol-input-text.entry.cjs.js.map +1 -0
- package/dist/cjs/kol-kolibri.cjs.entry.js +1 -1
- package/dist/cjs/kol-kolibri.cjs.entry.js.map +1 -1
- package/dist/cjs/kol-kolibri.entry.cjs.js.map +1 -0
- package/dist/cjs/kol-link-button.cjs.entry.js +1 -1
- package/dist/cjs/kol-link-button.cjs.entry.js.map +1 -1
- package/dist/cjs/kol-link-button.entry.cjs.js.map +1 -0
- package/dist/cjs/kol-link-wc.cjs.entry.js +1 -1
- package/dist/cjs/kol-link-wc.cjs.entry.js.map +1 -1
- package/dist/cjs/kol-link-wc.entry.cjs.js.map +1 -0
- package/dist/cjs/kol-link.cjs.entry.js +1 -1
- package/dist/cjs/kol-link.cjs.entry.js.map +1 -1
- package/dist/cjs/kol-link.entry.cjs.js.map +1 -0
- package/dist/cjs/kol-modal.cjs.entry.js +1 -1
- package/dist/cjs/kol-modal.cjs.entry.js.map +1 -1
- package/dist/cjs/kol-modal.entry.cjs.js.map +1 -0
- package/dist/cjs/kol-nav.cjs.entry.js +1 -1
- package/dist/cjs/kol-nav.cjs.entry.js.map +1 -1
- package/dist/cjs/kol-nav.entry.cjs.js.map +1 -0
- package/dist/cjs/kol-pagination-wc.cjs.entry.js +1 -1
- package/dist/cjs/kol-pagination-wc.cjs.entry.js.map +1 -1
- package/dist/cjs/kol-pagination-wc.entry.cjs.js.map +1 -0
- package/dist/cjs/kol-pagination.cjs.entry.js +1 -1
- package/dist/cjs/kol-pagination.cjs.entry.js.map +1 -1
- package/dist/cjs/kol-pagination.entry.cjs.js.map +1 -0
- package/dist/cjs/kol-popover-button-wc.cjs.entry.js +1 -1
- package/dist/cjs/kol-popover-button-wc.cjs.entry.js.map +1 -1
- package/dist/cjs/kol-popover-button-wc.entry.cjs.js.map +1 -0
- package/dist/cjs/kol-popover-button.cjs.entry.js +1 -1
- package/dist/cjs/kol-popover-button.cjs.entry.js.map +1 -1
- package/dist/cjs/kol-popover-button.entry.cjs.js.map +1 -0
- package/dist/cjs/kol-popover-wc.cjs.entry.js +1 -1
- package/dist/cjs/kol-popover-wc.cjs.entry.js.map +1 -1
- package/dist/cjs/kol-popover-wc.entry.cjs.js.map +1 -0
- package/dist/cjs/kol-progress.cjs.entry.js +1 -1
- package/dist/cjs/kol-progress.cjs.entry.js.map +1 -1
- package/dist/cjs/kol-progress.entry.cjs.js.map +1 -0
- package/dist/cjs/kol-quote.cjs.entry.js +1 -1
- package/dist/cjs/kol-quote.cjs.entry.js.map +1 -1
- package/dist/cjs/kol-quote.entry.cjs.js.map +1 -0
- package/dist/cjs/kol-select.cjs.entry.js +1 -1
- package/dist/cjs/kol-select.cjs.entry.js.map +1 -1
- package/dist/cjs/kol-select.entry.cjs.js.map +1 -0
- package/dist/cjs/kol-single-select.cjs.entry.js +1 -1
- package/dist/cjs/kol-single-select.cjs.entry.js.map +1 -1
- package/dist/cjs/kol-single-select.entry.cjs.js.map +1 -0
- package/dist/cjs/kol-skip-nav.cjs.entry.js +1 -1
- package/dist/cjs/kol-skip-nav.cjs.entry.js.map +1 -1
- package/dist/cjs/kol-skip-nav.entry.cjs.js.map +1 -0
- package/dist/cjs/kol-spin.cjs.entry.js +1 -1
- package/dist/cjs/kol-spin.cjs.entry.js.map +1 -1
- package/dist/cjs/kol-spin.entry.cjs.js.map +1 -0
- package/dist/cjs/kol-split-button.cjs.entry.js +1 -1
- package/dist/cjs/kol-split-button.cjs.entry.js.map +1 -1
- package/dist/cjs/kol-split-button.entry.cjs.js.map +1 -0
- package/dist/cjs/kol-table-settings-wc.cjs.entry.js +1 -1
- package/dist/cjs/kol-table-settings-wc.cjs.entry.js.map +1 -1
- package/dist/cjs/kol-table-settings-wc.entry.cjs.js.map +1 -0
- package/dist/cjs/kol-table-stateful.cjs.entry.js +1 -1
- package/dist/cjs/kol-table-stateful.cjs.entry.js.map +1 -1
- package/dist/cjs/kol-table-stateful.entry.cjs.js.map +1 -0
- package/dist/cjs/kol-table-stateless-wc.cjs.entry.js +1 -1
- package/dist/cjs/kol-table-stateless-wc.cjs.entry.js.map +1 -1
- package/dist/cjs/kol-table-stateless-wc.entry.cjs.js.map +1 -0
- package/dist/cjs/kol-table-stateless.cjs.entry.js +1 -1
- package/dist/cjs/kol-table-stateless.cjs.entry.js.map +1 -1
- package/dist/cjs/kol-table-stateless.entry.cjs.js.map +1 -0
- package/dist/cjs/kol-tabs.cjs.entry.js +1 -1
- package/dist/cjs/kol-tabs.cjs.entry.js.map +1 -1
- package/dist/cjs/kol-tabs.entry.cjs.js.map +1 -0
- package/dist/cjs/kol-textarea.cjs.entry.js +1 -1
- package/dist/cjs/kol-textarea.cjs.entry.js.map +1 -1
- package/dist/cjs/kol-textarea.entry.cjs.js.map +1 -0
- package/dist/cjs/kol-toast-container.cjs.entry.js +1 -1
- package/dist/cjs/kol-toast-container.cjs.entry.js.map +1 -1
- package/dist/cjs/kol-toast-container.entry.cjs.js.map +1 -0
- package/dist/cjs/kol-toolbar.cjs.entry.js +1 -1
- package/dist/cjs/kol-toolbar.cjs.entry.js.map +1 -1
- package/dist/cjs/kol-toolbar.entry.cjs.js.map +1 -0
- package/dist/cjs/kol-tooltip-wc.cjs.entry.js +1 -1
- package/dist/cjs/kol-tooltip-wc.cjs.entry.js.map +1 -1
- package/dist/cjs/kol-tooltip-wc.entry.cjs.js.map +1 -0
- package/dist/cjs/kol-tree-item-wc.cjs.entry.js +1 -1
- package/dist/cjs/kol-tree-item-wc.cjs.entry.js.map +1 -1
- package/dist/cjs/kol-tree-item-wc.entry.cjs.js.map +1 -0
- package/dist/cjs/kol-tree-item.cjs.entry.js +1 -1
- package/dist/cjs/kol-tree-item.cjs.entry.js.map +1 -1
- package/dist/cjs/kol-tree-item.entry.cjs.js.map +1 -0
- package/dist/cjs/kol-tree-wc.cjs.entry.js +1 -1
- package/dist/cjs/kol-tree-wc.cjs.entry.js.map +1 -1
- package/dist/cjs/kol-tree-wc.entry.cjs.js.map +1 -0
- package/dist/cjs/kol-tree.cjs.entry.js +1 -1
- package/dist/cjs/kol-tree.cjs.entry.js.map +1 -1
- package/dist/cjs/kol-tree.entry.cjs.js.map +1 -0
- package/dist/cjs/kol-version.cjs.entry.js +1 -1
- package/dist/cjs/kol-version.cjs.entry.js.map +1 -1
- package/dist/cjs/kol-version.entry.cjs.js.map +1 -0
- package/dist/cjs/kolibri.cjs.js +1 -1
- package/dist/cjs/kolibri.cjs.js.map +1 -1
- package/dist/cjs/label-DB9qL3Jc.js +4 -0
- package/dist/cjs/label-DB9qL3Jc.js.map +1 -0
- package/dist/cjs/link-variant-B2dSS_7B.js +4 -0
- package/dist/cjs/link-variant-B2dSS_7B.js.map +1 -0
- package/dist/cjs/loader.cjs.js +1 -1
- package/dist/cjs/loader.cjs.js.map +1 -1
- package/dist/cjs/markdown-DvfMTw_n.js +4 -0
- package/dist/cjs/markdown-DvfMTw_n.js.map +1 -0
- package/dist/cjs/max-length-behavior-Bc3VzR7q.js +4 -0
- package/dist/cjs/max-length-behavior-Bc3VzR7q.js.map +1 -0
- package/dist/cjs/open-BYkQzj7z.js +4 -0
- package/dist/cjs/open-BYkQzj7z.js.map +1 -0
- package/dist/cjs/orientation-GuxBJIo5.js +4 -0
- package/dist/cjs/orientation-GuxBJIo5.js.map +1 -0
- package/dist/cjs/progress-Dys184zO.js +4 -0
- package/dist/cjs/progress-Dys184zO.js.map +1 -0
- package/dist/cjs/rows-BddZxHSg.js +4 -0
- package/dist/cjs/rows-BddZxHSg.js.map +1 -0
- package/dist/cjs/show-PxpThNY_.js +4 -0
- package/dist/cjs/show-PxpThNY_.js.map +1 -0
- package/dist/cjs/spell-check-ChQXG27e.js +4 -0
- package/dist/cjs/spell-check-ChQXG27e.js.map +1 -0
- package/dist/cjs/suggestions-D3lIp-8W.js +4 -0
- package/dist/cjs/suggestions-D3lIp-8W.js.map +1 -0
- package/dist/cjs/table-settings-C3f5xiAf.js +4 -0
- package/dist/cjs/table-settings-C3f5xiAf.js.map +1 -0
- package/dist/cjs/test-component.cjs.entry.js +1 -1
- package/dist/cjs/test-component.cjs.entry.js.map +1 -1
- package/dist/cjs/test-component.entry.cjs.js.map +1 -0
- package/dist/cjs/tooltip-align-CREZ2m1O.js +4 -0
- package/dist/cjs/tooltip-align-CREZ2m1O.js.map +1 -0
- package/dist/cjs/unique-nav-labels-Cn-gkZqz.js +4 -0
- package/dist/cjs/unique-nav-labels-Cn-gkZqz.js.map +1 -0
- package/dist/cjs/validation-BmVEyFp-.js +4 -0
- package/dist/cjs/validation-BmVEyFp-.js.map +1 -0
- package/dist/cjs/validation-CC_-v6qH.js +4 -0
- package/dist/cjs/validation-CC_-v6qH.js.map +1 -0
- package/dist/components/Alert.js +1 -1
- package/dist/components/Alert.js.map +1 -1
- package/dist/components/Collapsible.js +1 -1
- package/dist/components/Collapsible.js.map +1 -1
- package/dist/components/CustomSuggestionsOptionsGroup.js +1 -1
- package/dist/components/CustomSuggestionsOptionsGroup.js.map +1 -1
- package/dist/components/FieldControlStateWrapper.js +1 -1
- package/dist/components/FieldControlStateWrapper.js.map +1 -1
- package/dist/components/Heading.js +1 -1
- package/dist/components/Heading.js.map +1 -1
- package/dist/components/Icon.js +1 -1
- package/dist/components/Icon.js.map +1 -1
- package/dist/components/Input.js +1 -1
- package/dist/components/Input.js.map +1 -1
- package/dist/components/InputContainerStateWrapper.js +1 -1
- package/dist/components/InputContainerStateWrapper.js.map +1 -1
- package/dist/components/InputStateWrapper.js +1 -1
- package/dist/components/InputStateWrapper.js.map +1 -1
- package/dist/components/InternalUnderlinedBadgeText.js +1 -1
- package/dist/components/InternalUnderlinedBadgeText.js.map +1 -1
- package/dist/components/Span.js +1 -1
- package/dist/components/Span.js.map +1 -1
- package/dist/components/access-and-short-key.js +1 -1
- package/dist/components/access-and-short-key.js.map +1 -1
- package/dist/components/align-floating-elements.js +1 -1
- package/dist/components/align-floating-elements.js.map +1 -1
- package/dist/components/align.js +1 -1
- package/dist/components/align.js.map +1 -1
- package/dist/components/ariaCurrentService.js.map +1 -1
- package/dist/components/associated.controller.js +1 -1
- package/dist/components/associated.controller.js.map +1 -1
- package/dist/components/auto-complete.js +4 -0
- package/dist/components/auto-complete.js.map +1 -0
- package/dist/components/bem.js.map +1 -1
- package/dist/components/bem2.js.map +1 -1
- package/dist/components/bootstrap.js +1 -1
- package/dist/components/bootstrap.js.map +1 -1
- package/dist/components/browser.js +1 -1
- package/dist/components/browser.js.map +1 -1
- package/dist/components/color.js +1 -1
- package/dist/components/color.js.map +1 -1
- package/dist/components/component-names.js +1 -1
- package/dist/components/component-names.js.map +1 -1
- package/dist/components/controller.js +1 -1
- package/dist/components/controller.js.map +1 -1
- package/dist/components/controller2.js +1 -1
- package/dist/components/controller2.js.map +1 -1
- package/dist/components/controller3.js +1 -1
- package/dist/components/controller3.js.map +1 -1
- package/dist/components/controller4.js +1 -1
- package/dist/components/controller4.js.map +1 -1
- package/dist/components/custom-class.js +1 -1
- package/dist/components/custom-class.js.map +1 -1
- package/dist/components/dev.utils.js +1 -1
- package/dist/components/dev.utils.js.map +1 -1
- package/dist/components/devtools.js +1 -1
- package/dist/components/devtools.js.map +1 -1
- package/dist/components/disabled.js +1 -1
- package/dist/components/disabled.js.map +1 -1
- package/dist/components/events.js.map +1 -1
- package/dist/components/getRenderStates.js +1 -1
- package/dist/components/getRenderStates.js.map +1 -1
- package/dist/components/has-closer.js +1 -1
- package/dist/components/has-closer.js.map +1 -1
- package/dist/components/hide-label.js +1 -1
- package/dist/components/hide-label.js.map +1 -1
- package/dist/components/href.js +1 -1
- package/dist/components/href.js.map +1 -1
- package/dist/components/i18n.js +1 -1
- package/dist/components/i18n.js.map +1 -1
- package/dist/components/i18n2.js +1 -1
- package/dist/components/i18n2.js.map +1 -1
- package/dist/components/icons.js +1 -1
- package/dist/components/icons.js.map +1 -1
- package/dist/components/image-source.js +1 -1
- package/dist/components/image-source.js.map +1 -1
- package/dist/components/index.js +1 -1
- package/dist/components/index.js.map +1 -1
- package/dist/components/isObject.js +1 -1
- package/dist/components/isObject.js.map +1 -1
- package/dist/components/keyboard.js.map +1 -1
- package/dist/components/kol-abbr.js +1 -1
- package/dist/components/kol-abbr.js.map +1 -1
- package/dist/components/kol-accordion.js +1 -1
- package/dist/components/kol-accordion.js.map +1 -1
- package/dist/components/kol-alert-wc.js +1 -1
- package/dist/components/kol-alert-wc.js.map +1 -1
- package/dist/components/kol-alert.js +1 -1
- package/dist/components/kol-alert.js.map +1 -1
- package/dist/components/kol-avatar-wc.js +1 -1
- package/dist/components/kol-avatar-wc.js.map +1 -1
- package/dist/components/kol-avatar.js +1 -1
- package/dist/components/kol-avatar.js.map +1 -1
- package/dist/components/kol-badge.js +1 -1
- package/dist/components/kol-badge.js.map +1 -1
- package/dist/components/kol-breadcrumb.js +1 -1
- package/dist/components/kol-breadcrumb.js.map +1 -1
- package/dist/components/kol-button-link.js +1 -1
- package/dist/components/kol-button-link.js.map +1 -1
- package/dist/components/kol-button-wc.js +1 -1
- package/dist/components/kol-button-wc.js.map +1 -1
- package/dist/components/kol-button.js +1 -1
- package/dist/components/kol-button.js.map +1 -1
- package/dist/components/kol-card-wc.js +1 -1
- package/dist/components/kol-card-wc.js.map +1 -1
- package/dist/components/kol-card.js +1 -1
- package/dist/components/kol-card.js.map +1 -1
- package/dist/components/kol-combobox.js +1 -1
- package/dist/components/kol-combobox.js.map +1 -1
- package/dist/components/kol-details.js +1 -1
- package/dist/components/kol-details.js.map +1 -1
- package/dist/components/kol-drawer.js +1 -1
- package/dist/components/kol-drawer.js.map +1 -1
- package/dist/components/kol-form.js +1 -1
- package/dist/components/kol-form.js.map +1 -1
- package/dist/components/kol-heading.js +1 -1
- package/dist/components/kol-heading.js.map +1 -1
- package/dist/components/kol-icon.js +1 -1
- package/dist/components/kol-icon.js.map +1 -1
- package/dist/components/kol-image.js +1 -1
- package/dist/components/kol-image.js.map +1 -1
- package/dist/components/kol-input-checkbox.js +1 -1
- package/dist/components/kol-input-checkbox.js.map +1 -1
- package/dist/components/kol-input-color.js +1 -1
- package/dist/components/kol-input-color.js.map +1 -1
- package/dist/components/kol-input-date.js +1 -1
- package/dist/components/kol-input-date.js.map +1 -1
- package/dist/components/kol-input-email.js +1 -1
- package/dist/components/kol-input-email.js.map +1 -1
- package/dist/components/kol-input-file.js +1 -1
- package/dist/components/kol-input-file.js.map +1 -1
- package/dist/components/kol-input-number.js +1 -1
- package/dist/components/kol-input-number.js.map +1 -1
- package/dist/components/kol-input-password.js +1 -1
- package/dist/components/kol-input-password.js.map +1 -1
- package/dist/components/kol-input-radio.js +1 -1
- package/dist/components/kol-input-radio.js.map +1 -1
- package/dist/components/kol-input-range.js +1 -1
- package/dist/components/kol-input-range.js.map +1 -1
- package/dist/components/kol-input-text.js +1 -1
- package/dist/components/kol-input-text.js.map +1 -1
- package/dist/components/kol-kolibri.js +1 -1
- package/dist/components/kol-kolibri.js.map +1 -1
- package/dist/components/kol-link-button.js +1 -1
- package/dist/components/kol-link-button.js.map +1 -1
- package/dist/components/kol-link-wc.js +1 -1
- package/dist/components/kol-link-wc.js.map +1 -1
- package/dist/components/kol-link.js +1 -1
- package/dist/components/kol-link.js.map +1 -1
- package/dist/components/kol-modal.js +1 -1
- package/dist/components/kol-modal.js.map +1 -1
- package/dist/components/kol-nav.js +1 -1
- package/dist/components/kol-nav.js.map +1 -1
- package/dist/components/kol-pagination-wc.js +1 -1
- package/dist/components/kol-pagination-wc.js.map +1 -1
- package/dist/components/kol-pagination.js +1 -1
- package/dist/components/kol-pagination.js.map +1 -1
- package/dist/components/kol-popover-button-wc.js +1 -1
- package/dist/components/kol-popover-button-wc.js.map +1 -1
- package/dist/components/kol-popover-button.js +1 -1
- package/dist/components/kol-popover-button.js.map +1 -1
- package/dist/components/kol-popover-wc.js +1 -1
- package/dist/components/kol-popover-wc.js.map +1 -1
- package/dist/components/kol-progress.js +1 -1
- package/dist/components/kol-progress.js.map +1 -1
- package/dist/components/kol-quote.js +1 -1
- package/dist/components/kol-quote.js.map +1 -1
- package/dist/components/kol-select.js +1 -1
- package/dist/components/kol-select.js.map +1 -1
- package/dist/components/kol-single-select.js +1 -1
- package/dist/components/kol-single-select.js.map +1 -1
- package/dist/components/kol-skip-nav.js +1 -1
- package/dist/components/kol-skip-nav.js.map +1 -1
- package/dist/components/kol-spin.js +1 -1
- package/dist/components/kol-spin.js.map +1 -1
- package/dist/components/kol-split-button.js +1 -1
- package/dist/components/kol-split-button.js.map +1 -1
- package/dist/components/kol-table-settings-wc.js +1 -1
- package/dist/components/kol-table-settings-wc.js.map +1 -1
- package/dist/components/kol-table-stateful.js +1 -1
- package/dist/components/kol-table-stateful.js.map +1 -1
- package/dist/components/kol-table-stateless-wc.js +1 -1
- package/dist/components/kol-table-stateless-wc.js.map +1 -1
- package/dist/components/kol-table-stateless.js +1 -1
- package/dist/components/kol-table-stateless.js.map +1 -1
- package/dist/components/kol-tabs.js +1 -1
- package/dist/components/kol-tabs.js.map +1 -1
- package/dist/components/kol-textarea.js +1 -1
- package/dist/components/kol-textarea.js.map +1 -1
- package/dist/components/kol-toast-container.js +1 -1
- package/dist/components/kol-toast-container.js.map +1 -1
- package/dist/components/kol-toolbar.js +1 -1
- package/dist/components/kol-toolbar.js.map +1 -1
- package/dist/components/kol-tooltip-wc.js +1 -1
- package/dist/components/kol-tooltip-wc.js.map +1 -1
- package/dist/components/kol-tree-item-wc.js +1 -1
- package/dist/components/kol-tree-item-wc.js.map +1 -1
- package/dist/components/kol-tree-item.js +1 -1
- package/dist/components/kol-tree-item.js.map +1 -1
- package/dist/components/kol-tree-wc.js +1 -1
- package/dist/components/kol-tree-wc.js.map +1 -1
- package/dist/components/kol-tree.js +1 -1
- package/dist/components/kol-tree.js.map +1 -1
- package/dist/components/kol-version.js +1 -1
- package/dist/components/kol-version.js.map +1 -1
- package/dist/components/label.js +1 -1
- package/dist/components/label.js.map +1 -1
- package/dist/components/link-variant.js +1 -1
- package/dist/components/link-variant.js.map +1 -1
- package/dist/components/markdown.js +1 -1
- package/dist/components/markdown.js.map +1 -1
- package/dist/components/max-length-behavior.js +4 -0
- package/dist/components/max-length-behavior.js.map +1 -0
- package/dist/components/open.js +1 -1
- package/dist/components/open.js.map +1 -1
- package/dist/components/orientation.js +1 -1
- package/dist/components/orientation.js.map +1 -1
- package/dist/components/progress.js +4 -0
- package/dist/components/progress.js.map +1 -0
- package/dist/components/rows.js +1 -1
- package/dist/components/rows.js.map +1 -1
- package/dist/components/show.js +1 -1
- package/dist/components/show.js.map +1 -1
- package/dist/components/spell-check.js +1 -1
- package/dist/components/spell-check.js.map +1 -1
- package/dist/components/suggestions.js +1 -1
- package/dist/components/suggestions.js.map +1 -1
- package/dist/components/table-settings.js +1 -1
- package/dist/components/table-settings.js.map +1 -1
- package/dist/components/test-component.js.map +1 -1
- package/dist/components/tooltip-align.js +1 -1
- package/dist/components/tooltip-align.js.map +1 -1
- package/dist/components/unique-nav-labels.js +1 -1
- package/dist/components/unique-nav-labels.js.map +1 -1
- package/dist/components/validation.js +1 -1
- package/dist/components/validation.js.map +1 -1
- package/dist/components/validation2.js +1 -1
- package/dist/components/validation2.js.map +1 -1
- package/dist/esm/Alert-DnD_hO6X.js +4 -0
- package/dist/esm/Alert-DnD_hO6X.js.map +1 -0
- package/dist/esm/Collapsible-LunXGXro.js +4 -0
- package/dist/esm/Collapsible-LunXGXro.js.map +1 -0
- package/dist/esm/CustomSuggestionsOptionsGroup-BQa7raa8.js +4 -0
- package/dist/esm/CustomSuggestionsOptionsGroup-BQa7raa8.js.map +1 -0
- package/dist/esm/FieldControlStateWrapper-DC7YlV6o.js +4 -0
- package/dist/esm/FieldControlStateWrapper-DC7YlV6o.js.map +1 -0
- package/dist/esm/Heading-D_vnx163.js +4 -0
- package/dist/esm/Heading-D_vnx163.js.map +1 -0
- package/dist/esm/Icon-XldYcxyr.js +4 -0
- package/dist/esm/Icon-XldYcxyr.js.map +1 -0
- package/dist/esm/Input-D27-m66t.js +4 -0
- package/dist/esm/Input-D27-m66t.js.map +1 -0
- package/dist/esm/InputStateWrapper-BJzpAEGU.js +4 -0
- package/dist/esm/InputStateWrapper-BJzpAEGU.js.map +1 -0
- package/dist/esm/InternalUnderlinedBadgeText-Cy3ElU32.js +4 -0
- package/dist/esm/InternalUnderlinedBadgeText-Cy3ElU32.js.map +1 -0
- package/dist/esm/Span-DMpXIiTW.js +4 -0
- package/dist/esm/Span-DMpXIiTW.js.map +1 -0
- package/dist/esm/access-and-short-key-CykHF9HL.js +4 -0
- package/dist/esm/access-and-short-key-CykHF9HL.js.map +1 -0
- package/dist/esm/align-floating-elements-op7c4od4.js +4 -0
- package/dist/esm/align-floating-elements-op7c4od4.js.map +1 -0
- package/dist/esm/align-tkanisJ7.js +4 -0
- package/dist/esm/align-tkanisJ7.js.map +1 -0
- package/dist/esm/app-globals-CwNbquxh.js +4 -0
- package/dist/esm/app-globals-CwNbquxh.js.map +1 -0
- package/dist/esm/ariaCurrentService-YoLNpD5S.js.map +1 -0
- package/dist/esm/associated.controller-ClhjBSrR.js +4 -0
- package/dist/esm/associated.controller-ClhjBSrR.js.map +1 -0
- package/dist/esm/auto-complete-DTSb0_Qv.js +4 -0
- package/dist/esm/auto-complete-DTSb0_Qv.js.map +1 -0
- package/dist/esm/bem-Cpz0pDYV.js +4 -0
- package/dist/esm/bem-Cpz0pDYV.js.map +1 -0
- package/dist/esm/bem-Cy03CwUU.js +4 -0
- package/dist/esm/bem-Cy03CwUU.js.map +1 -0
- package/dist/esm/bootstrap-lABol9ew.js +4 -0
- package/dist/esm/bootstrap-lABol9ew.js.map +1 -0
- package/dist/esm/browser-DnRYLgeW.js +4 -0
- package/dist/esm/browser-DnRYLgeW.js.map +1 -0
- package/dist/esm/clsx-eK3rPvPS.js.map +1 -0
- package/dist/esm/color-DLr6p32D.js +4 -0
- package/dist/esm/color-DLr6p32D.js.map +1 -0
- package/dist/esm/component-names-CkE54Ym7.js +4 -0
- package/dist/esm/component-names-CkE54Ym7.js.map +1 -0
- package/dist/esm/controller-BLBS8eKf.js +4 -0
- package/dist/esm/controller-BLBS8eKf.js.map +1 -0
- package/dist/esm/controller-BUK8x0Dz.js +4 -0
- package/dist/esm/controller-BUK8x0Dz.js.map +1 -0
- package/dist/esm/controller-Bbk-o0Dz.js +4 -0
- package/dist/esm/controller-Bbk-o0Dz.js.map +1 -0
- package/dist/esm/controller-BevWqlyP.js +4 -0
- package/dist/esm/controller-BevWqlyP.js.map +1 -0
- package/dist/esm/controller-icon-C2QQZ_hH.js +4 -0
- package/dist/esm/controller-icon-C2QQZ_hH.js.map +1 -0
- package/dist/esm/custom-class-CH7NMpHZ.js +4 -0
- package/dist/esm/custom-class-CH7NMpHZ.js.map +1 -0
- package/dist/esm/dev.utils-tIfWUJtH.js +4 -0
- package/dist/esm/dev.utils-tIfWUJtH.js.map +1 -0
- package/dist/esm/devtools-Cp_-hWNr.js +4 -0
- package/dist/esm/devtools-Cp_-hWNr.js.map +1 -0
- package/dist/esm/disabled-hQGJULeA.js +4 -0
- package/dist/esm/disabled-hQGJULeA.js.map +1 -0
- package/dist/esm/events-CoPFQEiC.js.map +1 -0
- package/dist/esm/getRenderStates-B4Xg8PG8.js +4 -0
- package/dist/esm/getRenderStates-B4Xg8PG8.js.map +1 -0
- package/dist/esm/has-closer-DB5qR5TQ.js +4 -0
- package/dist/esm/has-closer-DB5qR5TQ.js.map +1 -0
- package/dist/esm/hide-label-DYRsvAHX.js +4 -0
- package/dist/esm/hide-label-DYRsvAHX.js.map +1 -0
- package/dist/esm/href-BKuPIzvr.js +4 -0
- package/dist/esm/href-BKuPIzvr.js.map +1 -0
- package/dist/esm/i18n-CjhRejiw.js +4 -0
- package/dist/esm/i18n-CjhRejiw.js.map +1 -0
- package/dist/esm/i18n-H9CUbi--.js +4 -0
- package/dist/esm/i18n-H9CUbi--.js.map +1 -0
- package/dist/esm/icons-BVOoMgA0.js +4 -0
- package/dist/esm/icons-BVOoMgA0.js.map +1 -0
- package/dist/esm/image-source-CtDEzXRs.js +4 -0
- package/dist/esm/image-source-CtDEzXRs.js.map +1 -0
- package/dist/esm/index-BhaeJ-uM.js +4 -0
- package/dist/esm/index-BhaeJ-uM.js.map +1 -0
- package/dist/esm/index.js +1 -1
- package/dist/esm/index.js.map +1 -1
- package/dist/esm/isObject-DvSELytj.js +4 -0
- package/dist/esm/isObject-DvSELytj.js.map +1 -0
- package/dist/esm/keyboard-D6PoWr38.js.map +1 -0
- package/dist/esm/kol-abbr.entry.js +1 -1
- package/dist/esm/kol-abbr.entry.js.map +1 -1
- package/dist/esm/kol-accordion.entry.js +1 -1
- package/dist/esm/kol-accordion.entry.js.map +1 -1
- package/dist/esm/kol-alert-wc.entry.js +1 -1
- package/dist/esm/kol-alert-wc.entry.js.map +1 -1
- package/dist/esm/kol-alert.entry.js +1 -1
- package/dist/esm/kol-alert.entry.js.map +1 -1
- package/dist/esm/kol-avatar-wc.entry.js +1 -1
- package/dist/esm/kol-avatar-wc.entry.js.map +1 -1
- package/dist/esm/kol-avatar.entry.js +1 -1
- package/dist/esm/kol-avatar.entry.js.map +1 -1
- package/dist/esm/kol-badge.entry.js +1 -1
- package/dist/esm/kol-badge.entry.js.map +1 -1
- package/dist/esm/kol-breadcrumb.entry.js +1 -1
- package/dist/esm/kol-breadcrumb.entry.js.map +1 -1
- package/dist/esm/kol-button-link.entry.js +1 -1
- package/dist/esm/kol-button-link.entry.js.map +1 -1
- package/dist/esm/kol-button-wc.entry.js +1 -1
- package/dist/esm/kol-button-wc.entry.js.map +1 -1
- package/dist/esm/kol-button.entry.js +1 -1
- package/dist/esm/kol-button.entry.js.map +1 -1
- package/dist/esm/kol-card-wc.entry.js +1 -1
- package/dist/esm/kol-card-wc.entry.js.map +1 -1
- package/dist/esm/kol-card.entry.js +1 -1
- package/dist/esm/kol-card.entry.js.map +1 -1
- package/dist/esm/kol-combobox.entry.js +1 -1
- package/dist/esm/kol-combobox.entry.js.map +1 -1
- package/dist/esm/kol-details.entry.js +1 -1
- package/dist/esm/kol-details.entry.js.map +1 -1
- package/dist/esm/kol-drawer.entry.js +1 -1
- package/dist/esm/kol-drawer.entry.js.map +1 -1
- package/dist/esm/kol-form.entry.js +1 -1
- package/dist/esm/kol-form.entry.js.map +1 -1
- package/dist/esm/kol-heading.entry.js +1 -1
- package/dist/esm/kol-heading.entry.js.map +1 -1
- package/dist/esm/kol-icon.entry.js +1 -1
- package/dist/esm/kol-icon.entry.js.map +1 -1
- package/dist/esm/kol-image.entry.js +1 -1
- package/dist/esm/kol-image.entry.js.map +1 -1
- package/dist/esm/kol-input-checkbox.entry.js +1 -1
- package/dist/esm/kol-input-checkbox.entry.js.map +1 -1
- package/dist/esm/kol-input-color.entry.js +1 -1
- package/dist/esm/kol-input-color.entry.js.map +1 -1
- package/dist/esm/kol-input-date.entry.js +1 -1
- package/dist/esm/kol-input-date.entry.js.map +1 -1
- package/dist/esm/kol-input-email.entry.js +1 -1
- package/dist/esm/kol-input-email.entry.js.map +1 -1
- package/dist/esm/kol-input-file.entry.js +1 -1
- package/dist/esm/kol-input-file.entry.js.map +1 -1
- package/dist/esm/kol-input-number.entry.js +1 -1
- package/dist/esm/kol-input-number.entry.js.map +1 -1
- package/dist/esm/kol-input-password.entry.js +1 -1
- package/dist/esm/kol-input-password.entry.js.map +1 -1
- package/dist/esm/kol-input-radio.entry.js +1 -1
- package/dist/esm/kol-input-radio.entry.js.map +1 -1
- package/dist/esm/kol-input-range.entry.js +1 -1
- package/dist/esm/kol-input-range.entry.js.map +1 -1
- package/dist/esm/kol-input-text.entry.js +1 -1
- package/dist/esm/kol-input-text.entry.js.map +1 -1
- package/dist/esm/kol-kolibri.entry.js +1 -1
- package/dist/esm/kol-kolibri.entry.js.map +1 -1
- package/dist/esm/kol-link-button.entry.js +1 -1
- package/dist/esm/kol-link-button.entry.js.map +1 -1
- package/dist/esm/kol-link-wc.entry.js +1 -1
- package/dist/esm/kol-link-wc.entry.js.map +1 -1
- package/dist/esm/kol-link.entry.js +1 -1
- package/dist/esm/kol-link.entry.js.map +1 -1
- package/dist/esm/kol-modal.entry.js +1 -1
- package/dist/esm/kol-modal.entry.js.map +1 -1
- package/dist/esm/kol-nav.entry.js +1 -1
- package/dist/esm/kol-nav.entry.js.map +1 -1
- package/dist/esm/kol-pagination-wc.entry.js +1 -1
- package/dist/esm/kol-pagination-wc.entry.js.map +1 -1
- package/dist/esm/kol-pagination.entry.js +1 -1
- package/dist/esm/kol-pagination.entry.js.map +1 -1
- package/dist/esm/kol-popover-button-wc.entry.js +1 -1
- package/dist/esm/kol-popover-button-wc.entry.js.map +1 -1
- package/dist/esm/kol-popover-button.entry.js +1 -1
- package/dist/esm/kol-popover-button.entry.js.map +1 -1
- package/dist/esm/kol-popover-wc.entry.js +1 -1
- package/dist/esm/kol-popover-wc.entry.js.map +1 -1
- package/dist/esm/kol-progress.entry.js +1 -1
- package/dist/esm/kol-progress.entry.js.map +1 -1
- package/dist/esm/kol-quote.entry.js +1 -1
- package/dist/esm/kol-quote.entry.js.map +1 -1
- package/dist/esm/kol-select.entry.js +1 -1
- package/dist/esm/kol-select.entry.js.map +1 -1
- package/dist/esm/kol-single-select.entry.js +1 -1
- package/dist/esm/kol-single-select.entry.js.map +1 -1
- package/dist/esm/kol-skip-nav.entry.js +1 -1
- package/dist/esm/kol-skip-nav.entry.js.map +1 -1
- package/dist/esm/kol-spin.entry.js +1 -1
- package/dist/esm/kol-spin.entry.js.map +1 -1
- package/dist/esm/kol-split-button.entry.js +1 -1
- package/dist/esm/kol-split-button.entry.js.map +1 -1
- package/dist/esm/kol-table-settings-wc.entry.js +1 -1
- package/dist/esm/kol-table-settings-wc.entry.js.map +1 -1
- package/dist/esm/kol-table-stateful.entry.js +1 -1
- package/dist/esm/kol-table-stateful.entry.js.map +1 -1
- package/dist/esm/kol-table-stateless-wc.entry.js +1 -1
- package/dist/esm/kol-table-stateless-wc.entry.js.map +1 -1
- package/dist/esm/kol-table-stateless.entry.js +1 -1
- package/dist/esm/kol-table-stateless.entry.js.map +1 -1
- package/dist/esm/kol-tabs.entry.js +1 -1
- package/dist/esm/kol-tabs.entry.js.map +1 -1
- package/dist/esm/kol-textarea.entry.js +1 -1
- package/dist/esm/kol-textarea.entry.js.map +1 -1
- package/dist/esm/kol-toast-container.entry.js +1 -1
- package/dist/esm/kol-toast-container.entry.js.map +1 -1
- package/dist/esm/kol-toolbar.entry.js +1 -1
- package/dist/esm/kol-toolbar.entry.js.map +1 -1
- package/dist/esm/kol-tooltip-wc.entry.js +1 -1
- package/dist/esm/kol-tooltip-wc.entry.js.map +1 -1
- package/dist/esm/kol-tree-item-wc.entry.js +1 -1
- package/dist/esm/kol-tree-item-wc.entry.js.map +1 -1
- package/dist/esm/kol-tree-item.entry.js +1 -1
- package/dist/esm/kol-tree-item.entry.js.map +1 -1
- package/dist/esm/kol-tree-wc.entry.js +1 -1
- package/dist/esm/kol-tree-wc.entry.js.map +1 -1
- package/dist/esm/kol-tree.entry.js +1 -1
- package/dist/esm/kol-tree.entry.js.map +1 -1
- package/dist/esm/kol-version.entry.js +1 -1
- package/dist/esm/kol-version.entry.js.map +1 -1
- package/dist/esm/kolibri.js +1 -1
- package/dist/esm/kolibri.js.map +1 -1
- package/dist/esm/label-D3d1qqIG.js +4 -0
- package/dist/esm/label-D3d1qqIG.js.map +1 -0
- package/dist/esm/link-variant-BoV22Jh0.js +4 -0
- package/dist/esm/link-variant-BoV22Jh0.js.map +1 -0
- package/dist/esm/loader.js +1 -1
- package/dist/esm/loader.js.map +1 -1
- package/dist/esm/markdown-vxO4XBWP.js +4 -0
- package/dist/esm/markdown-vxO4XBWP.js.map +1 -0
- package/dist/esm/max-length-behavior-Dz2KB_23.js +4 -0
- package/dist/esm/max-length-behavior-Dz2KB_23.js.map +1 -0
- package/dist/esm/open-8iQ59IbX.js +4 -0
- package/dist/esm/open-8iQ59IbX.js.map +1 -0
- package/dist/esm/orientation-D3xx-ujZ.js +4 -0
- package/dist/esm/orientation-D3xx-ujZ.js.map +1 -0
- package/dist/esm/progress-DvHYRA46.js +4 -0
- package/dist/esm/progress-DvHYRA46.js.map +1 -0
- package/dist/esm/rows-DyB9epqs.js +4 -0
- package/dist/esm/rows-DyB9epqs.js.map +1 -0
- package/dist/esm/show-CdatXiQZ.js +4 -0
- package/dist/esm/show-CdatXiQZ.js.map +1 -0
- package/dist/esm/spell-check-CMcp2-Ad.js +4 -0
- package/dist/esm/spell-check-CMcp2-Ad.js.map +1 -0
- package/dist/esm/suggestions-BfRFzmYR.js +4 -0
- package/dist/esm/suggestions-BfRFzmYR.js.map +1 -0
- package/dist/esm/table-settings-BtONOLMh.js +4 -0
- package/dist/esm/table-settings-BtONOLMh.js.map +1 -0
- package/dist/esm/test-component.entry.js +1 -1
- package/dist/esm/test-component.entry.js.map +1 -1
- package/dist/esm/tooltip-align-5cqqmpu7.js +4 -0
- package/dist/esm/tooltip-align-5cqqmpu7.js.map +1 -0
- package/dist/esm/unique-nav-labels-gGjh_FbY.js +4 -0
- package/dist/esm/unique-nav-labels-gGjh_FbY.js.map +1 -0
- package/dist/esm/validation-BL4fIKiW.js +4 -0
- package/dist/esm/validation-BL4fIKiW.js.map +1 -0
- package/dist/esm/validation-C2b7CFWx.js +4 -0
- package/dist/esm/validation-C2b7CFWx.js.map +1 -0
- package/dist/kolibri/Alert-DnD_hO6X.js +4 -0
- package/dist/kolibri/Alert-DnD_hO6X.js.map +1 -0
- package/dist/kolibri/Collapsible-LunXGXro.js +4 -0
- package/dist/kolibri/Collapsible-LunXGXro.js.map +1 -0
- package/dist/kolibri/CustomSuggestionsOptionsGroup-BQa7raa8.js +4 -0
- package/dist/kolibri/CustomSuggestionsOptionsGroup-BQa7raa8.js.map +1 -0
- package/dist/kolibri/FieldControlStateWrapper-DC7YlV6o.js +4 -0
- package/dist/kolibri/FieldControlStateWrapper-DC7YlV6o.js.map +1 -0
- package/dist/kolibri/Heading-D_vnx163.js +4 -0
- package/dist/kolibri/Heading-D_vnx163.js.map +1 -0
- package/dist/kolibri/Icon-XldYcxyr.js +4 -0
- package/dist/kolibri/Icon-XldYcxyr.js.map +1 -0
- package/dist/kolibri/Input-D27-m66t.js +4 -0
- package/dist/kolibri/Input-D27-m66t.js.map +1 -0
- package/dist/kolibri/InputStateWrapper-BJzpAEGU.js +4 -0
- package/dist/kolibri/InputStateWrapper-BJzpAEGU.js.map +1 -0
- package/dist/kolibri/InternalUnderlinedBadgeText-Cy3ElU32.js +4 -0
- package/dist/kolibri/InternalUnderlinedBadgeText-Cy3ElU32.js.map +1 -0
- package/dist/kolibri/Span-DMpXIiTW.js +4 -0
- package/dist/kolibri/Span-DMpXIiTW.js.map +1 -0
- package/dist/kolibri/access-and-short-key-CykHF9HL.js +4 -0
- package/dist/kolibri/access-and-short-key-CykHF9HL.js.map +1 -0
- package/dist/kolibri/align-floating-elements-op7c4od4.js +4 -0
- package/dist/kolibri/align-floating-elements-op7c4od4.js.map +1 -0
- package/dist/kolibri/align-tkanisJ7.js +4 -0
- package/dist/kolibri/align-tkanisJ7.js.map +1 -0
- package/dist/kolibri/app-globals-CwNbquxh.js +4 -0
- package/dist/kolibri/app-globals-CwNbquxh.js.map +1 -0
- package/dist/kolibri/ariaCurrentService-YoLNpD5S.js.map +1 -0
- package/dist/kolibri/associated.controller-ClhjBSrR.js +4 -0
- package/dist/kolibri/associated.controller-ClhjBSrR.js.map +1 -0
- package/dist/kolibri/auto-complete-DTSb0_Qv.js +4 -0
- package/dist/kolibri/auto-complete-DTSb0_Qv.js.map +1 -0
- package/dist/kolibri/bem-Cpz0pDYV.js +4 -0
- package/dist/kolibri/bem-Cpz0pDYV.js.map +1 -0
- package/dist/kolibri/bem-Cy03CwUU.js +4 -0
- package/dist/kolibri/bem-Cy03CwUU.js.map +1 -0
- package/dist/kolibri/bootstrap-lABol9ew.js +4 -0
- package/dist/kolibri/bootstrap-lABol9ew.js.map +1 -0
- package/dist/kolibri/browser-DnRYLgeW.js +4 -0
- package/dist/kolibri/browser-DnRYLgeW.js.map +1 -0
- package/dist/kolibri/clsx-eK3rPvPS.js.map +1 -0
- package/dist/kolibri/color-DLr6p32D.js +4 -0
- package/dist/kolibri/color-DLr6p32D.js.map +1 -0
- package/dist/kolibri/component-names-CkE54Ym7.js +4 -0
- package/dist/kolibri/component-names-CkE54Ym7.js.map +1 -0
- package/dist/kolibri/controller-BLBS8eKf.js +4 -0
- package/dist/kolibri/controller-BLBS8eKf.js.map +1 -0
- package/dist/kolibri/controller-BUK8x0Dz.js +4 -0
- package/dist/kolibri/controller-BUK8x0Dz.js.map +1 -0
- package/dist/kolibri/controller-Bbk-o0Dz.js +4 -0
- package/dist/kolibri/controller-Bbk-o0Dz.js.map +1 -0
- package/dist/kolibri/controller-BevWqlyP.js +4 -0
- package/dist/kolibri/controller-BevWqlyP.js.map +1 -0
- package/dist/kolibri/controller-icon-C2QQZ_hH.js +4 -0
- package/dist/kolibri/controller-icon-C2QQZ_hH.js.map +1 -0
- package/dist/kolibri/custom-class-CH7NMpHZ.js +4 -0
- package/dist/kolibri/custom-class-CH7NMpHZ.js.map +1 -0
- package/dist/kolibri/dev.utils-tIfWUJtH.js +4 -0
- package/dist/kolibri/dev.utils-tIfWUJtH.js.map +1 -0
- package/dist/kolibri/devtools-Cp_-hWNr.js +4 -0
- package/dist/kolibri/devtools-Cp_-hWNr.js.map +1 -0
- package/dist/kolibri/disabled-hQGJULeA.js +4 -0
- package/dist/kolibri/disabled-hQGJULeA.js.map +1 -0
- package/dist/kolibri/events-CoPFQEiC.js.map +1 -0
- package/dist/kolibri/getRenderStates-B4Xg8PG8.js +4 -0
- package/dist/kolibri/getRenderStates-B4Xg8PG8.js.map +1 -0
- package/dist/kolibri/has-closer-DB5qR5TQ.js +4 -0
- package/dist/kolibri/has-closer-DB5qR5TQ.js.map +1 -0
- package/dist/kolibri/hide-label-DYRsvAHX.js +4 -0
- package/dist/kolibri/hide-label-DYRsvAHX.js.map +1 -0
- package/dist/kolibri/href-BKuPIzvr.js +4 -0
- package/dist/kolibri/href-BKuPIzvr.js.map +1 -0
- package/dist/kolibri/i18n-CjhRejiw.js +4 -0
- package/dist/kolibri/i18n-CjhRejiw.js.map +1 -0
- package/dist/kolibri/i18n-H9CUbi--.js +4 -0
- package/dist/kolibri/i18n-H9CUbi--.js.map +1 -0
- package/dist/kolibri/icons-BVOoMgA0.js +4 -0
- package/dist/kolibri/icons-BVOoMgA0.js.map +1 -0
- package/dist/kolibri/image-source-CtDEzXRs.js +4 -0
- package/dist/kolibri/image-source-CtDEzXRs.js.map +1 -0
- package/dist/kolibri/index-BhaeJ-uM.js +5 -0
- package/dist/kolibri/index-BhaeJ-uM.js.map +1 -0
- package/dist/kolibri/index.esm.js +1 -1
- package/dist/kolibri/index.esm.js.map +1 -1
- package/dist/kolibri/isObject-DvSELytj.js +4 -0
- package/dist/kolibri/isObject-DvSELytj.js.map +1 -0
- package/dist/kolibri/keyboard-D6PoWr38.js.map +1 -0
- package/dist/kolibri/kol-abbr.entry.esm.js.map +1 -0
- package/dist/kolibri/kol-abbr.entry.js +1 -1
- package/dist/kolibri/kol-abbr.entry.js.map +1 -1
- package/dist/kolibri/kol-accordion.entry.esm.js.map +1 -0
- package/dist/kolibri/kol-accordion.entry.js +1 -1
- package/dist/kolibri/kol-accordion.entry.js.map +1 -1
- package/dist/kolibri/kol-alert-wc.entry.esm.js.map +1 -0
- package/dist/kolibri/kol-alert-wc.entry.js +1 -1
- package/dist/kolibri/kol-alert-wc.entry.js.map +1 -1
- package/dist/kolibri/kol-alert.entry.esm.js.map +1 -0
- package/dist/kolibri/kol-alert.entry.js +1 -1
- package/dist/kolibri/kol-alert.entry.js.map +1 -1
- package/dist/kolibri/kol-avatar-wc.entry.esm.js.map +1 -0
- package/dist/kolibri/kol-avatar-wc.entry.js +1 -1
- package/dist/kolibri/kol-avatar-wc.entry.js.map +1 -1
- package/dist/kolibri/kol-avatar.entry.esm.js.map +1 -0
- package/dist/kolibri/kol-avatar.entry.js +1 -1
- package/dist/kolibri/kol-avatar.entry.js.map +1 -1
- package/dist/kolibri/kol-badge.entry.esm.js.map +1 -0
- package/dist/kolibri/kol-badge.entry.js +1 -1
- package/dist/kolibri/kol-badge.entry.js.map +1 -1
- package/dist/kolibri/kol-breadcrumb.entry.esm.js.map +1 -0
- package/dist/kolibri/kol-breadcrumb.entry.js +1 -1
- package/dist/kolibri/kol-breadcrumb.entry.js.map +1 -1
- package/dist/kolibri/kol-button-link.entry.esm.js.map +1 -0
- package/dist/kolibri/kol-button-link.entry.js +1 -1
- package/dist/kolibri/kol-button-link.entry.js.map +1 -1
- package/dist/kolibri/kol-button-wc.entry.esm.js.map +1 -0
- package/dist/kolibri/kol-button-wc.entry.js +1 -1
- package/dist/kolibri/kol-button-wc.entry.js.map +1 -1
- package/dist/kolibri/kol-button.entry.esm.js.map +1 -0
- package/dist/kolibri/kol-button.entry.js +1 -1
- package/dist/kolibri/kol-button.entry.js.map +1 -1
- package/dist/kolibri/kol-card-wc.entry.esm.js.map +1 -0
- package/dist/kolibri/kol-card-wc.entry.js +1 -1
- package/dist/kolibri/kol-card-wc.entry.js.map +1 -1
- package/dist/kolibri/kol-card.entry.esm.js.map +1 -0
- package/dist/kolibri/kol-card.entry.js +1 -1
- package/dist/kolibri/kol-card.entry.js.map +1 -1
- package/dist/kolibri/kol-combobox.entry.esm.js.map +1 -0
- package/dist/kolibri/kol-combobox.entry.js +1 -1
- package/dist/kolibri/kol-combobox.entry.js.map +1 -1
- package/dist/kolibri/kol-details.entry.esm.js.map +1 -0
- package/dist/kolibri/kol-details.entry.js +1 -1
- package/dist/kolibri/kol-details.entry.js.map +1 -1
- package/dist/kolibri/kol-drawer.entry.esm.js.map +1 -0
- package/dist/kolibri/kol-drawer.entry.js +1 -1
- package/dist/kolibri/kol-drawer.entry.js.map +1 -1
- package/dist/kolibri/kol-form.entry.esm.js.map +1 -0
- package/dist/kolibri/kol-form.entry.js +1 -1
- package/dist/kolibri/kol-form.entry.js.map +1 -1
- package/dist/kolibri/kol-heading.entry.esm.js.map +1 -0
- package/dist/kolibri/kol-heading.entry.js +1 -1
- package/dist/kolibri/kol-heading.entry.js.map +1 -1
- package/dist/kolibri/kol-icon.entry.esm.js.map +1 -0
- package/dist/kolibri/kol-icon.entry.js +1 -1
- package/dist/kolibri/kol-icon.entry.js.map +1 -1
- package/dist/kolibri/kol-image.entry.esm.js.map +1 -0
- package/dist/kolibri/kol-image.entry.js +1 -1
- package/dist/kolibri/kol-image.entry.js.map +1 -1
- package/dist/kolibri/kol-input-checkbox.entry.esm.js.map +1 -0
- package/dist/kolibri/kol-input-checkbox.entry.js +1 -1
- package/dist/kolibri/kol-input-checkbox.entry.js.map +1 -1
- package/dist/kolibri/kol-input-color.entry.esm.js.map +1 -0
- package/dist/kolibri/kol-input-color.entry.js +1 -1
- package/dist/kolibri/kol-input-color.entry.js.map +1 -1
- package/dist/kolibri/kol-input-date.entry.esm.js.map +1 -0
- package/dist/kolibri/kol-input-date.entry.js +1 -1
- package/dist/kolibri/kol-input-date.entry.js.map +1 -1
- package/dist/kolibri/kol-input-email.entry.esm.js.map +1 -0
- package/dist/kolibri/kol-input-email.entry.js +1 -1
- package/dist/kolibri/kol-input-email.entry.js.map +1 -1
- package/dist/kolibri/kol-input-file.entry.esm.js.map +1 -0
- package/dist/kolibri/kol-input-file.entry.js +1 -1
- package/dist/kolibri/kol-input-file.entry.js.map +1 -1
- package/dist/kolibri/kol-input-number.entry.esm.js.map +1 -0
- package/dist/kolibri/kol-input-number.entry.js +1 -1
- package/dist/kolibri/kol-input-number.entry.js.map +1 -1
- package/dist/kolibri/kol-input-password.entry.esm.js.map +1 -0
- package/dist/kolibri/kol-input-password.entry.js +1 -1
- package/dist/kolibri/kol-input-password.entry.js.map +1 -1
- package/dist/kolibri/kol-input-radio.entry.esm.js.map +1 -0
- package/dist/kolibri/kol-input-radio.entry.js +1 -1
- package/dist/kolibri/kol-input-radio.entry.js.map +1 -1
- package/dist/kolibri/kol-input-range.entry.esm.js.map +1 -0
- package/dist/kolibri/kol-input-range.entry.js +1 -1
- package/dist/kolibri/kol-input-range.entry.js.map +1 -1
- package/dist/kolibri/kol-input-text.entry.esm.js.map +1 -0
- package/dist/kolibri/kol-input-text.entry.js +1 -1
- package/dist/kolibri/kol-input-text.entry.js.map +1 -1
- package/dist/kolibri/kol-kolibri.entry.esm.js.map +1 -0
- package/dist/kolibri/kol-kolibri.entry.js +1 -1
- package/dist/kolibri/kol-kolibri.entry.js.map +1 -1
- package/dist/kolibri/kol-link-button.entry.esm.js.map +1 -0
- package/dist/kolibri/kol-link-button.entry.js +1 -1
- package/dist/kolibri/kol-link-button.entry.js.map +1 -1
- package/dist/kolibri/kol-link-wc.entry.esm.js.map +1 -0
- package/dist/kolibri/kol-link-wc.entry.js +1 -1
- package/dist/kolibri/kol-link-wc.entry.js.map +1 -1
- package/dist/kolibri/kol-link.entry.esm.js.map +1 -0
- package/dist/kolibri/kol-link.entry.js +1 -1
- package/dist/kolibri/kol-link.entry.js.map +1 -1
- package/dist/kolibri/kol-modal.entry.esm.js.map +1 -0
- package/dist/kolibri/kol-modal.entry.js +1 -1
- package/dist/kolibri/kol-modal.entry.js.map +1 -1
- package/dist/kolibri/kol-nav.entry.esm.js.map +1 -0
- package/dist/kolibri/kol-nav.entry.js +1 -1
- package/dist/kolibri/kol-nav.entry.js.map +1 -1
- package/dist/kolibri/kol-pagination-wc.entry.esm.js.map +1 -0
- package/dist/kolibri/kol-pagination-wc.entry.js +1 -1
- package/dist/kolibri/kol-pagination-wc.entry.js.map +1 -1
- package/dist/kolibri/kol-pagination.entry.esm.js.map +1 -0
- package/dist/kolibri/kol-pagination.entry.js +1 -1
- package/dist/kolibri/kol-pagination.entry.js.map +1 -1
- package/dist/kolibri/kol-popover-button-wc.entry.esm.js.map +1 -0
- package/dist/kolibri/kol-popover-button-wc.entry.js +1 -1
- package/dist/kolibri/kol-popover-button-wc.entry.js.map +1 -1
- package/dist/kolibri/kol-popover-button.entry.esm.js.map +1 -0
- package/dist/kolibri/kol-popover-button.entry.js +1 -1
- package/dist/kolibri/kol-popover-button.entry.js.map +1 -1
- package/dist/kolibri/kol-popover-wc.entry.esm.js.map +1 -0
- package/dist/kolibri/kol-popover-wc.entry.js +1 -1
- package/dist/kolibri/kol-popover-wc.entry.js.map +1 -1
- package/dist/kolibri/kol-progress.entry.esm.js.map +1 -0
- package/dist/kolibri/kol-progress.entry.js +1 -1
- package/dist/kolibri/kol-progress.entry.js.map +1 -1
- package/dist/kolibri/kol-quote.entry.esm.js.map +1 -0
- package/dist/kolibri/kol-quote.entry.js +1 -1
- package/dist/kolibri/kol-quote.entry.js.map +1 -1
- package/dist/kolibri/kol-select.entry.esm.js.map +1 -0
- package/dist/kolibri/kol-select.entry.js +1 -1
- package/dist/kolibri/kol-select.entry.js.map +1 -1
- package/dist/kolibri/kol-single-select.entry.esm.js.map +1 -0
- package/dist/kolibri/kol-single-select.entry.js +1 -1
- package/dist/kolibri/kol-single-select.entry.js.map +1 -1
- package/dist/kolibri/kol-skip-nav.entry.esm.js.map +1 -0
- package/dist/kolibri/kol-skip-nav.entry.js +1 -1
- package/dist/kolibri/kol-skip-nav.entry.js.map +1 -1
- package/dist/kolibri/kol-spin.entry.esm.js.map +1 -0
- package/dist/kolibri/kol-spin.entry.js +1 -1
- package/dist/kolibri/kol-spin.entry.js.map +1 -1
- package/dist/kolibri/kol-split-button.entry.esm.js.map +1 -0
- package/dist/kolibri/kol-split-button.entry.js +1 -1
- package/dist/kolibri/kol-split-button.entry.js.map +1 -1
- package/dist/kolibri/kol-table-settings-wc.entry.esm.js.map +1 -0
- package/dist/kolibri/kol-table-settings-wc.entry.js +1 -1
- package/dist/kolibri/kol-table-settings-wc.entry.js.map +1 -1
- package/dist/kolibri/kol-table-stateful.entry.esm.js.map +1 -0
- package/dist/kolibri/kol-table-stateful.entry.js +1 -1
- package/dist/kolibri/kol-table-stateful.entry.js.map +1 -1
- package/dist/kolibri/kol-table-stateless-wc.entry.esm.js.map +1 -0
- package/dist/kolibri/kol-table-stateless-wc.entry.js +1 -1
- package/dist/kolibri/kol-table-stateless-wc.entry.js.map +1 -1
- package/dist/kolibri/kol-table-stateless.entry.esm.js.map +1 -0
- package/dist/kolibri/kol-table-stateless.entry.js +1 -1
- package/dist/kolibri/kol-table-stateless.entry.js.map +1 -1
- package/dist/kolibri/kol-tabs.entry.esm.js.map +1 -0
- package/dist/kolibri/kol-tabs.entry.js +1 -1
- package/dist/kolibri/kol-tabs.entry.js.map +1 -1
- package/dist/kolibri/kol-textarea.entry.esm.js.map +1 -0
- package/dist/kolibri/kol-textarea.entry.js +1 -1
- package/dist/kolibri/kol-textarea.entry.js.map +1 -1
- package/dist/kolibri/kol-toast-container.entry.esm.js.map +1 -0
- package/dist/kolibri/kol-toast-container.entry.js +1 -1
- package/dist/kolibri/kol-toast-container.entry.js.map +1 -1
- package/dist/kolibri/kol-toolbar.entry.esm.js.map +1 -0
- package/dist/kolibri/kol-toolbar.entry.js +1 -1
- package/dist/kolibri/kol-toolbar.entry.js.map +1 -1
- package/dist/kolibri/kol-tooltip-wc.entry.esm.js.map +1 -0
- package/dist/kolibri/kol-tooltip-wc.entry.js +1 -1
- package/dist/kolibri/kol-tooltip-wc.entry.js.map +1 -1
- package/dist/kolibri/kol-tree-item-wc.entry.esm.js.map +1 -0
- package/dist/kolibri/kol-tree-item-wc.entry.js +1 -1
- package/dist/kolibri/kol-tree-item-wc.entry.js.map +1 -1
- package/dist/kolibri/kol-tree-item.entry.esm.js.map +1 -0
- package/dist/kolibri/kol-tree-item.entry.js +1 -1
- package/dist/kolibri/kol-tree-item.entry.js.map +1 -1
- package/dist/kolibri/kol-tree-wc.entry.esm.js.map +1 -0
- package/dist/kolibri/kol-tree-wc.entry.js +1 -1
- package/dist/kolibri/kol-tree-wc.entry.js.map +1 -1
- package/dist/kolibri/kol-tree.entry.esm.js.map +1 -0
- package/dist/kolibri/kol-tree.entry.js +1 -1
- package/dist/kolibri/kol-tree.entry.js.map +1 -1
- package/dist/kolibri/kol-version.entry.esm.js.map +1 -0
- package/dist/kolibri/kol-version.entry.js +1 -1
- package/dist/kolibri/kol-version.entry.js.map +1 -1
- package/dist/kolibri/kolibri.esm.js +1 -1
- package/dist/kolibri/kolibri.esm.js.map +1 -1
- package/dist/kolibri/label-D3d1qqIG.js +4 -0
- package/dist/kolibri/label-D3d1qqIG.js.map +1 -0
- package/dist/kolibri/link-variant-BoV22Jh0.js +4 -0
- package/dist/kolibri/link-variant-BoV22Jh0.js.map +1 -0
- package/dist/kolibri/loader.esm.js.map +1 -0
- package/dist/kolibri/markdown-vxO4XBWP.js +4 -0
- package/dist/kolibri/markdown-vxO4XBWP.js.map +1 -0
- package/dist/kolibri/max-length-behavior-Dz2KB_23.js +4 -0
- package/dist/kolibri/max-length-behavior-Dz2KB_23.js.map +1 -0
- package/dist/kolibri/open-8iQ59IbX.js +4 -0
- package/dist/kolibri/open-8iQ59IbX.js.map +1 -0
- package/dist/kolibri/orientation-D3xx-ujZ.js +4 -0
- package/dist/kolibri/orientation-D3xx-ujZ.js.map +1 -0
- package/dist/kolibri/progress-DvHYRA46.js +4 -0
- package/dist/kolibri/progress-DvHYRA46.js.map +1 -0
- package/dist/kolibri/rows-DyB9epqs.js +4 -0
- package/dist/kolibri/rows-DyB9epqs.js.map +1 -0
- package/dist/kolibri/show-CdatXiQZ.js +4 -0
- package/dist/kolibri/show-CdatXiQZ.js.map +1 -0
- package/dist/kolibri/spell-check-CMcp2-Ad.js +4 -0
- package/dist/kolibri/spell-check-CMcp2-Ad.js.map +1 -0
- package/dist/kolibri/suggestions-BfRFzmYR.js +4 -0
- package/dist/kolibri/suggestions-BfRFzmYR.js.map +1 -0
- package/dist/kolibri/table-settings-BtONOLMh.js +4 -0
- package/dist/kolibri/table-settings-BtONOLMh.js.map +1 -0
- package/dist/kolibri/test-component.entry.esm.js.map +1 -0
- package/dist/kolibri/test-component.entry.js +1 -1
- package/dist/kolibri/test-component.entry.js.map +1 -1
- package/dist/kolibri/tooltip-align-5cqqmpu7.js +4 -0
- package/dist/kolibri/tooltip-align-5cqqmpu7.js.map +1 -0
- package/dist/kolibri/unique-nav-labels-gGjh_FbY.js +4 -0
- package/dist/kolibri/unique-nav-labels-gGjh_FbY.js.map +1 -0
- package/dist/kolibri/validation-BL4fIKiW.js +4 -0
- package/dist/kolibri/validation-BL4fIKiW.js.map +1 -0
- package/dist/kolibri/validation-C2b7CFWx.js +4 -0
- package/dist/kolibri/validation-C2b7CFWx.js.map +1 -0
- package/dist/types/components/@deprecated/input/controller.d.ts +7 -4
- package/dist/types/components/button/component.d.ts +6 -5
- package/dist/types/components/card/component.d.ts +1 -0
- package/dist/types/components/combobox/shadow.d.ts +4 -4
- package/dist/types/components/form/shadow.d.ts +3 -0
- package/dist/types/components/input-checkbox/shadow.d.ts +4 -4
- package/dist/types/components/input-color/controller.d.ts +2 -2
- package/dist/types/components/input-color/shadow.d.ts +6 -6
- package/dist/types/components/input-date/controller.d.ts +2 -2
- package/dist/types/components/input-date/shadow.d.ts +6 -6
- package/dist/types/components/input-email/controller.d.ts +2 -1
- package/dist/types/components/input-email/shadow.d.ts +10 -8
- package/dist/types/components/input-file/shadow.d.ts +6 -4
- package/dist/types/components/input-number/controller.d.ts +2 -2
- package/dist/types/components/input-number/shadow.d.ts +6 -6
- package/dist/types/components/input-password/controller.d.ts +4 -3
- package/dist/types/components/input-password/shadow.d.ts +12 -8
- package/dist/types/components/input-radio/shadow.d.ts +4 -4
- package/dist/types/components/input-range/controller.d.ts +2 -2
- package/dist/types/components/input-range/shadow.d.ts +6 -6
- package/dist/types/components/input-text/shadow.d.ts +10 -8
- package/dist/types/components/kolibri/shadow.d.ts +1 -0
- package/dist/types/components/link/component.d.ts +3 -2
- package/dist/types/components/modal/shadow.d.ts +1 -0
- package/dist/types/components/pagination/component.d.ts +7 -0
- package/dist/types/components/select/controller.d.ts +3 -1
- package/dist/types/components/select/shadow.d.ts +7 -7
- package/dist/types/components/single-select/shadow.d.ts +6 -4
- package/dist/types/components/spin/shadow.d.ts +2 -0
- package/dist/types/components/table-stateless/component.d.ts +3 -1
- package/dist/types/components/table-stateless/table-settings.d.ts +4 -0
- package/dist/types/components/textarea/controller.d.ts +3 -1
- package/dist/types/components/textarea/shadow.d.ts +8 -6
- package/dist/types/components/toaster/shadow.d.ts +1 -0
- package/dist/types/components/tooltip/component.d.ts +5 -5
- package/dist/types/components/version/shadow.d.ts +1 -0
- package/dist/types/components.d.ts +547 -37
- package/dist/types/e2e/index.d.ts +1 -1
- package/dist/types/e2e/input-character-limit.d.ts +2 -0
- package/dist/types/e2e/input-msg.d.ts +5 -0
- package/dist/types/functional-component-wrappers/FormFieldStateWrapper/FormFieldStateWrapper.d.ts +3 -2
- package/dist/types/functional-components/Collapsible/Collapsible.d.ts +3 -2
- package/dist/types/functional-components/FormField/FormField.d.ts +4 -2
- package/dist/types/functional-components/FormFieldCharacterLimitHint/FormFieldCharacterLimitHint.d.ts +8 -0
- package/dist/types/functional-components/FormFieldCounter/FormFieldCounter.d.ts +3 -1
- package/dist/types/functional-components/Heading/Heading.d.ts +0 -2
- package/dist/types/functional-components/inputs/Input/Input.d.ts +4 -4
- package/dist/types/functional-components/inputs/_types/index.d.ts +3 -1
- package/dist/types/global/script.d.ts +2 -1
- package/dist/types/locales/de.d.ts +7 -2
- package/dist/types/locales/en.d.ts +7 -2
- package/dist/types/schema/components/combobox.d.ts +3 -5
- package/dist/types/schema/components/index.d.ts +1 -1
- package/dist/types/schema/components/input-checkbox.d.ts +3 -5
- package/dist/types/schema/components/input-color.d.ts +4 -8
- package/dist/types/schema/components/input-date.d.ts +12 -6
- package/dist/types/schema/components/input-email.d.ts +6 -9
- package/dist/types/schema/components/input-file.d.ts +3 -5
- package/dist/types/schema/components/input-number.d.ts +10 -6
- package/dist/types/schema/components/input-password.d.ts +6 -9
- package/dist/types/schema/components/input-radio.d.ts +3 -5
- package/dist/types/schema/components/input-range.d.ts +4 -8
- package/dist/types/schema/components/input-text.d.ts +8 -9
- package/dist/types/schema/components/input.d.ts +0 -14
- package/dist/types/schema/components/select.d.ts +5 -7
- package/dist/types/schema/components/single-select.d.ts +3 -5
- package/dist/types/schema/components/textarea.d.ts +4 -5
- package/dist/types/schema/components/toaster.d.ts +1 -0
- package/dist/types/schema/props/aria-selected.d.ts +1 -2
- package/dist/types/schema/props/auto-complete.d.ts +7 -0
- package/dist/types/schema/props/hint.d.ts +6 -0
- package/dist/types/schema/props/index.d.ts +1 -1
- package/dist/types/schema/props/max-length-behavior.d.ts +8 -0
- package/dist/types/schema/props/msg.d.ts +2 -2
- package/dist/types/schema/types/aria.d.ts +4 -0
- package/dist/types/schema/types/index.d.ts +1 -1
- package/dist/types/schema/types/input/types.d.ts +0 -2
- package/dist/types/stencil-public-runtime.d.ts +37 -2
- package/doc/accordion.md +1 -1
- package/doc/alert.md +1 -1
- package/doc/button-link.md +1 -1
- package/doc/button.md +1 -1
- package/doc/card.md +1 -1
- package/doc/combobox.md +1 -1
- package/doc/details.md +1 -1
- package/doc/drawer.md +1 -1
- package/doc/form.md +2 -2
- package/doc/input-checkbox.md +1 -1
- package/doc/input-color.md +2 -2
- package/doc/input-date.md +6 -6
- package/doc/input-email.md +28 -27
- package/doc/input-file.md +1 -1
- package/doc/input-number.md +6 -6
- package/doc/input-password.md +27 -26
- package/doc/input-radio.md +1 -1
- package/doc/input-range.md +6 -6
- package/doc/input-text.md +29 -28
- package/doc/link-button.md +1 -1
- package/doc/link.md +1 -1
- package/doc/modal.md +1 -1
- package/doc/pagination.md +1 -1
- package/doc/popover-button.md +1 -1
- package/doc/select.md +4 -4
- package/doc/single-select.md +1 -1
- package/doc/split-button.md +1 -1
- package/doc/table-stateful.md +2 -2
- package/doc/table-stateless.md +10 -10
- package/doc/tabs.md +1 -1
- package/doc/textarea.md +27 -26
- package/doc/toaster.md +3 -3
- package/doc/toolbar.md +1 -1
- package/index.scss +3 -0
- package/package.json +2 -1
- package/vscode-custom-data.json +211 -67
- package/dist/cjs/Alert-7ea86720.js +0 -4
- package/dist/cjs/Alert-7ea86720.js.map +0 -1
- package/dist/cjs/Collapsible-3bebbfe5.js +0 -4
- package/dist/cjs/Collapsible-3bebbfe5.js.map +0 -1
- package/dist/cjs/CustomSuggestionsOptionsGroup-a3e67ea2.js +0 -4
- package/dist/cjs/CustomSuggestionsOptionsGroup-a3e67ea2.js.map +0 -1
- package/dist/cjs/FieldControlStateWrapper-8eb8a6da.js +0 -4
- package/dist/cjs/FieldControlStateWrapper-8eb8a6da.js.map +0 -1
- package/dist/cjs/Heading-9d176ecc.js +0 -4
- package/dist/cjs/Heading-9d176ecc.js.map +0 -1
- package/dist/cjs/Icon-9036a8c7.js +0 -4
- package/dist/cjs/Icon-9036a8c7.js.map +0 -1
- package/dist/cjs/Input-c47b81c2.js +0 -4
- package/dist/cjs/Input-c47b81c2.js.map +0 -1
- package/dist/cjs/InputStateWrapper-7563600f.js +0 -4
- package/dist/cjs/InputStateWrapper-7563600f.js.map +0 -1
- package/dist/cjs/InternalUnderlinedBadgeText-ad3a2668.js +0 -4
- package/dist/cjs/InternalUnderlinedBadgeText-ad3a2668.js.map +0 -1
- package/dist/cjs/Span-81e357ce.js +0 -4
- package/dist/cjs/Span-81e357ce.js.map +0 -1
- package/dist/cjs/access-and-short-key-ba5dc318.js +0 -4
- package/dist/cjs/access-and-short-key-ba5dc318.js.map +0 -1
- package/dist/cjs/align-6dbf7621.js +0 -4
- package/dist/cjs/align-6dbf7621.js.map +0 -1
- package/dist/cjs/align-floating-elements-8ddb8593.js +0 -4
- package/dist/cjs/align-floating-elements-8ddb8593.js.map +0 -1
- package/dist/cjs/app-globals-f6e2212a.js +0 -4
- package/dist/cjs/app-globals-f6e2212a.js.map +0 -1
- package/dist/cjs/ariaCurrentService-53afa476.js.map +0 -1
- package/dist/cjs/associated.controller-7b651bde.js +0 -4
- package/dist/cjs/associated.controller-7b651bde.js.map +0 -1
- package/dist/cjs/bem-85316256.js +0 -4
- package/dist/cjs/bem-85316256.js.map +0 -1
- package/dist/cjs/bem-c7c596d7.js +0 -4
- package/dist/cjs/bem-c7c596d7.js.map +0 -1
- package/dist/cjs/bootstrap-0ea93cf5.js +0 -4
- package/dist/cjs/bootstrap-0ea93cf5.js.map +0 -1
- package/dist/cjs/browser-4433089a.js +0 -4
- package/dist/cjs/browser-4433089a.js.map +0 -1
- package/dist/cjs/clsx-dd4d6dd1.js.map +0 -1
- package/dist/cjs/color-9f3a33be.js +0 -4
- package/dist/cjs/color-9f3a33be.js.map +0 -1
- package/dist/cjs/component-names-1cb5b7ce.js.map +0 -1
- package/dist/cjs/controller-01211f54.js +0 -4
- package/dist/cjs/controller-01211f54.js.map +0 -1
- package/dist/cjs/controller-61cc059b.js +0 -4
- package/dist/cjs/controller-61cc059b.js.map +0 -1
- package/dist/cjs/controller-75a14bc0.js +0 -4
- package/dist/cjs/controller-75a14bc0.js.map +0 -1
- package/dist/cjs/controller-ec3215b7.js +0 -4
- package/dist/cjs/controller-ec3215b7.js.map +0 -1
- package/dist/cjs/controller-icon-8c9b9b0a.js +0 -4
- package/dist/cjs/controller-icon-8c9b9b0a.js.map +0 -1
- package/dist/cjs/custom-class-65fdabdc.js +0 -4
- package/dist/cjs/custom-class-65fdabdc.js.map +0 -1
- package/dist/cjs/dev.utils-56d3762c.js +0 -4
- package/dist/cjs/dev.utils-56d3762c.js.map +0 -1
- package/dist/cjs/devtools-a6133e20.js +0 -4
- package/dist/cjs/devtools-a6133e20.js.map +0 -1
- package/dist/cjs/disabled-1872d3f6.js +0 -4
- package/dist/cjs/disabled-1872d3f6.js.map +0 -1
- package/dist/cjs/events-df7aa71f.js.map +0 -1
- package/dist/cjs/getRenderStates-7d624f2f.js +0 -4
- package/dist/cjs/getRenderStates-7d624f2f.js.map +0 -1
- package/dist/cjs/has-closer-b9c139d3.js +0 -4
- package/dist/cjs/has-closer-b9c139d3.js.map +0 -1
- package/dist/cjs/has-counter-edfb692b.js +0 -4
- package/dist/cjs/has-counter-edfb692b.js.map +0 -1
- package/dist/cjs/hide-label-18d6d9e2.js +0 -4
- package/dist/cjs/hide-label-18d6d9e2.js.map +0 -1
- package/dist/cjs/href-b36c8e1d.js +0 -4
- package/dist/cjs/href-b36c8e1d.js.map +0 -1
- package/dist/cjs/i18n-8c288a27.js +0 -4
- package/dist/cjs/i18n-8c288a27.js.map +0 -1
- package/dist/cjs/i18n-b01aa5d0.js +0 -4
- package/dist/cjs/i18n-b01aa5d0.js.map +0 -1
- package/dist/cjs/icons-99569c9b.js +0 -4
- package/dist/cjs/icons-99569c9b.js.map +0 -1
- package/dist/cjs/image-source-481ea03a.js +0 -4
- package/dist/cjs/image-source-481ea03a.js.map +0 -1
- package/dist/cjs/index-233be018.js +0 -4
- package/dist/cjs/index-233be018.js.map +0 -1
- package/dist/cjs/index-94c17ce6.js +0 -4
- package/dist/cjs/index-94c17ce6.js.map +0 -1
- package/dist/cjs/isArray-e114fe6e.js +0 -4
- package/dist/cjs/isArray-e114fe6e.js.map +0 -1
- package/dist/cjs/isObject-6090b636.js +0 -4
- package/dist/cjs/isObject-6090b636.js.map +0 -1
- package/dist/cjs/keyboard-19a7833a.js.map +0 -1
- package/dist/cjs/label-7b22af75.js +0 -4
- package/dist/cjs/label-7b22af75.js.map +0 -1
- package/dist/cjs/link-variant-fa5e798a.js +0 -4
- package/dist/cjs/link-variant-fa5e798a.js.map +0 -1
- package/dist/cjs/markdown-164534bf.js +0 -4
- package/dist/cjs/markdown-164534bf.js.map +0 -1
- package/dist/cjs/open-350f3b99.js +0 -4
- package/dist/cjs/open-350f3b99.js.map +0 -1
- package/dist/cjs/orientation-7bef64eb.js +0 -4
- package/dist/cjs/orientation-7bef64eb.js.map +0 -1
- package/dist/cjs/rows-00510978.js +0 -4
- package/dist/cjs/rows-00510978.js.map +0 -1
- package/dist/cjs/show-0449c2d9.js +0 -4
- package/dist/cjs/show-0449c2d9.js.map +0 -1
- package/dist/cjs/spell-check-e7bda657.js +0 -4
- package/dist/cjs/spell-check-e7bda657.js.map +0 -1
- package/dist/cjs/suggestions-88f8f404.js +0 -4
- package/dist/cjs/suggestions-88f8f404.js.map +0 -1
- package/dist/cjs/table-settings-3f1de70e.js +0 -4
- package/dist/cjs/table-settings-3f1de70e.js.map +0 -1
- package/dist/cjs/tooltip-align-6938fb01.js +0 -4
- package/dist/cjs/tooltip-align-6938fb01.js.map +0 -1
- package/dist/cjs/tslib.es6-5e301284.js +0 -4
- package/dist/cjs/tslib.es6-5e301284.js.map +0 -1
- package/dist/cjs/unique-nav-labels-eee92e0a.js +0 -4
- package/dist/cjs/unique-nav-labels-eee92e0a.js.map +0 -1
- package/dist/cjs/validation-515de18a.js +0 -4
- package/dist/cjs/validation-515de18a.js.map +0 -1
- package/dist/cjs/validation-8f012860.js +0 -4
- package/dist/cjs/validation-8f012860.js.map +0 -1
- package/dist/components/has-counter.js +0 -4
- package/dist/components/has-counter.js.map +0 -1
- package/dist/components/index2.js +0 -4
- package/dist/components/index2.js.map +0 -1
- package/dist/components/isArray.js +0 -4
- package/dist/components/isArray.js.map +0 -1
- package/dist/components/tslib.es6.js +0 -4
- package/dist/components/tslib.es6.js.map +0 -1
- package/dist/esm/Alert-ade6062d.js +0 -4
- package/dist/esm/Alert-ade6062d.js.map +0 -1
- package/dist/esm/Collapsible-c36b4d9f.js +0 -4
- package/dist/esm/Collapsible-c36b4d9f.js.map +0 -1
- package/dist/esm/CustomSuggestionsOptionsGroup-9cc47a5e.js +0 -4
- package/dist/esm/CustomSuggestionsOptionsGroup-9cc47a5e.js.map +0 -1
- package/dist/esm/FieldControlStateWrapper-c97fccf7.js +0 -4
- package/dist/esm/FieldControlStateWrapper-c97fccf7.js.map +0 -1
- package/dist/esm/Heading-2e6ec8e7.js +0 -4
- package/dist/esm/Heading-2e6ec8e7.js.map +0 -1
- package/dist/esm/Icon-352464b0.js +0 -4
- package/dist/esm/Icon-352464b0.js.map +0 -1
- package/dist/esm/Input-108e0727.js +0 -4
- package/dist/esm/Input-108e0727.js.map +0 -1
- package/dist/esm/InputStateWrapper-6a2151b0.js +0 -4
- package/dist/esm/InputStateWrapper-6a2151b0.js.map +0 -1
- package/dist/esm/InternalUnderlinedBadgeText-d999ca8e.js +0 -4
- package/dist/esm/InternalUnderlinedBadgeText-d999ca8e.js.map +0 -1
- package/dist/esm/Span-8137fbf2.js +0 -4
- package/dist/esm/Span-8137fbf2.js.map +0 -1
- package/dist/esm/access-and-short-key-f743a5c4.js +0 -4
- package/dist/esm/access-and-short-key-f743a5c4.js.map +0 -1
- package/dist/esm/align-d2572387.js +0 -4
- package/dist/esm/align-d2572387.js.map +0 -1
- package/dist/esm/align-floating-elements-9459ccc3.js +0 -4
- package/dist/esm/align-floating-elements-9459ccc3.js.map +0 -1
- package/dist/esm/app-globals-6b604880.js +0 -4
- package/dist/esm/app-globals-6b604880.js.map +0 -1
- package/dist/esm/ariaCurrentService-6fe36ebc.js.map +0 -1
- package/dist/esm/associated.controller-4237c28d.js +0 -4
- package/dist/esm/associated.controller-4237c28d.js.map +0 -1
- package/dist/esm/bem-dabd96cc.js +0 -4
- package/dist/esm/bem-dabd96cc.js.map +0 -1
- package/dist/esm/bem-e4c3a2e6.js +0 -4
- package/dist/esm/bem-e4c3a2e6.js.map +0 -1
- package/dist/esm/bootstrap-53ed580c.js +0 -4
- package/dist/esm/bootstrap-53ed580c.js.map +0 -1
- package/dist/esm/browser-f629a56a.js +0 -4
- package/dist/esm/browser-f629a56a.js.map +0 -1
- package/dist/esm/clsx-09a06a12.js.map +0 -1
- package/dist/esm/color-1228dab7.js +0 -4
- package/dist/esm/color-1228dab7.js.map +0 -1
- package/dist/esm/component-names-0657b355.js +0 -4
- package/dist/esm/component-names-0657b355.js.map +0 -1
- package/dist/esm/controller-11e34c4e.js +0 -4
- package/dist/esm/controller-11e34c4e.js.map +0 -1
- package/dist/esm/controller-235b6c3b.js +0 -4
- package/dist/esm/controller-235b6c3b.js.map +0 -1
- package/dist/esm/controller-e04b9250.js +0 -4
- package/dist/esm/controller-e04b9250.js.map +0 -1
- package/dist/esm/controller-ea5c62d7.js +0 -4
- package/dist/esm/controller-ea5c62d7.js.map +0 -1
- package/dist/esm/controller-icon-0e724fd0.js +0 -4
- package/dist/esm/controller-icon-0e724fd0.js.map +0 -1
- package/dist/esm/custom-class-d73b81b1.js +0 -4
- package/dist/esm/custom-class-d73b81b1.js.map +0 -1
- package/dist/esm/dev.utils-a094a355.js +0 -4
- package/dist/esm/dev.utils-a094a355.js.map +0 -1
- package/dist/esm/devtools-898e9fb6.js +0 -4
- package/dist/esm/devtools-898e9fb6.js.map +0 -1
- package/dist/esm/disabled-e1038f54.js +0 -4
- package/dist/esm/disabled-e1038f54.js.map +0 -1
- package/dist/esm/events-bad0a075.js.map +0 -1
- package/dist/esm/getRenderStates-65321bc2.js +0 -4
- package/dist/esm/getRenderStates-65321bc2.js.map +0 -1
- package/dist/esm/has-closer-798e8f4d.js +0 -4
- package/dist/esm/has-closer-798e8f4d.js.map +0 -1
- package/dist/esm/has-counter-3fc44829.js +0 -4
- package/dist/esm/has-counter-3fc44829.js.map +0 -1
- package/dist/esm/hide-label-8b3a8709.js +0 -4
- package/dist/esm/hide-label-8b3a8709.js.map +0 -1
- package/dist/esm/href-d9ccbbdf.js +0 -4
- package/dist/esm/href-d9ccbbdf.js.map +0 -1
- package/dist/esm/i18n-260f0fe9.js +0 -4
- package/dist/esm/i18n-260f0fe9.js.map +0 -1
- package/dist/esm/i18n-45224cc3.js +0 -4
- package/dist/esm/i18n-45224cc3.js.map +0 -1
- package/dist/esm/icons-a9c52ed8.js +0 -4
- package/dist/esm/icons-a9c52ed8.js.map +0 -1
- package/dist/esm/image-source-8079f8a5.js +0 -4
- package/dist/esm/image-source-8079f8a5.js.map +0 -1
- package/dist/esm/index-3309536d.js +0 -4
- package/dist/esm/index-3309536d.js.map +0 -1
- package/dist/esm/index-ebe5a881.js +0 -4
- package/dist/esm/index-ebe5a881.js.map +0 -1
- package/dist/esm/isArray-7a60fa7f.js +0 -4
- package/dist/esm/isArray-7a60fa7f.js.map +0 -1
- package/dist/esm/isObject-ffcbbb76.js +0 -4
- package/dist/esm/isObject-ffcbbb76.js.map +0 -1
- package/dist/esm/keyboard-2483c6de.js.map +0 -1
- package/dist/esm/label-bf9966d0.js +0 -4
- package/dist/esm/label-bf9966d0.js.map +0 -1
- package/dist/esm/link-variant-47605ebe.js +0 -4
- package/dist/esm/link-variant-47605ebe.js.map +0 -1
- package/dist/esm/markdown-f827f2ac.js +0 -4
- package/dist/esm/markdown-f827f2ac.js.map +0 -1
- package/dist/esm/open-385de2c9.js +0 -4
- package/dist/esm/open-385de2c9.js.map +0 -1
- package/dist/esm/orientation-409d844a.js +0 -4
- package/dist/esm/orientation-409d844a.js.map +0 -1
- package/dist/esm/rows-225b4f43.js +0 -4
- package/dist/esm/rows-225b4f43.js.map +0 -1
- package/dist/esm/show-fabfe6d7.js +0 -4
- package/dist/esm/show-fabfe6d7.js.map +0 -1
- package/dist/esm/spell-check-5559a801.js +0 -4
- package/dist/esm/spell-check-5559a801.js.map +0 -1
- package/dist/esm/suggestions-198125b7.js +0 -4
- package/dist/esm/suggestions-198125b7.js.map +0 -1
- package/dist/esm/table-settings-c12356ed.js +0 -4
- package/dist/esm/table-settings-c12356ed.js.map +0 -1
- package/dist/esm/tooltip-align-465a8590.js +0 -4
- package/dist/esm/tooltip-align-465a8590.js.map +0 -1
- package/dist/esm/tslib.es6-1173d062.js +0 -4
- package/dist/esm/tslib.es6-1173d062.js.map +0 -1
- package/dist/esm/unique-nav-labels-e20db0b7.js +0 -4
- package/dist/esm/unique-nav-labels-e20db0b7.js.map +0 -1
- package/dist/esm/validation-152ea092.js +0 -4
- package/dist/esm/validation-152ea092.js.map +0 -1
- package/dist/esm/validation-9d549145.js +0 -4
- package/dist/esm/validation-9d549145.js.map +0 -1
- package/dist/kolibri/Alert-ade6062d.js +0 -4
- package/dist/kolibri/Alert-ade6062d.js.map +0 -1
- package/dist/kolibri/Collapsible-c36b4d9f.js +0 -4
- package/dist/kolibri/Collapsible-c36b4d9f.js.map +0 -1
- package/dist/kolibri/CustomSuggestionsOptionsGroup-9cc47a5e.js +0 -4
- package/dist/kolibri/CustomSuggestionsOptionsGroup-9cc47a5e.js.map +0 -1
- package/dist/kolibri/FieldControlStateWrapper-c97fccf7.js +0 -4
- package/dist/kolibri/FieldControlStateWrapper-c97fccf7.js.map +0 -1
- package/dist/kolibri/Heading-2e6ec8e7.js +0 -4
- package/dist/kolibri/Heading-2e6ec8e7.js.map +0 -1
- package/dist/kolibri/Icon-352464b0.js +0 -4
- package/dist/kolibri/Icon-352464b0.js.map +0 -1
- package/dist/kolibri/Input-108e0727.js +0 -4
- package/dist/kolibri/Input-108e0727.js.map +0 -1
- package/dist/kolibri/InputStateWrapper-6a2151b0.js +0 -4
- package/dist/kolibri/InputStateWrapper-6a2151b0.js.map +0 -1
- package/dist/kolibri/InternalUnderlinedBadgeText-d999ca8e.js +0 -4
- package/dist/kolibri/InternalUnderlinedBadgeText-d999ca8e.js.map +0 -1
- package/dist/kolibri/Span-8137fbf2.js +0 -4
- package/dist/kolibri/Span-8137fbf2.js.map +0 -1
- package/dist/kolibri/access-and-short-key-f743a5c4.js +0 -4
- package/dist/kolibri/access-and-short-key-f743a5c4.js.map +0 -1
- package/dist/kolibri/align-d2572387.js +0 -4
- package/dist/kolibri/align-d2572387.js.map +0 -1
- package/dist/kolibri/align-floating-elements-9459ccc3.js +0 -4
- package/dist/kolibri/align-floating-elements-9459ccc3.js.map +0 -1
- package/dist/kolibri/app-globals-6b604880.js +0 -4
- package/dist/kolibri/app-globals-6b604880.js.map +0 -1
- package/dist/kolibri/ariaCurrentService-6fe36ebc.js.map +0 -1
- package/dist/kolibri/associated.controller-4237c28d.js +0 -4
- package/dist/kolibri/associated.controller-4237c28d.js.map +0 -1
- package/dist/kolibri/bem-dabd96cc.js +0 -4
- package/dist/kolibri/bem-dabd96cc.js.map +0 -1
- package/dist/kolibri/bem-e4c3a2e6.js +0 -4
- package/dist/kolibri/bem-e4c3a2e6.js.map +0 -1
- package/dist/kolibri/bootstrap-53ed580c.js +0 -4
- package/dist/kolibri/bootstrap-53ed580c.js.map +0 -1
- package/dist/kolibri/browser-f629a56a.js +0 -4
- package/dist/kolibri/browser-f629a56a.js.map +0 -1
- package/dist/kolibri/clsx-09a06a12.js.map +0 -1
- package/dist/kolibri/color-1228dab7.js +0 -4
- package/dist/kolibri/color-1228dab7.js.map +0 -1
- package/dist/kolibri/component-names-0657b355.js +0 -4
- package/dist/kolibri/component-names-0657b355.js.map +0 -1
- package/dist/kolibri/controller-11e34c4e.js +0 -4
- package/dist/kolibri/controller-11e34c4e.js.map +0 -1
- package/dist/kolibri/controller-235b6c3b.js +0 -4
- package/dist/kolibri/controller-235b6c3b.js.map +0 -1
- package/dist/kolibri/controller-e04b9250.js +0 -4
- package/dist/kolibri/controller-e04b9250.js.map +0 -1
- package/dist/kolibri/controller-ea5c62d7.js +0 -4
- package/dist/kolibri/controller-ea5c62d7.js.map +0 -1
- package/dist/kolibri/controller-icon-0e724fd0.js +0 -4
- package/dist/kolibri/controller-icon-0e724fd0.js.map +0 -1
- package/dist/kolibri/custom-class-d73b81b1.js +0 -4
- package/dist/kolibri/custom-class-d73b81b1.js.map +0 -1
- package/dist/kolibri/dev.utils-a094a355.js +0 -4
- package/dist/kolibri/dev.utils-a094a355.js.map +0 -1
- package/dist/kolibri/devtools-898e9fb6.js +0 -4
- package/dist/kolibri/devtools-898e9fb6.js.map +0 -1
- package/dist/kolibri/disabled-e1038f54.js +0 -4
- package/dist/kolibri/disabled-e1038f54.js.map +0 -1
- package/dist/kolibri/events-bad0a075.js.map +0 -1
- package/dist/kolibri/getRenderStates-65321bc2.js +0 -4
- package/dist/kolibri/getRenderStates-65321bc2.js.map +0 -1
- package/dist/kolibri/has-closer-798e8f4d.js +0 -4
- package/dist/kolibri/has-closer-798e8f4d.js.map +0 -1
- package/dist/kolibri/has-counter-3fc44829.js +0 -4
- package/dist/kolibri/has-counter-3fc44829.js.map +0 -1
- package/dist/kolibri/hide-label-8b3a8709.js +0 -4
- package/dist/kolibri/hide-label-8b3a8709.js.map +0 -1
- package/dist/kolibri/href-d9ccbbdf.js +0 -4
- package/dist/kolibri/href-d9ccbbdf.js.map +0 -1
- package/dist/kolibri/i18n-260f0fe9.js +0 -4
- package/dist/kolibri/i18n-260f0fe9.js.map +0 -1
- package/dist/kolibri/i18n-45224cc3.js +0 -4
- package/dist/kolibri/i18n-45224cc3.js.map +0 -1
- package/dist/kolibri/icons-a9c52ed8.js +0 -4
- package/dist/kolibri/icons-a9c52ed8.js.map +0 -1
- package/dist/kolibri/image-source-8079f8a5.js +0 -4
- package/dist/kolibri/image-source-8079f8a5.js.map +0 -1
- package/dist/kolibri/index-3309536d.js +0 -5
- package/dist/kolibri/index-3309536d.js.map +0 -1
- package/dist/kolibri/index-ebe5a881.js +0 -4
- package/dist/kolibri/index-ebe5a881.js.map +0 -1
- package/dist/kolibri/isArray-7a60fa7f.js +0 -4
- package/dist/kolibri/isArray-7a60fa7f.js.map +0 -1
- package/dist/kolibri/isObject-ffcbbb76.js +0 -4
- package/dist/kolibri/isObject-ffcbbb76.js.map +0 -1
- package/dist/kolibri/keyboard-2483c6de.js.map +0 -1
- package/dist/kolibri/label-bf9966d0.js +0 -4
- package/dist/kolibri/label-bf9966d0.js.map +0 -1
- package/dist/kolibri/link-variant-47605ebe.js +0 -4
- package/dist/kolibri/link-variant-47605ebe.js.map +0 -1
- package/dist/kolibri/markdown-f827f2ac.js +0 -4
- package/dist/kolibri/markdown-f827f2ac.js.map +0 -1
- package/dist/kolibri/open-385de2c9.js +0 -4
- package/dist/kolibri/open-385de2c9.js.map +0 -1
- package/dist/kolibri/orientation-409d844a.js +0 -4
- package/dist/kolibri/orientation-409d844a.js.map +0 -1
- package/dist/kolibri/rows-225b4f43.js +0 -4
- package/dist/kolibri/rows-225b4f43.js.map +0 -1
- package/dist/kolibri/show-fabfe6d7.js +0 -4
- package/dist/kolibri/show-fabfe6d7.js.map +0 -1
- package/dist/kolibri/spell-check-5559a801.js +0 -4
- package/dist/kolibri/spell-check-5559a801.js.map +0 -1
- package/dist/kolibri/suggestions-198125b7.js +0 -4
- package/dist/kolibri/suggestions-198125b7.js.map +0 -1
- package/dist/kolibri/table-settings-c12356ed.js +0 -4
- package/dist/kolibri/table-settings-c12356ed.js.map +0 -1
- package/dist/kolibri/tooltip-align-465a8590.js +0 -4
- package/dist/kolibri/tooltip-align-465a8590.js.map +0 -1
- package/dist/kolibri/tslib.es6-1173d062.js +0 -4
- package/dist/kolibri/tslib.es6-1173d062.js.map +0 -1
- package/dist/kolibri/unique-nav-labels-e20db0b7.js +0 -4
- package/dist/kolibri/unique-nav-labels-e20db0b7.js.map +0 -1
- package/dist/kolibri/validation-152ea092.js +0 -4
- package/dist/kolibri/validation-152ea092.js.map +0 -1
- package/dist/kolibri/validation-9d549145.js +0 -4
- package/dist/kolibri/validation-9d549145.js.map +0 -1
- package/dist/loader/package.json +0 -11
- package/dist/types/components/input/controller.d.ts +0 -11
- package/dist/types/components/input/types.d.ts +0 -13
- package/dist/types/functional-component-wrappers/CheckboxStateWrapper/index.d.ts +0 -1
- package/dist/types/functional-component-wrappers/FieldControlStateWrapper/index.d.ts +0 -1
- package/dist/types/functional-component-wrappers/FormFieldStateWrapper/index.d.ts +0 -1
- package/dist/types/functional-component-wrappers/InputContainerStateWrapper/index.d.ts +0 -1
- package/dist/types/functional-component-wrappers/InputStateWrapper/index.d.ts +0 -1
- package/dist/types/functional-component-wrappers/RadioStateWrapper/index.d.ts +0 -1
- package/dist/types/functional-component-wrappers/SelectStateWrapper/index.d.ts +0 -1
- package/dist/types/functional-component-wrappers/TextAreaStateWrapper/index.d.ts +0 -1
- package/dist/types/schema/types/input/control/number.d.ts +0 -24
- package/dist/types/schema/types/input/control/text.d.ts +0 -2
- /package/dist/cjs/{ariaCurrentService-53afa476.js → ariaCurrentService-3051l6MI.js} +0 -0
- /package/dist/cjs/{clsx-dd4d6dd1.js → clsx-CkZlkaek.js} +0 -0
- /package/dist/cjs/{component-names-1cb5b7ce.js → component-names-D7MwtuB7.js} +0 -0
- /package/dist/cjs/{events-df7aa71f.js → events-DDhO-Ns8.js} +0 -0
- /package/dist/cjs/{keyboard-19a7833a.js → keyboard-C096g_BV.js} +0 -0
- /package/dist/esm/{ariaCurrentService-6fe36ebc.js → ariaCurrentService-YoLNpD5S.js} +0 -0
- /package/dist/esm/{clsx-09a06a12.js → clsx-eK3rPvPS.js} +0 -0
- /package/dist/esm/{events-bad0a075.js → events-CoPFQEiC.js} +0 -0
- /package/dist/esm/{keyboard-2483c6de.js → keyboard-D6PoWr38.js} +0 -0
- /package/dist/kolibri/{ariaCurrentService-6fe36ebc.js → ariaCurrentService-YoLNpD5S.js} +0 -0
- /package/dist/kolibri/{clsx-09a06a12.js → clsx-eK3rPvPS.js} +0 -0
- /package/dist/kolibri/{events-bad0a075.js → events-CoPFQEiC.js} +0 -0
- /package/dist/kolibri/{keyboard-2483c6de.js → keyboard-D6PoWr38.js} +0 -0
@@ -1,4 +1,4 @@
|
|
1
1
|
/*!
|
2
2
|
* KoliBri - The accessible HTML-Standard
|
3
3
|
*/
|
4
|
-
import{h as t,r as e,g as n}from"./index-3309536d.js";import{c as i}from"./clsx-09a06a12.js";import{n as s}from"./dev.utils-a094a355.js";import{F as o}from"./getRenderStates-65321bc2.js";import{B as a,i as l}from"./index-ebe5a881.js";import{I as r,a as h}from"./controller-icon-0e724fd0.js";import{v as d}from"./suggestions-198125b7.js";import{C as c,a as u,b as f,g as p}from"./CustomSuggestionsOptionsGroup-9cc47a5e.js";import{I as m}from"./InputStateWrapper-6a2151b0.js";import"./events-bad0a075.js";import"./associated.controller-4237c28d.js";import"./bootstrap-53ed580c.js";import"./component-names-0657b355.js";import"./i18n-45224cc3.js";import"./access-and-short-key-f743a5c4.js";import"./tooltip-align-465a8590.js";import"./align-d2572387.js";import"./hide-label-8b3a8709.js";import"./label-bf9966d0.js";import"./tslib.es6-1173d062.js";import"./Alert-ade6062d.js";import"./i18n-260f0fe9.js";import"./bem-e4c3a2e6.js";import"./browser-f629a56a.js";import"./Heading-2e6ec8e7.js";import"./InternalUnderlinedBadgeText-d999ca8e.js";import"./isArray-7a60fa7f.js";import"./Icon-352464b0.js";import"./isObject-ffcbbb76.js";import"./icons-a9c52ed8.js";import"./Input-108e0727.js";class b extends r{constructor(e,t,n){super(e,t,n),this.component=e}validatePlaceholder(e){a(this.component,"_placeholder",e)}validateRequired(e){l(this.component,"_required",e)}validateSuggestions(e){d(this.component,e)}validateValue(e){a(this.component,"_value",e)}componentWillLoad(){super.componentWillLoad(),this.validatePlaceholder(this.component._placeholder),this.validateRequired(this.component._required),this.validateSuggestions(this.component._suggestions),this.validateValue(this.component._value)}}const g="/*\n * This file contains all rules for accessibility.\n */\n@layer kol-global {\n :host {\n /*\n * Minimum size of interactive elements.\n */\n --a11y-min-size: calc(44rem / var(--kolibri-root-font-size, 16));\n /*\n * No element should be used without a background and font color whose contrast ratio has\n * not been checked. By initially setting the background color to white and the font color\n * to black, the contrast ratio is ensured and explicit adjustment is forced.\n */\n background-color: white;\n color: black;\n }\n * {\n /*\n * This rule enables the word dividing for all texts. That is important for high zoom levels.\n */\n hyphens: auto;\n /*\n * Verdana is an accessible font that can be used without requiring additional loading time.\n */\n font-family: Verdana;\n /*\n * Letter spacing is required for all texts.\n */\n letter-spacing: inherit;\n /*\n * This rule enables the word dividing for all texts. That is important for high zoom levels.\n */\n word-break: break-word;\n /*\n * Word spacing is required for all texts.\n */\n word-spacing: inherit;\n }\n /*\n * All interactive elements should have a minimum size of rem(44).\n */\n /* input:not([type='checkbox'], [type='radio'], [type='range']), */\n /* option, */\n /* select, */\n /* textarea, */\n [role=button],\n button:not([role=link]),\n .kol-input .input {\n min-height: var(--a11y-min-size);\n min-width: var(--a11y-min-size);\n }\n /*\n * Some interactive elements should not inherit the font-family and font-size.\n */\n a,\n button,\n h1,\n h2,\n h3,\n h4,\n h5,\n h6,\n input,\n option,\n select,\n textarea {\n /*\n * All elements should inherit the font family from his parent element.\n */\n font-family: inherit;\n /*\n * All elements should inherit the font size from his parent element.\n */\n font-size: inherit;\n }\n}\n/**\n * Sometimes we need the semantic element for accessibility reasons,\n * but we don't want to show it.\n *\n * - https://www.a11yproject.com/posts/how-to-hide-content/\n */\n.visually-hidden {\n clip: rect(0 0 0 0);\n clip-path: inset(50%);\n height: 1px;\n overflow: hidden;\n position: absolute;\n white-space: nowrap;\n width: 1px;\n}\n\n@layer kol-global {\n /*\n * Dieses CSS stellt sicher, dass der Standard-Style\n * von A und Button resettet werden.\n */\n :is(a, button) {\n background-color: transparent;\n border: none;\n margin: 0;\n padding: 0;\n width: 100%;\n /* 100% needed for custom width from outside */\n }\n /*\n * Ensure elements with hidden attribute to be actually not visible\n * @see https://meowni.ca/hidden.is.a.lie.html\n */\n [hidden] {\n display: none !important;\n }\n .badge-text-hint {\n background-color: lightgray;\n color: black;\n }\n}\n@layer kol-global {\n :host {\n font-size: rem(16);\n /*\n * The max-width is needed to prevent the table from overflowing the\n * parent node, if the table is wider than the parent node.\n */\n max-width: 100%;\n }\n * {\n /*\n * We prefer to box-sizing: border-box for all elements.\n */\n box-sizing: border-box;\n }\n .kol-span {\n /* KolSpan is a layout component with icons in all directions and a label text in the middle. */\n display: grid;\n place-items: center;\n /* The sub span in KolSpan is the horizontal span with icon left and right and the label text in the middle. */\n }\n .kol-span__container {\n display: flex;\n place-items: center;\n }\n a,\n button {\n cursor: pointer;\n }\n .kol-span .kol-span__label--hide-label .kol-span__label {\n display: none;\n }\n /* Reset browser agent style. */\n button:disabled {\n color: unset;\n }\n .disabled label,\n .disabled:focus-within label,\n [aria-disabled=true],\n [aria-disabled=true]:focus,\n [disabled],\n [disabled]:focus {\n cursor: not-allowed;\n opacity: 0.5;\n outline: none;\n }\n [aria-disabled=true]:focus .kol-span,\n [disabled]:focus .kol-span {\n outline: none !important;\n }\n}\n@layer kol-component {\n :host {\n display: block;\n }\n}\n@layer kol-component {\n .kol-tooltip {\n display: contents;\n }\n .kol-tooltip__floating {\n animation-duration: 0.25s;\n animation-iteration-count: 1;\n animation-name: fadeInOpacity;\n animation-timing-function: ease-in;\n display: none;\n position: fixed;\n visibility: hidden;\n /* Avoid layout interference - see https://floating-ui.com/docs/computePosition */\n top: 0;\n left: 0;\n max-width: 90vw;\n max-height: 90vh;\n /* Can be used to specify the tooltip-width from the outside. Unset by default. */\n width: var(--kol-tooltip-width);\n }\n .kol-tooltip__arrow {\n background-color: #fff;\n color: #000;\n height: calc(10rem / var(--kolibri-root-font-size, 16));\n position: absolute;\n transform: rotate(45deg);\n width: calc(10rem / var(--kolibri-root-font-size, 16));\n z-index: 999;\n }\n .kol-tooltip__content {\n background-color: #fff;\n color: #000;\n position: relative;\n z-index: 1000;\n }\n @keyframes fadeInOpacity {\n 0% {\n opacity: 0;\n }\n 100% {\n opacity: 1;\n }\n }\n}\n@layer kol-component {\n .kol-alert {\n display: grid;\n }\n .kol-alert__container {\n place-items: center;\n display: flex;\n }\n .kol-alert__container-content {\n flex-grow: 1;\n }\n .kol-alert__closer {\n /* Visible with forced colors */\n outline: transparent solid calc(1rem / var(--kolibri-root-font-size, 16));\n }\n}\n@layer kol-component {\n .kol-custom-suggestions-option {\n cursor: pointer;\n white-space: normal;\n overflow-wrap: break-word;\n word-wrap: break-word;\n line-height: 1.5;\n }\n .kol-custom-suggestions-options-group--cursor-hidden .kol-custom-suggestions-option {\n cursor: none !important;\n }\n}\n@layer kol-component {\n .kol-custom-suggestions-options-group {\n display: block;\n position: absolute;\n list-style-type: none;\n margin: 0;\n padding: 0;\n overflow-y: auto;\n overflow-x: hidden;\n z-index: 2;\n background-color: white;\n max-height: calc(250rem / var(--kolibri-root-font-size, 16));\n }\n}\n@layer kol-component {\n .kol-custom-suggestions-toggle {\n align-items: center;\n display: flex;\n height: var(--a11y-min-size);\n width: var(--a11y-min-size);\n }\n .kol-custom-suggestions-toggle:not(:disabled) {\n cursor: pointer;\n }\n}\n@layer kol-component {\n .kol-form-field {\n display: grid;\n }\n .kol-form-field:not(.kol-form-field--disabled) .kol-form-field__label {\n cursor: pointer;\n }\n .kol-form-field--disabled .kol-form-field__label {\n opacity: 0.5;\n }\n .kol-form-field--required .kol-form-field__label-text::after {\n content: \"*\";\n }\n .kol-form-field--disabled .kol-form-field__hint {\n opacity: 0.5;\n }\n .kol-form-field--required .kol-form-field__tooltip .span-label::after {\n content: \"*\";\n }\n}\n@layer kol-component {\n .kol-input-container {\n align-items: center;\n background-color: white;\n display: grid;\n grid-template-columns: 1fr;\n min-height: var(--a11y-min-size);\n min-width: var(--a11y-min-size);\n width: 100%;\n }\n .kol-input-container:has(> .kol-input-container__adornment--start) {\n grid-template-columns: auto 1fr;\n }\n .kol-input-container:has(> .kol-input-container__adornment--end) {\n grid-template-columns: 1fr auto;\n }\n .kol-input-container:has(> .kol-input-container__adornment--start):has(> .kol-input-container__adornment--end) {\n grid-template-columns: auto 1fr auto;\n }\n .kol-input-container__container {\n position: relative;\n }\n .kol-input-container__adornment {\n display: flex;\n align-items: center;\n }\n .kol-input-container__adornment .kol-icon {\n display: grid;\n height: var(--a11y-min-size);\n place-items: center;\n }\n}\n@layer kol-component {\n .kol-input {\n min-width: var(--a11y-min-size);\n width: 100%;\n }\n .kol-input:focus {\n outline: none;\n }\n}",v=g,k=class{async getValue(){return this.state._value}async kolFocus(){var e;null===(e=this.refInput)||void 0===e||e.focus()}selectOption(e){var t;this.controller.onFacade.onInput(new CustomEvent("input",{bubbles:!0,detail:{name:this.state._name,value:e}}),!0,e),this.controller.onFacade.onChange(new CustomEvent("change",{bubbles:!0,detail:{name:this.state._name,value:e}}),e),this.controller.setFormAssociatedValue(e),this.state._value=e,null===(t=this.refInput)||void 0===t||t.focus()}onInput(e){const t=e.target;this.state._value=t.value,this._value=t.value,this.controller.onFacade.onInput(e),this.setFilteredSuggestionsByQuery(t.value),this._focusedOptionIndex=-1}handleKeyDownDropdown(e){1===e.key.length&&/[a-z0-9]/i.test(e.key)&&(this._isOpen=!0,this.focusSuggestionStartingWith(e.key))}setFilteredSuggestionsByQuery(e){""===e.trim()?this._filteredSuggestions=[...this._suggestions]:(this._filteredSuggestions=Array.isArray(this._suggestions)?this._suggestions.filter((t=>t.toLowerCase().includes(e.toLowerCase()))):this._filteredSuggestions,this._isOpen=!!(this._filteredSuggestions&&this._filteredSuggestions.length>0))}moveFocus(e){if(!this._filteredSuggestions)return;let t=this._focusedOptionIndex+e;t>=this._filteredSuggestions.length&&(t=0),t<0&&(t=this._filteredSuggestions.length-1),this.focusOption(t)}focusOption(e){if(this._focusedOptionIndex=e,this.refSuggestions){const t=this.refSuggestions[e];null==t||t.focus()}}focusSuggestionStartingWith(e){const t=e.toLowerCase(),n=Array.isArray(this._filteredSuggestions)&&this._filteredSuggestions.length>0&&this._filteredSuggestions.findIndex((e=>e.toLowerCase().startsWith(t)));"number"==typeof n&&this.focusOption(n)}getFormFieldProps(){return{state:this.state,class:i("kol-combobox",{"has-value":this.state._hasValue}),tooltipAlign:this._tooltipAlign,onClick:()=>{var e;return null===(e=this.refInput)||void 0===e?void 0:e.focus()},alert:this.showAsAlert()}}getInputProps(){const{ariaDescribedBy:e}=p(this.state);return Object.assign(Object.assign({ref:this.catchRef,state:this.state,class:"kol-combobox__input",type:"text",role:"combobox","aria-autocomplete":"both","aria-expanded":this._isOpen?"true":"false","aria-controls":"listbox","aria-describedby":e.length>0?e.join(" "):void 0,"aria-label":this.state._hideLabel&&"string"==typeof this.state._label?this.state._label:void 0,"aria-labelledby":this.state._id,"aria-activedescendant":this._isOpen&&this._focusedOptionIndex>=0?`option-${this._focusedOptionIndex}`:void 0,value:this.state._value,accessKey:this.state._accessKey,autocapitalize:"off",autocorrect:"off",disabled:this.state._disabled,customSuggestions:!0,id:this.state._id,name:this.state._name,required:this.state._required},this.controller.onFacade),{onFocus:e=>{this.controller.onFacade.onFocus(e),this.inputHasFocus=!0},onBlur:e=>{this.controller.onFacade.onBlur(e),this.inputHasFocus=!1},onChange:this.onChange.bind(this),onInput:this.onInput.bind(this),placeholder:this.state._placeholder})}render(){return t(o,Object.assign({key:"44bc85c62caa382896b635dbc743f16d24863644"},this.getFormFieldProps()),t(h,{key:"fd4b270034c88219b2f7f7eae2591334906ece02",state:this.state},t("div",{key:"d4510edc466749cef9b6291afd9c282c77b88f8f",class:"kol-combobox__group"},t(m,Object.assign({key:"ddc7d75b247724e081da3b8360238e271110cdca"},this.getInputProps())),t(c,{key:"4531ca610c2f04d45072823222cac12c49c3ab74",onClick:this.toggleListbox.bind(this),disabled:this.state._disabled})),this._isOpen&&!(!0===this.state._disabled)&&t(u,{key:"d995a87095216c4f1cf32b8e6c789dffffcf2572",blockSuggestionMouseOver:this.blockSuggestionMouseOver,onKeyDown:this.handleKeyDownDropdown.bind(this)},Array.isArray(this._filteredSuggestions)&&this._filteredSuggestions.length>0&&this._filteredSuggestions.map(((e,n)=>t(f,{index:n,option:e,searchTerm:this.state._value,ref:e=>{e&&(this.refSuggestions[n]=e)},selected:this.state._value===e,onClick:()=>{this.selectOption(e),this.toggleListbox(),this._isOpen=!1,this._hasOpened=!1},onMouseOver:()=>{this.blockSuggestionMouseOver||this.focusOption(n)},onFocus:()=>{this.focusOption(n)},onKeyDown:t=>{"Enter"!==t.key&&"NumpadEnter"!==t.key||(this.selectOption(e),this.toggleListbox(),t.preventDefault())}}))))))}handleKeyDown(e){var t,n;const i=(t,n)=>{var i;e.preventDefault(),void 0!==t&&(this._isOpen=t,t||null===(i=this.refInput)||void 0===i||i.focus()),null==n||n()};switch(e.key){case"Down":case"ArrowDown":this.blockSuggestionMouseOver=!0,i(!0,(()=>this.moveFocus(1)));break;case"Up":case"ArrowUp":this.blockSuggestionMouseOver=!0,i(!0,(()=>this.moveFocus(-1)));break;case"Tab":this._isOpen&&(this._isOpen=!1,null===(t=this.refInput)||void 0===t||t.focus());break;case"Esc":case"Escape":this._hasOpened=!1,this._isOpen=!1,e.preventDefault(),null===(n=this.refInput)||void 0===n||n.focus();break;case"NumpadEnter":case"Enter":this._isOpen&&this._focusedOptionIndex>=0?(this._filteredSuggestions&&this.selectOption(this._filteredSuggestions[this._focusedOptionIndex]),this._isOpen=!1,this._hasOpened=!1):this.toggleListbox(),e.preventDefault();break;case"Home":this.blockSuggestionMouseOver=!0,i(void 0,(()=>{this._isOpen&&this.focusOption(0)}));break;case"End":this.blockSuggestionMouseOver=!0,i(void 0,(()=>{this._isOpen&&this.focusOption(this._filteredSuggestions?this._filteredSuggestions.length-1:0)}));break;case"PageUp":this.blockSuggestionMouseOver=!0,i(void 0,(()=>this._isOpen&&this.moveFocus(-10)));break;case"PageDown":this.blockSuggestionMouseOver=!0,i(void 0,(()=>this._isOpen&&this.moveFocus(10)))}}handleWindowClick(e){void 0===this.host||this.host.contains(e.target)||(this._isOpen=!1)}constructor(t){e(this,t),this.refSuggestions=[],this._focusedOptionIndex=-1,this.toggleListbox=()=>{var e;if(!0===this.state._disabled)this._isOpen=!1;else if(null===(e=this.refInput)||void 0===e||e.focus(),!this._hasOpened&&Array.isArray(this._filteredSuggestions)&&this._filteredSuggestions.length>0){this._isOpen=!0,this._hasOpened=!0;const e=this._filteredSuggestions.findIndex((e=>e===this.state._value));this._focusedOptionIndex=e>=0?e:-1,this.focusOption(this._focusedOptionIndex)}},this.catchRef=e=>{this.refInput=e},this.blockSuggestionMouseOver=!1,this._isOpen=!1,this._filteredSuggestions=void 0,this._hasOpened=!1,this._accessKey=void 0,this._placeholder=void 0,this._disabled=!1,this._hideMsg=!1,this._hideLabel=!1,this._hint="",this._icons=void 0,this._id=void 0,this._label=void 0,this._msg=void 0,this._name=void 0,this._on=void 0,this._suggestions=void 0,this._required=!1,this._shortKey=void 0,this._syncValueBySelector=void 0,this._tooltipAlign="top",this._touched=!1,this._value=void 0,this.state={_hasValue:!1,_hideMsg:!1,_id:`id-${s()}`,_label:"",_suggestions:[],_value:""},this.inputHasFocus=!1,this.controller=new b(this,"combobox",this.host),this.onInput=this.onInput.bind(this)}showAsAlert(){return Boolean(this.state._touched)&&!this.inputHasFocus}validatePlaceholder(e){this.controller.validatePlaceholder(e)}validateAccessKey(e){this.controller.validateAccessKey(e)}validateDisabled(e){this.controller.validateDisabled(e)}validateHideMsg(e){this.controller.validateHideMsg(e)}validateHideLabel(e){this.controller.validateHideLabel(e)}validateHint(e){this.controller.validateHint(e)}validateIcons(e){this.controller.validateIcons(e)}validateId(e){this.controller.validateId(e)}validateLabel(e){this.controller.validateLabel(e)}validateMsg(e){this.controller.validateMsg(e)}validateName(e){this.controller.validateName(e)}validateOn(e){this.controller.validateOn(e)}validateShortKey(e){this.controller.validateShortKey(e)}validateSuggestions(e){this.controller.validateSuggestions(e),this._filteredSuggestions=e}validateRequired(e){this.controller.validateRequired(e)}validateSyncValueBySelector(e){this.controller.validateSyncValueBySelector(e)}validateTouched(e){this.controller.validateTouched(e)}validateValue(e){this.controller.validateValue(e),this.controller.setFormAssociatedValue(e)}componentWillLoad(){this.refSuggestions=[],this._touched=!0===this._touched,this.controller.componentWillLoad(),this.state._hasValue=!!this.state._value,this.controller.addValueChangeListener((e=>this.state._hasValue=!!e)),this._filteredSuggestions=this.state._suggestions}handleMouseEvent(){this.blockSuggestionMouseOver=!1}handleFocusOut(){setTimeout((()=>{var e;(null===(e=this.host)||void 0===e?void 0:e.contains(document.activeElement))||this.onBlur()}),0)}handleWindowBlur(){this.onBlur()}onBlur(){var e;this._hasOpened=!1,this._isOpen&&(this._isOpen=!this._isOpen,null===(e=this.refInput)||void 0===e||e.focus())}onChange(e){this.controller.onFacade.onChange(e),this.controller.setFormAssociatedValue(this.state._value)}static get delegatesFocus(){return!0}get host(){return n(this)}static get watchers(){return{_placeholder:["validatePlaceholder"],_accessKey:["validateAccessKey"],_disabled:["validateDisabled"],_hideMsg:["validateHideMsg"],_hideLabel:["validateHideLabel"],_hint:["validateHint"],_icons:["validateIcons"],_id:["validateId"],_label:["validateLabel"],_msg:["validateMsg"],_name:["validateName"],_on:["validateOn"],_shortKey:["validateShortKey"],_suggestions:["validateSuggestions"],_required:["validateRequired"],_syncValueBySelector:["validateSyncValueBySelector"],_touched:["validateTouched"],_value:["validateValue"]}}};k.style={default:v};export{k as kol_combobox};
|
4
|
+
import{h as t,r as n,g as e}from"./index-BhaeJ-uM.js";import{c as i}from"./clsx-eK3rPvPS.js";import{n as s}from"./dev.utils-tIfWUJtH.js";import{g as o,F as a}from"./getRenderStates-B4Xg8PG8.js";import{e as l,d as r}from"./progress-DvHYRA46.js";import{v as h}from"./suggestions-BfRFzmYR.js";import{I as d,a as c}from"./controller-icon-C2QQZ_hH.js";import{I as u}from"./InputStateWrapper-BJzpAEGU.js";import{C as p,a as m,b as f}from"./CustomSuggestionsOptionsGroup-BQa7raa8.js";import"./access-and-short-key-CykHF9HL.js";import"./hide-label-DYRsvAHX.js";import"./label-D3d1qqIG.js";import"./tooltip-align-5cqqmpu7.js";import"./align-tkanisJ7.js";import"./events-CoPFQEiC.js";import"./associated.controller-ClhjBSrR.js";import"./bootstrap-lABol9ew.js";import"./component-names-CkE54Ym7.js";import"./i18n-CjhRejiw.js";import"./isObject-DvSELytj.js";import"./Heading-D_vnx163.js";import"./Alert-DnD_hO6X.js";import"./i18n-H9CUbi--.js";import"./bem-Cpz0pDYV.js";import"./browser-DnRYLgeW.js";import"./InternalUnderlinedBadgeText-Cy3ElU32.js";import"./Icon-XldYcxyr.js";import"./icons-BVOoMgA0.js";import"./Input-D27-m66t.js";class b extends d{constructor(e,t,n){super(e,t,n),this.component=e}validatePlaceholder(e){l(this.component,"_placeholder",e)}validateRequired(e){r(this.component,"_required",e)}validateSuggestions(e){h(this.component,e)}validateValue(e){l(this.component,"_value",e)}componentWillLoad(){super.componentWillLoad(),this.validatePlaceholder(this.component._placeholder),this.validateRequired(this.component._required),this.validateSuggestions(this.component._suggestions),this.validateValue(this.component._value)}}const g="/* forward the rem function */\n/*\n * This file contains all rules for accessibility.\n */\n@layer kol-global {\n :host {\n /*\n * Minimum size of interactive elements.\n */\n --a11y-min-size: calc(44rem / var(--kolibri-root-font-size, 16));\n /*\n * No element should be used without a background and font color whose contrast ratio has\n * not been checked. By initially setting the background color to white and the font color\n * to black, the contrast ratio is ensured and explicit adjustment is forced.\n */\n background-color: white;\n color: black;\n }\n * {\n /*\n * This rule enables the word dividing for all texts. That is important for high zoom levels.\n */\n hyphens: auto;\n /*\n * Verdana is an accessible font that can be used without requiring additional loading time.\n */\n font-family: Verdana;\n /*\n * Letter spacing is required for all texts.\n */\n letter-spacing: inherit;\n /*\n * This rule enables the word dividing for all texts. That is important for high zoom levels.\n */\n word-break: break-word;\n /*\n * Word spacing is required for all texts.\n */\n word-spacing: inherit;\n }\n /*\n * All interactive elements should have a minimum size of to-rem(44).\n */\n /* input:not([type='checkbox'], [type='radio'], [type='range']), */\n /* option, */\n /* select, */\n /* textarea, */\n [role=button],\n button:not([role=link]),\n .kol-input .input {\n min-height: var(--a11y-min-size);\n min-width: var(--a11y-min-size);\n }\n /*\n * Some interactive elements should not inherit the font-family and font-size.\n */\n a,\n button,\n h1,\n h2,\n h3,\n h4,\n h5,\n h6,\n input,\n option,\n select,\n textarea {\n /*\n * All elements should inherit the font family from his parent element.\n */\n font-family: inherit;\n /*\n * All elements should inherit the font size from his parent element.\n */\n font-size: inherit;\n }\n}\n/**\n * Sometimes we need the semantic element for accessibility reasons,\n * but we don't want to show it.\n *\n * - https://www.a11yproject.com/posts/how-to-hide-content/\n */\n.visually-hidden {\n clip: rect(0 0 0 0);\n clip-path: inset(50%);\n height: 1px;\n overflow: hidden;\n position: absolute;\n white-space: nowrap;\n width: 1px;\n}\n\n@layer kol-global {\n /*\n * Dieses CSS stellt sicher, dass der Standard-Style\n * von A und Button resettet werden.\n */\n :is(a, button) {\n background-color: transparent;\n border: none;\n margin: 0;\n padding: 0;\n width: 100%;\n /* 100% needed for custom width from outside */\n }\n /*\n * Ensure elements with hidden attribute to be actually not visible\n * @see https://meowni.ca/hidden.is.a.lie.html\n */\n [hidden] {\n display: none !important;\n }\n .badge-text-hint {\n background-color: lightgray;\n color: black;\n }\n}\n@layer kol-global {\n :host {\n font-size: calc(16rem / var(--kolibri-root-font-size, 16));\n /*\n * The max-width is needed to prevent the table from overflowing the\n * parent node, if the table is wider than the parent node.\n */\n max-width: 100%;\n }\n * {\n /*\n * We prefer to box-sizing: border-box for all elements.\n */\n box-sizing: border-box;\n }\n .kol-span {\n /* KolSpan is a layout component with icons in all directions and a label text in the middle. */\n display: grid;\n place-items: center;\n /* The sub span in KolSpan is the horizontal span with icon left and right and the label text in the middle. */\n }\n .kol-span__container {\n display: flex;\n place-items: center;\n }\n a,\n button {\n cursor: pointer;\n }\n .kol-span .kol-span__label--hide-label .kol-span__label {\n display: none;\n }\n /* Reset browser agent style. */\n button:disabled {\n color: unset;\n }\n .disabled label,\n .disabled:focus-within label,\n [aria-disabled=true],\n [aria-disabled=true]:focus,\n [disabled],\n [disabled]:focus {\n cursor: not-allowed;\n opacity: 0.5;\n outline: none;\n }\n [aria-disabled=true]:focus .kol-span,\n [disabled]:focus .kol-span {\n outline: none !important;\n }\n}\n@layer kol-component {\n :host {\n display: block;\n }\n}\n@layer kol-component {\n .kol-tooltip {\n contain: layout;\n display: contents;\n }\n .kol-tooltip__floating {\n animation-duration: 0.25s;\n animation-iteration-count: 1;\n animation-name: fadeInOpacity;\n animation-timing-function: ease-in;\n display: none;\n position: fixed;\n visibility: hidden;\n /* Avoid layout interference - see https://floating-ui.com/docs/computePosition */\n top: 0;\n left: 0;\n max-width: 90vw;\n max-height: 90vh;\n /* Can be used to specify the tooltip-width from the outside. Unset by default. */\n width: var(--kol-tooltip-width);\n }\n .kol-tooltip__arrow {\n background-color: #fff;\n color: #000;\n height: calc(10rem / var(--kolibri-root-font-size, 16));\n position: absolute;\n transform: rotate(45deg);\n width: calc(10rem / var(--kolibri-root-font-size, 16));\n z-index: 999;\n }\n .kol-tooltip__content {\n background-color: #fff;\n color: #000;\n position: relative;\n z-index: 1000;\n }\n @keyframes fadeInOpacity {\n 0% {\n opacity: 0;\n }\n 100% {\n opacity: 1;\n }\n }\n}\n@layer kol-component {\n .kol-alert {\n display: grid;\n }\n .kol-alert__container {\n place-items: center;\n display: flex;\n }\n .kol-alert__container-content {\n flex-grow: 1;\n }\n .kol-alert__closer {\n /* Visible with forced colors */\n outline: transparent solid calc(1rem / var(--kolibri-root-font-size, 16));\n }\n}\n@layer kol-component {\n .kol-custom-suggestions-option {\n cursor: pointer;\n white-space: normal;\n overflow-wrap: break-word;\n word-wrap: break-word;\n line-height: 1.5;\n }\n .kol-custom-suggestions-options-group--cursor-hidden .kol-custom-suggestions-option {\n cursor: none !important;\n }\n}\n@layer kol-component {\n .kol-custom-suggestions-options-group {\n display: block;\n position: absolute;\n list-style-type: none;\n margin: 0;\n padding: 0;\n overflow-y: auto;\n overflow-x: hidden;\n z-index: 2;\n background-color: white;\n max-height: calc(250rem / var(--kolibri-root-font-size, 16));\n }\n}\n@layer kol-component {\n .kol-custom-suggestions-toggle {\n align-items: center;\n display: flex;\n height: var(--a11y-min-size);\n width: var(--a11y-min-size);\n }\n .kol-custom-suggestions-toggle:not(:disabled) {\n cursor: pointer;\n }\n}\n@layer kol-component {\n .kol-form-field {\n display: grid;\n }\n .kol-form-field:not(.kol-form-field--disabled) .kol-form-field__label {\n cursor: pointer;\n }\n .kol-form-field--disabled .kol-form-field__label {\n opacity: 0.5;\n }\n .kol-form-field--required .kol-form-field__label-text::after {\n content: \"*\";\n }\n .kol-form-field--disabled .kol-form-field__hint {\n opacity: 0.5;\n }\n .kol-form-field--required .kol-form-field__tooltip .span-label::after {\n content: \"*\";\n }\n}\n@layer kol-component {\n .kol-input-container {\n align-items: center;\n background-color: white;\n display: grid;\n grid-template-columns: 1fr;\n min-height: var(--a11y-min-size);\n min-width: var(--a11y-min-size);\n width: 100%;\n }\n .kol-input-container:has(> .kol-input-container__adornment--start) {\n grid-template-columns: auto 1fr;\n }\n .kol-input-container:has(> .kol-input-container__adornment--end) {\n grid-template-columns: 1fr auto;\n }\n .kol-input-container:has(> .kol-input-container__adornment--start):has(> .kol-input-container__adornment--end) {\n grid-template-columns: auto 1fr auto;\n }\n .kol-input-container__container {\n position: relative;\n }\n .kol-input-container__adornment {\n display: flex;\n align-items: center;\n }\n .kol-input-container__adornment .kol-icon {\n display: grid;\n height: var(--a11y-min-size);\n place-items: center;\n }\n}\n@layer kol-component {\n .kol-input {\n min-width: var(--a11y-min-size);\n width: 100%;\n }\n .kol-input:focus {\n outline: none;\n }\n}",v=class{async getValue(){return this.state._value}async kolFocus(){var e;null===(e=this.refInput)||void 0===e||e.focus()}selectOption(e){var t;this.controller.onFacade.onInput(new CustomEvent("input",{bubbles:!0,detail:{name:this.state._name,value:e}}),!0,e),this.controller.onFacade.onChange(new CustomEvent("change",{bubbles:!0,detail:{name:this.state._name,value:e}}),e),this.controller.setFormAssociatedValue(e),this.state._value=e,null===(t=this.refInput)||void 0===t||t.focus()}onInput(e){const t=e.target;this.state._value=t.value,this._value=t.value,this.controller.onFacade.onInput(e),this.setFilteredSuggestionsByQuery(t.value),this._focusedOptionIndex=-1}handleKeyDownDropdown(e){1===e.key.length&&/[a-z0-9]/i.test(e.key)&&(this._isOpen=!0,this.focusSuggestionStartingWith(e.key))}setFilteredSuggestionsByQuery(e){""===e.trim()?this._filteredSuggestions=[...this._suggestions]:(this._filteredSuggestions=Array.isArray(this._suggestions)?this._suggestions.filter((t=>t.toLowerCase().includes(e.toLowerCase()))):this._filteredSuggestions,this._isOpen=!!(this._filteredSuggestions&&this._filteredSuggestions.length>0))}moveFocus(e){if(!this._filteredSuggestions)return;let t=this._focusedOptionIndex+e;t>=this._filteredSuggestions.length&&(t=0),t<0&&(t=this._filteredSuggestions.length-1),this.focusOption(t)}focusOption(e){if(this._focusedOptionIndex=e,this.refSuggestions){const t=this.refSuggestions[e];null==t||t.focus()}}focusSuggestionStartingWith(e){const t=e.toLowerCase(),n=Array.isArray(this._filteredSuggestions)&&this._filteredSuggestions.length>0&&this._filteredSuggestions.findIndex((e=>e.toLowerCase().startsWith(t)));"number"==typeof n&&this.focusOption(n)}getFormFieldProps(){return{state:this.state,class:i("kol-combobox",{"has-value":this.state._hasValue}),tooltipAlign:this._tooltipAlign,onClick:()=>{var e;return null===(e=this.refInput)||void 0===e?void 0:e.focus()},alert:this.showAsAlert()}}getInputProps(){const{ariaDescribedBy:e}=o(this.state),t=!0===this.state._disabled;return Object.assign(Object.assign({ref:this.catchRef,state:this.state,class:"kol-combobox__input",type:"text",role:"combobox","aria-autocomplete":"both","aria-expanded":this._isOpen?"true":"false","aria-controls":"listbox","aria-describedby":e.length>0?e.join(" "):void 0,"aria-label":this.state._hideLabel&&"string"==typeof this.state._label?this.state._label:void 0,"aria-labelledby":this.state._id,"aria-activedescendant":this._isOpen&&this._focusedOptionIndex>=0?`option-${this._focusedOptionIndex}`:void 0,value:this.state._value,accessKey:this.state._accessKey,autocapitalize:"off",autocorrect:"off",disabled:t,customSuggestions:!0,id:this.state._id,name:this.state._name,required:this.state._required},this.controller.onFacade),{onFocus:e=>{this.controller.onFacade.onFocus(e),this.inputHasFocus=!0},onBlur:e=>{this.controller.onFacade.onBlur(e),this.inputHasFocus=!1},onChange:this.onChange.bind(this),onInput:this.onInput.bind(this),placeholder:this.state._placeholder})}render(){const e=!0===this.state._disabled;return t(a,Object.assign({key:"a7ffc64154f10e860ac2ab8abe4849b92d76a5a1"},this.getFormFieldProps()),t(c,{key:"6a7dd8ac2f5881defa88b1cdf6c2f2a1e603f3bb",state:this.state},t("div",{key:"f22e806387c4c0dc529c603c4fbd13480bacd30a",class:"kol-combobox__group"},t(u,Object.assign({key:"22844d8e4344d28e5b880247864d787138a6a61d"},this.getInputProps())),t(p,{key:"66de87a237ee53c363164914538af886582cc62d",onClick:this.toggleListbox.bind(this),disabled:e})),this._isOpen&&!e&&t(m,{key:"a7028c5259279f19e8b80b784b0770baa7cc6fe4",blockSuggestionMouseOver:this.blockSuggestionMouseOver,onKeyDown:this.handleKeyDownDropdown.bind(this)},Array.isArray(this._filteredSuggestions)&&this._filteredSuggestions.length>0&&this._filteredSuggestions.map(((e,n)=>t(f,{index:n,option:e,searchTerm:this.state._value,ref:e=>{e&&(this.refSuggestions[n]=e)},selected:this.state._value===e,onClick:()=>{this.selectOption(e),this.toggleListbox(),this._isOpen=!1,this._hasOpened=!1},onMouseOver:()=>{this.blockSuggestionMouseOver||this.focusOption(n)},onFocus:()=>{this.focusOption(n)},onKeyDown:t=>{"Enter"!==t.key&&"NumpadEnter"!==t.key||(this.selectOption(e),this.toggleListbox(),t.preventDefault())}}))))))}handleKeyDown(e){var t,n;const i=(t,n)=>{var i;e.preventDefault(),void 0!==t&&(this._isOpen=t,t||null===(i=this.refInput)||void 0===i||i.focus()),null==n||n()};switch(e.key){case"Down":case"ArrowDown":this.blockSuggestionMouseOver=!0,i(!0,(()=>this.moveFocus(1)));break;case"Up":case"ArrowUp":this.blockSuggestionMouseOver=!0,i(!0,(()=>this.moveFocus(-1)));break;case"Tab":this._isOpen&&(this._isOpen=!1,null===(t=this.refInput)||void 0===t||t.focus());break;case"Esc":case"Escape":this._hasOpened=!1,this._isOpen=!1,e.preventDefault(),null===(n=this.refInput)||void 0===n||n.focus();break;case"NumpadEnter":case"Enter":this._isOpen&&this._focusedOptionIndex>=0?(this._filteredSuggestions&&this.selectOption(this._filteredSuggestions[this._focusedOptionIndex]),this._isOpen=!1,this._hasOpened=!1):this.toggleListbox(),e.preventDefault();break;case"Home":this.blockSuggestionMouseOver=!0,i(void 0,(()=>{this._isOpen&&this.focusOption(0)}));break;case"End":this.blockSuggestionMouseOver=!0,i(void 0,(()=>{this._isOpen&&this.focusOption(this._filteredSuggestions?this._filteredSuggestions.length-1:0)}));break;case"PageUp":this.blockSuggestionMouseOver=!0,i(void 0,(()=>this._isOpen&&this.moveFocus(-10)));break;case"PageDown":this.blockSuggestionMouseOver=!0,i(void 0,(()=>this._isOpen&&this.moveFocus(10)))}}handleWindowClick(e){void 0===this.host||this.host.contains(e.target)||(this._isOpen=!1)}constructor(e){n(this,e),this.refSuggestions=[],this._focusedOptionIndex=-1,this.toggleListbox=()=>{var e;if(!0===this.state._disabled)this._isOpen=!1;else if(null===(e=this.refInput)||void 0===e||e.focus(),!this._hasOpened&&Array.isArray(this._filteredSuggestions)&&this._filteredSuggestions.length>0){this._isOpen=!0,this._hasOpened=!0;const e=this._filteredSuggestions.findIndex((e=>e===this.state._value));this._focusedOptionIndex=e>=0?e:-1,this.focusOption(this._focusedOptionIndex)}},this.catchRef=e=>{this.refInput=e},this.blockSuggestionMouseOver=!1,this._isOpen=!1,this._hasOpened=!1,this._disabled=!1,this._hideMsg=!1,this._hideLabel=!1,this._hint="",this._required=!1,this._tooltipAlign="top",this._touched=!1,this.state={_hasValue:!1,_hideMsg:!1,_id:`id-${s()}`,_label:"",_suggestions:[],_value:""},this.inputHasFocus=!1,this.controller=new b(this,"combobox",this.host),this.onInput=this.onInput.bind(this)}showAsAlert(){return Boolean(this.state._touched)&&!this.inputHasFocus}validatePlaceholder(e){this.controller.validatePlaceholder(e)}validateAccessKey(e){this.controller.validateAccessKey(e)}validateDisabled(e){this.controller.validateDisabled(e)}validateHideMsg(e){this.controller.validateHideMsg(e)}validateHideLabel(e){this.controller.validateHideLabel(e)}validateHint(e){this.controller.validateHint(e)}validateIcons(e){this.controller.validateIcons(e)}validateId(e){this.controller.validateId(e)}validateLabel(e){this.controller.validateLabel(e)}validateMsg(e){this.controller.validateMsg(e)}validateName(e){this.controller.validateName(e)}validateOn(e){this.controller.validateOn(e)}validateShortKey(e){this.controller.validateShortKey(e)}validateSuggestions(e){this.controller.validateSuggestions(e),this._filteredSuggestions=e}validateRequired(e){this.controller.validateRequired(e)}validateSyncValueBySelector(e){this.controller.validateSyncValueBySelector(e)}validateTouched(e){this.controller.validateTouched(e)}validateValue(e){this.controller.validateValue(e),this.controller.setFormAssociatedValue(e)}componentWillLoad(){this.refSuggestions=[],this._touched=!0===this._touched,this.controller.componentWillLoad(),this.state._hasValue=!!this.state._value,this.controller.addValueChangeListener((e=>this.state._hasValue=!!e)),this._filteredSuggestions=this.state._suggestions}handleMouseEvent(){this.blockSuggestionMouseOver=!1}handleFocusOut(){setTimeout((()=>{var e;(null===(e=this.host)||void 0===e?void 0:e.contains(document.activeElement))||this.onBlur()}),0)}handleWindowBlur(){this.onBlur()}onBlur(){var e;this._hasOpened=!1,this._isOpen&&(this._isOpen=!this._isOpen,null===(e=this.refInput)||void 0===e||e.focus())}onChange(e){this.controller.onFacade.onChange(e),this.controller.setFormAssociatedValue(this.state._value)}static get delegatesFocus(){return!0}get host(){return e(this)}static get watchers(){return{_placeholder:["validatePlaceholder"],_accessKey:["validateAccessKey"],_disabled:["validateDisabled"],_hideMsg:["validateHideMsg"],_hideLabel:["validateHideLabel"],_hint:["validateHint"],_icons:["validateIcons"],_id:["validateId"],_label:["validateLabel"],_msg:["validateMsg"],_name:["validateName"],_on:["validateOn"],_shortKey:["validateShortKey"],_suggestions:["validateSuggestions"],_required:["validateRequired"],_syncValueBySelector:["validateSyncValueBySelector"],_touched:["validateTouched"],_value:["validateValue"]}}};v.style={default:g};export{v as kol_combobox};
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"names":["ComboboxController","InputIconController","constructor","component","name","host","super","this","validatePlaceholder","value","watchString","validateRequired","watchBoolean","validateSuggestions","validateValue","componentWillLoad","_placeholder","_required","_suggestions","_value","defaultStyleCss","KolComboboxDefaultStyle0","KolCombobox","getValue","state","kolFocus","_a","refInput","focus","selectOption","option","controller","onFacade","onInput","CustomEvent","bubbles","detail","_name","onChange","setFormAssociatedValue","event","target","setFilteredSuggestionsByQuery","_focusedOptionIndex","handleKeyDownDropdown","key","length","test","_isOpen","focusSuggestionStartingWith","query","trim","_filteredSuggestions","Array","isArray","filter","toLowerCase","includes","moveFocus","delta","newIndex","focusOption","index","refSuggestions","optionElement","char","charLowerCase","findIndex","startsWith","getFormFieldProps","class","clsx","_hasValue","tooltipAlign","_tooltipAlign","onClick","alert","showAsAlert","getInputProps","ariaDescribedBy","getRenderStates","Object","assign","ref","catchRef","type","role","join","undefined","_hideLabel","_label","_id","accessKey","_accessKey","autocapitalize","autocorrect","disabled","_disabled","customSuggestions","id","required","onFocus","inputHasFocus","onBlur","bind","placeholder","render","h","KolFormFieldStateWrapperFc","KolInputContainerFc","KolInputStateWrapperFc","CustomSuggestionsToggleFc","toggleListbox","CustomSuggestionsOptionsGroupFc","blockSuggestionMouseOver","onKeyDown","map","CustomSuggestionsOptionFc","searchTerm","el","selected","_hasOpened","onMouseOver","e","preventDefault","handleKeyDown","handleEvent","isOpen","callback","_b","handleWindowClick","contains","hostRef","selectedIndex","_hideMsg","nonce","Boolean","_touched","validateAccessKey","validateDisabled","validateHideMsg","validateHideLabel","validateHint","validateIcons","validateId","validateLabel","validateMsg","validateName","validateOn","validateShortKey","validateSyncValueBySelector","validateTouched","addValueChangeListener","v","handleMouseEvent","handleFocusOut","setTimeout","document","activeElement","handleWindowBlur"],"sources":["src/components/combobox/controller.ts","src/components/combobox/style.scss?tag=kol-combobox&mode=default&encapsulation=shadow","src/components/combobox/shadow.tsx"],"sourcesContent":["import type { ComboboxWatches, ComboboxProps, SuggestionsPropType } from '../../schema';\nimport { watchBoolean, validateSuggestions, watchString } from '../../schema';\n\nimport { InputIconController } from '../@deprecated/input/controller-icon';\n\nimport type { Generic } from 'adopted-style-sheets';\n\nexport class ComboboxController extends InputIconController implements ComboboxWatches {\n\tprotected readonly component: Generic.Element.Component & ComboboxProps;\n\n\tpublic constructor(component: Generic.Element.Component & ComboboxProps, name: string, host?: HTMLElement) {\n\t\tsuper(component, name, host);\n\t\tthis.component = component;\n\t}\n\n\tpublic validatePlaceholder(value?: string): void {\n\t\twatchString(this.component, '_placeholder', value);\n\t}\n\tpublic validateRequired(value?: boolean): void {\n\t\twatchBoolean(this.component, '_required', value);\n\t}\n\n\tpublic validateSuggestions(value?: SuggestionsPropType): void {\n\t\tvalidateSuggestions(this.component, value);\n\t}\n\n\tpublic validateValue(value?: string): void {\n\t\twatchString(this.component, '_value', value);\n\t}\n\n\tpublic componentWillLoad(): void {\n\t\tsuper.componentWillLoad();\n\t\tthis.validatePlaceholder(this.component._placeholder);\n\t\tthis.validateRequired(this.component._required);\n\t\tthis.validateSuggestions(this.component._suggestions);\n\t\tthis.validateValue(this.component._value);\n\t}\n}\n","@use '../../styles/global' as *;\n@use '../../styles/kol-alert-mixin' as *;\n@use '../../styles/kol-custom-suggestions-option' as *;\n@use '../../styles/kol-custom-suggestions-options-group' as *;\n@use '../../styles/kol-custom-suggestions-toggle' as *;\n@use '../../styles/kol-form-field-mixin' as *;\n@use '../../styles/kol-input-container-mixin' as *;\n@use '../../styles/kol-input-mixin' as *;\n@use '../@shared/mixins' as *;\n\n@include kol-alert;\n@include kol-custom-suggestions-option;\n@include kol-custom-suggestions-options-group;\n@include kol-custom-suggestions-toggle;\n@include kol-form-field;\n@include kol-input-container;\n@include kol-input;\n","import type { JSX } from '@stencil/core';\nimport { Component, Element, h, Listen, Method, Prop, State, Watch } from '@stencil/core';\nimport type {\n\tComboboxAPI,\n\tComboboxStates,\n\tHideMsgPropType,\n\tIconsHorizontalPropType,\n\tIdPropType,\n\tInputTypeOnDefault,\n\tLabelWithExpertSlotPropType,\n\tMsgPropType,\n\tNamePropType,\n\tShortKeyPropType,\n\tStringified,\n\tSuggestionsPropType,\n\tSyncValueBySelectorPropType,\n\tTooltipAlignPropType,\n\tW3CInputValue,\n} from '../../schema';\nimport clsx from 'clsx';\nimport { nonce } from '../../utils/dev.utils';\nimport KolFormFieldStateWrapperFc, { type FormFieldStateWrapperProps } from '../../functional-component-wrappers/FormFieldStateWrapper';\nimport { ComboboxController } from './controller';\nimport { getRenderStates } from '../input/controller';\nimport type { InputStateWrapperProps } from '../../functional-component-wrappers/InputStateWrapper';\nimport KolInputStateWrapperFc from '../../functional-component-wrappers/InputStateWrapper/InputStateWrapper';\nimport KolInputContainerFc from '../../functional-component-wrappers/InputContainerStateWrapper';\nimport CustomSuggestionsToggleFc from '../../functional-components/CustomSuggestionsToggle';\nimport CustomSuggestionsOptionFc from '../../functional-components/CustomSuggestionsOption/CustomSuggestionsOption';\nimport CustomSuggestionsOptionsGroupFc from '../../functional-components/CustomSuggestionsOptionsGroup';\nimport type { EventDetail } from '../../schema/interfaces/EventDetail';\n\n/**\n * @slot - Die Beschriftung des Eingabefeldes.\n */\n@Component({\n\ttag: 'kol-combobox',\n\tstyleUrls: {\n\t\tdefault: './style.scss',\n\t},\n\tshadow: {\n\t\tdelegatesFocus: true,\n\t},\n})\nexport class KolCombobox implements ComboboxAPI {\n\t@Element() private readonly host?: HTMLKolComboboxElement;\n\tprivate refInput?: HTMLInputElement;\n\tprivate refSuggestions: HTMLLIElement[] = [];\n\tprivate _focusedOptionIndex: number = -1;\n\n\t@Method()\n\t// eslint-disable-next-line @typescript-eslint/require-await\n\tpublic async getValue(): Promise<string> {\n\t\treturn this.state._value;\n\t}\n\n\t@Method()\n\t// eslint-disable-next-line @typescript-eslint/require-await\n\tpublic async kolFocus() {\n\t\tthis.refInput?.focus();\n\t}\n\n\tprivate toggleListbox = () => {\n\t\tif (this.state._disabled === true) {\n\t\t\tthis._isOpen = false;\n\t\t} else {\n\t\t\tthis.refInput?.focus();\n\t\t\tif (!this._hasOpened && Array.isArray(this._filteredSuggestions) && this._filteredSuggestions.length > 0) {\n\t\t\t\tthis._isOpen = true;\n\t\t\t\tthis._hasOpened = true;\n\t\t\t\tconst selectedIndex = this._filteredSuggestions.findIndex((option) => option === this.state._value);\n\t\t\t\tthis._focusedOptionIndex = selectedIndex >= 0 ? selectedIndex : -1;\n\t\t\t\tthis.focusOption(this._focusedOptionIndex);\n\t\t\t}\n\t\t}\n\t};\n\tprivate readonly catchRef = (ref?: HTMLInputElement) => {\n\t\tthis.refInput = ref;\n\t};\n\n\tprivate selectOption(option: string) {\n\t\tthis.controller.onFacade.onInput(\n\t\t\tnew CustomEvent<EventDetail>('input', { bubbles: true, detail: { name: this.state._name as string, value: option } }),\n\t\t\ttrue,\n\t\t\toption,\n\t\t);\n\t\tthis.controller.onFacade.onChange(\n\t\t\tnew CustomEvent<EventDetail>('change', { bubbles: true, detail: { name: this.state._name as string, value: option } }),\n\t\t\toption,\n\t\t);\n\t\tthis.controller.setFormAssociatedValue(option);\n\t\tthis.state._value = option;\n\t\tthis.refInput?.focus();\n\t}\n\tprivate onInput(event: Event) {\n\t\tconst target = event.target as HTMLInputElement;\n\t\tthis.state._value = target.value;\n\t\tthis._value = target.value;\n\t\tthis.controller.onFacade.onInput(event);\n\t\tthis.setFilteredSuggestionsByQuery(target.value);\n\t\tthis._focusedOptionIndex = -1;\n\t}\n\n\tprivate handleKeyDownDropdown(event: KeyboardEvent) {\n\t\tif (event.key.length === 1 && /[a-z0-9]/i.test(event.key)) {\n\t\t\tthis._isOpen = true;\n\t\t\tthis.focusSuggestionStartingWith(event.key);\n\t\t}\n\t}\n\n\tprivate setFilteredSuggestionsByQuery(query: string) {\n\t\tif (query.trim() === '') {\n\t\t\tthis._filteredSuggestions = [...this._suggestions];\n\t\t} else {\n\t\t\tthis._filteredSuggestions = Array.isArray(this._suggestions)\n\t\t\t\t? this._suggestions.filter((option: W3CInputValue) => {\n\t\t\t\t\t\treturn (option as string).toLowerCase().includes(query.toLowerCase());\n\t\t\t\t\t})\n\t\t\t\t: this._filteredSuggestions;\n\n\t\t\tthis._isOpen = this._filteredSuggestions && this._filteredSuggestions.length > 0 ? true : false;\n\t\t}\n\t}\n\n\tprivate moveFocus(delta: number) {\n\t\tif (!this._filteredSuggestions) {\n\t\t\treturn;\n\t\t}\n\t\tlet newIndex = this._focusedOptionIndex + delta;\n\n\t\tif (newIndex >= this._filteredSuggestions.length) {\n\t\t\tnewIndex = 0;\n\t\t}\n\n\t\tif (newIndex < 0) {\n\t\t\tnewIndex = this._filteredSuggestions.length - 1;\n\t\t}\n\t\tthis.focusOption(newIndex);\n\t}\n\n\tprivate focusOption(index: number) {\n\t\tthis._focusedOptionIndex = index;\n\t\tif (this.refSuggestions) {\n\t\t\tconst optionElement = this.refSuggestions[index];\n\t\t\toptionElement?.focus();\n\t\t}\n\t}\n\n\tprivate focusSuggestionStartingWith(char: string) {\n\t\tconst charLowerCase = char.toLowerCase();\n\n\t\tconst index =\n\t\t\tArray.isArray(this._filteredSuggestions) &&\n\t\t\tthis._filteredSuggestions.length > 0 &&\n\t\t\tthis._filteredSuggestions.findIndex((option: W3CInputValue) => (option as string).toLowerCase().startsWith(charLowerCase));\n\n\t\tif (typeof index === 'number') {\n\t\t\tthis.focusOption(index);\n\t\t}\n\t}\n\n\tprivate getFormFieldProps(): FormFieldStateWrapperProps {\n\t\treturn {\n\t\t\tstate: this.state,\n\t\t\tclass: clsx('kol-combobox', {\n\t\t\t\t'has-value': this.state._hasValue,\n\t\t\t}),\n\t\t\ttooltipAlign: this._tooltipAlign,\n\t\t\tonClick: () => this.refInput?.focus(),\n\t\t\talert: this.showAsAlert(),\n\t\t};\n\t}\n\n\tprivate getInputProps(): InputStateWrapperProps {\n\t\tconst { ariaDescribedBy } = getRenderStates(this.state);\n\n\t\treturn {\n\t\t\tref: this.catchRef,\n\t\t\tstate: this.state,\n\t\t\tclass: 'kol-combobox__input',\n\t\t\ttype: 'text',\n\t\t\trole: 'combobox',\n\t\t\t'aria-autocomplete': 'both',\n\t\t\t'aria-expanded': this._isOpen ? 'true' : 'false',\n\t\t\t'aria-controls': 'listbox',\n\t\t\t'aria-describedby': ariaDescribedBy.length > 0 ? ariaDescribedBy.join(' ') : undefined,\n\t\t\t'aria-label': this.state._hideLabel && typeof this.state._label === 'string' ? this.state._label : undefined,\n\t\t\t'aria-labelledby': this.state._id,\n\t\t\t'aria-activedescendant': this._isOpen && this._focusedOptionIndex >= 0 ? `option-${this._focusedOptionIndex}` : undefined,\n\t\t\tvalue: this.state._value,\n\t\t\taccessKey: this.state._accessKey,\n\t\t\tautocapitalize: 'off',\n\t\t\tautocorrect: 'off',\n\t\t\tdisabled: this.state._disabled,\n\t\t\tcustomSuggestions: true,\n\t\t\tid: this.state._id,\n\t\t\tname: this.state._name,\n\t\t\trequired: this.state._required,\n\t\t\t...this.controller.onFacade,\n\t\t\tonFocus: (event) => {\n\t\t\t\tthis.controller.onFacade.onFocus(event);\n\t\t\t\tthis.inputHasFocus = true;\n\t\t\t},\n\t\t\tonBlur: (event) => {\n\t\t\t\tthis.controller.onFacade.onBlur(event);\n\t\t\t\tthis.inputHasFocus = false;\n\t\t\t},\n\t\t\tonChange: this.onChange.bind(this),\n\t\t\tonInput: this.onInput.bind(this),\n\t\t\tplaceholder: this.state._placeholder,\n\t\t};\n\t}\n\n\tpublic render(): JSX.Element {\n\t\treturn (\n\t\t\t<KolFormFieldStateWrapperFc {...this.getFormFieldProps()}>\n\t\t\t\t<KolInputContainerFc state={this.state}>\n\t\t\t\t\t<div class=\"kol-combobox__group\">\n\t\t\t\t\t\t<KolInputStateWrapperFc {...this.getInputProps()} />\n\t\t\t\t\t\t<CustomSuggestionsToggleFc onClick={this.toggleListbox.bind(this)} disabled={this.state._disabled} />\n\t\t\t\t\t</div>\n\n\t\t\t\t\t{this._isOpen && !(this.state._disabled === true) && (\n\t\t\t\t\t\t<CustomSuggestionsOptionsGroupFc blockSuggestionMouseOver={this.blockSuggestionMouseOver} onKeyDown={this.handleKeyDownDropdown.bind(this)}>\n\t\t\t\t\t\t\t{Array.isArray(this._filteredSuggestions) &&\n\t\t\t\t\t\t\t\tthis._filteredSuggestions.length > 0 &&\n\t\t\t\t\t\t\t\tthis._filteredSuggestions.map((option, index) => (\n\t\t\t\t\t\t\t\t\t<CustomSuggestionsOptionFc\n\t\t\t\t\t\t\t\t\t\tindex={index}\n\t\t\t\t\t\t\t\t\t\toption={option}\n\t\t\t\t\t\t\t\t\t\tsearchTerm={this.state._value}\n\t\t\t\t\t\t\t\t\t\tref={(el) => {\n\t\t\t\t\t\t\t\t\t\t\tif (el) this.refSuggestions[index] = el;\n\t\t\t\t\t\t\t\t\t\t}}\n\t\t\t\t\t\t\t\t\t\tselected={this.state._value === option}\n\t\t\t\t\t\t\t\t\t\tonClick={() => {\n\t\t\t\t\t\t\t\t\t\t\tthis.selectOption(option as string);\n\t\t\t\t\t\t\t\t\t\t\tthis.toggleListbox();\n\t\t\t\t\t\t\t\t\t\t\tthis._isOpen = false;\n\t\t\t\t\t\t\t\t\t\t\tthis._hasOpened = false;\n\t\t\t\t\t\t\t\t\t\t}}\n\t\t\t\t\t\t\t\t\t\tonMouseOver={() => {\n\t\t\t\t\t\t\t\t\t\t\tif (!this.blockSuggestionMouseOver) {\n\t\t\t\t\t\t\t\t\t\t\t\tthis.focusOption(index);\n\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t}}\n\t\t\t\t\t\t\t\t\t\tonFocus={() => {\n\t\t\t\t\t\t\t\t\t\t\tthis.focusOption(index);\n\t\t\t\t\t\t\t\t\t\t}}\n\t\t\t\t\t\t\t\t\t\tonKeyDown={(e) => {\n\t\t\t\t\t\t\t\t\t\t\tif (e.key === 'Enter' || e.key === 'NumpadEnter') {\n\t\t\t\t\t\t\t\t\t\t\t\tthis.selectOption(option as string);\n\t\t\t\t\t\t\t\t\t\t\t\tthis.toggleListbox();\n\t\t\t\t\t\t\t\t\t\t\t\te.preventDefault();\n\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t}}\n\t\t\t\t\t\t\t\t\t/>\n\t\t\t\t\t\t\t\t))}\n\t\t\t\t\t\t</CustomSuggestionsOptionsGroupFc>\n\t\t\t\t\t)}\n\t\t\t\t</KolInputContainerFc>\n\t\t\t</KolFormFieldStateWrapperFc>\n\t\t);\n\t}\n\n\t@Listen('keydown')\n\tpublic handleKeyDown(event: KeyboardEvent) {\n\t\tconst handleEvent = (isOpen?: boolean, callback?: () => void): void => {\n\t\t\tevent.preventDefault();\n\t\t\tif (isOpen !== undefined) {\n\t\t\t\tthis._isOpen = isOpen;\n\t\t\t\tif (!isOpen) {\n\t\t\t\t\tthis.refInput?.focus();\n\t\t\t\t}\n\t\t\t}\n\t\t\tcallback?.();\n\t\t};\n\t\tswitch (event.key) {\n\t\t\tcase 'Down':\n\t\t\tcase 'ArrowDown': {\n\t\t\t\tthis.blockSuggestionMouseOver = true;\n\t\t\t\thandleEvent(true, () => this.moveFocus(1));\n\t\t\t\tbreak;\n\t\t\t}\n\t\t\tcase 'Up':\n\t\t\tcase 'ArrowUp': {\n\t\t\t\tthis.blockSuggestionMouseOver = true;\n\t\t\t\thandleEvent(true, () => this.moveFocus(-1));\n\t\t\t\tbreak;\n\t\t\t}\n\t\t\tcase 'Tab':\n\t\t\t\tif (this._isOpen) {\n\t\t\t\t\tthis._isOpen = false;\n\t\t\t\t\tthis.refInput?.focus();\n\t\t\t\t}\n\t\t\t\tbreak;\n\t\t\tcase 'Esc':\n\t\t\tcase 'Escape': {\n\t\t\t\tthis._hasOpened = false;\n\t\t\t\tthis._isOpen = false;\n\t\t\t\tevent.preventDefault();\n\t\t\t\tthis.refInput?.focus();\n\t\t\t\tbreak;\n\t\t\t}\n\t\t\tcase 'NumpadEnter':\n\t\t\tcase 'Enter': {\n\t\t\t\tif (this._isOpen && this._focusedOptionIndex >= 0) {\n\t\t\t\t\tthis._filteredSuggestions && this.selectOption(this._filteredSuggestions[this._focusedOptionIndex] as string);\n\t\t\t\t\tthis._isOpen = false;\n\t\t\t\t\tthis._hasOpened = false;\n\t\t\t\t} else {\n\t\t\t\t\tthis.toggleListbox();\n\t\t\t\t}\n\t\t\t\tevent.preventDefault();\n\t\t\t\tbreak;\n\t\t\t}\n\t\t\tcase 'Home': {\n\t\t\t\tthis.blockSuggestionMouseOver = true;\n\t\t\t\thandleEvent(undefined, () => {\n\t\t\t\t\tif (this._isOpen) {\n\t\t\t\t\t\tthis.focusOption(0);\n\t\t\t\t\t}\n\t\t\t\t});\n\t\t\t\tbreak;\n\t\t\t}\n\t\t\tcase 'End': {\n\t\t\t\tthis.blockSuggestionMouseOver = true;\n\t\t\t\thandleEvent(undefined, () => {\n\t\t\t\t\tif (this._isOpen) {\n\t\t\t\t\t\tthis.focusOption(this._filteredSuggestions ? this._filteredSuggestions.length - 1 : 0);\n\t\t\t\t\t}\n\t\t\t\t});\n\t\t\t\tbreak;\n\t\t\t}\n\t\t\tcase 'PageUp': {\n\t\t\t\tthis.blockSuggestionMouseOver = true;\n\t\t\t\thandleEvent(undefined, () => this._isOpen && this.moveFocus(-10));\n\t\t\t\tbreak;\n\t\t\t}\n\t\t\tcase 'PageDown': {\n\t\t\t\tthis.blockSuggestionMouseOver = true;\n\t\t\t\thandleEvent(undefined, () => this._isOpen && this.moveFocus(10));\n\t\t\t\tbreak;\n\t\t\t}\n\t\t}\n\t}\n\n\tprivate readonly controller: ComboboxController;\n\t@State()\n\tprivate blockSuggestionMouseOver: boolean = false;\n\t@State()\n\tprivate _isOpen: boolean = false;\n\t@State()\n\tprivate _filteredSuggestions?: SuggestionsPropType;\n\t@State()\n\tprivate _hasOpened = false;\n\n\t@Listen('click', { target: 'window' })\n\thandleWindowClick(event: MouseEvent) {\n\t\tif (this.host !== undefined && !this.host.contains(event.target as Node)) {\n\t\t\tthis._isOpen = false;\n\t\t}\n\t}\n\n\t/**\n\t * Defines which key combination can be used to trigger or focus the interactive element of the component.\n\t */\n\t@Prop() public _accessKey?: string;\n\n\t/**\n\t * Defines the placeholder for input field. To be shown when there's no value.\n\t */\n\t@Prop() public _placeholder?: string;\n\n\t/**\n\t * Makes the element not focusable and ignore all events.\n\t */\n\t@Prop() public _disabled?: boolean = false;\n\n\t/**\n\t * Hides the error message but leaves it in the DOM for the input's aria-describedby.\n\t * @TODO: Change type back to `HideMsgPropType` after Stencil#4663 has been resolved.\n\t */\n\t@Prop({ mutable: true, reflect: true }) public _hideMsg?: boolean = false;\n\n\t/**\n\t * Hides the caption by default and displays the caption text with a tooltip when the\n\t * interactive element is focused or the mouse is over it.\n\t * @TODO: Change type back to `HideLabelPropType` after Stencil#4663 has been resolved.\n\t */\n\t@Prop() public _hideLabel?: boolean = false;\n\n\t/**\n\t * Defines the hint text.\n\t */\n\t@Prop() public _hint?: string = '';\n\n\t/**\n\t * Defines the icon classnames (e.g. `_icons=\"fa-solid fa-user\"`).\n\t */\n\t@Prop() public _icons?: IconsHorizontalPropType;\n\n\t/**\n\t * Defines the internal ID of the primary component element.\n\t */\n\t@Prop() public _id?: IdPropType;\n\n\t/**\n\t * Defines the visible or semantic label of the component (e.g. aria-label, label, headline, caption, summary, etc.). Set to `false` to enable the expert slot.\n\t */\n\t@Prop() public _label!: LabelWithExpertSlotPropType;\n\n\t/**\n\t * Defines the properties for a message rendered as Alert component.\n\t */\n\t@Prop() public _msg?: Stringified<MsgPropType>;\n\n\t/**\n\t * Defines the technical name of an input field.\n\t */\n\t@Prop() public _name?: NamePropType;\n\n\t/**\n\t * Gibt die EventCallback-Funktionen für das Input-Event an.\n\t */\n\t@Prop() public _on?: InputTypeOnDefault;\n\n\t/**\n\t * Suggestions to provide for the input.\n\t */\n\t@Prop() public _suggestions!: SuggestionsPropType;\n\n\t/**\n\t * Makes the input element required.\n\t * @TODO: Change type back to `RequiredPropType` after Stencil#4663 has been resolved.\n\t */\n\t@Prop() public _required?: boolean = false;\n\n\t/**\n\t * Adds a visual short key hint to the component.\n\t */\n\t@Prop() public _shortKey?: ShortKeyPropType;\n\n\t/**\n\t * Selector for synchronizing the value with another input element.\n\t * @internal\n\t */\n\t@Prop() public _syncValueBySelector?: SyncValueBySelectorPropType;\n\n\t/**\n\t * Defines where to show the Tooltip preferably: top, right, bottom or left.\n\t */\n\t@Prop() public _tooltipAlign?: TooltipAlignPropType = 'top';\n\n\t/**\n\t * Shows if the input was touched by a user.\n\t * @TODO: Change type back to `TouchedPropType` after Stencil#4663 has been resolved.\n\t */\n\t@Prop({ mutable: true, reflect: true }) public _touched?: boolean = false;\n\n\t/**\n\t * Defines the value of the input.\n\t */\n\t@Prop({ mutable: true, reflect: true }) public _value?: string;\n\n\t@State() public state: ComboboxStates = {\n\t\t_hasValue: false,\n\t\t_hideMsg: false,\n\t\t_id: `id-${nonce()}`,\n\t\t_label: '', // ⚠ required\n\t\t_suggestions: [],\n\t\t_value: '',\n\t};\n\n\t@State() private inputHasFocus = false;\n\n\tpublic constructor() {\n\t\tthis.controller = new ComboboxController(this, 'combobox', this.host);\n\t\tthis.onInput = this.onInput.bind(this);\n\t}\n\n\tprivate showAsAlert(): boolean {\n\t\treturn Boolean(this.state._touched) && !this.inputHasFocus;\n\t}\n\n\t@Watch('_placeholder')\n\tpublic validatePlaceholder(value?: string): void {\n\t\tthis.controller.validatePlaceholder(value);\n\t}\n\n\t@Watch('_accessKey')\n\tpublic validateAccessKey(value?: string): void {\n\t\tthis.controller.validateAccessKey(value);\n\t}\n\n\t@Watch('_disabled')\n\tpublic validateDisabled(value?: boolean): void {\n\t\tthis.controller.validateDisabled(value);\n\t}\n\n\t@Watch('_hideMsg')\n\tpublic validateHideMsg(value?: HideMsgPropType): void {\n\t\tthis.controller.validateHideMsg(value);\n\t}\n\n\t@Watch('_hideLabel')\n\tpublic validateHideLabel(value?: boolean): void {\n\t\tthis.controller.validateHideLabel(value);\n\t}\n\n\t@Watch('_hint')\n\tpublic validateHint(value?: string): void {\n\t\tthis.controller.validateHint(value);\n\t}\n\n\t@Watch('_icons')\n\tpublic validateIcons(value?: IconsHorizontalPropType): void {\n\t\tthis.controller.validateIcons(value);\n\t}\n\n\t@Watch('_id')\n\tpublic validateId(value?: string): void {\n\t\tthis.controller.validateId(value);\n\t}\n\n\t@Watch('_label')\n\tpublic validateLabel(value?: LabelWithExpertSlotPropType): void {\n\t\tthis.controller.validateLabel(value);\n\t}\n\n\t@Watch('_msg')\n\tpublic validateMsg(value?: Stringified<MsgPropType>): void {\n\t\tthis.controller.validateMsg(value);\n\t}\n\n\t@Watch('_name')\n\tpublic validateName(value?: string): void {\n\t\tthis.controller.validateName(value);\n\t}\n\n\t@Watch('_on')\n\tpublic validateOn(value?: InputTypeOnDefault): void {\n\t\tthis.controller.validateOn(value);\n\t}\n\n\t@Watch('_shortKey')\n\tpublic validateShortKey(value?: ShortKeyPropType): void {\n\t\tthis.controller.validateShortKey(value);\n\t}\n\n\t@Watch('_suggestions')\n\tpublic validateSuggestions(value?: SuggestionsPropType): void {\n\t\tthis.controller.validateSuggestions(value);\n\t\tthis._filteredSuggestions = value;\n\t}\n\n\t@Watch('_required')\n\tpublic validateRequired(value?: boolean): void {\n\t\tthis.controller.validateRequired(value);\n\t}\n\n\t@Watch('_syncValueBySelector')\n\tpublic validateSyncValueBySelector(value?: SyncValueBySelectorPropType): void {\n\t\tthis.controller.validateSyncValueBySelector(value);\n\t}\n\n\t@Watch('_touched')\n\tpublic validateTouched(value?: boolean): void {\n\t\tthis.controller.validateTouched(value);\n\t}\n\n\t@Watch('_value')\n\tpublic validateValue(value?: string): void {\n\t\tthis.controller.validateValue(value);\n\t\tthis.controller.setFormAssociatedValue(value);\n\t}\n\n\tpublic componentWillLoad(): void {\n\t\tthis.refSuggestions = [];\n\t\tthis._touched = this._touched === true;\n\t\tthis.controller.componentWillLoad();\n\n\t\tthis.state._hasValue = !!this.state._value;\n\t\tthis.controller.addValueChangeListener((v) => (this.state._hasValue = !!v));\n\t\tthis._filteredSuggestions = this.state._suggestions;\n\t}\n\n\t@Listen('mousemove')\n\tpublic handleMouseEvent() {\n\t\tthis.blockSuggestionMouseOver = false;\n\t}\n\n\t@Listen('focusout', { target: 'window' })\n\tpublic handleFocusOut() {\n\t\tsetTimeout(() => {\n\t\t\tif (!this.host?.contains(document.activeElement)) {\n\t\t\t\tthis.onBlur();\n\t\t\t}\n\t\t}, 0);\n\t}\n\t@Listen('blur', { target: 'window' })\n\tpublic handleWindowBlur() {\n\t\tthis.onBlur();\n\t}\n\n\tprivate onBlur() {\n\t\tthis._hasOpened = false;\n\t\tif (this._isOpen) {\n\t\t\tthis._isOpen = !this._isOpen;\n\t\t\tthis.refInput?.focus();\n\t\t}\n\t}\n\n\tprivate onChange(event: Event): void {\n\t\tthis.controller.onFacade.onChange(event);\n\n\t\t// Static form handling\n\t\tthis.controller.setFormAssociatedValue(this.state._value as unknown as string);\n\t}\n}\n"],"mappings":"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","ignoreList":[]}
|
1
|
+
{"version":3,"names":["ComboboxController","InputIconController","constructor","component","name","host","super","this","validatePlaceholder","value","watchString","validateRequired","watchBoolean","validateSuggestions","validateValue","componentWillLoad","_placeholder","_required","_suggestions","_value","defaultStyleCss","KolCombobox","getValue","state","kolFocus","_a","refInput","focus","selectOption","option","controller","onFacade","onInput","CustomEvent","bubbles","detail","_name","onChange","setFormAssociatedValue","event","target","setFilteredSuggestionsByQuery","_focusedOptionIndex","handleKeyDownDropdown","key","length","test","_isOpen","focusSuggestionStartingWith","query","trim","_filteredSuggestions","Array","isArray","filter","toLowerCase","includes","moveFocus","delta","newIndex","focusOption","index","refSuggestions","optionElement","char","charLowerCase","findIndex","startsWith","getFormFieldProps","class","clsx","_hasValue","tooltipAlign","_tooltipAlign","onClick","alert","showAsAlert","getInputProps","ariaDescribedBy","getRenderStates","isDisabled","_disabled","Object","assign","ref","catchRef","type","role","join","undefined","_hideLabel","_label","_id","accessKey","_accessKey","autocapitalize","autocorrect","disabled","customSuggestions","id","required","onFocus","inputHasFocus","onBlur","bind","placeholder","render","h","KolFormFieldStateWrapperFc","KolInputContainerFc","KolInputStateWrapperFc","CustomSuggestionsToggleFc","toggleListbox","CustomSuggestionsOptionsGroupFc","blockSuggestionMouseOver","onKeyDown","map","CustomSuggestionsOptionFc","searchTerm","el","selected","_hasOpened","onMouseOver","e","preventDefault","handleKeyDown","handleEvent","isOpen","callback","_b","handleWindowClick","contains","hostRef","selectedIndex","_hideMsg","_hint","_touched","nonce","Boolean","validateAccessKey","validateDisabled","validateHideMsg","validateHideLabel","validateHint","validateIcons","validateId","validateLabel","validateMsg","validateName","validateOn","validateShortKey","validateSyncValueBySelector","validateTouched","addValueChangeListener","v","handleMouseEvent","handleFocusOut","setTimeout","document","activeElement","handleWindowBlur"],"sources":["src/components/combobox/controller.ts","src/components/combobox/style.scss?tag=kol-combobox&mode=default&encapsulation=shadow","src/components/combobox/shadow.tsx"],"sourcesContent":["import type { ComboboxWatches, ComboboxProps, SuggestionsPropType } from '../../schema';\nimport { watchBoolean, validateSuggestions, watchString } from '../../schema';\n\nimport { InputIconController } from '../@deprecated/input/controller-icon';\n\nimport type { Generic } from 'adopted-style-sheets';\n\nexport class ComboboxController extends InputIconController implements ComboboxWatches {\n\tprotected readonly component: Generic.Element.Component & ComboboxProps;\n\n\tpublic constructor(component: Generic.Element.Component & ComboboxProps, name: string, host?: HTMLElement) {\n\t\tsuper(component, name, host);\n\t\tthis.component = component;\n\t}\n\n\tpublic validatePlaceholder(value?: string): void {\n\t\twatchString(this.component, '_placeholder', value);\n\t}\n\tpublic validateRequired(value?: boolean): void {\n\t\twatchBoolean(this.component, '_required', value);\n\t}\n\n\tpublic validateSuggestions(value?: SuggestionsPropType): void {\n\t\tvalidateSuggestions(this.component, value);\n\t}\n\n\tpublic validateValue(value?: string): void {\n\t\twatchString(this.component, '_value', value);\n\t}\n\n\tpublic componentWillLoad(): void {\n\t\tsuper.componentWillLoad();\n\t\tthis.validatePlaceholder(this.component._placeholder);\n\t\tthis.validateRequired(this.component._required);\n\t\tthis.validateSuggestions(this.component._suggestions);\n\t\tthis.validateValue(this.component._value);\n\t}\n}\n","@use '../../styles/global' as *;\n@use '../../styles/kol-alert-mixin' as *;\n@use '../../styles/kol-custom-suggestions-option' as *;\n@use '../../styles/kol-custom-suggestions-options-group' as *;\n@use '../../styles/kol-custom-suggestions-toggle' as *;\n@use '../../styles/kol-form-field-mixin' as *;\n@use '../../styles/kol-input-container-mixin' as *;\n@use '../../styles/kol-input-mixin' as *;\n@use '../@shared/mixins' as *;\n\n@include kol-alert;\n@include kol-custom-suggestions-option;\n@include kol-custom-suggestions-options-group;\n@include kol-custom-suggestions-toggle;\n@include kol-form-field;\n@include kol-input-container;\n@include kol-input;\n","import type { JSX } from '@stencil/core';\nimport { Component, Element, h, Listen, Method, Prop, State, Watch } from '@stencil/core';\nimport type {\n\tComboboxAPI,\n\tComboboxStates,\n\tHideMsgPropType,\n\tIconsHorizontalPropType,\n\tIdPropType,\n\tInputTypeOnDefault,\n\tLabelWithExpertSlotPropType,\n\tMsgPropType,\n\tNamePropType,\n\tShortKeyPropType,\n\tStringified,\n\tSuggestionsPropType,\n\tSyncValueBySelectorPropType,\n\tTooltipAlignPropType,\n\tDisabledPropType,\n\tHideLabelPropType,\n\tHintPropType,\n\tW3CInputValue,\n} from '../../schema';\nimport clsx from 'clsx';\nimport { nonce } from '../../utils/dev.utils';\nimport KolFormFieldStateWrapperFc, { type FormFieldStateWrapperProps } from '../../functional-component-wrappers/FormFieldStateWrapper/FormFieldStateWrapper';\nimport { ComboboxController } from './controller';\nimport { getRenderStates } from '../../functional-component-wrappers/_helpers/getRenderStates';\nimport type { InputStateWrapperProps } from '../../functional-component-wrappers/InputStateWrapper/InputStateWrapper';\nimport KolInputStateWrapperFc from '../../functional-component-wrappers/InputStateWrapper/InputStateWrapper';\nimport KolInputContainerFc from '../../functional-component-wrappers/InputContainerStateWrapper/InputContainerStateWrapper';\nimport CustomSuggestionsToggleFc from '../../functional-components/CustomSuggestionsToggle';\nimport CustomSuggestionsOptionFc from '../../functional-components/CustomSuggestionsOption/CustomSuggestionsOption';\nimport CustomSuggestionsOptionsGroupFc from '../../functional-components/CustomSuggestionsOptionsGroup';\nimport type { EventDetail } from '../../schema/interfaces/EventDetail';\n\n/**\n * @slot - Die Beschriftung des Eingabefeldes.\n */\n@Component({\n\ttag: 'kol-combobox',\n\tstyleUrls: {\n\t\tdefault: './style.scss',\n\t},\n\tshadow: {\n\t\tdelegatesFocus: true,\n\t},\n})\nexport class KolCombobox implements ComboboxAPI {\n\t@Element() private readonly host?: HTMLKolComboboxElement;\n\tprivate refInput?: HTMLInputElement;\n\tprivate refSuggestions: HTMLLIElement[] = [];\n\tprivate _focusedOptionIndex: number = -1;\n\n\t@Method()\n\t// eslint-disable-next-line @typescript-eslint/require-await\n\tpublic async getValue(): Promise<string> {\n\t\treturn this.state._value;\n\t}\n\n\t@Method()\n\t// eslint-disable-next-line @typescript-eslint/require-await\n\tpublic async kolFocus() {\n\t\tthis.refInput?.focus();\n\t}\n\n\tprivate toggleListbox = () => {\n\t\tconst isDisabled = this.state._disabled === true;\n\t\tif (isDisabled) {\n\t\t\tthis._isOpen = false;\n\t\t} else {\n\t\t\tthis.refInput?.focus();\n\t\t\tif (!this._hasOpened && Array.isArray(this._filteredSuggestions) && this._filteredSuggestions.length > 0) {\n\t\t\t\tthis._isOpen = true;\n\t\t\t\tthis._hasOpened = true;\n\t\t\t\tconst selectedIndex = this._filteredSuggestions.findIndex((option) => option === this.state._value);\n\t\t\t\tthis._focusedOptionIndex = selectedIndex >= 0 ? selectedIndex : -1;\n\t\t\t\tthis.focusOption(this._focusedOptionIndex);\n\t\t\t}\n\t\t}\n\t};\n\tprivate readonly catchRef = (ref?: HTMLInputElement) => {\n\t\tthis.refInput = ref;\n\t};\n\n\tprivate selectOption(option: string) {\n\t\tthis.controller.onFacade.onInput(\n\t\t\tnew CustomEvent<EventDetail>('input', { bubbles: true, detail: { name: this.state._name as string, value: option } }),\n\t\t\ttrue,\n\t\t\toption,\n\t\t);\n\t\tthis.controller.onFacade.onChange(\n\t\t\tnew CustomEvent<EventDetail>('change', { bubbles: true, detail: { name: this.state._name as string, value: option } }),\n\t\t\toption,\n\t\t);\n\t\tthis.controller.setFormAssociatedValue(option);\n\t\tthis.state._value = option;\n\t\tthis.refInput?.focus();\n\t}\n\tprivate onInput(event: Event) {\n\t\tconst target = event.target as HTMLInputElement;\n\t\tthis.state._value = target.value;\n\t\tthis._value = target.value;\n\t\tthis.controller.onFacade.onInput(event);\n\t\tthis.setFilteredSuggestionsByQuery(target.value);\n\t\tthis._focusedOptionIndex = -1;\n\t}\n\n\tprivate handleKeyDownDropdown(event: KeyboardEvent) {\n\t\tif (event.key.length === 1 && /[a-z0-9]/i.test(event.key)) {\n\t\t\tthis._isOpen = true;\n\t\t\tthis.focusSuggestionStartingWith(event.key);\n\t\t}\n\t}\n\n\tprivate setFilteredSuggestionsByQuery(query: string) {\n\t\tif (query.trim() === '') {\n\t\t\tthis._filteredSuggestions = [...this._suggestions];\n\t\t} else {\n\t\t\tthis._filteredSuggestions = Array.isArray(this._suggestions)\n\t\t\t\t? this._suggestions.filter((option: W3CInputValue) => {\n\t\t\t\t\t\treturn (option as string).toLowerCase().includes(query.toLowerCase());\n\t\t\t\t\t})\n\t\t\t\t: this._filteredSuggestions;\n\n\t\t\tthis._isOpen = this._filteredSuggestions && this._filteredSuggestions.length > 0 ? true : false;\n\t\t}\n\t}\n\n\tprivate moveFocus(delta: number) {\n\t\tif (!this._filteredSuggestions) {\n\t\t\treturn;\n\t\t}\n\t\tlet newIndex = this._focusedOptionIndex + delta;\n\n\t\tif (newIndex >= this._filteredSuggestions.length) {\n\t\t\tnewIndex = 0;\n\t\t}\n\n\t\tif (newIndex < 0) {\n\t\t\tnewIndex = this._filteredSuggestions.length - 1;\n\t\t}\n\t\tthis.focusOption(newIndex);\n\t}\n\n\tprivate focusOption(index: number) {\n\t\tthis._focusedOptionIndex = index;\n\t\tif (this.refSuggestions) {\n\t\t\tconst optionElement = this.refSuggestions[index];\n\t\t\toptionElement?.focus();\n\t\t}\n\t}\n\n\tprivate focusSuggestionStartingWith(char: string) {\n\t\tconst charLowerCase = char.toLowerCase();\n\n\t\tconst index =\n\t\t\tArray.isArray(this._filteredSuggestions) &&\n\t\t\tthis._filteredSuggestions.length > 0 &&\n\t\t\tthis._filteredSuggestions.findIndex((option: W3CInputValue) => (option as string).toLowerCase().startsWith(charLowerCase));\n\n\t\tif (typeof index === 'number') {\n\t\t\tthis.focusOption(index);\n\t\t}\n\t}\n\n\tprivate getFormFieldProps(): FormFieldStateWrapperProps {\n\t\treturn {\n\t\t\tstate: this.state,\n\t\t\tclass: clsx('kol-combobox', {\n\t\t\t\t'has-value': this.state._hasValue,\n\t\t\t}),\n\t\t\ttooltipAlign: this._tooltipAlign,\n\t\t\tonClick: () => this.refInput?.focus(),\n\t\t\talert: this.showAsAlert(),\n\t\t};\n\t}\n\n\tprivate getInputProps(): InputStateWrapperProps {\n\t\tconst { ariaDescribedBy } = getRenderStates(this.state);\n\t\tconst isDisabled = this.state._disabled === true;\n\n\t\treturn {\n\t\t\tref: this.catchRef,\n\t\t\tstate: this.state,\n\t\t\tclass: 'kol-combobox__input',\n\t\t\ttype: 'text',\n\t\t\trole: 'combobox',\n\t\t\t'aria-autocomplete': 'both',\n\t\t\t'aria-expanded': this._isOpen ? 'true' : 'false',\n\t\t\t'aria-controls': 'listbox',\n\t\t\t'aria-describedby': ariaDescribedBy.length > 0 ? ariaDescribedBy.join(' ') : undefined,\n\t\t\t'aria-label': this.state._hideLabel && typeof this.state._label === 'string' ? this.state._label : undefined,\n\t\t\t'aria-labelledby': this.state._id,\n\t\t\t'aria-activedescendant': this._isOpen && this._focusedOptionIndex >= 0 ? `option-${this._focusedOptionIndex}` : undefined,\n\t\t\tvalue: this.state._value,\n\t\t\taccessKey: this.state._accessKey,\n\t\t\tautocapitalize: 'off',\n\t\t\tautocorrect: 'off',\n\t\t\tdisabled: isDisabled,\n\t\t\tcustomSuggestions: true,\n\t\t\tid: this.state._id,\n\t\t\tname: this.state._name,\n\t\t\trequired: this.state._required,\n\t\t\t...this.controller.onFacade,\n\t\t\tonFocus: (event) => {\n\t\t\t\tthis.controller.onFacade.onFocus(event);\n\t\t\t\tthis.inputHasFocus = true;\n\t\t\t},\n\t\t\tonBlur: (event) => {\n\t\t\t\tthis.controller.onFacade.onBlur(event);\n\t\t\t\tthis.inputHasFocus = false;\n\t\t\t},\n\t\t\tonChange: this.onChange.bind(this),\n\t\t\tonInput: this.onInput.bind(this),\n\t\t\tplaceholder: this.state._placeholder,\n\t\t};\n\t}\n\n\tpublic render(): JSX.Element {\n\t\tconst isDisabled = this.state._disabled === true;\n\t\treturn (\n\t\t\t<KolFormFieldStateWrapperFc {...this.getFormFieldProps()}>\n\t\t\t\t<KolInputContainerFc state={this.state}>\n\t\t\t\t\t<div class=\"kol-combobox__group\">\n\t\t\t\t\t\t<KolInputStateWrapperFc {...this.getInputProps()} />\n\t\t\t\t\t\t<CustomSuggestionsToggleFc onClick={this.toggleListbox.bind(this)} disabled={isDisabled} />\n\t\t\t\t\t</div>\n\n\t\t\t\t\t{this._isOpen && !isDisabled && (\n\t\t\t\t\t\t<CustomSuggestionsOptionsGroupFc blockSuggestionMouseOver={this.blockSuggestionMouseOver} onKeyDown={this.handleKeyDownDropdown.bind(this)}>\n\t\t\t\t\t\t\t{Array.isArray(this._filteredSuggestions) &&\n\t\t\t\t\t\t\t\tthis._filteredSuggestions.length > 0 &&\n\t\t\t\t\t\t\t\tthis._filteredSuggestions.map((option, index) => (\n\t\t\t\t\t\t\t\t\t<CustomSuggestionsOptionFc\n\t\t\t\t\t\t\t\t\t\tindex={index}\n\t\t\t\t\t\t\t\t\t\toption={option}\n\t\t\t\t\t\t\t\t\t\tsearchTerm={this.state._value}\n\t\t\t\t\t\t\t\t\t\tref={(el) => {\n\t\t\t\t\t\t\t\t\t\t\tif (el) this.refSuggestions[index] = el;\n\t\t\t\t\t\t\t\t\t\t}}\n\t\t\t\t\t\t\t\t\t\tselected={this.state._value === option}\n\t\t\t\t\t\t\t\t\t\tonClick={() => {\n\t\t\t\t\t\t\t\t\t\t\tthis.selectOption(option as string);\n\t\t\t\t\t\t\t\t\t\t\tthis.toggleListbox();\n\t\t\t\t\t\t\t\t\t\t\tthis._isOpen = false;\n\t\t\t\t\t\t\t\t\t\t\tthis._hasOpened = false;\n\t\t\t\t\t\t\t\t\t\t}}\n\t\t\t\t\t\t\t\t\t\tonMouseOver={() => {\n\t\t\t\t\t\t\t\t\t\t\tif (!this.blockSuggestionMouseOver) {\n\t\t\t\t\t\t\t\t\t\t\t\tthis.focusOption(index);\n\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t}}\n\t\t\t\t\t\t\t\t\t\tonFocus={() => {\n\t\t\t\t\t\t\t\t\t\t\tthis.focusOption(index);\n\t\t\t\t\t\t\t\t\t\t}}\n\t\t\t\t\t\t\t\t\t\tonKeyDown={(e) => {\n\t\t\t\t\t\t\t\t\t\t\tif (e.key === 'Enter' || e.key === 'NumpadEnter') {\n\t\t\t\t\t\t\t\t\t\t\t\tthis.selectOption(option as string);\n\t\t\t\t\t\t\t\t\t\t\t\tthis.toggleListbox();\n\t\t\t\t\t\t\t\t\t\t\t\te.preventDefault();\n\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t}}\n\t\t\t\t\t\t\t\t\t/>\n\t\t\t\t\t\t\t\t))}\n\t\t\t\t\t\t</CustomSuggestionsOptionsGroupFc>\n\t\t\t\t\t)}\n\t\t\t\t</KolInputContainerFc>\n\t\t\t</KolFormFieldStateWrapperFc>\n\t\t);\n\t}\n\n\t@Listen('keydown')\n\tpublic handleKeyDown(event: KeyboardEvent) {\n\t\tconst handleEvent = (isOpen?: boolean, callback?: () => void): void => {\n\t\t\tevent.preventDefault();\n\t\t\tif (isOpen !== undefined) {\n\t\t\t\tthis._isOpen = isOpen;\n\t\t\t\tif (!isOpen) {\n\t\t\t\t\tthis.refInput?.focus();\n\t\t\t\t}\n\t\t\t}\n\t\t\tcallback?.();\n\t\t};\n\t\tswitch (event.key) {\n\t\t\tcase 'Down':\n\t\t\tcase 'ArrowDown': {\n\t\t\t\tthis.blockSuggestionMouseOver = true;\n\t\t\t\thandleEvent(true, () => this.moveFocus(1));\n\t\t\t\tbreak;\n\t\t\t}\n\t\t\tcase 'Up':\n\t\t\tcase 'ArrowUp': {\n\t\t\t\tthis.blockSuggestionMouseOver = true;\n\t\t\t\thandleEvent(true, () => this.moveFocus(-1));\n\t\t\t\tbreak;\n\t\t\t}\n\t\t\tcase 'Tab':\n\t\t\t\tif (this._isOpen) {\n\t\t\t\t\tthis._isOpen = false;\n\t\t\t\t\tthis.refInput?.focus();\n\t\t\t\t}\n\t\t\t\tbreak;\n\t\t\tcase 'Esc':\n\t\t\tcase 'Escape': {\n\t\t\t\tthis._hasOpened = false;\n\t\t\t\tthis._isOpen = false;\n\t\t\t\tevent.preventDefault();\n\t\t\t\tthis.refInput?.focus();\n\t\t\t\tbreak;\n\t\t\t}\n\t\t\tcase 'NumpadEnter':\n\t\t\tcase 'Enter': {\n\t\t\t\tif (this._isOpen && this._focusedOptionIndex >= 0) {\n\t\t\t\t\tthis._filteredSuggestions && this.selectOption(this._filteredSuggestions[this._focusedOptionIndex] as string);\n\t\t\t\t\tthis._isOpen = false;\n\t\t\t\t\tthis._hasOpened = false;\n\t\t\t\t} else {\n\t\t\t\t\tthis.toggleListbox();\n\t\t\t\t}\n\t\t\t\tevent.preventDefault();\n\t\t\t\tbreak;\n\t\t\t}\n\t\t\tcase 'Home': {\n\t\t\t\tthis.blockSuggestionMouseOver = true;\n\t\t\t\thandleEvent(undefined, () => {\n\t\t\t\t\tif (this._isOpen) {\n\t\t\t\t\t\tthis.focusOption(0);\n\t\t\t\t\t}\n\t\t\t\t});\n\t\t\t\tbreak;\n\t\t\t}\n\t\t\tcase 'End': {\n\t\t\t\tthis.blockSuggestionMouseOver = true;\n\t\t\t\thandleEvent(undefined, () => {\n\t\t\t\t\tif (this._isOpen) {\n\t\t\t\t\t\tthis.focusOption(this._filteredSuggestions ? this._filteredSuggestions.length - 1 : 0);\n\t\t\t\t\t}\n\t\t\t\t});\n\t\t\t\tbreak;\n\t\t\t}\n\t\t\tcase 'PageUp': {\n\t\t\t\tthis.blockSuggestionMouseOver = true;\n\t\t\t\thandleEvent(undefined, () => this._isOpen && this.moveFocus(-10));\n\t\t\t\tbreak;\n\t\t\t}\n\t\t\tcase 'PageDown': {\n\t\t\t\tthis.blockSuggestionMouseOver = true;\n\t\t\t\thandleEvent(undefined, () => this._isOpen && this.moveFocus(10));\n\t\t\t\tbreak;\n\t\t\t}\n\t\t}\n\t}\n\n\tprivate readonly controller: ComboboxController;\n\t@State()\n\tprivate blockSuggestionMouseOver: boolean = false;\n\t@State()\n\tprivate _isOpen: boolean = false;\n\t@State()\n\tprivate _filteredSuggestions?: SuggestionsPropType;\n\t@State()\n\tprivate _hasOpened = false;\n\n\t@Listen('click', { target: 'window' })\n\thandleWindowClick(event: MouseEvent) {\n\t\tif (this.host !== undefined && !this.host.contains(event.target as Node)) {\n\t\t\tthis._isOpen = false;\n\t\t}\n\t}\n\n\t/**\n\t * Defines which key combination can be used to trigger or focus the interactive element of the component.\n\t */\n\t@Prop() public _accessKey?: string;\n\n\t/**\n\t * Defines the placeholder for input field. To be shown when there's no value.\n\t */\n\t@Prop() public _placeholder?: string;\n\n\t/**\n\t * Makes the element not focusable and ignore all events.\n\t */\n\t@Prop() public _disabled?: boolean = false;\n\n\t/**\n\t * Hides the error message but leaves it in the DOM for the input's aria-describedby.\n\t * @TODO: Change type back to `HideMsgPropType` after Stencil#4663 has been resolved.\n\t */\n\t@Prop({ mutable: true, reflect: true }) public _hideMsg?: boolean = false;\n\n\t/**\n\t * Hides the caption by default and displays the caption text with a tooltip when the\n\t * interactive element is focused or the mouse is over it.\n\t * @TODO: Change type back to `HideLabelPropType` after Stencil#4663 has been resolved.\n\t */\n\t@Prop() public _hideLabel?: boolean = false;\n\n\t/**\n\t * Defines the hint text.\n\t */\n\t@Prop() public _hint?: string = '';\n\n\t/**\n\t * Defines the icon classnames (e.g. `_icons=\"fa-solid fa-user\"`).\n\t */\n\t@Prop() public _icons?: IconsHorizontalPropType;\n\n\t/**\n\t * Defines the internal ID of the primary component element.\n\t */\n\t@Prop() public _id?: IdPropType;\n\n\t/**\n\t * Defines the visible or semantic label of the component (e.g. aria-label, label, headline, caption, summary, etc.). Set to `false` to enable the expert slot.\n\t */\n\t@Prop() public _label!: LabelWithExpertSlotPropType;\n\n\t/**\n\t * Defines the properties for a message rendered as Alert component.\n\t */\n\t@Prop() public _msg?: Stringified<MsgPropType>;\n\n\t/**\n\t * Defines the technical name of an input field.\n\t */\n\t@Prop() public _name?: NamePropType;\n\n\t/**\n\t * Gibt die EventCallback-Funktionen für das Input-Event an.\n\t */\n\t@Prop() public _on?: InputTypeOnDefault;\n\n\t/**\n\t * Suggestions to provide for the input.\n\t */\n\t@Prop() public _suggestions!: SuggestionsPropType;\n\n\t/**\n\t * Makes the input element required.\n\t * @TODO: Change type back to `RequiredPropType` after Stencil#4663 has been resolved.\n\t */\n\t@Prop() public _required?: boolean = false;\n\n\t/**\n\t * Adds a visual short key hint to the component.\n\t */\n\t@Prop() public _shortKey?: ShortKeyPropType;\n\n\t/**\n\t * Selector for synchronizing the value with another input element.\n\t * @internal\n\t */\n\t@Prop() public _syncValueBySelector?: SyncValueBySelectorPropType;\n\n\t/**\n\t * Defines where to show the Tooltip preferably: top, right, bottom or left.\n\t */\n\t@Prop() public _tooltipAlign?: TooltipAlignPropType = 'top';\n\n\t/**\n\t * Shows if the input was touched by a user.\n\t * @TODO: Change type back to `TouchedPropType` after Stencil#4663 has been resolved.\n\t */\n\t@Prop({ mutable: true, reflect: true }) public _touched?: boolean = false;\n\n\t/**\n\t * Defines the value of the input.\n\t */\n\t@Prop({ mutable: true, reflect: true }) public _value?: string;\n\n\t@State() public state: ComboboxStates = {\n\t\t_hasValue: false,\n\t\t_hideMsg: false,\n\t\t_id: `id-${nonce()}`,\n\t\t_label: '', // ⚠ required\n\t\t_suggestions: [],\n\t\t_value: '',\n\t};\n\n\t@State() private inputHasFocus = false;\n\n\tpublic constructor() {\n\t\tthis.controller = new ComboboxController(this, 'combobox', this.host);\n\t\tthis.onInput = this.onInput.bind(this);\n\t}\n\n\tprivate showAsAlert(): boolean {\n\t\treturn Boolean(this.state._touched) && !this.inputHasFocus;\n\t}\n\n\t@Watch('_placeholder')\n\tpublic validatePlaceholder(value?: string): void {\n\t\tthis.controller.validatePlaceholder(value);\n\t}\n\n\t@Watch('_accessKey')\n\tpublic validateAccessKey(value?: string): void {\n\t\tthis.controller.validateAccessKey(value);\n\t}\n\n\t@Watch('_disabled')\n\tpublic validateDisabled(value?: DisabledPropType): void {\n\t\tthis.controller.validateDisabled(value);\n\t}\n\n\t@Watch('_hideMsg')\n\tpublic validateHideMsg(value?: HideMsgPropType): void {\n\t\tthis.controller.validateHideMsg(value);\n\t}\n\n\t@Watch('_hideLabel')\n\tpublic validateHideLabel(value?: HideLabelPropType): void {\n\t\tthis.controller.validateHideLabel(value);\n\t}\n\n\t@Watch('_hint')\n\tpublic validateHint(value?: HintPropType): void {\n\t\tthis.controller.validateHint(value);\n\t}\n\n\t@Watch('_icons')\n\tpublic validateIcons(value?: IconsHorizontalPropType): void {\n\t\tthis.controller.validateIcons(value);\n\t}\n\n\t@Watch('_id')\n\tpublic validateId(value?: string): void {\n\t\tthis.controller.validateId(value);\n\t}\n\n\t@Watch('_label')\n\tpublic validateLabel(value?: LabelWithExpertSlotPropType): void {\n\t\tthis.controller.validateLabel(value);\n\t}\n\n\t@Watch('_msg')\n\tpublic validateMsg(value?: Stringified<MsgPropType>): void {\n\t\tthis.controller.validateMsg(value);\n\t}\n\n\t@Watch('_name')\n\tpublic validateName(value?: string): void {\n\t\tthis.controller.validateName(value);\n\t}\n\n\t@Watch('_on')\n\tpublic validateOn(value?: InputTypeOnDefault): void {\n\t\tthis.controller.validateOn(value);\n\t}\n\n\t@Watch('_shortKey')\n\tpublic validateShortKey(value?: ShortKeyPropType): void {\n\t\tthis.controller.validateShortKey(value);\n\t}\n\n\t@Watch('_suggestions')\n\tpublic validateSuggestions(value?: SuggestionsPropType): void {\n\t\tthis.controller.validateSuggestions(value);\n\t\tthis._filteredSuggestions = value;\n\t}\n\n\t@Watch('_required')\n\tpublic validateRequired(value?: boolean): void {\n\t\tthis.controller.validateRequired(value);\n\t}\n\n\t@Watch('_syncValueBySelector')\n\tpublic validateSyncValueBySelector(value?: SyncValueBySelectorPropType): void {\n\t\tthis.controller.validateSyncValueBySelector(value);\n\t}\n\n\t@Watch('_touched')\n\tpublic validateTouched(value?: boolean): void {\n\t\tthis.controller.validateTouched(value);\n\t}\n\n\t@Watch('_value')\n\tpublic validateValue(value?: string): void {\n\t\tthis.controller.validateValue(value);\n\t\tthis.controller.setFormAssociatedValue(value);\n\t}\n\n\tpublic componentWillLoad(): void {\n\t\tthis.refSuggestions = [];\n\t\tthis._touched = this._touched === true;\n\t\tthis.controller.componentWillLoad();\n\n\t\tthis.state._hasValue = !!this.state._value;\n\t\tthis.controller.addValueChangeListener((v) => (this.state._hasValue = !!v));\n\t\tthis._filteredSuggestions = this.state._suggestions;\n\t}\n\n\t@Listen('mousemove')\n\tpublic handleMouseEvent() {\n\t\tthis.blockSuggestionMouseOver = false;\n\t}\n\n\t@Listen('focusout', { target: 'window' })\n\tpublic handleFocusOut() {\n\t\tsetTimeout(() => {\n\t\t\tif (!this.host?.contains(document.activeElement)) {\n\t\t\t\tthis.onBlur();\n\t\t\t}\n\t\t}, 0);\n\t}\n\t@Listen('blur', { target: 'window' })\n\tpublic handleWindowBlur() {\n\t\tthis.onBlur();\n\t}\n\n\tprivate onBlur() {\n\t\tthis._hasOpened = false;\n\t\tif (this._isOpen) {\n\t\t\tthis._isOpen = !this._isOpen;\n\t\t\tthis.refInput?.focus();\n\t\t}\n\t}\n\n\tprivate onChange(event: Event): void {\n\t\tthis.controller.onFacade.onChange(event);\n\n\t\t// Static form handling\n\t\tthis.controller.setFormAssociatedValue(this.state._value as unknown as string);\n\t}\n}\n"],"mappings":";;;gmCAOM,MAAOA,UAA2BC,EAGvC,WAAAC,CAAmBC,EAAsDC,EAAcC,GACtFC,MAAMH,EAAWC,EAAMC,GACvBE,KAAKJ,UAAYA,C,CAGX,mBAAAK,CAAoBC,GAC1BC,EAAYH,KAAKJ,UAAW,eAAgBM,E,CAEtC,gBAAAE,CAAiBF,GACvBG,EAAaL,KAAKJ,UAAW,YAAaM,E,CAGpC,mBAAAI,CAAoBJ,GAC1BI,EAAoBN,KAAKJ,UAAWM,E,CAG9B,aAAAK,CAAcL,GACpBC,EAAYH,KAAKJ,UAAW,SAAUM,E,CAGhC,iBAAAM,GACNT,MAAMS,oBACNR,KAAKC,oBAAoBD,KAAKJ,UAAUa,cACxCT,KAAKI,iBAAiBJ,KAAKJ,UAAUc,WACrCV,KAAKM,oBAAoBN,KAAKJ,UAAUe,cACxCX,KAAKO,cAAcP,KAAKJ,UAAUgB,O,ECnCpC,MAAMC,EAAkB,grQ,MC+CXC,EAAW,MAQhB,cAAMC,GACZ,OAAOf,KAAKgB,MAAMJ,M,CAKZ,cAAMK,G,OACZC,EAAAlB,KAAKmB,YAAU,MAAAD,SAAA,SAAAA,EAAAE,O,CAsBR,YAAAC,CAAaC,G,MACpBtB,KAAKuB,WAAWC,SAASC,QACxB,IAAIC,YAAyB,QAAS,CAAEC,QAAS,KAAMC,OAAQ,CAAE/B,KAAMG,KAAKgB,MAAMa,MAAiB3B,MAAOoB,KAC1G,KACAA,GAEDtB,KAAKuB,WAAWC,SAASM,SACxB,IAAIJ,YAAyB,SAAU,CAAEC,QAAS,KAAMC,OAAQ,CAAE/B,KAAMG,KAAKgB,MAAMa,MAAiB3B,MAAOoB,KAC3GA,GAEDtB,KAAKuB,WAAWQ,uBAAuBT,GACvCtB,KAAKgB,MAAMJ,OAASU,GACpBJ,EAAAlB,KAAKmB,YAAU,MAAAD,SAAA,SAAAA,EAAAE,O,CAER,OAAAK,CAAQO,GACf,MAAMC,EAASD,EAAMC,OACrBjC,KAAKgB,MAAMJ,OAASqB,EAAO/B,MAC3BF,KAAKY,OAASqB,EAAO/B,MACrBF,KAAKuB,WAAWC,SAASC,QAAQO,GACjChC,KAAKkC,8BAA8BD,EAAO/B,OAC1CF,KAAKmC,qBAAsB,C,CAGpB,qBAAAC,CAAsBJ,GAC7B,GAAIA,EAAMK,IAAIC,SAAW,GAAK,YAAYC,KAAKP,EAAMK,KAAM,CAC1DrC,KAAKwC,QAAU,KACfxC,KAAKyC,4BAA4BT,EAAMK,I,EAIjC,6BAAAH,CAA8BQ,GACrC,GAAIA,EAAMC,SAAW,GAAI,CACxB3C,KAAK4C,qBAAuB,IAAI5C,KAAKW,a,KAC/B,CACNX,KAAK4C,qBAAuBC,MAAMC,QAAQ9C,KAAKW,cAC5CX,KAAKW,aAAaoC,QAAQzB,GAClBA,EAAkB0B,cAAcC,SAASP,EAAMM,iBAEvDhD,KAAK4C,qBAER5C,KAAKwC,QAAUxC,KAAK4C,sBAAwB5C,KAAK4C,qBAAqBN,OAAS,EAAI,KAAO,K,EAIpF,SAAAY,CAAUC,GACjB,IAAKnD,KAAK4C,qBAAsB,CAC/B,M,CAED,IAAIQ,EAAWpD,KAAKmC,oBAAsBgB,EAE1C,GAAIC,GAAYpD,KAAK4C,qBAAqBN,OAAQ,CACjDc,EAAW,C,CAGZ,GAAIA,EAAW,EAAG,CACjBA,EAAWpD,KAAK4C,qBAAqBN,OAAS,C,CAE/CtC,KAAKqD,YAAYD,E,CAGV,WAAAC,CAAYC,GACnBtD,KAAKmC,oBAAsBmB,EAC3B,GAAItD,KAAKuD,eAAgB,CACxB,MAAMC,EAAgBxD,KAAKuD,eAAeD,GAC1CE,IAAa,MAAbA,SAAa,SAAbA,EAAepC,O,EAIT,2BAAAqB,CAA4BgB,GACnC,MAAMC,EAAgBD,EAAKT,cAE3B,MAAMM,EACLT,MAAMC,QAAQ9C,KAAK4C,uBACnB5C,KAAK4C,qBAAqBN,OAAS,GACnCtC,KAAK4C,qBAAqBe,WAAWrC,GAA2BA,EAAkB0B,cAAcY,WAAWF,KAE5G,UAAWJ,IAAU,SAAU,CAC9BtD,KAAKqD,YAAYC,E,EAIX,iBAAAO,GACP,MAAO,CACN7C,MAAOhB,KAAKgB,MACZ8C,MAAOC,EAAK,eAAgB,CAC3B,YAAa/D,KAAKgB,MAAMgD,YAEzBC,aAAcjE,KAAKkE,cACnBC,QAAS,KAAK,IAAAjD,EAAC,OAAAA,EAAAlB,KAAKmB,YAAQ,MAAAD,SAAA,SAAAA,EAAEE,OAAO,EACrCgD,MAAOpE,KAAKqE,c,CAIN,aAAAC,GACP,MAAMC,gBAAEA,GAAoBC,EAAgBxE,KAAKgB,OACjD,MAAMyD,EAAazE,KAAKgB,MAAM0D,YAAc,KAE5C,OACCC,OAAAC,OAAAD,OAAAC,OAAA,CAAAC,IAAK7E,KAAK8E,SACV9D,MAAOhB,KAAKgB,MACZ8C,MAAO,sBACPiB,KAAM,OACNC,KAAM,WACN,oBAAqB,OACrB,gBAAiBhF,KAAKwC,QAAU,OAAS,QACzC,gBAAiB,UACjB,mBAAoB+B,EAAgBjC,OAAS,EAAIiC,EAAgBU,KAAK,KAAOC,UAC7E,aAAclF,KAAKgB,MAAMmE,mBAAqBnF,KAAKgB,MAAMoE,SAAW,SAAWpF,KAAKgB,MAAMoE,OAASF,UACnG,kBAAmBlF,KAAKgB,MAAMqE,IAC9B,wBAAyBrF,KAAKwC,SAAWxC,KAAKmC,qBAAuB,EAAI,UAAUnC,KAAKmC,sBAAwB+C,UAChHhF,MAAOF,KAAKgB,MAAMJ,OAClB0E,UAAWtF,KAAKgB,MAAMuE,WACtBC,eAAgB,MAChBC,YAAa,MACbC,SAAUjB,EACVkB,kBAAmB,KACnBC,GAAI5F,KAAKgB,MAAMqE,IACfxF,KAAMG,KAAKgB,MAAMa,MACjBgE,SAAU7F,KAAKgB,MAAMN,WAClBV,KAAKuB,WAAWC,UAAQ,CAC3BsE,QAAU9D,IACThC,KAAKuB,WAAWC,SAASsE,QAAQ9D,GACjChC,KAAK+F,cAAgB,IAAI,EAE1BC,OAAShE,IACRhC,KAAKuB,WAAWC,SAASwE,OAAOhE,GAChChC,KAAK+F,cAAgB,KAAK,EAE3BjE,SAAU9B,KAAK8B,SAASmE,KAAKjG,MAC7ByB,QAASzB,KAAKyB,QAAQwE,KAAKjG,MAC3BkG,YAAalG,KAAKgB,MAAMP,c,CAInB,MAAA0F,GACN,MAAM1B,EAAazE,KAAKgB,MAAM0D,YAAc,KAC5C,OACC0B,EAACC,EAA0B1B,OAAAC,OAAA,CAAAvC,IAAA,4CAAKrC,KAAK6D,qBACpCuC,EAACE,EAAoB,CAAAjE,IAAA,2CAAArB,MAAOhB,KAAKgB,OAChCoF,EAAK,OAAA/D,IAAA,2CAAAyB,MAAM,uBACVsC,EAACG,EAA2B5B,OAAAC,OAAA,CAAAvC,IAAA,4CAAArC,KAAKsE,kBACjC8B,EAACI,EAA0B,CAAAnE,IAAA,2CAAA8B,QAASnE,KAAKyG,cAAcR,KAAKjG,MAAO0F,SAAUjB,KAG7EzE,KAAKwC,UAAYiC,GACjB2B,EAACM,EAA+B,CAAArE,IAAA,2CAACsE,yBAA0B3G,KAAK2G,yBAA0BC,UAAW5G,KAAKoC,sBAAsB6D,KAAKjG,OACnI6C,MAAMC,QAAQ9C,KAAK4C,uBACnB5C,KAAK4C,qBAAqBN,OAAS,GACnCtC,KAAK4C,qBAAqBiE,KAAI,CAACvF,EAAQgC,IACtC8C,EAACU,EAAyB,CACzBxD,MAAOA,EACPhC,OAAQA,EACRyF,WAAY/G,KAAKgB,MAAMJ,OACvBiE,IAAMmC,IACL,GAAIA,EAAIhH,KAAKuD,eAAeD,GAAS0D,CAAE,EAExCC,SAAUjH,KAAKgB,MAAMJ,SAAWU,EAChC6C,QAAS,KACRnE,KAAKqB,aAAaC,GAClBtB,KAAKyG,gBACLzG,KAAKwC,QAAU,MACfxC,KAAKkH,WAAa,KAAK,EAExBC,YAAa,KACZ,IAAKnH,KAAK2G,yBAA0B,CACnC3G,KAAKqD,YAAYC,E,GAGnBwC,QAAS,KACR9F,KAAKqD,YAAYC,EAAM,EAExBsD,UAAYQ,IACX,GAAIA,EAAE/E,MAAQ,SAAW+E,EAAE/E,MAAQ,cAAe,CACjDrC,KAAKqB,aAAaC,GAClBtB,KAAKyG,gBACLW,EAAEC,gB,UAaN,aAAAC,CAActF,G,QACpB,MAAMuF,EAAc,CAACC,EAAkBC,K,MACtCzF,EAAMqF,iBACN,GAAIG,IAAWtC,UAAW,CACzBlF,KAAKwC,QAAUgF,EACf,IAAKA,EAAQ,EACZtG,EAAAlB,KAAKmB,YAAU,MAAAD,SAAA,SAAAA,EAAAE,O,EAGjBqG,IAAA,MAAAA,SAAA,SAAAA,GAAY,EAEb,OAAQzF,EAAMK,KACb,IAAK,OACL,IAAK,YAAa,CACjBrC,KAAK2G,yBAA2B,KAChCY,EAAY,MAAM,IAAMvH,KAAKkD,UAAU,KACvC,K,CAED,IAAK,KACL,IAAK,UAAW,CACflD,KAAK2G,yBAA2B,KAChCY,EAAY,MAAM,IAAMvH,KAAKkD,WAAU,KACvC,K,CAED,IAAK,MACJ,GAAIlD,KAAKwC,QAAS,CACjBxC,KAAKwC,QAAU,OACftB,EAAAlB,KAAKmB,YAAU,MAAAD,SAAA,SAAAA,EAAAE,O,CAEhB,MACD,IAAK,MACL,IAAK,SAAU,CACdpB,KAAKkH,WAAa,MAClBlH,KAAKwC,QAAU,MACfR,EAAMqF,kBACNK,EAAA1H,KAAKmB,YAAU,MAAAuG,SAAA,SAAAA,EAAAtG,QACf,K,CAED,IAAK,cACL,IAAK,QAAS,CACb,GAAIpB,KAAKwC,SAAWxC,KAAKmC,qBAAuB,EAAG,CAClDnC,KAAK4C,sBAAwB5C,KAAKqB,aAAarB,KAAK4C,qBAAqB5C,KAAKmC,sBAC9EnC,KAAKwC,QAAU,MACfxC,KAAKkH,WAAa,K,KACZ,CACNlH,KAAKyG,e,CAENzE,EAAMqF,iBACN,K,CAED,IAAK,OAAQ,CACZrH,KAAK2G,yBAA2B,KAChCY,EAAYrC,WAAW,KACtB,GAAIlF,KAAKwC,QAAS,CACjBxC,KAAKqD,YAAY,E,KAGnB,K,CAED,IAAK,MAAO,CACXrD,KAAK2G,yBAA2B,KAChCY,EAAYrC,WAAW,KACtB,GAAIlF,KAAKwC,QAAS,CACjBxC,KAAKqD,YAAYrD,KAAK4C,qBAAuB5C,KAAK4C,qBAAqBN,OAAS,EAAI,E,KAGtF,K,CAED,IAAK,SAAU,CACdtC,KAAK2G,yBAA2B,KAChCY,EAAYrC,WAAW,IAAMlF,KAAKwC,SAAWxC,KAAKkD,WAAU,MAC5D,K,CAED,IAAK,WAAY,CAChBlD,KAAK2G,yBAA2B,KAChCY,EAAYrC,WAAW,IAAMlF,KAAKwC,SAAWxC,KAAKkD,UAAU,MAC5D,K,GAgBH,iBAAAyE,CAAkB3F,GACjB,GAAIhC,KAAKF,OAASoF,YAAclF,KAAKF,KAAK8H,SAAS5F,EAAMC,QAAiB,CACzEjC,KAAKwC,QAAU,K,EAoHjB,WAAA7C,CAAAkI,G,UAhbQ7H,KAAcuD,eAAoB,GAClCvD,KAAmBmC,qBAAW,EAc9BnC,KAAayG,cAAG,K,MACvB,MAAMhC,EAAazE,KAAKgB,MAAM0D,YAAc,KAC5C,GAAID,EAAY,CACfzE,KAAKwC,QAAU,K,KACT,EACNtB,EAAAlB,KAAKmB,YAAU,MAAAD,SAAA,SAAAA,EAAAE,QACf,IAAKpB,KAAKkH,YAAcrE,MAAMC,QAAQ9C,KAAK4C,uBAAyB5C,KAAK4C,qBAAqBN,OAAS,EAAG,CACzGtC,KAAKwC,QAAU,KACfxC,KAAKkH,WAAa,KAClB,MAAMY,EAAgB9H,KAAK4C,qBAAqBe,WAAWrC,GAAWA,IAAWtB,KAAKgB,MAAMJ,SAC5FZ,KAAKmC,oBAAsB2F,GAAiB,EAAIA,GAAgB,EAChE9H,KAAKqD,YAAYrD,KAAKmC,oB,IAIRnC,KAAA8E,SAAYD,IAC5B7E,KAAKmB,SAAW0D,CAAG,EAkRZ7E,KAAwB2G,yBAAY,MAEpC3G,KAAOwC,QAAY,MAInBxC,KAAUkH,WAAG,MAsBNlH,KAAS0E,UAAa,MAMU1E,KAAQ+H,SAAa,MAOrD/H,KAAUmF,WAAa,MAKvBnF,KAAKgI,MAAY,GAyCjBhI,KAASU,UAAa,MAgBtBV,KAAakE,cAA0B,MAMPlE,KAAQiI,SAAa,MAOpDjI,KAAAgB,MAAwB,CACvCgD,UAAW,MACX+D,SAAU,MACV1C,IAAK,MAAM6C,MACX9C,OAAQ,GACRzE,aAAc,GACdC,OAAQ,IAGQZ,KAAa+F,cAAG,MAGhC/F,KAAKuB,WAAa,IAAI9B,EAAmBO,KAAM,WAAYA,KAAKF,MAChEE,KAAKyB,QAAUzB,KAAKyB,QAAQwE,KAAKjG,KACjC,CAEO,WAAAqE,GACP,OAAO8D,QAAQnI,KAAKgB,MAAMiH,YAAcjI,KAAK+F,a,CAIvC,mBAAA9F,CAAoBC,GAC1BF,KAAKuB,WAAWtB,oBAAoBC,E,CAI9B,iBAAAkI,CAAkBlI,GACxBF,KAAKuB,WAAW6G,kBAAkBlI,E,CAI5B,gBAAAmI,CAAiBnI,GACvBF,KAAKuB,WAAW8G,iBAAiBnI,E,CAI3B,eAAAoI,CAAgBpI,GACtBF,KAAKuB,WAAW+G,gBAAgBpI,E,CAI1B,iBAAAqI,CAAkBrI,GACxBF,KAAKuB,WAAWgH,kBAAkBrI,E,CAI5B,YAAAsI,CAAatI,GACnBF,KAAKuB,WAAWiH,aAAatI,E,CAIvB,aAAAuI,CAAcvI,GACpBF,KAAKuB,WAAWkH,cAAcvI,E,CAIxB,UAAAwI,CAAWxI,GACjBF,KAAKuB,WAAWmH,WAAWxI,E,CAIrB,aAAAyI,CAAczI,GACpBF,KAAKuB,WAAWoH,cAAczI,E,CAIxB,WAAA0I,CAAY1I,GAClBF,KAAKuB,WAAWqH,YAAY1I,E,CAItB,YAAA2I,CAAa3I,GACnBF,KAAKuB,WAAWsH,aAAa3I,E,CAIvB,UAAA4I,CAAW5I,GACjBF,KAAKuB,WAAWuH,WAAW5I,E,CAIrB,gBAAA6I,CAAiB7I,GACvBF,KAAKuB,WAAWwH,iBAAiB7I,E,CAI3B,mBAAAI,CAAoBJ,GAC1BF,KAAKuB,WAAWjB,oBAAoBJ,GACpCF,KAAK4C,qBAAuB1C,C,CAItB,gBAAAE,CAAiBF,GACvBF,KAAKuB,WAAWnB,iBAAiBF,E,CAI3B,2BAAA8I,CAA4B9I,GAClCF,KAAKuB,WAAWyH,4BAA4B9I,E,CAItC,eAAA+I,CAAgB/I,GACtBF,KAAKuB,WAAW0H,gBAAgB/I,E,CAI1B,aAAAK,CAAcL,GACpBF,KAAKuB,WAAWhB,cAAcL,GAC9BF,KAAKuB,WAAWQ,uBAAuB7B,E,CAGjC,iBAAAM,GACNR,KAAKuD,eAAiB,GACtBvD,KAAKiI,SAAWjI,KAAKiI,WAAa,KAClCjI,KAAKuB,WAAWf,oBAEhBR,KAAKgB,MAAMgD,YAAchE,KAAKgB,MAAMJ,OACpCZ,KAAKuB,WAAW2H,wBAAwBC,GAAOnJ,KAAKgB,MAAMgD,YAAcmF,IACxEnJ,KAAK4C,qBAAuB5C,KAAKgB,MAAML,Y,CAIjC,gBAAAyI,GACNpJ,KAAK2G,yBAA2B,K,CAI1B,cAAA0C,GACNC,YAAW,K,MACV,MAAKpI,EAAAlB,KAAKF,QAAI,MAAAoB,SAAA,SAAAA,EAAE0G,SAAS2B,SAASC,gBAAgB,CACjDxJ,KAAKgG,Q,IAEJ,E,CAGG,gBAAAyD,GACNzJ,KAAKgG,Q,CAGE,MAAAA,G,MACPhG,KAAKkH,WAAa,MAClB,GAAIlH,KAAKwC,QAAS,CACjBxC,KAAKwC,SAAWxC,KAAKwC,SACrBtB,EAAAlB,KAAKmB,YAAU,MAAAD,SAAA,SAAAA,EAAAE,O,EAIT,QAAAU,CAASE,GAChBhC,KAAKuB,WAAWC,SAASM,SAASE,GAGlChC,KAAKuB,WAAWQ,uBAAuB/B,KAAKgB,MAAMJ,O","ignoreList":[]}
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"kol-details.entry.esm.js","sources":["src/schema/props/details-callbacks.ts","src/components/details/style.scss?tag=kol-details&mode=default&encapsulation=shadow","src/components/details/shadow.tsx"],"sourcesContent":["import type { Generic } from 'adopted-style-sheets';\nimport type { Callback } from '../enums';\nimport type { EventValueOrEventCallback } from '../types/callbacks';\nimport { watchValidator } from '../utils';\n\n/* types */\nexport type DetailsCallbacksPropType<T> = {\n\t[Callback.onToggle]?: EventValueOrEventCallback<MouseEvent, T>;\n};\n\n/**\n * Defines the callback functions for detail events.\n */\nexport type PropDetailsCallbacks<T> = {\n\ton: DetailsCallbacksPropType<T>;\n};\n\n/* validator */\nexport const validateDetailsCallbacks = (component: Generic.Element.Component, value?: DetailsCallbacksPropType<boolean>): void => {\n\twatchValidator(component, `_on`, (value) => typeof value === 'object' && value !== null, new Set(['DetailsCallbacksPropType {Events.onToggle}']), value);\n};\n","@use '../@shared/mixins' as *;\n@use '../../styles/global' as *;\n@use '../host-display-block' as *;\n@use '../../functional-components/Collapsible/collapsible' as *;\n\n@layer kol-component {\n\t.kol-details {\n\t\t&__heading-button {\n\t\t\tdisplay: flex;\n\n\t\t\t.kol-button {\n\t\t\t\tmin-height: auto;\n\n\t\t\t\t.kol-span {\n\t\t\t\t\t&__label {\n\t\t\t\t\t\tborder-bottom-color: grey;\n\t\t\t\t\t\tborder-bottom-style: solid;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\t.collapsible--open &__heading-button {\n\t\t\t.kol-icon::part(icon) {\n\t\t\t\ttransform: rotate(90deg);\n\t\t\t}\n\t\t}\n\t}\n}\n","import { Component, Element, h, type JSX, Method, Prop, State, Watch } from '@stencil/core';\nimport type { DetailsAPI, DetailsCallbacksPropType, DetailsStates, DisabledPropType, FocusableElement, HeadingLevel, LabelPropType } from '../../schema';\nimport { validateDetailsCallbacks, validateDisabled, validateLabel, validateOpen } from '../../schema';\nimport KolCollapsibleFc, { type CollapsibleProps } from '../../functional-components/Collapsible';\nimport { nonce } from '../../utils/dev.utils';\nimport { watchHeadingLevel } from '../heading/validation';\nimport { dispatchDomEvent, KolEvent } from '../../utils/events';\n\n/**\n * @slot - Der Inhalt, der in der Detailbeschreibung angezeigt wird.\n */\n@Component({\n\ttag: 'kol-details',\n\tstyleUrls: {\n\t\tdefault: './style.scss',\n\t},\n\tshadow: true,\n})\nexport class KolDetails implements DetailsAPI, FocusableElement {\n\t@Element() private readonly host?: HTMLKolDetailsElement;\n\n\tprivate readonly nonce = nonce();\n\tprivate buttonWcRef?: HTMLKolButtonWcElement;\n\n\tprivate readonly catchRef = (ref?: HTMLKolButtonWcElement) => {\n\t\tthis.buttonWcRef = ref;\n\t};\n\n\t@Method()\n\t// eslint-disable-next-line @typescript-eslint/require-await\n\tpublic async kolFocus() {\n\t\tawait this.buttonWcRef?.kolFocus();\n\t}\n\n\tprivate toggleTimeout?: ReturnType<typeof setTimeout>;\n\n\tprivate handleOnClick = (event: MouseEvent) => {\n\t\tthis._open = !this._open;\n\n\t\t/**\n\t\t * Der Timeout wird benötigt, damit das Event\n\t\t * vom Button- auf das Accordion-Event wechselt.\n\t\t * So ist es dem Anwendenden möglich das _open-\n\t\t * Attribute abzufragen.\n\t\t */\n\n\t\tclearTimeout(this.toggleTimeout);\n\n\t\tthis.toggleTimeout = setTimeout(() => {\n\t\t\tif (this.host) {\n\t\t\t\tdispatchDomEvent(this.host, KolEvent.toggle, Boolean(this._open));\n\t\t\t}\n\t\t\tthis.state._on?.onToggle?.(event, Boolean(this._open));\n\t\t}, 25);\n\t};\n\n\tpublic render(): JSX.Element {\n\t\tconst { _open, _label, _disabled, _level } = this.state;\n\n\t\tconst rootClass = 'kol-details';\n\n\t\tconst props: CollapsibleProps = {\n\t\t\tid: this.nonce,\n\t\t\tlabel: _label,\n\t\t\topen: _open,\n\t\t\tdisabled: _disabled,\n\t\t\tlevel: _level,\n\t\t\tonClick: this.handleOnClick,\n\t\t\tclass: rootClass,\n\t\t\tHeadingProps: { class: `${rootClass}__heading` },\n\t\t\tHeadingButtonProps: {\n\t\t\t\tref: this.catchRef,\n\t\t\t\tclass: `${rootClass}__heading-button`,\n\t\t\t\t_icons: 'codicon codicon-chevron-right',\n\t\t\t},\n\t\t\tContentProps: {\n\t\t\t\tclass: `${rootClass}__content indented-text`,\n\t\t\t\twrapperClass: `${rootClass}__wrapper`,\n\t\t\t\tanimationClass: `${rootClass}__wrapper-animation`,\n\t\t\t},\n\t\t};\n\n\t\treturn (\n\t\t\t<KolCollapsibleFc {...props}>\n\t\t\t\t<slot />\n\t\t\t</KolCollapsibleFc>\n\t\t);\n\t}\n\n\t/**\n\t * Makes the element not focusable and ignore all events.\n\t */\n\t@Prop() public _disabled?: boolean = false;\n\n\t/**\n\t * Defines the visible or semantic label of the component (e.g. aria-label, label, headline, caption, summary, etc.).\n\t */\n\t@Prop() public _label!: LabelPropType;\n\n\t/**\n\t * Defines which H-level from 1-6 the heading has. 0 specifies no heading and is shown as bold text.\n\t */\n\t@Prop() public _level?: HeadingLevel = 0;\n\n\t/**\n\t * Defines the callback functions for details.\n\t */\n\t@Prop() public _on?: DetailsCallbacksPropType<boolean>;\n\n\t/**\n\t * Opens/expands the element when truthy, closes/collapses when falsy.\n\t * @TODO: Change type back to `OpenPropType` after Stencil#4663 has been resolved.\n\t */\n\t@Prop({ mutable: true, reflect: true }) public _open?: boolean = false;\n\n\t@State() public state: DetailsStates = {\n\t\t_label: '', // ⚠ required\n\t\t_level: 0,\n\t\t_on: {},\n\t};\n\n\t@Watch('_disabled')\n\tpublic validateDisabled(value?: DisabledPropType): void {\n\t\tvalidateDisabled(this, value);\n\t}\n\n\t@Watch('_label')\n\tpublic validateLabel(value?: LabelPropType): void {\n\t\tvalidateLabel(this, value, {\n\t\t\trequired: true,\n\t\t});\n\t}\n\n\t@Watch('_level')\n\tpublic validateLevel(value?: HeadingLevel): void {\n\t\twatchHeadingLevel(this, value);\n\t}\n\n\t@Watch('_on')\n\tpublic validateOn(on?: DetailsCallbacksPropType<boolean>) {\n\t\tvalidateDetailsCallbacks(this, on);\n\t}\n\n\t@Watch('_open')\n\tpublic validateOpen(value?: boolean): void {\n\t\tvalidateOpen(this, value);\n\t}\n\n\tpublic componentWillLoad(): void {\n\t\tthis.validateDisabled(this._disabled);\n\t\tthis.validateLabel(this._label);\n\t\tthis.validateLevel(this._level);\n\t\tthis.validateOn(this._on);\n\t\tthis.validateOpen(this._open);\n\t}\n}\n"],"names":[],"mappings":"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"}
|
@@ -1,4 +1,4 @@
|
|
1
1
|
/*!
|
2
2
|
* KoliBri - The accessible HTML-Standard
|
3
3
|
*/
|
4
|
-
import{r as n,h as e,g as t}from"./index-
|
4
|
+
import{r as n,h as e,g as t}from"./index-BhaeJ-uM.js";import{w as i}from"./progress-DvHYRA46.js";import{v as o}from"./disabled-hQGJULeA.js";import{v as a}from"./label-D3d1qqIG.js";import{v as s}from"./open-8iQ59IbX.js";import{K as l}from"./Collapsible-LunXGXro.js";import{n as r}from"./dev.utils-tIfWUJtH.js";import{w as d}from"./validation-C2b7CFWx.js";import{d as h,K as c}from"./events-CoPFQEiC.js";import"./Heading-D_vnx163.js";import"./clsx-eK3rPvPS.js";import"./component-names-CkE54Ym7.js";const p=(n,e)=>{i(n,"_on",(n=>"object"==typeof n&&null!==n),new Set(["DetailsCallbacksPropType {Events.onToggle}"]),e)},b="/* forward the rem function */\n/*\n * This file contains all rules for accessibility.\n */\n@layer kol-global {\n :host {\n /*\n * Minimum size of interactive elements.\n */\n --a11y-min-size: calc(44rem / var(--kolibri-root-font-size, 16));\n /*\n * No element should be used without a background and font color whose contrast ratio has\n * not been checked. By initially setting the background color to white and the font color\n * to black, the contrast ratio is ensured and explicit adjustment is forced.\n */\n background-color: white;\n color: black;\n }\n * {\n /*\n * This rule enables the word dividing for all texts. That is important for high zoom levels.\n */\n hyphens: auto;\n /*\n * Verdana is an accessible font that can be used without requiring additional loading time.\n */\n font-family: Verdana;\n /*\n * Letter spacing is required for all texts.\n */\n letter-spacing: inherit;\n /*\n * This rule enables the word dividing for all texts. That is important for high zoom levels.\n */\n word-break: break-word;\n /*\n * Word spacing is required for all texts.\n */\n word-spacing: inherit;\n }\n /*\n * All interactive elements should have a minimum size of to-rem(44).\n */\n /* input:not([type='checkbox'], [type='radio'], [type='range']), */\n /* option, */\n /* select, */\n /* textarea, */\n [role=button],\n button:not([role=link]),\n .kol-input .input {\n min-height: var(--a11y-min-size);\n min-width: var(--a11y-min-size);\n }\n /*\n * Some interactive elements should not inherit the font-family and font-size.\n */\n a,\n button,\n h1,\n h2,\n h3,\n h4,\n h5,\n h6,\n input,\n option,\n select,\n textarea {\n /*\n * All elements should inherit the font family from his parent element.\n */\n font-family: inherit;\n /*\n * All elements should inherit the font size from his parent element.\n */\n font-size: inherit;\n }\n}\n/**\n * Sometimes we need the semantic element for accessibility reasons,\n * but we don't want to show it.\n *\n * - https://www.a11yproject.com/posts/how-to-hide-content/\n */\n.visually-hidden {\n clip: rect(0 0 0 0);\n clip-path: inset(50%);\n height: 1px;\n overflow: hidden;\n position: absolute;\n white-space: nowrap;\n width: 1px;\n}\n\n@layer kol-global {\n /*\n * Dieses CSS stellt sicher, dass der Standard-Style\n * von A und Button resettet werden.\n */\n :is(a, button) {\n background-color: transparent;\n border: none;\n margin: 0;\n padding: 0;\n width: 100%;\n /* 100% needed for custom width from outside */\n }\n /*\n * Ensure elements with hidden attribute to be actually not visible\n * @see https://meowni.ca/hidden.is.a.lie.html\n */\n [hidden] {\n display: none !important;\n }\n .badge-text-hint {\n background-color: lightgray;\n color: black;\n }\n}\n@layer kol-global {\n :host {\n font-size: calc(16rem / var(--kolibri-root-font-size, 16));\n /*\n * The max-width is needed to prevent the table from overflowing the\n * parent node, if the table is wider than the parent node.\n */\n max-width: 100%;\n }\n * {\n /*\n * We prefer to box-sizing: border-box for all elements.\n */\n box-sizing: border-box;\n }\n .kol-span {\n /* KolSpan is a layout component with icons in all directions and a label text in the middle. */\n display: grid;\n place-items: center;\n /* The sub span in KolSpan is the horizontal span with icon left and right and the label text in the middle. */\n }\n .kol-span__container {\n display: flex;\n place-items: center;\n }\n a,\n button {\n cursor: pointer;\n }\n .kol-span .kol-span__label--hide-label .kol-span__label {\n display: none;\n }\n /* Reset browser agent style. */\n button:disabled {\n color: unset;\n }\n .disabled label,\n .disabled:focus-within label,\n [aria-disabled=true],\n [aria-disabled=true]:focus,\n [disabled],\n [disabled]:focus {\n cursor: not-allowed;\n opacity: 0.5;\n outline: none;\n }\n [aria-disabled=true]:focus .kol-span,\n [disabled]:focus .kol-span {\n outline: none !important;\n }\n}\n@layer kol-component {\n :host {\n display: block;\n }\n}\n/* For animation technique see https://css-tricks.com/css-grid-can-do-auto-height-transitions/ */\n@layer kol-component {\n .collapsible {\n /* @see https://github.com/public-ui/kolibri/issues/5952 */\n /*\n * Inside a button, the caption text is always centered.\n * So we have to align the text to the left.\n */\n }\n .collapsible__wrapper {\n display: grid;\n grid-template-rows: 0fr;\n overflow: hidden;\n transition: grid-template-rows 0.3s;\n /* Forces the element into its own GPU compositing layer (via 3D transform). Helps prevent rendering/layout bugs (e.g. #7511) and may improve animation performance. */\n transform: translateZ(0);\n }\n .collapsible__wrapper-animation {\n min-height: 0;\n transition: visibility 0.3s;\n /* This property is important to keep in sync with the visual transition (template-rows). Without it interactive elements within the accordion would stay focusable. */\n visibility: hidden;\n }\n .collapsible--open .collapsible__wrapper {\n grid-template-rows: 1fr;\n }\n .collapsible--open .collapsible__wrapper-animation {\n visibility: visible;\n }\n @media (prefers-reduced-motion) {\n .collapsible__wrapper-animation, .collapsible__wrapper {\n transition-duration: 0s;\n }\n }\n @media print {\n :not(.collapsible--open) .collapsible__wrapper-animation {\n display: none;\n }\n }\n .collapsible__heading-button button .kol-span {\n justify-items: start;\n }\n}\n@layer kol-component {\n .kol-details__heading-button {\n display: flex;\n }\n .kol-details__heading-button .kol-button {\n min-height: auto;\n }\n .kol-details__heading-button .kol-button .kol-span__label {\n border-bottom-color: grey;\n border-bottom-style: solid;\n }\n .collapsible--open .kol-details__heading-button .kol-icon::part(icon) {\n transform: rotate(90deg);\n }\n}",m=class{constructor(e){n(this,e),this.nonce=r(),this.catchRef=n=>{this.buttonWcRef=n},this.handleOnClick=n=>{this._open=!this._open,clearTimeout(this.toggleTimeout),this.toggleTimeout=setTimeout((()=>{var e,t;this.host&&h(this.host,c.toggle,Boolean(this._open)),null===(t=null===(e=this.state._on)||void 0===e?void 0:e.onToggle)||void 0===t||t.call(e,n,Boolean(this._open))}),25)},this._disabled=!1,this._level=0,this._open=!1,this.state={_label:"",_level:0,_on:{}}}async kolFocus(){var n;await(null===(n=this.buttonWcRef)||void 0===n?void 0:n.kolFocus())}render(){const{_open:n,_label:t,_disabled:i,_level:o}=this.state,a="kol-details",s={id:this.nonce,label:t,open:n,disabled:i,level:o,onClick:this.handleOnClick,class:a,HeadingProps:{class:`${a}__heading`},HeadingButtonProps:{ref:this.catchRef,class:`${a}__heading-button`,_icons:"codicon codicon-chevron-right"},ContentProps:{class:`${a}__content indented-text`,wrapperClass:`${a}__wrapper`,animationClass:`${a}__wrapper-animation`}};return e(l,Object.assign({key:"66ab4c4a61c0ac220f184174cc77bf5038e0b65c"},s),e("slot",{key:"121a4d8fd086db1177eccc25b5b6a860741b1917"}))}validateDisabled(n){o(this,n)}validateLabel(n){a(this,n,{required:!0})}validateLevel(n){d(this,n)}validateOn(n){p(this,n)}validateOpen(n){s(this,n)}componentWillLoad(){this.validateDisabled(this._disabled),this.validateLabel(this._label),this.validateLevel(this._level),this.validateOn(this._on),this.validateOpen(this._open)}get host(){return t(this)}static get watchers(){return{_disabled:["validateDisabled"],_label:["validateLabel"],_level:["validateLevel"],_on:["validateOn"],_open:["validateOpen"]}}};m.style={default:b};export{m as kol_details};
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"names":["validateDetailsCallbacks","component","value","watchValidator","Set","defaultStyleCss","
|
1
|
+
{"version":3,"names":["validateDetailsCallbacks","component","value","watchValidator","Set","defaultStyleCss","KolDetails","constructor","hostRef","this","nonce","catchRef","ref","buttonWcRef","handleOnClick","event","_open","clearTimeout","toggleTimeout","setTimeout","host","dispatchDomEvent","KolEvent","toggle","Boolean","_b","_a","state","_on","onToggle","call","_disabled","_level","_label","kolFocus","render","rootClass","props","id","label","open","disabled","level","onClick","class","HeadingProps","HeadingButtonProps","_icons","ContentProps","wrapperClass","animationClass","h","KolCollapsibleFc","Object","assign","key","validateDisabled","validateLabel","required","validateLevel","watchHeadingLevel","validateOn","on","validateOpen","componentWillLoad"],"sources":["src/schema/props/details-callbacks.ts","src/components/details/style.scss?tag=kol-details&mode=default&encapsulation=shadow","src/components/details/shadow.tsx"],"sourcesContent":["import type { Generic } from 'adopted-style-sheets';\nimport type { Callback } from '../enums';\nimport type { EventValueOrEventCallback } from '../types/callbacks';\nimport { watchValidator } from '../utils';\n\n/* types */\nexport type DetailsCallbacksPropType<T> = {\n\t[Callback.onToggle]?: EventValueOrEventCallback<MouseEvent, T>;\n};\n\n/**\n * Defines the callback functions for detail events.\n */\nexport type PropDetailsCallbacks<T> = {\n\ton: DetailsCallbacksPropType<T>;\n};\n\n/* validator */\nexport const validateDetailsCallbacks = (component: Generic.Element.Component, value?: DetailsCallbacksPropType<boolean>): void => {\n\twatchValidator(component, `_on`, (value) => typeof value === 'object' && value !== null, new Set(['DetailsCallbacksPropType {Events.onToggle}']), value);\n};\n","@use '../@shared/mixins' as *;\n@use '../../styles/global' as *;\n@use '../host-display-block' as *;\n@use '../../functional-components/Collapsible/collapsible' as *;\n\n@layer kol-component {\n\t.kol-details {\n\t\t&__heading-button {\n\t\t\tdisplay: flex;\n\n\t\t\t.kol-button {\n\t\t\t\tmin-height: auto;\n\n\t\t\t\t.kol-span {\n\t\t\t\t\t&__label {\n\t\t\t\t\t\tborder-bottom-color: grey;\n\t\t\t\t\t\tborder-bottom-style: solid;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\t.collapsible--open &__heading-button {\n\t\t\t.kol-icon::part(icon) {\n\t\t\t\ttransform: rotate(90deg);\n\t\t\t}\n\t\t}\n\t}\n}\n","import { Component, Element, h, type JSX, Method, Prop, State, Watch } from '@stencil/core';\nimport type { DetailsAPI, DetailsCallbacksPropType, DetailsStates, DisabledPropType, FocusableElement, HeadingLevel, LabelPropType } from '../../schema';\nimport { validateDetailsCallbacks, validateDisabled, validateLabel, validateOpen } from '../../schema';\nimport KolCollapsibleFc, { type CollapsibleProps } from '../../functional-components/Collapsible';\nimport { nonce } from '../../utils/dev.utils';\nimport { watchHeadingLevel } from '../heading/validation';\nimport { dispatchDomEvent, KolEvent } from '../../utils/events';\n\n/**\n * @slot - Der Inhalt, der in der Detailbeschreibung angezeigt wird.\n */\n@Component({\n\ttag: 'kol-details',\n\tstyleUrls: {\n\t\tdefault: './style.scss',\n\t},\n\tshadow: true,\n})\nexport class KolDetails implements DetailsAPI, FocusableElement {\n\t@Element() private readonly host?: HTMLKolDetailsElement;\n\n\tprivate readonly nonce = nonce();\n\tprivate buttonWcRef?: HTMLKolButtonWcElement;\n\n\tprivate readonly catchRef = (ref?: HTMLKolButtonWcElement) => {\n\t\tthis.buttonWcRef = ref;\n\t};\n\n\t@Method()\n\t// eslint-disable-next-line @typescript-eslint/require-await\n\tpublic async kolFocus() {\n\t\tawait this.buttonWcRef?.kolFocus();\n\t}\n\n\tprivate toggleTimeout?: ReturnType<typeof setTimeout>;\n\n\tprivate handleOnClick = (event: MouseEvent) => {\n\t\tthis._open = !this._open;\n\n\t\t/**\n\t\t * Der Timeout wird benötigt, damit das Event\n\t\t * vom Button- auf das Accordion-Event wechselt.\n\t\t * So ist es dem Anwendenden möglich das _open-\n\t\t * Attribute abzufragen.\n\t\t */\n\n\t\tclearTimeout(this.toggleTimeout);\n\n\t\tthis.toggleTimeout = setTimeout(() => {\n\t\t\tif (this.host) {\n\t\t\t\tdispatchDomEvent(this.host, KolEvent.toggle, Boolean(this._open));\n\t\t\t}\n\t\t\tthis.state._on?.onToggle?.(event, Boolean(this._open));\n\t\t}, 25);\n\t};\n\n\tpublic render(): JSX.Element {\n\t\tconst { _open, _label, _disabled, _level } = this.state;\n\n\t\tconst rootClass = 'kol-details';\n\n\t\tconst props: CollapsibleProps = {\n\t\t\tid: this.nonce,\n\t\t\tlabel: _label,\n\t\t\topen: _open,\n\t\t\tdisabled: _disabled,\n\t\t\tlevel: _level,\n\t\t\tonClick: this.handleOnClick,\n\t\t\tclass: rootClass,\n\t\t\tHeadingProps: { class: `${rootClass}__heading` },\n\t\t\tHeadingButtonProps: {\n\t\t\t\tref: this.catchRef,\n\t\t\t\tclass: `${rootClass}__heading-button`,\n\t\t\t\t_icons: 'codicon codicon-chevron-right',\n\t\t\t},\n\t\t\tContentProps: {\n\t\t\t\tclass: `${rootClass}__content indented-text`,\n\t\t\t\twrapperClass: `${rootClass}__wrapper`,\n\t\t\t\tanimationClass: `${rootClass}__wrapper-animation`,\n\t\t\t},\n\t\t};\n\n\t\treturn (\n\t\t\t<KolCollapsibleFc {...props}>\n\t\t\t\t<slot />\n\t\t\t</KolCollapsibleFc>\n\t\t);\n\t}\n\n\t/**\n\t * Makes the element not focusable and ignore all events.\n\t */\n\t@Prop() public _disabled?: boolean = false;\n\n\t/**\n\t * Defines the visible or semantic label of the component (e.g. aria-label, label, headline, caption, summary, etc.).\n\t */\n\t@Prop() public _label!: LabelPropType;\n\n\t/**\n\t * Defines which H-level from 1-6 the heading has. 0 specifies no heading and is shown as bold text.\n\t */\n\t@Prop() public _level?: HeadingLevel = 0;\n\n\t/**\n\t * Defines the callback functions for details.\n\t */\n\t@Prop() public _on?: DetailsCallbacksPropType<boolean>;\n\n\t/**\n\t * Opens/expands the element when truthy, closes/collapses when falsy.\n\t * @TODO: Change type back to `OpenPropType` after Stencil#4663 has been resolved.\n\t */\n\t@Prop({ mutable: true, reflect: true }) public _open?: boolean = false;\n\n\t@State() public state: DetailsStates = {\n\t\t_label: '', // ⚠ required\n\t\t_level: 0,\n\t\t_on: {},\n\t};\n\n\t@Watch('_disabled')\n\tpublic validateDisabled(value?: DisabledPropType): void {\n\t\tvalidateDisabled(this, value);\n\t}\n\n\t@Watch('_label')\n\tpublic validateLabel(value?: LabelPropType): void {\n\t\tvalidateLabel(this, value, {\n\t\t\trequired: true,\n\t\t});\n\t}\n\n\t@Watch('_level')\n\tpublic validateLevel(value?: HeadingLevel): void {\n\t\twatchHeadingLevel(this, value);\n\t}\n\n\t@Watch('_on')\n\tpublic validateOn(on?: DetailsCallbacksPropType<boolean>) {\n\t\tvalidateDetailsCallbacks(this, on);\n\t}\n\n\t@Watch('_open')\n\tpublic validateOpen(value?: boolean): void {\n\t\tvalidateOpen(this, value);\n\t}\n\n\tpublic componentWillLoad(): void {\n\t\tthis.validateDisabled(this._disabled);\n\t\tthis.validateLabel(this._label);\n\t\tthis.validateLevel(this._level);\n\t\tthis.validateOn(this._on);\n\t\tthis.validateOpen(this._open);\n\t}\n}\n"],"mappings":";;;ifAkBO,MAAMA,EAA2B,CAACC,EAAsCC,KAC9EC,EAAeF,EAAW,OAAQC,UAAiBA,IAAU,UAAYA,IAAU,MAAM,IAAIE,IAAI,CAAC,+CAAgDF,EAAM,ECnBzJ,MAAMG,EAAkB,8mM,MCkBXC,EAAU,MAPvB,WAAAC,CAAAC,G,UAUkBC,KAAKC,MAAGA,IAGRD,KAAAE,SAAYC,IAC5BH,KAAKI,YAAcD,CAAG,EAWfH,KAAAK,cAAiBC,IACxBN,KAAKO,OAASP,KAAKO,MASnBC,aAAaR,KAAKS,eAElBT,KAAKS,cAAgBC,YAAW,K,QAC/B,GAAIV,KAAKW,KAAM,CACdC,EAAiBZ,KAAKW,KAAME,EAASC,OAAQC,QAAQf,KAAKO,O,EAE3DS,GAAAC,EAAAjB,KAAKkB,MAAMC,OAAG,MAAAF,SAAA,SAAAA,EAAEG,YAAQ,MAAAJ,SAAA,SAAAA,EAAAK,KAAAJ,EAAGX,EAAOS,QAAQf,KAAKO,OAAO,GACpD,GAAG,EAuCQP,KAASsB,UAAa,MAUtBtB,KAAMuB,OAAkB,EAWQvB,KAAKO,MAAa,MAEjDP,KAAAkB,MAAuB,CACtCM,OAAQ,GACRD,OAAQ,EACRJ,IAAK,GAqCN,CA7HO,cAAMM,G,aACNR,EAAAjB,KAAKI,eAAa,MAAAa,SAAA,SAAAA,EAAAQ,W,CAyBlB,MAAAC,GACN,MAAMnB,MAAEA,EAAKiB,OAAEA,EAAMF,UAAEA,EAASC,OAAEA,GAAWvB,KAAKkB,MAElD,MAAMS,EAAY,cAElB,MAAMC,EAA0B,CAC/BC,GAAI7B,KAAKC,MACT6B,MAAON,EACPO,KAAMxB,EACNyB,SAAUV,EACVW,MAAOV,EACPW,QAASlC,KAAKK,cACd8B,MAAOR,EACPS,aAAc,CAAED,MAAO,GAAGR,cAC1BU,mBAAoB,CACnBlC,IAAKH,KAAKE,SACViC,MAAO,GAAGR,oBACVW,OAAQ,iCAETC,aAAc,CACbJ,MAAO,GAAGR,2BACVa,aAAc,GAAGb,aACjBc,eAAgB,GAAGd,yBAIrB,OACCe,EAACC,EAAgBC,OAAAC,OAAA,CAAAC,IAAA,4CAAKlB,GACrBc,EAAQ,QAAAI,IAAA,6C,CAsCJ,gBAAAC,CAAiBtD,GACvBsD,EAAiB/C,KAAMP,E,CAIjB,aAAAuD,CAAcvD,GACpBuD,EAAchD,KAAMP,EAAO,CAC1BwD,SAAU,M,CAKL,aAAAC,CAAczD,GACpB0D,EAAkBnD,KAAMP,E,CAIlB,UAAA2D,CAAWC,GACjB9D,EAAyBS,KAAMqD,E,CAIzB,YAAAC,CAAa7D,GACnB6D,EAAatD,KAAMP,E,CAGb,iBAAA8D,GACNvD,KAAK+C,iBAAiB/C,KAAKsB,WAC3BtB,KAAKgD,cAAchD,KAAKwB,QACxBxB,KAAKkD,cAAclD,KAAKuB,QACxBvB,KAAKoD,WAAWpD,KAAKmB,KACrBnB,KAAKsD,aAAatD,KAAKO,M","ignoreList":[]}
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"kol-drawer.entry.esm.js","sources":["src/components/drawer/style.scss?tag=kol-drawer&mode=default&encapsulation=shadow","src/components/drawer/shadow.tsx"],"sourcesContent":["@use '../../styles/global' as *;\n@use '../../styles/kol-card-mixin' as *;\n@use '../@shared/mixins' as *;\n@use '../tooltip/style.scss' as *;\n\n@include kol-card;\n\n@layer kol-component {\n\t.kol-drawer {\n\t\t$root: &;\n\n\t\t&__dialog {\n\t\t\tpadding: 0;\n\t\t\tborder: none;\n\t\t}\n\n\t\t&__wrapper {\n\t\t\tposition: fixed;\n\t\t\twidth: auto;\n\t\t\toverflow: auto;\n\n\t\t\t&--left {\n\t\t\t\ttop: 0;\n\t\t\t\tleft: 0;\n\t\t\t\theight: 100vh;\n\t\t\t\tmax-height: 100%;\n\n\t\t\t\t#{$root}__content {\n\t\t\t\t\theight: 100%;\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t&--right {\n\t\t\t\ttop: 0;\n\t\t\t\tright: 0;\n\t\t\t\theight: 100vh;\n\t\t\t\tmax-height: 100%;\n\n\t\t\t\t#{$root}__content {\n\t\t\t\t\theight: 100%;\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t&--top {\n\t\t\t\tleft: 0;\n\t\t\t\ttop: 0;\n\t\t\t\twidth: 100vw;\n\t\t\t\tmax-width: 100%;\n\n\t\t\t\t#{$root}__content {\n\t\t\t\t\twidth: 100%;\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t&--bottom {\n\t\t\t\tleft: 0;\n\t\t\t\tbottom: 0;\n\t\t\t\twidth: 100vw;\n\t\t\t\tmax-width: 100%;\n\n\t\t\t\t#{$root}__content {\n\t\t\t\t\twidth: 100%;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\t&__content {\n\t\t\tposition: relative;\n\t\t}\n\t}\n}\n","/* eslint-disable jsx-a11y/no-noninteractive-element-interactions */\nimport type { AlignPropType, DrawerAPI, DrawerStates, HasCloserPropType, KoliBriModalEventCallbacks, LabelPropType, OpenPropType } from '../../schema';\nimport { setState, validateAlign, validateHasCloser, validateLabel, validateOpen } from '../../schema';\nimport type { JSX } from '@stencil/core';\nimport { Component, Element, h, Host, Method, Prop, State, Watch } from '@stencil/core';\nimport { dispatchDomEvent, KolEvent } from '../../utils/events';\nimport clsx from 'clsx';\nimport { KolCardWcTag } from '../../core/component-names';\n\n/**\n * @slot - The Content of drawer.\n */\n@Component({\n\ttag: 'kol-drawer',\n\tstyleUrls: {\n\t\tdefault: './style.scss',\n\t},\n\tshadow: true,\n})\nexport class KolDrawer implements DrawerAPI {\n\t@Element() private readonly host?: HTMLKolDetailsElement;\n\tprivate dialogElement?: HTMLDialogElement;\n\tprivate dialogWrapperElement?: HTMLKolCardWcElement;\n\n\t@Method()\n\t// eslint-disable-next-line @typescript-eslint/require-await\n\tasync open() {\n\t\tthis.state = {\n\t\t\t...this.state,\n\t\t\t_open: true,\n\t\t};\n\t\tthis.dialogElement?.showModal();\n\t}\n\n\t@Method()\n\t// eslint-disable-next-line @typescript-eslint/require-await\n\tasync close() {\n\t\tthis.state = {\n\t\t\t...this.state,\n\t\t\t_open: false,\n\t\t};\n\t\tconst wrapper = this.dialogWrapperElement;\n\t\tif (!wrapper) return;\n\t\tconst computedStyle = window.getComputedStyle(wrapper);\n\t\tif (computedStyle.animationName === 'none') {\n\t\t\tthis.handleCloseDialog();\n\t\t}\n\t}\n\n\tprivate getWrapperRef = (el: HTMLKolCardWcElement | undefined) => (this.dialogWrapperElement = el as HTMLKolCardWcElement);\n\tprivate renderDialogContent() {\n\t\tconst align = this.state._align as string;\n\t\treturn (\n\t\t\t<KolCardWcTag\n\t\t\t\tref={this.getWrapperRef}\n\t\t\t\tclass={clsx(`kol-drawer__wrapper`, `kol-drawer__wrapper--${align}`, {\n\t\t\t\t\t'kol-drawer__wrapper--open': this.state._open,\n\t\t\t\t\t'kol-drawer__wrapper--is-closing': this.state._open === false,\n\t\t\t\t})}\n\t\t\t\t_label={this.state._label}\n\t\t\t\t_hasCloser={this.state._hasCloser}\n\t\t\t\t_on={{\n\t\t\t\t\tonClose: () => {\n\t\t\t\t\t\tvoid this.close();\n\t\t\t\t\t},\n\t\t\t\t}}\n\t\t\t>\n\t\t\t\t<div class=\"kol-drawer__content\">\n\t\t\t\t\t<slot />\n\t\t\t\t</div>\n\t\t\t</KolCardWcTag>\n\t\t);\n\t}\n\n\tprivate getRef = (el: HTMLDialogElement | undefined) => {\n\t\tthis.dialogElement = el as HTMLDialogElement;\n\t\tsetTimeout(() => {\n\t\t\tvoid this.openOrCloseBasedOnState(); // handle initial state as soon as element is ready\n\t\t});\n\t};\n\tpublic render(): JSX.Element {\n\t\treturn (\n\t\t\t<Host class=\"kol-drawer\">\n\t\t\t\t<dialog aria-label={this.state._label} class=\"kol-drawer__dialog\" ref={this.getRef}>\n\t\t\t\t\t{this.renderDialogContent()}\n\t\t\t\t</dialog>\n\t\t\t</Host>\n\t\t);\n\t}\n\n\t/**\n\t * Opens/expands the element when truthy, closes/collapses when falsy.\n\t */\n\t@Prop() public _open?: OpenPropType;\n\n\t/**\n\t * Defines the visual orientation of the component.\n\t */\n\t@Prop() public _align?: AlignPropType;\n\n\t/**\n\t * Defines whether the element can be closed.\n\t * @TODO: Change type back to `HasCloserPropType` after Stencil#4663 has been resolved.\n\t */\n\t@Prop() public _hasCloser?: boolean = false;\n\n\t/**\n\t * Defines the visible or semantic label of the component (e.g. aria-label, label, headline, caption, summary, etc.).\n\t */\n\t@Prop() public _label!: LabelPropType;\n\n\t/**\n\t * Specifies the EventCallback function to be called when the drawer is closing.\n\t */\n\t@Prop() public _on?: KoliBriModalEventCallbacks;\n\n\t@State() public state: DrawerStates = {\n\t\t_label: '', // ⚠ required\n\t\t_open: false,\n\t\t_align: 'left',\n\t};\n\n\t@Watch('_label')\n\tpublic validateLabel(value?: LabelPropType): void {\n\t\tvalidateLabel(this, value, {\n\t\t\trequired: true,\n\t\t});\n\t}\n\n\t@Watch('_align')\n\tpublic validateAlign(value?: AlignPropType): void {\n\t\tvalidateAlign(this, value);\n\t}\n\n\t@Watch('_hasCloser')\n\tpublic validateHasCloser(value?: HasCloserPropType): void {\n\t\tvalidateHasCloser(this, value);\n\t}\n\n\t@Watch('_open')\n\tpublic validateOpen(value?: OpenPropType) {\n\t\tif (typeof value === 'boolean') {\n\t\t\tvalidateOpen(this, value);\n\n\t\t\tif (this.dialogElement) {\n\t\t\t\t// handle property changes but not the initial validateOpen call\n\t\t\t\tvoid this.openOrCloseBasedOnState();\n\t\t\t}\n\t\t}\n\t}\n\n\tprivate async openOrCloseBasedOnState() {\n\t\tif (this.state._open) {\n\t\t\tawait this.open();\n\t\t} else {\n\t\t\tawait this.close();\n\t\t}\n\t}\n\n\t@Watch('_on')\n\tpublic validateOn(value?: KoliBriModalEventCallbacks): void {\n\t\tif (typeof value === 'object' && value !== null) {\n\t\t\tconst callbacks: KoliBriModalEventCallbacks = {};\n\t\t\tif (typeof value.onClose === 'function') {\n\t\t\t\tcallbacks.onClose = value.onClose;\n\t\t\t}\n\t\t\tsetState<KoliBriModalEventCallbacks>(this, '_on', callbacks);\n\t\t}\n\t}\n\n\tprivate handleCloseDialog() {\n\t\tthis.dialogElement?.close();\n\t\tthis._on?.onClose?.();\n\t\tif (this.host) {\n\t\t\tdispatchDomEvent(this.host, KolEvent.close);\n\t\t}\n\t}\n\n\tprivate handleClose() {\n\t\tvoid (async () => {\n\t\t\tawait this.close();\n\t\t\tthis.handleCloseDialog();\n\t\t})();\n\t}\n\n\tprivate handleAnimationEnd(e: Event): void {\n\t\tconst animationEvent = e as AnimationEvent;\n\t\tif (animationEvent.animationName.includes('slideOut')) {\n\t\t\tthis.handleCloseDialog();\n\t\t}\n\t}\n\n\tpublic componentDidLoad(): void {\n\t\tthis.dialogElement?.addEventListener('animationend', this.handleAnimationEnd.bind(this));\n\t\tthis.dialogElement?.addEventListener('close', this.handleClose.bind(this));\n\t}\n\n\tpublic disconnectedCallback(): void {\n\t\tthis.dialogElement?.removeEventListener('animationend', this.handleAnimationEnd.bind(this));\n\t\tthis.dialogElement?.removeEventListener('close', this.handleClose.bind(this));\n\t}\n\n\tpublic componentWillLoad() {\n\t\tthis.validateLabel(this._label);\n\t\tthis.validateOpen(this._open);\n\t\tthis.validateAlign(this._align);\n\t\tthis.validateHasCloser(this._hasCloser);\n\t\tthis.validateOn(this._on);\n\t}\n}\n"],"names":[],"mappings":"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"}
|
@@ -1,4 +1,4 @@
|
|
1
1
|
/*!
|
2
2
|
* KoliBri - The accessible HTML-Standard
|
3
3
|
*/
|
4
|
-
import{r as n,h as t,H as e,g as i}from"./index-
|
4
|
+
import{r as n,h as t,H as e,g as i}from"./index-BhaeJ-uM.js";import{s as o}from"./progress-DvHYRA46.js";import{v as a}from"./align-tkanisJ7.js";import{v as l}from"./has-closer-DB5qR5TQ.js";import{v as s}from"./label-D3d1qqIG.js";import{v as r}from"./open-8iQ59IbX.js";import{d,K as h}from"./events-CoPFQEiC.js";import{c}from"./clsx-eK3rPvPS.js";import{g as p}from"./component-names-CkE54Ym7.js";const f="/* forward the rem function */\n/*\n * This file contains all rules for accessibility.\n */\n@layer kol-global {\n :host {\n /*\n * Minimum size of interactive elements.\n */\n --a11y-min-size: calc(44rem / var(--kolibri-root-font-size, 16));\n /*\n * No element should be used without a background and font color whose contrast ratio has\n * not been checked. By initially setting the background color to white and the font color\n * to black, the contrast ratio is ensured and explicit adjustment is forced.\n */\n background-color: white;\n color: black;\n }\n * {\n /*\n * This rule enables the word dividing for all texts. That is important for high zoom levels.\n */\n hyphens: auto;\n /*\n * Verdana is an accessible font that can be used without requiring additional loading time.\n */\n font-family: Verdana;\n /*\n * Letter spacing is required for all texts.\n */\n letter-spacing: inherit;\n /*\n * This rule enables the word dividing for all texts. That is important for high zoom levels.\n */\n word-break: break-word;\n /*\n * Word spacing is required for all texts.\n */\n word-spacing: inherit;\n }\n /*\n * All interactive elements should have a minimum size of to-rem(44).\n */\n /* input:not([type='checkbox'], [type='radio'], [type='range']), */\n /* option, */\n /* select, */\n /* textarea, */\n [role=button],\n button:not([role=link]),\n .kol-input .input {\n min-height: var(--a11y-min-size);\n min-width: var(--a11y-min-size);\n }\n /*\n * Some interactive elements should not inherit the font-family and font-size.\n */\n a,\n button,\n h1,\n h2,\n h3,\n h4,\n h5,\n h6,\n input,\n option,\n select,\n textarea {\n /*\n * All elements should inherit the font family from his parent element.\n */\n font-family: inherit;\n /*\n * All elements should inherit the font size from his parent element.\n */\n font-size: inherit;\n }\n}\n/**\n * Sometimes we need the semantic element for accessibility reasons,\n * but we don't want to show it.\n *\n * - https://www.a11yproject.com/posts/how-to-hide-content/\n */\n.visually-hidden {\n clip: rect(0 0 0 0);\n clip-path: inset(50%);\n height: 1px;\n overflow: hidden;\n position: absolute;\n white-space: nowrap;\n width: 1px;\n}\n\n@layer kol-global {\n /*\n * Dieses CSS stellt sicher, dass der Standard-Style\n * von A und Button resettet werden.\n */\n :is(a, button) {\n background-color: transparent;\n border: none;\n margin: 0;\n padding: 0;\n width: 100%;\n /* 100% needed for custom width from outside */\n }\n /*\n * Ensure elements with hidden attribute to be actually not visible\n * @see https://meowni.ca/hidden.is.a.lie.html\n */\n [hidden] {\n display: none !important;\n }\n .badge-text-hint {\n background-color: lightgray;\n color: black;\n }\n}\n@layer kol-global {\n :host {\n font-size: calc(16rem / var(--kolibri-root-font-size, 16));\n /*\n * The max-width is needed to prevent the table from overflowing the\n * parent node, if the table is wider than the parent node.\n */\n max-width: 100%;\n }\n * {\n /*\n * We prefer to box-sizing: border-box for all elements.\n */\n box-sizing: border-box;\n }\n .kol-span {\n /* KolSpan is a layout component with icons in all directions and a label text in the middle. */\n display: grid;\n place-items: center;\n /* The sub span in KolSpan is the horizontal span with icon left and right and the label text in the middle. */\n }\n .kol-span__container {\n display: flex;\n place-items: center;\n }\n a,\n button {\n cursor: pointer;\n }\n .kol-span .kol-span__label--hide-label .kol-span__label {\n display: none;\n }\n /* Reset browser agent style. */\n button:disabled {\n color: unset;\n }\n .disabled label,\n .disabled:focus-within label,\n [aria-disabled=true],\n [aria-disabled=true]:focus,\n [disabled],\n [disabled]:focus {\n cursor: not-allowed;\n opacity: 0.5;\n outline: none;\n }\n [aria-disabled=true]:focus .kol-span,\n [disabled]:focus .kol-span {\n outline: none !important;\n }\n}\n@layer kol-component {\n .kol-tooltip {\n contain: layout;\n display: contents;\n }\n .kol-tooltip__floating {\n animation-duration: 0.25s;\n animation-iteration-count: 1;\n animation-name: fadeInOpacity;\n animation-timing-function: ease-in;\n display: none;\n position: fixed;\n visibility: hidden;\n /* Avoid layout interference - see https://floating-ui.com/docs/computePosition */\n top: 0;\n left: 0;\n max-width: 90vw;\n max-height: 90vh;\n /* Can be used to specify the tooltip-width from the outside. Unset by default. */\n width: var(--kol-tooltip-width);\n }\n .kol-tooltip__arrow {\n background-color: #fff;\n color: #000;\n height: calc(10rem / var(--kolibri-root-font-size, 16));\n position: absolute;\n transform: rotate(45deg);\n width: calc(10rem / var(--kolibri-root-font-size, 16));\n z-index: 999;\n }\n .kol-tooltip__content {\n background-color: #fff;\n color: #000;\n position: relative;\n z-index: 1000;\n }\n @keyframes fadeInOpacity {\n 0% {\n opacity: 0;\n }\n 100% {\n opacity: 1;\n }\n }\n}\n@layer kol-component {\n .kol-card {\n height: 100%;\n position: relative;\n /* Visible with forced colors */\n outline: transparent solid calc(1rem / var(--kolibri-root-font-size, 16));\n }\n .kol-card__close-button {\n position: absolute;\n top: 0;\n right: 0;\n }\n}\n@layer kol-component {\n .kol-drawer__dialog {\n padding: 0;\n border: none;\n }\n .kol-drawer__wrapper {\n position: fixed;\n width: auto;\n overflow: auto;\n }\n .kol-drawer__wrapper--left {\n top: 0;\n left: 0;\n height: 100vh;\n max-height: 100%;\n }\n .kol-drawer__wrapper--left .kol-drawer__content {\n height: 100%;\n }\n .kol-drawer__wrapper--right {\n top: 0;\n right: 0;\n height: 100vh;\n max-height: 100%;\n }\n .kol-drawer__wrapper--right .kol-drawer__content {\n height: 100%;\n }\n .kol-drawer__wrapper--top {\n left: 0;\n top: 0;\n width: 100vw;\n max-width: 100%;\n }\n .kol-drawer__wrapper--top .kol-drawer__content {\n width: 100%;\n }\n .kol-drawer__wrapper--bottom {\n left: 0;\n bottom: 0;\n width: 100vw;\n max-width: 100%;\n }\n .kol-drawer__wrapper--bottom .kol-drawer__content {\n width: 100%;\n }\n .kol-drawer__content {\n position: relative;\n }\n}",m=class{constructor(e){n(this,e),this.getWrapperRef=n=>this.dialogWrapperElement=n,this.getRef=n=>{this.dialogElement=n,setTimeout((()=>{this.openOrCloseBasedOnState()}))},this._hasCloser=!1,this.state={_label:"",_open:!1,_align:"left"}}async open(){var n;this.state=Object.assign(Object.assign({},this.state),{_open:!0}),null===(n=this.dialogElement)||void 0===n||n.showModal()}async close(){this.state=Object.assign(Object.assign({},this.state),{_open:!1});const n=this.dialogWrapperElement;if(!n)return;"none"===window.getComputedStyle(n).animationName&&this.handleCloseDialog()}renderDialogContent(){const n=this.state._align;return t(p,{ref:this.getWrapperRef,class:c("kol-drawer__wrapper",`kol-drawer__wrapper--${n}`,{"kol-drawer__wrapper--open":this.state._open,"kol-drawer__wrapper--is-closing":!1===this.state._open}),_label:this.state._label,_hasCloser:this.state._hasCloser,_on:{onClose:()=>{this.close()}}},t("div",{class:"kol-drawer__content"},t("slot",null)))}render(){return t(e,{key:"6a688ecbd6f17156a13d429abdfbbbd26aa45878",class:"kol-drawer"},t("dialog",{key:"cfbfa7d3eaf54db3915d4941b154c6ac21f99fc8","aria-label":this.state._label,class:"kol-drawer__dialog",ref:this.getRef},this.renderDialogContent()))}validateLabel(n){s(this,n,{required:!0})}validateAlign(n){a(this,n)}validateHasCloser(n){l(this,n)}validateOpen(n){"boolean"==typeof n&&(r(this,n),this.dialogElement&&this.openOrCloseBasedOnState())}async openOrCloseBasedOnState(){this.state._open?await this.open():await this.close()}validateOn(n){if("object"==typeof n&&null!==n){const e={};"function"==typeof n.onClose&&(e.onClose=n.onClose),o(this,"_on",e)}}handleCloseDialog(){var n,e,t;null===(n=this.dialogElement)||void 0===n||n.close(),null===(t=null===(e=this._on)||void 0===e?void 0:e.onClose)||void 0===t||t.call(e),this.host&&d(this.host,h.close)}handleClose(){(async()=>{await this.close(),this.handleCloseDialog()})()}handleAnimationEnd(n){n.animationName.includes("slideOut")&&this.handleCloseDialog()}componentDidLoad(){var n,e;null===(n=this.dialogElement)||void 0===n||n.addEventListener("animationend",this.handleAnimationEnd.bind(this)),null===(e=this.dialogElement)||void 0===e||e.addEventListener("close",this.handleClose.bind(this))}disconnectedCallback(){var n,e;null===(n=this.dialogElement)||void 0===n||n.removeEventListener("animationend",this.handleAnimationEnd.bind(this)),null===(e=this.dialogElement)||void 0===e||e.removeEventListener("close",this.handleClose.bind(this))}componentWillLoad(){this.validateLabel(this._label),this.validateOpen(this._open),this.validateAlign(this._align),this.validateHasCloser(this._hasCloser),this.validateOn(this._on)}get host(){return i(this)}static get watchers(){return{_label:["validateLabel"],_align:["validateAlign"],_hasCloser:["validateHasCloser"],_open:["validateOpen"],_on:["validateOn"]}}};m.style={default:f};export{m as kol_drawer};
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"names":["defaultStyleCss","KolDrawerDefaultStyle0","KolDrawer","this","getWrapperRef","el","dialogWrapperElement","getRef","dialogElement","setTimeout","openOrCloseBasedOnState","_label","_open","_align","open","state","Object","assign","_a","showModal","close","wrapper","computedStyle","window","getComputedStyle","animationName","handleCloseDialog","renderDialogContent","align","h","KolCardWcTag","ref","class","clsx","_hasCloser","_on","onClose","render","Host","key","validateLabel","value","required","validateAlign","validateHasCloser","validateOpen","validateOn","callbacks","setState","_c","_b","call","host","dispatchDomEvent","KolEvent","handleClose","handleAnimationEnd","e","animationEvent","includes","componentDidLoad","addEventListener","bind","disconnectedCallback","removeEventListener","componentWillLoad"],"sources":["src/components/drawer/style.scss?tag=kol-drawer&mode=default&encapsulation=shadow","src/components/drawer/shadow.tsx"],"sourcesContent":["@use '../../styles/global' as *;\n@use '../../styles/kol-card-mixin' as *;\n@use '../@shared/mixins' as *;\n@use '../tooltip/style.scss' as *;\n\n@include kol-card;\n\n@layer kol-component {\n\t.kol-drawer {\n\t\t$root: &;\n\n\t\t&__dialog {\n\t\t\tpadding: 0;\n\t\t\tborder: none;\n\t\t}\n\n\t\t&__wrapper {\n\t\t\tposition: fixed;\n\t\t\twidth: auto;\n\t\t\toverflow: auto;\n\n\t\t\t&--left {\n\t\t\t\ttop: 0;\n\t\t\t\tleft: 0;\n\t\t\t\theight: 100vh;\n\t\t\t\tmax-height: 100%;\n\n\t\t\t\t#{$root}__content {\n\t\t\t\t\theight: 100%;\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t&--right {\n\t\t\t\ttop: 0;\n\t\t\t\tright: 0;\n\t\t\t\theight: 100vh;\n\t\t\t\tmax-height: 100%;\n\n\t\t\t\t#{$root}__content {\n\t\t\t\t\theight: 100%;\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t&--top {\n\t\t\t\tleft: 0;\n\t\t\t\ttop: 0;\n\t\t\t\twidth: 100vw;\n\t\t\t\tmax-width: 100%;\n\n\t\t\t\t#{$root}__content {\n\t\t\t\t\twidth: 100%;\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t&--bottom {\n\t\t\t\tleft: 0;\n\t\t\t\tbottom: 0;\n\t\t\t\twidth: 100vw;\n\t\t\t\tmax-width: 100%;\n\n\t\t\t\t#{$root}__content {\n\t\t\t\t\twidth: 100%;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\t&__content {\n\t\t\tposition: relative;\n\t\t}\n\t}\n}\n","/* eslint-disable jsx-a11y/no-noninteractive-element-interactions */\nimport type { AlignPropType, DrawerAPI, DrawerStates, HasCloserPropType, KoliBriModalEventCallbacks, LabelPropType, OpenPropType } from '../../schema';\nimport { setState, validateAlign, validateHasCloser, validateLabel, validateOpen } from '../../schema';\nimport type { JSX } from '@stencil/core';\nimport { Component, Element, h, Host, Method, Prop, State, Watch } from '@stencil/core';\nimport { dispatchDomEvent, KolEvent } from '../../utils/events';\nimport clsx from 'clsx';\nimport { KolCardWcTag } from '../../core/component-names';\n\n/**\n * @slot - The Content of drawer.\n */\n@Component({\n\ttag: 'kol-drawer',\n\tstyleUrls: {\n\t\tdefault: './style.scss',\n\t},\n\tshadow: true,\n})\nexport class KolDrawer implements DrawerAPI {\n\t@Element() private readonly host?: HTMLKolDetailsElement;\n\tprivate dialogElement?: HTMLDialogElement;\n\tprivate dialogWrapperElement?: HTMLKolCardWcElement;\n\n\t@Method()\n\t// eslint-disable-next-line @typescript-eslint/require-await\n\tasync open() {\n\t\tthis.state = {\n\t\t\t...this.state,\n\t\t\t_open: true,\n\t\t};\n\t\tthis.dialogElement?.showModal();\n\t}\n\n\t@Method()\n\t// eslint-disable-next-line @typescript-eslint/require-await\n\tasync close() {\n\t\tthis.state = {\n\t\t\t...this.state,\n\t\t\t_open: false,\n\t\t};\n\t\tconst wrapper = this.dialogWrapperElement;\n\t\tif (!wrapper) return;\n\t\tconst computedStyle = window.getComputedStyle(wrapper);\n\t\tif (computedStyle.animationName === 'none') {\n\t\t\tthis.handleCloseDialog();\n\t\t}\n\t}\n\n\tprivate getWrapperRef = (el: HTMLKolCardWcElement | undefined) => (this.dialogWrapperElement = el as HTMLKolCardWcElement);\n\tprivate renderDialogContent() {\n\t\tconst align = this.state._align as string;\n\t\treturn (\n\t\t\t<KolCardWcTag\n\t\t\t\tref={this.getWrapperRef}\n\t\t\t\tclass={clsx(`kol-drawer__wrapper`, `kol-drawer__wrapper--${align}`, {\n\t\t\t\t\t'kol-drawer__wrapper--open': this.state._open,\n\t\t\t\t\t'kol-drawer__wrapper--is-closing': this.state._open === false,\n\t\t\t\t})}\n\t\t\t\t_label={this.state._label}\n\t\t\t\t_hasCloser={this.state._hasCloser}\n\t\t\t\t_on={{\n\t\t\t\t\tonClose: () => {\n\t\t\t\t\t\tvoid this.close();\n\t\t\t\t\t},\n\t\t\t\t}}\n\t\t\t>\n\t\t\t\t<div class=\"kol-drawer__content\">\n\t\t\t\t\t<slot />\n\t\t\t\t</div>\n\t\t\t</KolCardWcTag>\n\t\t);\n\t}\n\n\tprivate getRef = (el: HTMLDialogElement | undefined) => {\n\t\tthis.dialogElement = el as HTMLDialogElement;\n\t\tsetTimeout(() => {\n\t\t\tvoid this.openOrCloseBasedOnState(); // handle initial state as soon as element is ready\n\t\t});\n\t};\n\tpublic render(): JSX.Element {\n\t\treturn (\n\t\t\t<Host class=\"kol-drawer\">\n\t\t\t\t<dialog aria-label={this.state._label} class=\"kol-drawer__dialog\" ref={this.getRef}>\n\t\t\t\t\t{this.renderDialogContent()}\n\t\t\t\t</dialog>\n\t\t\t</Host>\n\t\t);\n\t}\n\n\t/**\n\t * Opens/expands the element when truthy, closes/collapses when falsy.\n\t */\n\t@Prop() public _open?: OpenPropType;\n\n\t/**\n\t * Defines the visual orientation of the component.\n\t */\n\t@Prop() public _align?: AlignPropType;\n\n\t/**\n\t * Defines whether the element can be closed.\n\t * @TODO: Change type back to `HasCloserPropType` after Stencil#4663 has been resolved.\n\t */\n\t@Prop() public _hasCloser?: boolean = false;\n\n\t/**\n\t * Defines the visible or semantic label of the component (e.g. aria-label, label, headline, caption, summary, etc.).\n\t */\n\t@Prop() public _label!: LabelPropType;\n\n\t/**\n\t * Specifies the EventCallback function to be called when the drawer is closing.\n\t */\n\t@Prop() public _on?: KoliBriModalEventCallbacks;\n\n\t@State() public state: DrawerStates = {\n\t\t_label: '', // ⚠ required\n\t\t_open: false,\n\t\t_align: 'left',\n\t};\n\n\t@Watch('_label')\n\tpublic validateLabel(value?: LabelPropType): void {\n\t\tvalidateLabel(this, value, {\n\t\t\trequired: true,\n\t\t});\n\t}\n\n\t@Watch('_align')\n\tpublic validateAlign(value?: AlignPropType): void {\n\t\tvalidateAlign(this, value);\n\t}\n\n\t@Watch('_hasCloser')\n\tpublic validateHasCloser(value?: HasCloserPropType): void {\n\t\tvalidateHasCloser(this, value);\n\t}\n\n\t@Watch('_open')\n\tpublic validateOpen(value?: OpenPropType) {\n\t\tif (typeof value === 'boolean') {\n\t\t\tvalidateOpen(this, value);\n\n\t\t\tif (this.dialogElement) {\n\t\t\t\t// handle property changes but not the initial validateOpen call\n\t\t\t\tvoid this.openOrCloseBasedOnState();\n\t\t\t}\n\t\t}\n\t}\n\n\tprivate async openOrCloseBasedOnState() {\n\t\tif (this.state._open) {\n\t\t\tawait this.open();\n\t\t} else {\n\t\t\tawait this.close();\n\t\t}\n\t}\n\n\t@Watch('_on')\n\tpublic validateOn(value?: KoliBriModalEventCallbacks): void {\n\t\tif (typeof value === 'object' && value !== null) {\n\t\t\tconst callbacks: KoliBriModalEventCallbacks = {};\n\t\t\tif (typeof value.onClose === 'function') {\n\t\t\t\tcallbacks.onClose = value.onClose;\n\t\t\t}\n\t\t\tsetState<KoliBriModalEventCallbacks>(this, '_on', callbacks);\n\t\t}\n\t}\n\n\tprivate handleCloseDialog() {\n\t\tthis.dialogElement?.close();\n\t\tthis._on?.onClose?.();\n\t\tif (this.host) {\n\t\t\tdispatchDomEvent(this.host, KolEvent.close);\n\t\t}\n\t}\n\n\tprivate handleClose() {\n\t\tvoid (async () => {\n\t\t\tawait this.close();\n\t\t\tthis.handleCloseDialog();\n\t\t})();\n\t}\n\n\tprivate handleAnimationEnd(e: Event): void {\n\t\tconst animationEvent = e as AnimationEvent;\n\t\tif (animationEvent.animationName.includes('slideOut')) {\n\t\t\tthis.handleCloseDialog();\n\t\t}\n\t}\n\n\tpublic componentDidLoad(): void {\n\t\tthis.dialogElement?.addEventListener('animationend', this.handleAnimationEnd.bind(this));\n\t\tthis.dialogElement?.addEventListener('close', this.handleClose.bind(this));\n\t}\n\n\tpublic disconnectedCallback(): void {\n\t\tthis.dialogElement?.removeEventListener('animationend', this.handleAnimationEnd.bind(this));\n\t\tthis.dialogElement?.removeEventListener('close', this.handleClose.bind(this));\n\t}\n\n\tpublic componentWillLoad() {\n\t\tthis.validateLabel(this._label);\n\t\tthis.validateOpen(this._open);\n\t\tthis.validateAlign(this._align);\n\t\tthis.validateHasCloser(this._hasCloser);\n\t\tthis.validateOn(this._on);\n\t}\n}\n"],"mappings":"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","ignoreList":[]}
|
1
|
+
{"version":3,"names":["defaultStyleCss","KolDrawer","constructor","hostRef","this","getWrapperRef","el","dialogWrapperElement","getRef","dialogElement","setTimeout","openOrCloseBasedOnState","_hasCloser","state","_label","_open","_align","open","Object","assign","_a","showModal","close","wrapper","computedStyle","window","getComputedStyle","animationName","handleCloseDialog","renderDialogContent","align","h","KolCardWcTag","ref","class","clsx","_on","onClose","render","Host","key","validateLabel","value","required","validateAlign","validateHasCloser","validateOpen","validateOn","callbacks","setState","_c","_b","call","host","dispatchDomEvent","KolEvent","handleClose","handleAnimationEnd","e","animationEvent","includes","componentDidLoad","addEventListener","bind","disconnectedCallback","removeEventListener","componentWillLoad"],"sources":["src/components/drawer/style.scss?tag=kol-drawer&mode=default&encapsulation=shadow","src/components/drawer/shadow.tsx"],"sourcesContent":["@use '../../styles/global' as *;\n@use '../../styles/kol-card-mixin' as *;\n@use '../@shared/mixins' as *;\n@use '../tooltip/style.scss' as *;\n\n@include kol-card;\n\n@layer kol-component {\n\t.kol-drawer {\n\t\t$root: &;\n\n\t\t&__dialog {\n\t\t\tpadding: 0;\n\t\t\tborder: none;\n\t\t}\n\n\t\t&__wrapper {\n\t\t\tposition: fixed;\n\t\t\twidth: auto;\n\t\t\toverflow: auto;\n\n\t\t\t&--left {\n\t\t\t\ttop: 0;\n\t\t\t\tleft: 0;\n\t\t\t\theight: 100vh;\n\t\t\t\tmax-height: 100%;\n\n\t\t\t\t#{$root}__content {\n\t\t\t\t\theight: 100%;\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t&--right {\n\t\t\t\ttop: 0;\n\t\t\t\tright: 0;\n\t\t\t\theight: 100vh;\n\t\t\t\tmax-height: 100%;\n\n\t\t\t\t#{$root}__content {\n\t\t\t\t\theight: 100%;\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t&--top {\n\t\t\t\tleft: 0;\n\t\t\t\ttop: 0;\n\t\t\t\twidth: 100vw;\n\t\t\t\tmax-width: 100%;\n\n\t\t\t\t#{$root}__content {\n\t\t\t\t\twidth: 100%;\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t&--bottom {\n\t\t\t\tleft: 0;\n\t\t\t\tbottom: 0;\n\t\t\t\twidth: 100vw;\n\t\t\t\tmax-width: 100%;\n\n\t\t\t\t#{$root}__content {\n\t\t\t\t\twidth: 100%;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\t&__content {\n\t\t\tposition: relative;\n\t\t}\n\t}\n}\n","/* eslint-disable jsx-a11y/no-noninteractive-element-interactions */\nimport type { AlignPropType, DrawerAPI, DrawerStates, HasCloserPropType, KoliBriModalEventCallbacks, LabelPropType, OpenPropType } from '../../schema';\nimport { setState, validateAlign, validateHasCloser, validateLabel, validateOpen } from '../../schema';\nimport type { JSX } from '@stencil/core';\nimport { Component, Element, h, Host, Method, Prop, State, Watch } from '@stencil/core';\nimport { dispatchDomEvent, KolEvent } from '../../utils/events';\nimport clsx from 'clsx';\nimport { KolCardWcTag } from '../../core/component-names';\n\n/**\n * @slot - The Content of drawer.\n */\n@Component({\n\ttag: 'kol-drawer',\n\tstyleUrls: {\n\t\tdefault: './style.scss',\n\t},\n\tshadow: true,\n})\nexport class KolDrawer implements DrawerAPI {\n\t@Element() private readonly host?: HTMLKolDetailsElement;\n\tprivate dialogElement?: HTMLDialogElement;\n\tprivate dialogWrapperElement?: HTMLKolCardWcElement;\n\n\t@Method()\n\t// eslint-disable-next-line @typescript-eslint/require-await\n\tasync open() {\n\t\tthis.state = {\n\t\t\t...this.state,\n\t\t\t_open: true,\n\t\t};\n\t\tthis.dialogElement?.showModal();\n\t}\n\n\t@Method()\n\t// eslint-disable-next-line @typescript-eslint/require-await\n\tasync close() {\n\t\tthis.state = {\n\t\t\t...this.state,\n\t\t\t_open: false,\n\t\t};\n\t\tconst wrapper = this.dialogWrapperElement;\n\t\tif (!wrapper) return;\n\t\tconst computedStyle = window.getComputedStyle(wrapper);\n\t\tif (computedStyle.animationName === 'none') {\n\t\t\tthis.handleCloseDialog();\n\t\t}\n\t}\n\n\tprivate getWrapperRef = (el: HTMLKolCardWcElement | undefined) => (this.dialogWrapperElement = el as HTMLKolCardWcElement);\n\tprivate renderDialogContent() {\n\t\tconst align = this.state._align as string;\n\t\treturn (\n\t\t\t<KolCardWcTag\n\t\t\t\tref={this.getWrapperRef}\n\t\t\t\tclass={clsx(`kol-drawer__wrapper`, `kol-drawer__wrapper--${align}`, {\n\t\t\t\t\t'kol-drawer__wrapper--open': this.state._open,\n\t\t\t\t\t'kol-drawer__wrapper--is-closing': this.state._open === false,\n\t\t\t\t})}\n\t\t\t\t_label={this.state._label}\n\t\t\t\t_hasCloser={this.state._hasCloser}\n\t\t\t\t_on={{\n\t\t\t\t\tonClose: () => {\n\t\t\t\t\t\tvoid this.close();\n\t\t\t\t\t},\n\t\t\t\t}}\n\t\t\t>\n\t\t\t\t<div class=\"kol-drawer__content\">\n\t\t\t\t\t<slot />\n\t\t\t\t</div>\n\t\t\t</KolCardWcTag>\n\t\t);\n\t}\n\n\tprivate getRef = (el: HTMLDialogElement | undefined) => {\n\t\tthis.dialogElement = el as HTMLDialogElement;\n\t\tsetTimeout(() => {\n\t\t\tvoid this.openOrCloseBasedOnState(); // handle initial state as soon as element is ready\n\t\t});\n\t};\n\tpublic render(): JSX.Element {\n\t\treturn (\n\t\t\t<Host class=\"kol-drawer\">\n\t\t\t\t<dialog aria-label={this.state._label} class=\"kol-drawer__dialog\" ref={this.getRef}>\n\t\t\t\t\t{this.renderDialogContent()}\n\t\t\t\t</dialog>\n\t\t\t</Host>\n\t\t);\n\t}\n\n\t/**\n\t * Opens/expands the element when truthy, closes/collapses when falsy.\n\t */\n\t@Prop() public _open?: OpenPropType;\n\n\t/**\n\t * Defines the visual orientation of the component.\n\t */\n\t@Prop() public _align?: AlignPropType;\n\n\t/**\n\t * Defines whether the element can be closed.\n\t * @TODO: Change type back to `HasCloserPropType` after Stencil#4663 has been resolved.\n\t */\n\t@Prop() public _hasCloser?: boolean = false;\n\n\t/**\n\t * Defines the visible or semantic label of the component (e.g. aria-label, label, headline, caption, summary, etc.).\n\t */\n\t@Prop() public _label!: LabelPropType;\n\n\t/**\n\t * Specifies the EventCallback function to be called when the drawer is closing.\n\t */\n\t@Prop() public _on?: KoliBriModalEventCallbacks;\n\n\t@State() public state: DrawerStates = {\n\t\t_label: '', // ⚠ required\n\t\t_open: false,\n\t\t_align: 'left',\n\t};\n\n\t@Watch('_label')\n\tpublic validateLabel(value?: LabelPropType): void {\n\t\tvalidateLabel(this, value, {\n\t\t\trequired: true,\n\t\t});\n\t}\n\n\t@Watch('_align')\n\tpublic validateAlign(value?: AlignPropType): void {\n\t\tvalidateAlign(this, value);\n\t}\n\n\t@Watch('_hasCloser')\n\tpublic validateHasCloser(value?: HasCloserPropType): void {\n\t\tvalidateHasCloser(this, value);\n\t}\n\n\t@Watch('_open')\n\tpublic validateOpen(value?: OpenPropType) {\n\t\tif (typeof value === 'boolean') {\n\t\t\tvalidateOpen(this, value);\n\n\t\t\tif (this.dialogElement) {\n\t\t\t\t// handle property changes but not the initial validateOpen call\n\t\t\t\tvoid this.openOrCloseBasedOnState();\n\t\t\t}\n\t\t}\n\t}\n\n\tprivate async openOrCloseBasedOnState() {\n\t\tif (this.state._open) {\n\t\t\tawait this.open();\n\t\t} else {\n\t\t\tawait this.close();\n\t\t}\n\t}\n\n\t@Watch('_on')\n\tpublic validateOn(value?: KoliBriModalEventCallbacks): void {\n\t\tif (typeof value === 'object' && value !== null) {\n\t\t\tconst callbacks: KoliBriModalEventCallbacks = {};\n\t\t\tif (typeof value.onClose === 'function') {\n\t\t\t\tcallbacks.onClose = value.onClose;\n\t\t\t}\n\t\t\tsetState<KoliBriModalEventCallbacks>(this, '_on', callbacks);\n\t\t}\n\t}\n\n\tprivate handleCloseDialog() {\n\t\tthis.dialogElement?.close();\n\t\tthis._on?.onClose?.();\n\t\tif (this.host) {\n\t\t\tdispatchDomEvent(this.host, KolEvent.close);\n\t\t}\n\t}\n\n\tprivate handleClose() {\n\t\tvoid (async () => {\n\t\t\tawait this.close();\n\t\t\tthis.handleCloseDialog();\n\t\t})();\n\t}\n\n\tprivate handleAnimationEnd(e: Event): void {\n\t\tconst animationEvent = e as AnimationEvent;\n\t\tif (animationEvent.animationName.includes('slideOut')) {\n\t\t\tthis.handleCloseDialog();\n\t\t}\n\t}\n\n\tpublic componentDidLoad(): void {\n\t\tthis.dialogElement?.addEventListener('animationend', this.handleAnimationEnd.bind(this));\n\t\tthis.dialogElement?.addEventListener('close', this.handleClose.bind(this));\n\t}\n\n\tpublic disconnectedCallback(): void {\n\t\tthis.dialogElement?.removeEventListener('animationend', this.handleAnimationEnd.bind(this));\n\t\tthis.dialogElement?.removeEventListener('close', this.handleClose.bind(this));\n\t}\n\n\tpublic componentWillLoad() {\n\t\tthis.validateLabel(this._label);\n\t\tthis.validateOpen(this._open);\n\t\tthis.validateAlign(this._align);\n\t\tthis.validateHasCloser(this._hasCloser);\n\t\tthis.validateOn(this._on);\n\t}\n}\n"],"mappings":"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","ignoreList":[]}
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"kol-form.entry.esm.js","sources":["src/schema/props/error-list.ts","src/components/form/style.scss?tag=kol-form&mode=default&encapsulation=shadow","src/components/form/shadow.tsx"],"sourcesContent":["import type { Generic } from 'adopted-style-sheets';\nimport type { EventCallback } from '../types';\nimport { watchValidator } from '../utils';\n\n/* types */\nexport type ErrorListPropType = {\n\tmessage: string;\n\tselector: string | EventCallback<Event>;\n};\n\nexport type PropErrorList = {\n\terrorList: ErrorListPropType[];\n};\n\n/* validator */\nexport const validateErrorList = (component: Generic.Element.Component, value?: ErrorListPropType[]): void => {\n\twatchValidator(\n\t\tcomponent,\n\t\t'errorList',\n\t\t(value): boolean => Array.isArray(value) && value.find((v) => !(typeof v === 'string' || typeof v === 'function')) === undefined,\n\t\tnew Set(['string', 'function']),\n\t\tvalue,\n\t);\n};\n","@use '../@shared/mixins' as *;\n@use '../../styles/global' as *;\n@use '../host-display-block' as *;\n@use '../@shared/kol-link-mixin' as *;\n@use '../../styles/kol-alert-mixin' as *;\n\n@layer kol-component {\n\t@include kol-link-styles('kol-link');\n\t@include kol-alert;\n}\n","import type { JSX } from '@stencil/core';\nimport { Component, Element, h, Host, Method, Prop, State, Watch } from '@stencil/core';\nimport { validateErrorList, watchBoolean, watchString } from '../../schema';\n\nimport { translate } from '../../i18n';\n\nimport { KolLinkWcTag } from '../../core/component-names';\nimport KolAlertFc from '../../functional-components/Alert';\nimport type { ErrorListPropType, FormAPI, FormStates, KoliBriFormCallbacks, Stringified } from '../../schema';\nimport { dispatchDomEvent, KolEvent } from '../../utils/events';\n\n/**\n * @slot - Inhalt der Form.\n */\n@Component({\n\ttag: 'kol-form',\n\tstyleUrls: {\n\t\tdefault: './style.scss',\n\t},\n\tshadow: true,\n})\nexport class KolForm implements FormAPI {\n\t@Element() private readonly host?: HTMLKolTextareaElement;\n\terrorListBlock?: HTMLElement;\n\terrorListFirstLink?: HTMLElement;\n\tprivate readonly translateErrorListMessage = translate('kol-error-list-message');\n\tprivate readonly translateErrorList = translate('kol-error-list');\n\tprivate readonly translateFormDescription = translate('kol-form-description');\n\n\t/* Hint: This method may not be used at all while events are handled in form/controller#propagateSubmitEventToForm */\n\tprivate readonly onSubmit = (event: Event) => {\n\t\tevent.preventDefault();\n\n\t\tif (typeof this.state._on?.onSubmit === 'function') {\n\t\t\tthis.state._on?.onSubmit(event as SubmitEvent);\n\t\t}\n\t\tif (this.host) {\n\t\t\tdispatchDomEvent(this.host, KolEvent.submit);\n\t\t}\n\t};\n\n\tprivate readonly onReset = (event: Event) => {\n\t\tevent.preventDefault();\n\t\tif (typeof this.state._on?.onReset === 'function') {\n\t\t\tthis.state._on?.onReset(event);\n\t\t}\n\t\tif (this.host) {\n\t\t\tdispatchDomEvent(this.host, KolEvent.reset);\n\t\t}\n\t};\n\n\tprivate readonly handleLinkClick = (selector: string) => {\n\t\tconst targetElement = document.querySelector<HTMLElement>(selector);\n\t\tif (targetElement && typeof targetElement.focus === 'function') {\n\t\t\ttargetElement.scrollIntoView({ behavior: 'smooth' });\n\t\t\ttargetElement.focus();\n\t\t}\n\t};\n\n\tprivate readonly setBlockElement = (el?: HTMLElement) => (this.errorListBlock = el);\n\n\tprivate readonly setFirstLinkElement = (el?: HTMLElement) => (this.errorListFirstLink = el);\n\n\tprivate renderErrorList(errorList?: ErrorListPropType[]): JSX.Element {\n\t\treturn (\n\t\t\t<KolAlertFc class=\"kol-form__alert\" ref={this.setBlockElement} type=\"error\" variant=\"card\" label={this.translateErrorListMessage}>\n\t\t\t\t<nav aria-label={this.translateErrorList}>\n\t\t\t\t\t<ul>\n\t\t\t\t\t\t{errorList?.map((error, index) => (\n\t\t\t\t\t\t\t<li key={index}>\n\t\t\t\t\t\t\t\t<KolLinkWcTag\n\t\t\t\t\t\t\t\t\tclass=\"kol-form__link\"\n\t\t\t\t\t\t\t\t\t_href=\"\"\n\t\t\t\t\t\t\t\t\t_label={error.message}\n\t\t\t\t\t\t\t\t\t_on={{ onClick: typeof error.selector === 'string' ? () => this.handleLinkClick(String(error.selector)) : error.selector }}\n\t\t\t\t\t\t\t\t\tref={index === 0 ? this.setFirstLinkElement : undefined}\n\t\t\t\t\t\t\t\t/>\n\t\t\t\t\t\t\t</li>\n\t\t\t\t\t\t))}\n\t\t\t\t\t</ul>\n\t\t\t\t</nav>\n\t\t\t</KolAlertFc>\n\t\t);\n\t}\n\n\tprivate renderFormElement(): JSX.Element {\n\t\treturn (\n\t\t\t<form class=\"kol-form\" method=\"post\" onSubmit={this.onSubmit} onReset={this.onReset} noValidate>\n\t\t\t\t{this.state._requiredText === true ? (\n\t\t\t\t\t<p>\n\t\t\t\t\t\t<div class=\"kol-form__mandatory-fields-hint\">{this.translateFormDescription}</div>\n\t\t\t\t\t</p>\n\t\t\t\t) : typeof this.state._requiredText === 'string' && this.state._requiredText.length > 0 ? (\n\t\t\t\t\t<p>\n\t\t\t\t\t\t<div class=\"kol-form__mandatory-fields-hint\">{this.state._requiredText}</div>\n\t\t\t\t\t</p>\n\t\t\t\t) : null}\n\t\t\t\t<slot />\n\t\t\t</form>\n\t\t);\n\t}\n\n\tpublic render(): JSX.Element {\n\t\tconst hasErrorList = Array.isArray(this._errorList) && this._errorList.length > 0;\n\n\t\treturn (\n\t\t\t<Host>\n\t\t\t\t{hasErrorList && this.renderErrorList(this._errorList)}\n\t\t\t\t{this.renderFormElement()}\n\t\t\t</Host>\n\t\t);\n\t}\n\n\tprivate scrollToErrorList(): void {\n\t\tthis.errorListBlock?.scrollIntoView({\n\t\t\tbehavior: 'smooth',\n\t\t\tblock: 'start',\n\t\t});\n\t\tsetTimeout(() => {\n\t\t\tthis.errorListFirstLink?.querySelector('a')?.focus();\n\t\t}, 250);\n\t}\n\n\t@Method()\n\tasync focusErrorList(): Promise<void> {\n\t\tthis.scrollToErrorList();\n\t\treturn Promise.resolve();\n\t}\n\n\t/**\n\t * Gibt die EventCallback-Funktionen für die Form-Events an.\n\t */\n\t@Prop() public _on?: KoliBriFormCallbacks;\n\n\t/**\n\t * Defines whether the mandatory-fields-hint should be shown. A string overrides the default text.\n\t */\n\t@Prop() public _requiredText?: Stringified<boolean> = true;\n\t/**\n\t * A list of error objects that each describe an issue encountered in the form.\n\t * Each error object contains a message and a selector for identifying the form element related to the error.\n\t */\n\t@Prop() public _errorList?: ErrorListPropType[];\n\n\t@State() public state: FormStates = {};\n\n\t@Watch('_on')\n\tpublic validateOn(value?: KoliBriFormCallbacks): void {\n\t\tif (typeof value === 'object' && value !== null) {\n\t\t\tthis.state = {\n\t\t\t\t...this.state,\n\t\t\t\t_on: value,\n\t\t\t};\n\t\t}\n\t}\n\n\t@Watch('_requiredText')\n\tpublic validateRequiredText(value?: Stringified<boolean>): void {\n\t\tif (typeof value === 'boolean') {\n\t\t\twatchBoolean(this, '_requiredText', value);\n\t\t} else {\n\t\t\twatchString(this, '_requiredText', value);\n\t\t}\n\t}\n\n\t@Watch('_errorList')\n\tpublic validateErrorList(value?: ErrorListPropType[]): void {\n\t\tvalidateErrorList(this, value);\n\t}\n\n\tpublic componentWillLoad(): void {\n\t\tthis.validateOn(this._on);\n\t\tthis.validateRequiredText(this._requiredText);\n\t\tthis.validateErrorList(this._errorList);\n\t}\n}\n"],"names":[],"mappings":";;;;;;;;;;;;;;;AAeO,MAAM,iBAAiB,GAAG,CAAC,SAAoC,EAAE,KAA2B,KAAU;IAC5G,cAAc,CACb,SAAS,EACT,WAAW,EACX,CAAC,KAAK,KAAc,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,IAAI,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK,EAAE,OAAO,CAAC,KAAK,QAAQ,IAAI,OAAO,CAAC,KAAK,UAAU,CAAC,CAAC,KAAK,SAAS,EAChI,IAAI,GAAG,CAAC,CAAC,QAAQ,EAAE,UAAU,CAAC,CAAC,EAC/B,KAAK,CACL;AACF,CAAC;;ACvBD,MAAM,eAAe,GAAG,u9MAAu9M;;MCqBl+M,OAAO,GAAA,MAAA;AAPpB,IAAA,WAAA,CAAA,OAAA,EAAA;;AAWkB,QAAA,IAAA,CAAA,yBAAyB,GAAG,SAAS,CAAC,wBAAwB,CAAC;AAC/D,QAAA,IAAA,CAAA,kBAAkB,GAAG,SAAS,CAAC,gBAAgB,CAAC;AAChD,QAAA,IAAA,CAAA,wBAAwB,GAAG,SAAS,CAAC,sBAAsB,CAAC;AAG5D,QAAA,IAAA,CAAA,QAAQ,GAAG,CAAC,KAAY,KAAI;;YAC5C,KAAK,CAAC,cAAc,EAAE;AAEtB,YAAA,IAAI,QAAO,CAAA,EAAA,GAAA,IAAI,CAAC,KAAK,CAAC,GAAG,MAAA,IAAA,IAAA,EAAA,KAAA,MAAA,GAAA,MAAA,GAAA,EAAA,CAAE,QAAQ,CAAA,KAAK,UAAU,EAAE;AACnD,gBAAA,CAAA,EAAA,GAAA,IAAI,CAAC,KAAK,CAAC,GAAG,0CAAE,QAAQ,CAAC,KAAoB,CAAC;;AAE/C,YAAA,IAAI,IAAI,CAAC,IAAI,EAAE;gBACd,gBAAgB,CAAC,IAAI,CAAC,IAAI,EAAE,QAAQ,CAAC,MAAM,CAAC;;AAE9C,SAAC;AAEgB,QAAA,IAAA,CAAA,OAAO,GAAG,CAAC,KAAY,KAAI;;YAC3C,KAAK,CAAC,cAAc,EAAE;AACtB,YAAA,IAAI,QAAO,CAAA,EAAA,GAAA,IAAI,CAAC,KAAK,CAAC,GAAG,MAAA,IAAA,IAAA,EAAA,KAAA,MAAA,GAAA,MAAA,GAAA,EAAA,CAAE,OAAO,CAAA,KAAK,UAAU,EAAE;AAClD,gBAAA,CAAA,EAAA,GAAA,IAAI,CAAC,KAAK,CAAC,GAAG,0CAAE,OAAO,CAAC,KAAK,CAAC;;AAE/B,YAAA,IAAI,IAAI,CAAC,IAAI,EAAE;gBACd,gBAAgB,CAAC,IAAI,CAAC,IAAI,EAAE,QAAQ,CAAC,KAAK,CAAC;;AAE7C,SAAC;AAEgB,QAAA,IAAA,CAAA,eAAe,GAAG,CAAC,QAAgB,KAAI;YACvD,MAAM,aAAa,GAAG,QAAQ,CAAC,aAAa,CAAc,QAAQ,CAAC;YACnE,IAAI,aAAa,IAAI,OAAO,aAAa,CAAC,KAAK,KAAK,UAAU,EAAE;gBAC/D,aAAa,CAAC,cAAc,CAAC,EAAE,QAAQ,EAAE,QAAQ,EAAE,CAAC;gBACpD,aAAa,CAAC,KAAK,EAAE;;AAEvB,SAAC;AAEgB,QAAA,IAAA,CAAA,eAAe,GAAG,CAAC,EAAgB,MAAM,IAAI,CAAC,cAAc,GAAG,EAAE,CAAC;AAElE,QAAA,IAAA,CAAA,mBAAmB,GAAG,CAAC,EAAgB,MAAM,IAAI,CAAC,kBAAkB,GAAG,EAAE,CAAC;AA4E5E,QAAA,IAAa,CAAA,aAAA,GAA0B,IAAI;AAO1C,QAAA,IAAK,CAAA,KAAA,GAAe,EAAE;AA+BtC;AAhHQ,IAAA,eAAe,CAAC,SAA+B,EAAA;AACtD,QAAA,QACC,CAAC,CAAA,UAAU,EAAC,EAAA,KAAK,EAAC,iBAAiB,EAAC,GAAG,EAAE,IAAI,CAAC,eAAe,EAAE,IAAI,EAAC,OAAO,EAAC,OAAO,EAAC,MAAM,EAAC,KAAK,EAAE,IAAI,CAAC,yBAAyB,EAAA,EAC/H,CAAiB,CAAA,KAAA,EAAA,EAAA,YAAA,EAAA,IAAI,CAAC,kBAAkB,EAAA,EACvC,CAAA,CAAA,IAAA,EAAA,IAAA,EACE,SAAS,KAAT,IAAA,IAAA,SAAS,uBAAT,SAAS,CAAE,GAAG,CAAC,CAAC,KAAK,EAAE,KAAK,MAC5B,CAAI,CAAA,IAAA,EAAA,EAAA,GAAG,EAAE,KAAK,EAAA,EACb,CAAA,CAAC,YAAY,EAAA,EACZ,KAAK,EAAC,gBAAgB,EACtB,KAAK,EAAC,EAAE,EACR,MAAM,EAAE,KAAK,CAAC,OAAO,EACrB,GAAG,EAAE,EAAE,OAAO,EAAE,OAAO,KAAK,CAAC,QAAQ,KAAK,QAAQ,GAAG,MAAM,IAAI,CAAC,eAAe,CAAC,MAAM,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC,GAAG,KAAK,CAAC,QAAQ,EAAE,EAC1H,GAAG,EAAE,KAAK,KAAK,CAAC,GAAG,IAAI,CAAC,mBAAmB,GAAG,SAAS,EACtD,CAAA,CACE,CACL,CAAC,CACE,CACA,CACM;;IAIP,iBAAiB,GAAA;AACxB,QAAA,QACC,YAAM,KAAK,EAAC,UAAU,EAAC,MAAM,EAAC,MAAM,EAAC,QAAQ,EAAE,IAAI,CAAC,QAAQ,EAAE,OAAO,EAAE,IAAI,CAAC,OAAO,EAAE,UAAU,EAAA,IAAA,EAAA,EAC7F,IAAI,CAAC,KAAK,CAAC,aAAa,KAAK,IAAI,IACjC,CAAA,CAAA,GAAA,EAAA,IAAA,EACC,CAAA,CAAA,KAAA,EAAA,EAAK,KAAK,EAAC,iCAAiC,EAAA,EAAE,IAAI,CAAC,wBAAwB,CAAO,CAC/E,IACD,OAAO,IAAI,CAAC,KAAK,CAAC,aAAa,KAAK,QAAQ,IAAI,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,MAAM,GAAG,CAAC,IACtF,CAAA,CAAA,GAAA,EAAA,IAAA,EACC,CAAA,CAAA,KAAA,EAAA,EAAK,KAAK,EAAC,iCAAiC,EAAA,EAAE,IAAI,CAAC,KAAK,CAAC,aAAa,CAAO,CAC1E,IACD,IAAI,EACR,CAAQ,CAAA,MAAA,EAAA,IAAA,CAAA,CACF;;IAIF,MAAM,GAAA;AACZ,QAAA,MAAM,YAAY,GAAG,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,UAAU,CAAC,IAAI,IAAI,CAAC,UAAU,CAAC,MAAM,GAAG,CAAC;AAEjF,QAAA,QACC,EAAC,IAAI,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,EACH,YAAY,IAAI,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,UAAU,CAAC,EACrD,IAAI,CAAC,iBAAiB,EAAE,CACnB;;IAID,iBAAiB,GAAA;;QACxB,CAAA,EAAA,GAAA,IAAI,CAAC,cAAc,MAAA,IAAA,IAAA,EAAA,KAAA,MAAA,GAAA,MAAA,GAAA,EAAA,CAAE,cAAc,CAAC;AACnC,YAAA,QAAQ,EAAE,QAAQ;AAClB,YAAA,KAAK,EAAE,OAAO;AACd,SAAA,CAAC;QACF,UAAU,CAAC,MAAK;;YACf,CAAA,EAAA,GAAA,CAAA,EAAA,GAAA,IAAI,CAAC,kBAAkB,MAAE,IAAA,IAAA,EAAA,KAAA,MAAA,GAAA,MAAA,GAAA,EAAA,CAAA,aAAa,CAAC,GAAG,CAAC,MAAA,IAAA,IAAA,EAAA,KAAA,MAAA,GAAA,MAAA,GAAA,EAAA,CAAE,KAAK,EAAE;SACpD,EAAE,GAAG,CAAC;;AAIR,IAAA,MAAM,cAAc,GAAA;QACnB,IAAI,CAAC,iBAAiB,EAAE;AACxB,QAAA,OAAO,OAAO,CAAC,OAAO,EAAE;;AAqBlB,IAAA,UAAU,CAAC,KAA4B,EAAA;QAC7C,IAAI,OAAO,KAAK,KAAK,QAAQ,IAAI,KAAK,KAAK,IAAI,EAAE;YAChD,IAAI,CAAC,KAAK,GAAA,MAAA,CAAA,MAAA,CAAA,MAAA,CAAA,MAAA,CAAA,EAAA,EACN,IAAI,CAAC,KAAK,CAAA,EAAA,EACb,GAAG,EAAE,KAAK,EAAA,CACV;;;AAKI,IAAA,oBAAoB,CAAC,KAA4B,EAAA;AACvD,QAAA,IAAI,OAAO,KAAK,KAAK,SAAS,EAAE;AAC/B,YAAA,YAAY,CAAC,IAAI,EAAE,eAAe,EAAE,KAAK,CAAC;;aACpC;AACN,YAAA,WAAW,CAAC,IAAI,EAAE,eAAe,EAAE,KAAK,CAAC;;;AAKpC,IAAA,iBAAiB,CAAC,KAA2B,EAAA;AACnD,QAAA,iBAAiB,CAAC,IAAI,EAAE,KAAK,CAAC;;IAGxB,iBAAiB,GAAA;AACvB,QAAA,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,GAAG,CAAC;AACzB,QAAA,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,aAAa,CAAC;AAC7C,QAAA,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,UAAU,CAAC;;;;;;;;;;;;;;;"}
|