@public-ui/components 2.0.13 → 2.0.15
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 +145 -3
- package/dist/cjs/{InternalUnderlinedAccessKey-44f3fd5d.js → InternalUnderlinedAccessKey-a5b060e1.js} +1 -1
- package/dist/cjs/{InternalUnderlinedAccessKey-44f3fd5d.js.map → InternalUnderlinedAccessKey-a5b060e1.js.map} +1 -1
- package/dist/cjs/{align-floating-elements-907f2fa3.js → align-floating-elements-a4f32471.js} +1 -1
- package/dist/cjs/{align-floating-elements-907f2fa3.js.map → align-floating-elements-a4f32471.js.map} +1 -1
- package/dist/cjs/{app-globals-c3d85b0a.js → app-globals-08227ea9.js} +1 -1
- package/dist/cjs/{app-globals-c3d85b0a.js.map → app-globals-08227ea9.js.map} +1 -1
- package/dist/cjs/{associated.controller-44964fd5.js → associated.controller-0defb8ca.js} +1 -1
- package/dist/cjs/{associated.controller-44964fd5.js.map → associated.controller-0defb8ca.js.map} +1 -1
- package/dist/cjs/component-names-21d7915c.js +4 -0
- package/dist/cjs/component-names-21d7915c.js.map +1 -0
- package/dist/cjs/controller-2a04b820.js +4 -0
- package/dist/cjs/controller-2a04b820.js.map +1 -0
- package/dist/cjs/{controller-67d07d7c.js → controller-5d8d3f88.js} +1 -1
- package/dist/cjs/controller-5d8d3f88.js.map +1 -0
- package/dist/cjs/{controller-97d1ca95.js → controller-69d0b6e3.js} +1 -1
- package/dist/cjs/{controller-97d1ca95.js.map → controller-69d0b6e3.js.map} +1 -1
- package/dist/cjs/{controller-1ba9a551.js → controller-cb2152bf.js} +1 -1
- package/dist/cjs/{controller-1ba9a551.js.map → controller-cb2152bf.js.map} +1 -1
- package/dist/cjs/{controller-be4b3d70.js → controller-dc7f3a60.js} +1 -1
- package/dist/cjs/{controller-be4b3d70.js.map → controller-dc7f3a60.js.map} +1 -1
- package/dist/cjs/{controller-icon-49e7ba81.js → controller-icon-e9a7c0dd.js} +1 -1
- package/dist/cjs/{controller-icon-49e7ba81.js.map → controller-icon-e9a7c0dd.js.map} +1 -1
- package/dist/cjs/{dev.utils-18748d0d.js → dev.utils-1e67d391.js} +1 -1
- package/dist/cjs/{dev.utils-18748d0d.js.map → dev.utils-1e67d391.js.map} +1 -1
- package/dist/cjs/{devtools-f5b7dc5c.js → devtools-23724a90.js} +1 -1
- package/dist/cjs/{devtools-f5b7dc5c.js.map → devtools-23724a90.js.map} +1 -1
- package/dist/cjs/{form-field-msg-4194be2d.js → form-field-msg-2e2600d7.js} +1 -1
- package/dist/cjs/{form-field-msg-4194be2d.js.map → form-field-msg-2e2600d7.js.map} +1 -1
- package/dist/cjs/i18n-ac90ee57.js +4 -0
- package/dist/cjs/i18n-ac90ee57.js.map +1 -0
- package/dist/cjs/i18n-db3c5520.js +4 -0
- package/dist/cjs/i18n-db3c5520.js.map +1 -0
- package/dist/cjs/index-26a11fc3.js +4 -0
- package/dist/cjs/index-26a11fc3.js.map +1 -0
- package/dist/cjs/{index-d33b9844.js → index-443b07fc.js} +1 -1
- package/dist/cjs/{index-d33b9844.js.map → index-443b07fc.js.map} +1 -1
- package/dist/cjs/index-fb60429b.js +4 -0
- package/dist/cjs/index-fb60429b.js.map +1 -0
- package/dist/cjs/index.cjs.js +1 -1
- 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-accordion.cjs.entry.js +1 -1
- package/dist/cjs/kol-accordion.cjs.entry.js.map +1 -1
- package/dist/cjs/kol-alert-wc.cjs.entry.js +1 -1
- 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-avatar-wc.cjs.entry.js +1 -1
- 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-badge.cjs.entry.js +1 -1
- package/dist/cjs/kol-badge.cjs.entry.js.map +1 -1
- 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-button-group-wc.cjs.entry.js +1 -1
- package/dist/cjs/kol-button-group.cjs.entry.js +1 -1
- package/dist/cjs/kol-button-group.cjs.entry.js.map +1 -1
- 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-wc.cjs.entry.js +1 -1
- 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-card.cjs.entry.js +1 -1
- package/dist/cjs/kol-card.cjs.entry.js.map +1 -1
- 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-form.cjs.entry.js +1 -1
- package/dist/cjs/kol-heading-wc.cjs.entry.js +1 -1
- 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-icon.cjs.entry.js +1 -1
- package/dist/cjs/kol-icon.cjs.entry.js.map +1 -1
- 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-indented-text.cjs.entry.js +1 -1
- package/dist/cjs/kol-indented-text.cjs.entry.js.map +1 -1
- 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-color.cjs.entry.js +1 -1
- package/dist/cjs/kol-input-color.cjs.entry.js.map +1 -1
- 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-email.cjs.entry.js +1 -1
- package/dist/cjs/kol-input-email.cjs.entry.js.map +1 -1
- 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-number.cjs.entry.js +1 -1
- package/dist/cjs/kol-input-number.cjs.entry.js.map +1 -1
- 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-radio.cjs.entry.js +1 -1
- package/dist/cjs/kol-input-radio.cjs.entry.js.map +1 -1
- 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-text.cjs.entry.js +1 -1
- package/dist/cjs/kol-input-text.cjs.entry.js.map +1 -1
- package/dist/cjs/kol-input.cjs.entry.js +1 -1
- package/dist/cjs/kol-input.cjs.entry.js.map +1 -1
- 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-link-button.cjs.entry.js +1 -1
- package/dist/cjs/kol-link-button.cjs.entry.js.map +1 -1
- package/dist/cjs/kol-link-group.cjs.entry.js +1 -1
- package/dist/cjs/kol-link-group.cjs.entry.js.map +1 -1
- package/dist/cjs/kol-link-wc.cjs.entry.js +1 -1
- 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-logo.cjs.entry.js +1 -1
- package/dist/cjs/kol-logo.cjs.entry.js.map +1 -1
- 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-nav.cjs.entry.js +1 -1
- package/dist/cjs/kol-nav.cjs.entry.js.map +1 -1
- 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-popover-wc.cjs.entry.js +1 -1
- package/dist/cjs/kol-popover-wc.cjs.entry.js.map +1 -1
- 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-quote.cjs.entry.js +1 -1
- package/dist/cjs/kol-quote.cjs.entry.js.map +1 -1
- 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-skip-nav.cjs.entry.js +1 -1
- package/dist/cjs/kol-skip-nav.cjs.entry.js.map +1 -1
- package/dist/cjs/kol-span-wc.cjs.entry.js +1 -1
- package/dist/cjs/kol-span.cjs.entry.js +1 -1
- package/dist/cjs/kol-span.cjs.entry.js.map +1 -1
- 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-split-button.cjs.entry.js +1 -1
- package/dist/cjs/kol-split-button.cjs.entry.js.map +1 -1
- package/dist/cjs/kol-symbol.cjs.entry.js +1 -1
- package/dist/cjs/kol-table-stateful.cjs.entry.js +4 -0
- package/dist/cjs/kol-table-stateful.cjs.entry.js.map +1 -0
- package/dist/cjs/kol-table-stateless-wc.cjs.entry.js +4 -0
- package/dist/cjs/kol-table-stateless-wc.cjs.entry.js.map +1 -0
- package/dist/cjs/kol-table-stateless.cjs.entry.js +4 -0
- package/dist/cjs/kol-table-stateless.cjs.entry.js.map +1 -0
- package/dist/cjs/kol-table.cjs.entry.js +1 -1
- package/dist/cjs/kol-table.cjs.entry.js.map +1 -1
- 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-textarea.cjs.entry.js +1 -1
- package/dist/cjs/kol-textarea.cjs.entry.js.map +1 -1
- 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-tooltip-wc.cjs.entry.js +1 -1
- package/dist/cjs/kol-tooltip-wc.cjs.entry.js.map +1 -1
- package/dist/cjs/kol-tree-item-wc.cjs.entry.js +1 -1
- 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-wc.cjs.entry.js +1 -1
- 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-version.cjs.entry.js +1 -1
- package/dist/cjs/kol-version.cjs.entry.js.map +1 -1
- package/dist/cjs/kolibri.cjs.js +1 -1
- package/dist/cjs/kolibri.cjs.js.map +1 -1
- package/dist/cjs/loader.cjs.js +1 -1
- package/dist/cjs/toaster-7cd54f74.js +4 -0
- package/dist/cjs/toaster-7cd54f74.js.map +1 -0
- package/dist/cjs/{toaster-693061df.js → toaster-e899a47f.js} +1 -1
- package/dist/cjs/{toaster-693061df.js.map → toaster-e899a47f.js.map} +1 -1
- package/dist/cjs/{validation-cc617690.js → validation-89c93141.js} +1 -1
- package/dist/cjs/{validation-cc617690.js.map → validation-89c93141.js.map} +1 -1
- package/dist/cjs/{validation-a25ab901.js → validation-db50789a.js} +1 -1
- package/dist/cjs/{validation-a25ab901.js.map → validation-db50789a.js.map} +1 -1
- package/dist/components/component-names.js +1 -1
- package/dist/components/component-names.js.map +1 -1
- package/dist/components/controller2.js +1 -1
- package/dist/components/controller2.js.map +1 -1
- package/dist/components/controller3.js.map +1 -1
- package/dist/components/controller4.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/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/index.js +1 -1
- package/dist/components/index.js.map +1 -1
- package/dist/components/index2.js +1 -1
- package/dist/components/index2.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.js +1 -1
- package/dist/components/kol-alert.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-group.js +1 -1
- package/dist/components/kol-button-group.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.js +1 -1
- package/dist/components/kol-button.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-details.js +1 -1
- package/dist/components/kol-details.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-indented-text.js +1 -1
- package/dist/components/kol-indented-text.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-input.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-group.js +1 -1
- package/dist/components/kol-link-group.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-logo.js +1 -1
- package/dist/components/kol-logo.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.js +1 -1
- package/dist/components/kol-pagination.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-skip-nav.js +1 -1
- package/dist/components/kol-skip-nav.js.map +1 -1
- package/dist/components/kol-span.js +1 -1
- package/dist/components/kol-span.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-stateful.d.ts +11 -0
- package/dist/components/kol-table-stateful.js +4 -0
- package/dist/components/kol-table-stateful.js.map +1 -0
- package/dist/components/kol-table-stateless-wc.d.ts +11 -0
- package/dist/components/kol-table-stateless-wc.js +4 -0
- package/dist/components/kol-table-stateless-wc.js.map +1 -0
- package/dist/components/kol-table-stateless.d.ts +11 -0
- package/dist/components/kol-table-stateless.js +4 -0
- package/dist/components/kol-table-stateless.js.map +1 -0
- package/dist/components/kol-table.js +1 -1
- package/dist/components/kol-table.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-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.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.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/esm/{InternalUnderlinedAccessKey-864ae1a6.js → InternalUnderlinedAccessKey-7fd49f04.js} +1 -1
- package/dist/esm/{InternalUnderlinedAccessKey-864ae1a6.js.map → InternalUnderlinedAccessKey-7fd49f04.js.map} +1 -1
- package/dist/esm/{align-floating-elements-a21bf44f.js → align-floating-elements-f7d913f4.js} +1 -1
- package/dist/esm/{align-floating-elements-a21bf44f.js.map → align-floating-elements-f7d913f4.js.map} +1 -1
- package/dist/esm/{app-globals-d172fbc3.js → app-globals-a87698fc.js} +1 -1
- package/dist/esm/{app-globals-d172fbc3.js.map → app-globals-a87698fc.js.map} +1 -1
- package/dist/esm/{associated.controller-c5369a0d.js → associated.controller-47f177a8.js} +1 -1
- package/dist/esm/{associated.controller-c5369a0d.js.map → associated.controller-47f177a8.js.map} +1 -1
- package/dist/esm/component-names-ed22f86e.js +4 -0
- package/dist/esm/component-names-ed22f86e.js.map +1 -0
- package/dist/esm/{controller-13634753.js → controller-06b047bd.js} +1 -1
- package/dist/esm/{controller-13634753.js.map → controller-06b047bd.js.map} +1 -1
- package/dist/esm/{controller-853ed72e.js → controller-09ce054b.js} +1 -1
- package/dist/esm/{controller-853ed72e.js.map → controller-09ce054b.js.map} +1 -1
- package/dist/esm/{controller-3c948f83.js → controller-5207185b.js} +1 -1
- package/dist/esm/controller-5207185b.js.map +1 -0
- package/dist/esm/controller-603b7d2b.js +4 -0
- package/dist/esm/controller-603b7d2b.js.map +1 -0
- package/dist/esm/{controller-77441244.js → controller-9c8cf4ce.js} +1 -1
- package/dist/esm/{controller-77441244.js.map → controller-9c8cf4ce.js.map} +1 -1
- package/dist/esm/{controller-icon-28a0edb3.js → controller-icon-23f9943c.js} +1 -1
- package/dist/esm/{controller-icon-28a0edb3.js.map → controller-icon-23f9943c.js.map} +1 -1
- package/dist/esm/{dev.utils-6d9b92c3.js → dev.utils-ba0ad340.js} +1 -1
- package/dist/esm/{dev.utils-6d9b92c3.js.map → dev.utils-ba0ad340.js.map} +1 -1
- package/dist/esm/{devtools-d4cd0545.js → devtools-8b54d55c.js} +1 -1
- package/dist/esm/{devtools-d4cd0545.js.map → devtools-8b54d55c.js.map} +1 -1
- package/dist/esm/{form-field-msg-660c0262.js → form-field-msg-244f6083.js} +1 -1
- package/dist/esm/{form-field-msg-660c0262.js.map → form-field-msg-244f6083.js.map} +1 -1
- package/dist/esm/i18n-0c047df5.js +4 -0
- package/dist/esm/i18n-0c047df5.js.map +1 -0
- package/dist/esm/i18n-7bf2bd6f.js +4 -0
- package/dist/esm/i18n-7bf2bd6f.js.map +1 -0
- package/dist/esm/index-3fbcceca.js +4 -0
- package/dist/esm/index-3fbcceca.js.map +1 -0
- package/dist/esm/index-44da6e7f.js +4 -0
- package/dist/esm/index-44da6e7f.js.map +1 -0
- package/dist/esm/{index-fff5a4e2.js → index-e9e31210.js} +1 -1
- package/dist/esm/{index-fff5a4e2.js.map → index-e9e31210.js.map} +1 -1
- package/dist/esm/index.js +1 -1
- 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.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.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-group-wc.entry.js +1 -1
- package/dist/esm/kol-button-group.entry.js +1 -1
- package/dist/esm/kol-button-group.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.entry.js +1 -1
- package/dist/esm/kol-button.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-details.entry.js +1 -1
- package/dist/esm/kol-details.entry.js.map +1 -1
- package/dist/esm/kol-form.entry.js +1 -1
- package/dist/esm/kol-heading-wc.entry.js +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-indented-text.entry.js +1 -1
- package/dist/esm/kol-indented-text.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-input.entry.js +1 -1
- package/dist/esm/kol-input.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-group.entry.js +1 -1
- package/dist/esm/kol-link-group.entry.js.map +1 -1
- package/dist/esm/kol-link-wc.entry.js +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-logo.entry.js +1 -1
- package/dist/esm/kol-logo.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.entry.js +1 -1
- package/dist/esm/kol-pagination.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-skip-nav.entry.js +1 -1
- package/dist/esm/kol-skip-nav.entry.js.map +1 -1
- package/dist/esm/kol-span-wc.entry.js +1 -1
- package/dist/esm/kol-span.entry.js +1 -1
- package/dist/esm/kol-span.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-symbol.entry.js +1 -1
- package/dist/esm/kol-table-stateful.entry.js +4 -0
- package/dist/esm/kol-table-stateful.entry.js.map +1 -0
- package/dist/esm/kol-table-stateless-wc.entry.js +4 -0
- package/dist/esm/kol-table-stateless-wc.entry.js.map +1 -0
- package/dist/esm/kol-table-stateless.entry.js +4 -0
- package/dist/esm/kol-table-stateless.entry.js.map +1 -0
- package/dist/esm/kol-table.entry.js +1 -1
- package/dist/esm/kol-table.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-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.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.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/loader.js +1 -1
- package/dist/esm/toaster-12097d83.js +4 -0
- package/dist/esm/toaster-12097d83.js.map +1 -0
- package/dist/esm/{toaster-1e7f1deb.js → toaster-4eb33f18.js} +1 -1
- package/dist/esm/{toaster-1e7f1deb.js.map → toaster-4eb33f18.js.map} +1 -1
- package/dist/esm/{validation-ffb20598.js → validation-61bf6538.js} +1 -1
- package/dist/esm/{validation-ffb20598.js.map → validation-61bf6538.js.map} +1 -1
- package/dist/esm/{validation-ed139130.js → validation-daa38230.js} +1 -1
- package/dist/esm/{validation-ed139130.js.map → validation-daa38230.js.map} +1 -1
- package/dist/kolibri/InternalUnderlinedAccessKey-7fd49f04.js +4 -0
- package/dist/kolibri/{align-floating-elements-a21bf44f.js → align-floating-elements-f7d913f4.js} +1 -1
- package/dist/kolibri/app-globals-a87698fc.js +4 -0
- package/dist/kolibri/{associated.controller-c5369a0d.js → associated.controller-47f177a8.js} +1 -1
- package/dist/kolibri/component-names-ed22f86e.js +4 -0
- package/dist/kolibri/component-names-ed22f86e.js.map +1 -0
- package/dist/kolibri/controller-06b047bd.js +4 -0
- package/dist/kolibri/{controller-853ed72e.js → controller-09ce054b.js} +1 -1
- package/dist/kolibri/{controller-3c948f83.js → controller-5207185b.js} +1 -1
- package/dist/kolibri/controller-5207185b.js.map +1 -0
- package/dist/kolibri/controller-603b7d2b.js +4 -0
- package/dist/kolibri/controller-603b7d2b.js.map +1 -0
- package/dist/kolibri/{controller-77441244.js → controller-9c8cf4ce.js} +1 -1
- package/dist/kolibri/controller-9c8cf4ce.js.map +1 -0
- package/dist/kolibri/{controller-icon-28a0edb3.js → controller-icon-23f9943c.js} +1 -1
- package/dist/kolibri/{dev.utils-6d9b92c3.js → dev.utils-ba0ad340.js} +1 -1
- package/dist/kolibri/{dev.utils-6d9b92c3.js.map → dev.utils-ba0ad340.js.map} +1 -1
- package/dist/kolibri/{devtools-d4cd0545.js → devtools-8b54d55c.js} +1 -1
- package/dist/kolibri/form-field-msg-244f6083.js +4 -0
- package/dist/kolibri/i18n-0c047df5.js +4 -0
- package/dist/kolibri/i18n-0c047df5.js.map +1 -0
- package/dist/kolibri/i18n-7bf2bd6f.js +4 -0
- package/dist/kolibri/i18n-7bf2bd6f.js.map +1 -0
- package/dist/kolibri/index-3fbcceca.js +5 -0
- package/dist/kolibri/index-3fbcceca.js.map +1 -0
- package/dist/kolibri/{index-fbc0a5be.js → index-44da6e7f.js} +1 -1
- package/dist/kolibri/index-44da6e7f.js.map +1 -0
- package/dist/kolibri/{index-fff5a4e2.js → index-e9e31210.js} +1 -1
- package/dist/kolibri/index.esm.js +1 -1
- 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.js +1 -1
- package/dist/kolibri/kol-accordion.entry.js.map +1 -1
- package/dist/kolibri/kol-alert-wc.entry.js +1 -1
- 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.js +1 -1
- 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.js +1 -1
- package/dist/kolibri/kol-badge.entry.js.map +1 -1
- package/dist/kolibri/kol-breadcrumb.entry.js +1 -1
- package/dist/kolibri/kol-breadcrumb.entry.js.map +1 -1
- package/dist/kolibri/kol-button-group-wc.entry.js +1 -1
- package/dist/kolibri/kol-button-group.entry.js +1 -1
- package/dist/kolibri/kol-button-group.entry.js.map +1 -1
- 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.js +1 -1
- package/dist/kolibri/kol-button.entry.js +1 -1
- package/dist/kolibri/kol-button.entry.js.map +1 -1
- package/dist/kolibri/kol-card.entry.js +1 -1
- package/dist/kolibri/kol-card.entry.js.map +1 -1
- package/dist/kolibri/kol-details.entry.js +1 -1
- package/dist/kolibri/kol-details.entry.js.map +1 -1
- package/dist/kolibri/kol-form.entry.js +1 -1
- package/dist/kolibri/kol-heading-wc.entry.js +1 -1
- 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.js +1 -1
- package/dist/kolibri/kol-icon.entry.js.map +1 -1
- package/dist/kolibri/kol-image.entry.js +1 -1
- package/dist/kolibri/kol-image.entry.js.map +1 -1
- package/dist/kolibri/kol-indented-text.entry.js +1 -1
- package/dist/kolibri/kol-indented-text.entry.js.map +1 -1
- 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.js +1 -1
- package/dist/kolibri/kol-input-color.entry.js.map +1 -1
- 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.js +1 -1
- package/dist/kolibri/kol-input-email.entry.js.map +1 -1
- 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.js +1 -1
- package/dist/kolibri/kol-input-number.entry.js.map +1 -1
- 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.js +1 -1
- package/dist/kolibri/kol-input-radio.entry.js.map +1 -1
- 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.js +1 -1
- package/dist/kolibri/kol-input-text.entry.js.map +1 -1
- package/dist/kolibri/kol-input.entry.js +1 -1
- package/dist/kolibri/kol-input.entry.js.map +1 -1
- 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.js +1 -1
- package/dist/kolibri/kol-link-button.entry.js.map +1 -1
- package/dist/kolibri/kol-link-group.entry.js +1 -1
- package/dist/kolibri/kol-link-group.entry.js.map +1 -1
- package/dist/kolibri/kol-link-wc.entry.js +1 -1
- package/dist/kolibri/kol-link.entry.js +1 -1
- package/dist/kolibri/kol-link.entry.js.map +1 -1
- package/dist/kolibri/kol-logo.entry.js +1 -1
- package/dist/kolibri/kol-logo.entry.js.map +1 -1
- 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.js +1 -1
- package/dist/kolibri/kol-nav.entry.js.map +1 -1
- package/dist/kolibri/kol-pagination.entry.js +1 -1
- package/dist/kolibri/kol-pagination.entry.js.map +1 -1
- 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.js +1 -1
- package/dist/kolibri/kol-progress.entry.js.map +1 -1
- 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.js +1 -1
- package/dist/kolibri/kol-select.entry.js.map +1 -1
- 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-span-wc.entry.js +1 -1
- package/dist/kolibri/kol-span.entry.js +1 -1
- package/dist/kolibri/kol-span.entry.js.map +1 -1
- 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.js +1 -1
- package/dist/kolibri/kol-split-button.entry.js.map +1 -1
- package/dist/kolibri/kol-symbol.entry.js +1 -1
- package/dist/kolibri/kol-table-stateful.entry.js +4 -0
- package/dist/kolibri/kol-table-stateful.entry.js.map +1 -0
- package/dist/kolibri/kol-table-stateless-wc.entry.js +4 -0
- package/dist/kolibri/kol-table-stateless-wc.entry.js.map +1 -0
- package/dist/kolibri/kol-table-stateless.entry.js +4 -0
- package/dist/kolibri/kol-table-stateless.entry.js.map +1 -0
- package/dist/kolibri/kol-table.entry.js +1 -1
- package/dist/kolibri/kol-table.entry.js.map +1 -1
- 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.js +1 -1
- package/dist/kolibri/kol-textarea.entry.js.map +1 -1
- 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-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.js +1 -1
- 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.js +1 -1
- 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.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/toaster-12097d83.js +4 -0
- package/dist/kolibri/toaster-12097d83.js.map +1 -0
- package/dist/kolibri/toaster-4eb33f18.js +4 -0
- package/dist/kolibri/{validation-ffb20598.js → validation-61bf6538.js} +1 -1
- package/dist/kolibri/{validation-ed139130.js → validation-daa38230.js} +1 -1
- package/dist/types/components/@deprecated/input/controller.d.ts +2 -1
- package/dist/types/components/input/test/html.mock.d.ts +2 -0
- package/dist/types/components/input-checkbox/test/html.mock.d.ts +2 -0
- package/dist/types/components/input-color/test/html.mock.d.ts +2 -0
- package/dist/types/components/input-date/test/html.mock.d.ts +2 -0
- package/dist/types/components/input-email/test/html.mock.d.ts +2 -0
- package/dist/types/components/input-file/test/html.mock.d.ts +2 -0
- package/dist/types/components/input-number/test/html.mock.d.ts +2 -0
- package/dist/types/components/input-password/test/html.mock.d.ts +2 -0
- package/dist/types/components/input-radio/component.d.ts +1 -0
- package/dist/types/components/input-radio/controller.d.ts +2 -2
- package/dist/types/components/input-radio/test/html.mock.d.ts +2 -0
- package/dist/types/components/input-range/test/html.mock.d.ts +2 -0
- package/dist/types/components/input-text/controller.d.ts +2 -2
- package/dist/types/components/input-text/test/html.mock.d.ts +2 -0
- package/dist/types/components/table/component.d.ts +2 -43
- package/dist/types/components/table-stateful/component.d.ts +39 -0
- package/dist/types/components/table-stateless/component.d.ts +38 -0
- package/dist/types/components/table-stateless/shadow.d.ts +11 -0
- package/dist/types/components/tabs/component.d.ts +0 -1
- package/dist/types/components/toaster/InternalToast.d.ts +4 -3
- package/dist/types/components/toaster/component.d.ts +2 -0
- package/dist/types/components.d.ts +213 -2
- package/dist/types/core/component-names.d.ts +9 -6
- package/dist/types/core/i18n.d.ts +7 -12
- package/dist/types/index.d.ts +5 -5
- package/dist/types/locales/de.d.ts +2 -0
- package/dist/types/locales/en.d.ts +2 -0
- package/doc/table-stateful.md +200 -0
- package/doc/table-stateless.md +57 -0
- package/doc/table.md +9 -1
- package/doc/toaster.md +3 -3
- package/package.json +1 -1
- package/vscode-custom-data.json +111 -1
- package/dist/cjs/component-names-4cf3e7f5.js +0 -4
- package/dist/cjs/component-names-4cf3e7f5.js.map +0 -1
- package/dist/cjs/controller-67d07d7c.js.map +0 -1
- package/dist/cjs/controller-b02ed1e6.js +0 -4
- package/dist/cjs/controller-b02ed1e6.js.map +0 -1
- package/dist/cjs/i18n-7971042d.js +0 -4
- package/dist/cjs/i18n-7971042d.js.map +0 -1
- package/dist/cjs/i18n-c3fa5bd7.js +0 -4
- package/dist/cjs/i18n-c3fa5bd7.js.map +0 -1
- package/dist/cjs/index-6a8528c2.js +0 -4
- package/dist/cjs/index-6a8528c2.js.map +0 -1
- package/dist/cjs/index-97424b25.js +0 -4
- package/dist/cjs/index-97424b25.js.map +0 -1
- package/dist/cjs/toaster-62a35c5f.js +0 -4
- package/dist/cjs/toaster-62a35c5f.js.map +0 -1
- package/dist/esm/component-names-61247f2f.js +0 -4
- package/dist/esm/component-names-61247f2f.js.map +0 -1
- package/dist/esm/controller-3c948f83.js.map +0 -1
- package/dist/esm/controller-f47b7bfc.js +0 -4
- package/dist/esm/controller-f47b7bfc.js.map +0 -1
- package/dist/esm/i18n-1e6a70ea.js +0 -4
- package/dist/esm/i18n-1e6a70ea.js.map +0 -1
- package/dist/esm/i18n-fddf0324.js +0 -4
- package/dist/esm/i18n-fddf0324.js.map +0 -1
- package/dist/esm/index-59e9528b.js +0 -4
- package/dist/esm/index-59e9528b.js.map +0 -1
- package/dist/esm/index-fbc0a5be.js +0 -4
- package/dist/esm/index-fbc0a5be.js.map +0 -1
- package/dist/esm/toaster-98560ca8.js +0 -4
- package/dist/esm/toaster-98560ca8.js.map +0 -1
- package/dist/kolibri/InternalUnderlinedAccessKey-864ae1a6.js +0 -4
- package/dist/kolibri/app-globals-d172fbc3.js +0 -4
- package/dist/kolibri/component-names-61247f2f.js +0 -4
- package/dist/kolibri/component-names-61247f2f.js.map +0 -1
- package/dist/kolibri/controller-13634753.js +0 -4
- package/dist/kolibri/controller-3c948f83.js.map +0 -1
- package/dist/kolibri/controller-77441244.js.map +0 -1
- package/dist/kolibri/controller-f47b7bfc.js +0 -4
- package/dist/kolibri/controller-f47b7bfc.js.map +0 -1
- package/dist/kolibri/form-field-msg-660c0262.js +0 -4
- package/dist/kolibri/i18n-1e6a70ea.js +0 -4
- package/dist/kolibri/i18n-1e6a70ea.js.map +0 -1
- package/dist/kolibri/i18n-fddf0324.js +0 -4
- package/dist/kolibri/i18n-fddf0324.js.map +0 -1
- package/dist/kolibri/index-59e9528b.js +0 -5
- package/dist/kolibri/index-59e9528b.js.map +0 -1
- package/dist/kolibri/index-fbc0a5be.js.map +0 -1
- package/dist/kolibri/toaster-1e7f1deb.js +0 -4
- package/dist/kolibri/toaster-98560ca8.js +0 -4
- package/dist/kolibri/toaster-98560ca8.js.map +0 -1
- /package/dist/kolibri/{InternalUnderlinedAccessKey-864ae1a6.js.map → InternalUnderlinedAccessKey-7fd49f04.js.map} +0 -0
- /package/dist/kolibri/{align-floating-elements-a21bf44f.js.map → align-floating-elements-f7d913f4.js.map} +0 -0
- /package/dist/kolibri/{app-globals-d172fbc3.js.map → app-globals-a87698fc.js.map} +0 -0
- /package/dist/kolibri/{associated.controller-c5369a0d.js.map → associated.controller-47f177a8.js.map} +0 -0
- /package/dist/kolibri/{controller-13634753.js.map → controller-06b047bd.js.map} +0 -0
- /package/dist/kolibri/{controller-853ed72e.js.map → controller-09ce054b.js.map} +0 -0
- /package/dist/kolibri/{controller-icon-28a0edb3.js.map → controller-icon-23f9943c.js.map} +0 -0
- /package/dist/kolibri/{devtools-d4cd0545.js.map → devtools-8b54d55c.js.map} +0 -0
- /package/dist/kolibri/{form-field-msg-660c0262.js.map → form-field-msg-244f6083.js.map} +0 -0
- /package/dist/kolibri/{index-fff5a4e2.js.map → index-e9e31210.js.map} +0 -0
- /package/dist/kolibri/{toaster-1e7f1deb.js.map → toaster-4eb33f18.js.map} +0 -0
- /package/dist/kolibri/{validation-ffb20598.js.map → validation-61bf6538.js.map} +0 -0
- /package/dist/kolibri/{validation-ed139130.js.map → validation-daa38230.js.map} +0 -0
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"names":["defaultStyleCss","KolSpanDefaultStyle0","KolSpan","render","h","KolSpanWcTag","key","_icons","this","_hideLabel","_label","_accessKey","class","name","slot"],"sources":["src/components/span/style.scss?tag=kol-span&mode=default&encapsulation=shadow","src/components/span/shadow.tsx"],"sourcesContent":["@import '../style';\n","import type { AccessKeyPropType, KoliBriIconsProp, LabelWithExpertSlotPropType, SpanProps, Stringified } from '@public-ui/schema';\nimport type { JSX } from '@stencil/core';\nimport { Component, h, Prop } from '@stencil/core';\nimport { KolSpanWcTag } from '../../core/component-names';\n\n@Component({\n\ttag: 'kol-span',\n\tstyleUrls: {\n\t\tdefault: './style.scss',\n\t},\n\tshadow: true,\n})\nexport class KolSpan implements SpanProps {\n\tpublic render(): JSX.Element {\n\t\treturn (\n\t\t\t<KolSpanWcTag _icons={this._icons} _hideLabel={this._hideLabel} _label={this._label} _accessKey={this._accessKey} class=\"kol-span\">\n\t\t\t\t<slot name=\"expert\" slot=\"expert\"></slot>\n\t\t\t</KolSpanWcTag>\n\t\t);\n\t}\n\n\t/**\n\t * Defines the elements access key.\n\t */\n\t@Prop() public _accessKey?: AccessKeyPropType;\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 g classnames (e.g. `_icons=\"fa-solid fa-user\"`).\n\t */\n\t@Prop() public _icons?: Stringified<KoliBriIconsProp>;\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"],"mappings":";;;iGAAA,MAAMA,EAAkB
|
1
|
+
{"version":3,"names":["defaultStyleCss","KolSpanDefaultStyle0","KolSpan","render","h","KolSpanWcTag","key","_icons","this","_hideLabel","_label","_accessKey","class","name","slot"],"sources":["src/components/span/style.scss?tag=kol-span&mode=default&encapsulation=shadow","src/components/span/shadow.tsx"],"sourcesContent":["@import '../style';\n@import '../@shared/mixins';\n\n@layer kol-component {\n\t:host {\n\t\tfont-size: rem(16);\n\t}\n}\n","import type { AccessKeyPropType, KoliBriIconsProp, LabelWithExpertSlotPropType, SpanProps, Stringified } from '@public-ui/schema';\nimport type { JSX } from '@stencil/core';\nimport { Component, h, Prop } from '@stencil/core';\nimport { KolSpanWcTag } from '../../core/component-names';\n\n@Component({\n\ttag: 'kol-span',\n\tstyleUrls: {\n\t\tdefault: './style.scss',\n\t},\n\tshadow: true,\n})\nexport class KolSpan implements SpanProps {\n\tpublic render(): JSX.Element {\n\t\treturn (\n\t\t\t<KolSpanWcTag _icons={this._icons} _hideLabel={this._hideLabel} _label={this._label} _accessKey={this._accessKey} class=\"kol-span\">\n\t\t\t\t<slot name=\"expert\" slot=\"expert\"></slot>\n\t\t\t</KolSpanWcTag>\n\t\t);\n\t}\n\n\t/**\n\t * Defines the elements access key.\n\t */\n\t@Prop() public _accessKey?: AccessKeyPropType;\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 g classnames (e.g. `_icons=\"fa-solid fa-user\"`).\n\t */\n\t@Prop() public _icons?: Stringified<KoliBriIconsProp>;\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"],"mappings":";;;iGAAA,MAAMA,EAAkB,2oIACxB,MAAAC,EAAeD,E,MCWFE,EAAO,M,mEAmBmB,M,4CAlB/B,MAAAC,GACN,OACCC,EAACC,EAAY,CAAAC,IAAA,2CAACC,OAAQC,KAAKD,OAAQE,WAAYD,KAAKC,WAAYC,OAAQF,KAAKE,OAAQC,WAAYH,KAAKG,WAAYC,MAAM,YACvHR,EAAA,QAAAE,IAAA,2CAAMO,KAAK,SAASC,KAAK,W"}
|
@@ -1,4 +1,4 @@
|
|
1
1
|
/*!
|
2
2
|
* KoliBri - The accessible HTML-Standard
|
3
3
|
*/
|
4
|
-
import{r as n,h as e,H as i,F as t}from"./index-
|
4
|
+
import{r as n,h as e,H as i,F as t}from"./index-3fbcceca.js";import{an as o,ao as a}from"./index-44da6e7f.js";import{t as r}from"./i18n-7bf2bd6f.js";import"./i18n-0c047df5.js";const s="/*\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: 44px;\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 * Verdana is an accessible font that can be used without requiring additional loading time.\n */\n font-family: Verdana;\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 * 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 44px.\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%; /* 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}\n@layer kol-global {\n :host {\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 /* KolSpan is a layout component with icons in all directions and a label text in the middle. */\n .kol-span-wc {\n display: grid;\n place-items: center;\n }\n /* The sub span in KolSpan is the horizontal span with icon left and right and the label text in the middle. */\n .kol-span-wc > span {\n display: flex;\n place-items: center;\n }\n a,\n button {\n cursor: pointer;\n }\n .hidden {\n display: none;\n visibility: hidden;\n }\n /* This is the text label. */\n .hide-label > .kol-span-wc > span > span {\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-wc,\n [disabled]:focus .kol-span-wc {\n outline: none !important;\n }\n}\n@layer kol-component {\n .spin.cycle {\n width: calc(48rem / var(--kolibri-root-font-size, 16));\n height: calc(48rem / var(--kolibri-root-font-size, 16));\n }\n .spin.cycle > .loader {\n display: block;\n width: 100%;\n height: 100%;\n border-radius: 50%;\n position: relative;\n animation: 2s linear infinite rotate;\n }\n .spin.cycle > .loader::before {\n content: \"\";\n box-sizing: border-box;\n position: absolute;\n inset: 0px;\n border-radius: 50%;\n border: 5px solid #333;\n animation: 3s linear infinite prixClipFix;\n }\n @keyframes rotate {\n 100% {\n transform: rotate(360deg);\n }\n }\n @keyframes prixClipFix {\n 0% {\n border-color: #fff;\n clip-path: polygon(50% 50%, 0 0, 0 0, 0 0, 0 0, 0 0);\n }\n 25% {\n border-color: #666;\n clip-path: polygon(50% 50%, 0 0, 100% 0, 100% 0, 100% 0, 100% 0);\n }\n 50% {\n border-color: #fc0;\n clip-path: polygon(50% 50%, 0 0, 100% 0, 100% 100%, 100% 100%, 100% 100%);\n }\n 75% {\n border-color: red;\n clip-path: polygon(50% 50%, 0 0, 100% 0, 100% 100%, 0 100%, 0 100%);\n }\n 100% {\n border-color: #000;\n clip-path: polygon(50% 50%, 0 0, 100% 0, 100% 100%, 0 100%, 0 0);\n }\n } /* https://developer.mozilla.org/en-US/docs/Web/CSS/@media/prefers-reduced-motion#toning_down_the_animation_scaling */\n @media (prefers-reduced-motion) {\n .spin.cycle > .loader {\n animation-duration: 4s;\n }\n .spin.cycle > .loader::before {\n animation-duration: 6s;\n }\n }\n}\n@layer kol-component {\n .spin.dot {\n height: calc(16rem / var(--kolibri-root-font-size, 16));\n width: calc(48rem / var(--kolibri-root-font-size, 16));\n }\n .spin.dot > span {\n animation-timing-function: cubic-bezier(0, 1, 1, 0);\n border-radius: 50%;\n border: calc(0.16rem / var(--kolibri-root-font-size, 16)) solid #fff;\n height: calc(12.8rem / var(--kolibri-root-font-size, 16));\n position: absolute;\n top: calc(0.16rem / var(--kolibri-root-font-size, 16));\n width: calc(12.8rem / var(--kolibri-root-font-size, 16));\n }\n .spin.dot > span:first-child {\n background-color: #fc0;\n z-index: 0;\n animation: 1s infinite spin1;\n left: calc(0.16rem / var(--kolibri-root-font-size, 16));\n }\n .spin.dot > span:nth-child(2) {\n background-color: red;\n z-index: 1;\n animation: 1s infinite spin2;\n left: calc(0.16rem / var(--kolibri-root-font-size, 16));\n }\n .spin.dot > span:nth-child(3) {\n background-color: #000;\n z-index: 1;\n animation: 1s infinite spin2;\n left: calc(17.6rem / var(--kolibri-root-font-size, 16));\n }\n .spin.dot > span:nth-child(4) {\n background-color: #666;\n z-index: 0;\n animation: 1s infinite spin3;\n left: calc(33.6rem / var(--kolibri-root-font-size, 16));\n }\n @keyframes spin1 {\n 0% {\n transform: scale(0);\n }\n 100% {\n transform: scale(1);\n }\n }\n @keyframes spin2 {\n 0% {\n transform: translate(0, 0);\n }\n 100% {\n transform: translate(calc(16rem / var(--kolibri-root-font-size, 16)), 0);\n }\n }\n @keyframes spin3 {\n 0% {\n transform: scale(1);\n }\n 100% {\n transform: scale(0);\n }\n } /* https://developer.mozilla.org/en-US/docs/Web/CSS/@media/prefers-reduced-motion#toning_down_the_animation_scaling */\n @media (prefers-reduced-motion) {\n .spin.dot > span:first-child,\n .spin.dot > span:nth-child(2),\n .spin.dot > span:nth-child(3),\n .spin.dot > span:nth-child(4) {\n animation-duration: 2s;\n }\n }\n}\n@layer kol-component {\n :host {\n font-size: calc(16rem / var(--kolibri-root-font-size, 16));\n }\n .spin {\n display: block;\n padding: calc(2rem / var(--kolibri-root-font-size, 16));\n position: relative;\n }\n}",l=s;function d(n){switch(n){case"cycle":return e("span",{class:"loader"});case"none":return e("slot",{name:"expert"});default:return e(t,null,e("span",{class:"bg-spin-1"}),e("span",{class:"bg-spin-2"}),e("span",{class:"bg-spin-3"}),e("span",{class:"bg-neutral"}))}}const c=class{constructor(e){n(this,e),this.showToggled=!1,this._show=!1,this._variant="dot",this.state={_variant:"dot"}}render(){return e(i,{key:"3a9df834f40a96c6d26795e41418611ce092ec82",class:"kol-spin"},this.state._show?e("span",{"aria-busy":"true","aria-label":r("kol-action-running"),"aria-live":"polite",class:{spin:!0,[this.state._variant]:!0},role:"alert"},d(this.state._variant)):this.showToggled&&e("span",{"aria-label":r("kol-action-done"),"aria-busy":"false","aria-live":"polite",role:"alert"}))}validateShow(n){this.showToggled=!0===this.state._show&&!1===this._show,o(this,n)}validateVariant(n){a(this,n)}componentWillLoad(){this.validateShow(this._show),this.validateVariant(this._variant)}static get watchers(){return{_show:["validateShow"],_variant:["validateVariant"]}}};c.style={default:l};export{c as kol_spin};
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"names":["defaultStyleCss","KolSpinDefaultStyle0","renderSpin","variant","h","class","name","Fragment","KolSpin","this","showToggled","_variant","render","Host","key","state","_show","translate","spin","role","validateShow","value","validateVariant","validateSpinVariant","componentWillLoad"],"sources":["src/components/spin/style.scss?tag=kol-spin&mode=default&encapsulation=shadow","src/components/spin/component.tsx"],"sourcesContent":["@import '../@shared/mixins';\n@import '../style';\n@import 'cycle';\n@import 'dot';\n\n@layer kol-component {\n\t.spin {\n\t\tdisplay: block;\n\t\tpadding: rem(2);\n\t\tposition: relative;\n\t}\n}\n","import type { JSX } from '@stencil/core';\nimport { validateShow, validateSpinVariant } from '@public-ui/schema';\nimport { Component, Fragment, h, Host, Prop, State, Watch } from '@stencil/core';\n\nimport { translate } from '../../i18n';\n\nimport type { ShowPropType, SpinAPI, SpinStates, SpinVariantPropType } from '@public-ui/schema';\nfunction renderSpin(variant: SpinVariantPropType): JSX.Element {\n\tswitch (variant) {\n\t\tcase 'cycle':\n\t\t\treturn <span class=\"loader\"></span>;\n\t\tcase 'none':\n\t\t\treturn <slot name=\"expert\"></slot>;\n\t\tdefault:\n\t\t\treturn (\n\t\t\t\t<>\n\t\t\t\t\t<span class=\"bg-spin-1\"></span>\n\t\t\t\t\t<span class=\"bg-spin-2\"></span>\n\t\t\t\t\t<span class=\"bg-spin-3\"></span>\n\t\t\t\t\t<span class=\"bg-neutral\"></span>\n\t\t\t\t</>\n\t\t\t);\n\t}\n}\n\n@Component({\n\ttag: 'kol-spin',\n\tstyleUrls: {\n\t\tdefault: './style.scss',\n\t},\n\tshadow: true,\n})\nexport class KolSpin implements SpinAPI {\n\tprivate showToggled = false;\n\n\tpublic render(): JSX.Element {\n\t\treturn (\n\t\t\t<Host class=\"kol-spin\">\n\t\t\t\t{this.state._show ? (\n\t\t\t\t\t<span\n\t\t\t\t\t\taria-busy=\"true\"\n\t\t\t\t\t\taria-label={translate('kol-action-running')}\n\t\t\t\t\t\taria-live=\"polite\"\n\t\t\t\t\t\tclass={{\n\t\t\t\t\t\t\tspin: true,\n\t\t\t\t\t\t\t[this.state._variant]: true,\n\t\t\t\t\t\t\t/* [`spin--${this.state._variant}`]: true, witch benefit have this notation? */\n\t\t\t\t\t\t}}\n\t\t\t\t\t\trole=\"alert\"\n\t\t\t\t\t>\n\t\t\t\t\t\t{renderSpin(this.state._variant)}\n\t\t\t\t\t</span>\n\t\t\t\t) : (\n\t\t\t\t\tthis.showToggled && <span aria-label={translate('kol-action-done')} aria-busy=\"false\" aria-live=\"polite\" role=\"alert\"></span>\n\t\t\t\t)}\n\t\t\t</Host>\n\t\t);\n\t}\n\n\t/**\n\t * Makes the element show up.\n\t * @TODO: Change type back to `ShowPropType` after Stencil#4663 has been resolved.\n\t */\n\t@Prop({ mutable: true, reflect: true }) public _show?: boolean = false;\n\n\t/**\n\t * Defines which variant should be used for presentation.\n\t */\n\t@Prop() public _variant?: SpinVariantPropType = 'dot';\n\n\t@State() public state: SpinStates = {\n\t\t_variant: 'dot',\n\t};\n\n\t@Watch('_show')\n\tpublic validateShow(value?: ShowPropType): void {\n\t\tthis.showToggled = this.state._show === true && this._show === false;\n\t\tvalidateShow(this, value);\n\t}\n\n\t@Watch('_variant')\n\tpublic validateVariant(value?: SpinVariantPropType): void {\n\t\tvalidateSpinVariant(this, value);\n\t}\n\n\tpublic componentWillLoad(): void {\n\t\tthis.validateShow(this._show);\n\t\tthis.validateVariant(this._variant);\n\t}\n}\n"],"mappings":";;;gLAAA,MAAMA,EAAkB,
|
1
|
+
{"version":3,"names":["defaultStyleCss","KolSpinDefaultStyle0","renderSpin","variant","h","class","name","Fragment","KolSpin","this","showToggled","_variant","render","Host","key","state","_show","translate","spin","role","validateShow","value","validateVariant","validateSpinVariant","componentWillLoad"],"sources":["src/components/spin/style.scss?tag=kol-spin&mode=default&encapsulation=shadow","src/components/spin/component.tsx"],"sourcesContent":["@import '../@shared/mixins';\n@import '../style';\n@import 'cycle';\n@import 'dot';\n\n@layer kol-component {\n\t:host {\n\t\tfont-size: rem(16);\n\t}\n\n\t.spin {\n\t\tdisplay: block;\n\t\tpadding: rem(2);\n\t\tposition: relative;\n\t}\n}\n","import type { JSX } from '@stencil/core';\nimport { validateShow, validateSpinVariant } from '@public-ui/schema';\nimport { Component, Fragment, h, Host, Prop, State, Watch } from '@stencil/core';\n\nimport { translate } from '../../i18n';\n\nimport type { ShowPropType, SpinAPI, SpinStates, SpinVariantPropType } from '@public-ui/schema';\nfunction renderSpin(variant: SpinVariantPropType): JSX.Element {\n\tswitch (variant) {\n\t\tcase 'cycle':\n\t\t\treturn <span class=\"loader\"></span>;\n\t\tcase 'none':\n\t\t\treturn <slot name=\"expert\"></slot>;\n\t\tdefault:\n\t\t\treturn (\n\t\t\t\t<>\n\t\t\t\t\t<span class=\"bg-spin-1\"></span>\n\t\t\t\t\t<span class=\"bg-spin-2\"></span>\n\t\t\t\t\t<span class=\"bg-spin-3\"></span>\n\t\t\t\t\t<span class=\"bg-neutral\"></span>\n\t\t\t\t</>\n\t\t\t);\n\t}\n}\n\n@Component({\n\ttag: 'kol-spin',\n\tstyleUrls: {\n\t\tdefault: './style.scss',\n\t},\n\tshadow: true,\n})\nexport class KolSpin implements SpinAPI {\n\tprivate showToggled = false;\n\n\tpublic render(): JSX.Element {\n\t\treturn (\n\t\t\t<Host class=\"kol-spin\">\n\t\t\t\t{this.state._show ? (\n\t\t\t\t\t<span\n\t\t\t\t\t\taria-busy=\"true\"\n\t\t\t\t\t\taria-label={translate('kol-action-running')}\n\t\t\t\t\t\taria-live=\"polite\"\n\t\t\t\t\t\tclass={{\n\t\t\t\t\t\t\tspin: true,\n\t\t\t\t\t\t\t[this.state._variant]: true,\n\t\t\t\t\t\t\t/* [`spin--${this.state._variant}`]: true, witch benefit have this notation? */\n\t\t\t\t\t\t}}\n\t\t\t\t\t\trole=\"alert\"\n\t\t\t\t\t>\n\t\t\t\t\t\t{renderSpin(this.state._variant)}\n\t\t\t\t\t</span>\n\t\t\t\t) : (\n\t\t\t\t\tthis.showToggled && <span aria-label={translate('kol-action-done')} aria-busy=\"false\" aria-live=\"polite\" role=\"alert\"></span>\n\t\t\t\t)}\n\t\t\t</Host>\n\t\t);\n\t}\n\n\t/**\n\t * Makes the element show up.\n\t * @TODO: Change type back to `ShowPropType` after Stencil#4663 has been resolved.\n\t */\n\t@Prop({ mutable: true, reflect: true }) public _show?: boolean = false;\n\n\t/**\n\t * Defines which variant should be used for presentation.\n\t */\n\t@Prop() public _variant?: SpinVariantPropType = 'dot';\n\n\t@State() public state: SpinStates = {\n\t\t_variant: 'dot',\n\t};\n\n\t@Watch('_show')\n\tpublic validateShow(value?: ShowPropType): void {\n\t\tthis.showToggled = this.state._show === true && this._show === false;\n\t\tvalidateShow(this, value);\n\t}\n\n\t@Watch('_variant')\n\tpublic validateVariant(value?: SpinVariantPropType): void {\n\t\tvalidateSpinVariant(this, value);\n\t}\n\n\tpublic componentWillLoad(): void {\n\t\tthis.validateShow(this._show);\n\t\tthis.validateVariant(this._variant);\n\t}\n}\n"],"mappings":";;;gLAAA,MAAMA,EAAkB,20PACxB,MAAAC,EAAeD,ECMf,SAASE,EAAWC,GACnB,OAAQA,GACP,IAAK,QACJ,OAAOC,EAAA,QAAMC,MAAM,WACpB,IAAK,OACJ,OAAOD,EAAA,QAAME,KAAK,WACnB,QACC,OACCF,EAAAG,EAAA,KACCH,EAAA,QAAMC,MAAM,cACZD,EAAA,QAAMC,MAAM,cACZD,EAAA,QAAMC,MAAM,cACZD,EAAA,QAAMC,MAAM,gBAIjB,C,MASaG,EAAO,M,yBACXC,KAAAC,YAAc,M,WA8B2C,M,cAKjB,M,WAEZ,CACnCC,SAAU,M,CApCJ,MAAAC,GACN,OACCR,EAACS,EAAI,CAAAC,IAAA,2CAACT,MAAM,YACVI,KAAKM,MAAMC,MACXZ,EAAA,oBACW,OAAM,aACJa,EAAU,sBAAqB,YACjC,SACVZ,MAAO,CACNa,KAAM,KACN,CAACT,KAAKM,MAAMJ,UAAW,MAGxBQ,KAAK,SAEJjB,EAAWO,KAAKM,MAAMJ,WAGxBF,KAAKC,aAAeN,EAAA,qBAAkBa,EAAU,mBAAkB,YAAY,QAAO,YAAW,SAASE,KAAK,U,CAsB3G,YAAAC,CAAaC,GACnBZ,KAAKC,YAAcD,KAAKM,MAAMC,QAAU,MAAQP,KAAKO,QAAU,MAC/DI,EAAaX,KAAMY,E,CAIb,eAAAC,CAAgBD,GACtBE,EAAoBd,KAAMY,E,CAGpB,iBAAAG,GACNf,KAAKW,aAAaX,KAAKO,OACvBP,KAAKa,gBAAgBb,KAAKE,S"}
|
@@ -1,4 +1,4 @@
|
|
1
1
|
/*!
|
2
2
|
* KoliBri - The accessible HTML-Standard
|
3
3
|
*/
|
4
|
-
import{r as n,h as e,H as t}from"./index-
|
4
|
+
import{r as n,h as e,H as t}from"./index-3fbcceca.js";import{t as i}from"./i18n-7bf2bd6f.js";import{c as s}from"./component-names-ed22f86e.js";import"./index-44da6e7f.js";import"./i18n-0c047df5.js";const o="/*\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: 44px;\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 * Verdana is an accessible font that can be used without requiring additional loading time.\n */\n font-family: Verdana;\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 * 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 44px.\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%; /* 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}\n@layer kol-global {\n :host {\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 /* KolSpan is a layout component with icons in all directions and a label text in the middle. */\n .kol-span-wc {\n display: grid;\n place-items: center;\n }\n /* The sub span in KolSpan is the horizontal span with icon left and right and the label text in the middle. */\n .kol-span-wc > span {\n display: flex;\n place-items: center;\n }\n a,\n button {\n cursor: pointer;\n }\n .hidden {\n display: none;\n visibility: hidden;\n }\n /* This is the text label. */\n .hide-label > .kol-span-wc > span > span {\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-wc,\n [disabled]:focus .kol-span-wc {\n outline: none !important;\n }\n}\n@layer kol-component {\n :host {\n display: flex;\n font-size: calc(16rem / var(--kolibri-root-font-size, 16));\n position: relative;\n }\n .main-button {\n flex-grow: 1;\n text-align: left;\n }\n /* popover */\n .popover {\n height: 0;\n left: 0;\n min-width: 100%;\n overflow: hidden;\n position: absolute;\n top: 100%;\n transition: height 0.3s ease-in-out;\n }\n .popover-content {\n inset: 0 0 auto 0;\n min-width: 100%;\n position: absolute;\n }\n}",a=o,l=class{constructor(t){n(this,t),this.clickButtonHandler={onClick:n=>{var t,e;"function"==typeof(null===(t=this._on)||void 0===t?void 0:t.onClick)?null===(e=this._on)||void 0===e||e.onClick(n,this._value):this.toggleDropdown()}},this.clickToggleHandler={onClick:()=>this.toggleDropdown()},this.openDropdown=()=>{this.dropdown&&this.dropdownContent&&(this.dropdown.style.height=`${this.dropdownContent.clientHeight}px`,this.state=Object.assign(Object.assign({},this.state),{_show:!0}))},this.closeDropdown=()=>{this.dropdown&&this.dropdownContent&&(this.dropdown.style.height="",this.state=Object.assign(Object.assign({},this.state),{_show:!1}))},this.toggleDropdown=n=>{("boolean"==typeof n?n:!this.state._show)?this.openDropdown():this.closeDropdown()},this.catchDropdownElements=n=>{n&&(this.dropdown=n,setTimeout((()=>{this.dropdownContent=n.firstChild})))},this._ariaControls=void 0,this._ariaExpanded=void 0,this._ariaSelected=void 0,this._customClass=void 0,this._disabled=!1,this._hideLabel=!1,this._icons=void 0,this._id=void 0,this._label=void 0,this._name=void 0,this._on=void 0,this._role=void 0,this._syncValueBySelector=void 0,this._tabIndex=void 0,this._tooltipAlign="top",this._type="button",this._value=void 0,this._variant="normal",this.state={_show:!1}}render(){const n="kol-split-button-dropdown-label";return e(t,{key:"bcf84f03e9bac2aca1b64b209c47feee77b1c12b",class:"kol-split-button"},e(s,{key:"9d72346bca0a38e55f6a154a2b4c44d22f614bc3",class:{"main-button":!0,button:!0,[this._variant]:"custom"!==this._variant,[this._customClass]:"custom"===this._variant&&"string"==typeof this._customClass&&this._customClass.length>0},_ariaControls:this._ariaControls,_ariaExpanded:this._ariaExpanded,_ariaSelected:this._ariaSelected,_customClass:this._customClass,_disabled:this._disabled,_icons:this._icons,_hideLabel:this._hideLabel,_label:this._label,_name:this._name,_on:this.clickButtonHandler,_role:this._role,_syncValueBySelector:this._syncValueBySelector,_tabIndex:this._tabIndex,_tooltipAlign:this._tooltipAlign,_type:this._type,_value:this._value,_variant:this._variant}),e("div",{key:"774d988e334f3bc122bb6193cfb33bb268bd5bb6",class:"horizontal-line"}),e(s,{key:"c1da46ad33f7e91864c557ece3001253d05d8228",class:"secondary-button",_disabled:this._disabled,_hideLabel:!0,_icons:"codicon codicon-triangle-down",_label:this.state._show?i(`${n}-close`):i(`${n}-open`),_on:this.clickToggleHandler}),e("div",{key:"88ce2d63c2a0c074bba4439d92c6ca623b5e38f8",class:"popover",ref:this.catchDropdownElements},e("div",{key:"c27f04ab4087e92f510acdff4990412a3945b13d",class:"popover-content"},e("slot",{key:"52ff1bab37fdf7a7b46bce4335861c8089fdf670"}))))}};l.style={default:a};export{l as kol_split_button};
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"names":["defaultStyleCss","KolSplitButtonDefaultStyle0","KolSplitButton","this","clickButtonHandler","onClick","e","_a","_on","_b","_value","toggleDropdown","clickToggleHandler","openDropdown","dropdown","dropdownContent","style","height","clientHeight","state","Object","assign","_show","closeDropdown","value","openIt","catchDropdownElements","setTimeout","firstChild","render","h","Host","key","class","KolButtonWcTag","button","_variant","_customClass","length","_ariaControls","_ariaExpanded","_ariaSelected","_disabled","_icons","_hideLabel","_label","_name","_role","_syncValueBySelector","_tabIndex","_tooltipAlign","_type","ref"],"sources":["src/components/split-button/style.scss?tag=kol-split-button&mode=default&encapsulation=shadow","src/components/split-button/component.tsx"],"sourcesContent":["@import '../style';\n\n@layer kol-component {\n\t:host {\n\t\tdisplay: flex;\n\t\tposition: relative;\n\t}\n\n\t.main-button {\n\t\tflex-grow: 1;\n\t\ttext-align: left;\n\t}\n\n\t/* popover */\n\t.popover {\n\t\theight: 0;\n\t\tleft: 0;\n\t\tmin-width: 100%;\n\t\toverflow: hidden;\n\t\tposition: absolute;\n\t\ttop: 100%;\n\t\ttransition: height 0.3s ease-in-out;\n\t}\n\n\t.popover-content {\n\t\tinset: 0 0 auto 0;\n\t\tmin-width: 100%;\n\t\tposition: absolute;\n\t}\n}\n","import type {\n\tAlternativeButtonLinkRolePropType,\n\tButtonCallbacksPropType,\n\tButtonTypePropType,\n\tButtonVariantPropType,\n\tCustomClassPropType,\n\tIconsPropType,\n\tLabelPropType,\n\tSplitButtonProps,\n\tSplitButtonStates,\n\tStencilUnknown,\n\tStringified,\n\tSyncValueBySelectorPropType,\n\tTooltipAlignPropType,\n} from '@public-ui/schema';\nimport type { JSX } from '@stencil/core';\nimport { Component, h, Host, Prop, State } from '@stencil/core';\nimport { KolButtonWcTag } from '../../core/component-names';\n\n/**\n * @slot - Ermöglicht das Einfügen beliebigen HTMLs in das dropdown.\n */\n@Component({\n\ttag: 'kol-split-button',\n\tstyleUrls: {\n\t\tdefault: './style.scss',\n\t},\n\tshadow: true,\n})\nexport class KolSplitButton implements SplitButtonProps /*, SplitButtonAPI*/ {\n\tprivate dropdown: HTMLDivElement | undefined;\n\tprivate dropdownContent: HTMLDivElement | undefined;\n\n\tprivate readonly clickButtonHandler = {\n\t\tonClick: (e: MouseEvent) => {\n\t\t\tif (typeof this._on?.onClick === 'function') {\n\t\t\t\t// TODO: this._on is not validated\n\t\t\t\tthis._on?.onClick(e, this._value);\n\t\t\t} else {\n\t\t\t\tthis.toggleDropdown();\n\t\t\t}\n\t\t},\n\t};\n\tprivate readonly clickToggleHandler = { onClick: () => this.toggleDropdown() };\n\n\tprivate readonly openDropdown = () => {\n\t\tif (this.dropdown && this.dropdownContent) {\n\t\t\tthis.dropdown.style.height = `${this.dropdownContent.clientHeight}px`;\n\t\t\tthis.state = { ...this.state, _show: true };\n\t\t}\n\t};\n\tprivate readonly closeDropdown = () => {\n\t\tif (this.dropdown && this.dropdownContent) {\n\t\t\tthis.dropdown.style.height = ``;\n\t\t\tthis.state = { ...this.state, _show: false };\n\t\t}\n\t};\n\tprivate readonly toggleDropdown = (value?: boolean) => {\n\t\tconst openIt = typeof value === 'boolean' ? value : !this.state._show;\n\t\tif (openIt) this.openDropdown();\n\t\telse this.closeDropdown();\n\t};\n\n\tprivate readonly catchDropdownElements = (e?: HTMLDivElement | null) => {\n\t\tif (e) {\n\t\t\tthis.dropdown = e;\n\t\t\tsetTimeout(() => {\n\t\t\t\tthis.dropdownContent = e.firstChild as HTMLDivElement;\n\t\t\t});\n\t\t}\n\t};\n\n\tpublic render(): JSX.Element {\n\t\treturn (\n\t\t\t<Host class=\"kol-split-button\">\n\t\t\t\t<KolButtonWcTag\n\t\t\t\t\tclass={{\n\t\t\t\t\t\t'main-button': true,\n\t\t\t\t\t\tbutton: true,\n\t\t\t\t\t\t[this._variant as string]: this._variant !== 'custom',\n\t\t\t\t\t\t[this._customClass as string]: this._variant === 'custom' && typeof this._customClass === 'string' && this._customClass.length > 0,\n\t\t\t\t\t}}\n\t\t\t\t\t_ariaControls={this._ariaControls}\n\t\t\t\t\t_ariaExpanded={this._ariaExpanded}\n\t\t\t\t\t_ariaSelected={this._ariaSelected}\n\t\t\t\t\t_customClass={this._customClass}\n\t\t\t\t\t_disabled={this._disabled}\n\t\t\t\t\t_icons={this._icons}\n\t\t\t\t\t_hideLabel={this._hideLabel}\n\t\t\t\t\t_label={this._label}\n\t\t\t\t\t_name={this._name}\n\t\t\t\t\t_on={this.clickButtonHandler}\n\t\t\t\t\t_role={this._role}\n\t\t\t\t\t_syncValueBySelector={this._syncValueBySelector}\n\t\t\t\t\t_tabIndex={this._tabIndex}\n\t\t\t\t\t_tooltipAlign={this._tooltipAlign}\n\t\t\t\t\t_type={this._type}\n\t\t\t\t\t_value={this._value}\n\t\t\t\t\t_variant={this._variant}\n\t\t\t\t></KolButtonWcTag>\n\t\t\t\t<div class=\"horizontal-line\"></div>\n\t\t\t\t<KolButtonWcTag\n\t\t\t\t\tclass=\"secondary-button\"\n\t\t\t\t\t_disabled={this._disabled}\n\t\t\t\t\t_hideLabel\n\t\t\t\t\t_icons=\"codicon codicon-triangle-down\"\n\t\t\t\t\t_label={`dropdown ${this.state._show ? 'schließen' : 'öffnen'}`} // @todo: translate\n\t\t\t\t\t_on={this.clickToggleHandler}\n\t\t\t\t></KolButtonWcTag>\n\t\t\t\t<div class=\"popover\" ref={this.catchDropdownElements}>\n\t\t\t\t\t<div class=\"popover-content\">\n\t\t\t\t\t\t<slot />\n\t\t\t\t\t</div>\n\t\t\t\t</div>\n\t\t\t</Host>\n\t\t);\n\t}\n\n\t/**\n\t * Defines which elements are controlled by this component. (https://developer.mozilla.org/en-US/docs/Web/Accessibility/ARIA/Attributes/aria-controls)\n\t */\n\t@Prop() public _ariaControls?: string;\n\n\t/**\n\t * Defines whether the interactive element of the component expanded something. (https://developer.mozilla.org/en-US/docs/Web/Accessibility/ARIA/Attributes/aria-expanded)\n\t */\n\t@Prop() public _ariaExpanded?: boolean;\n\n\t/**\n\t * Defines whether the interactive element of the component is selected (e.g. role=tab). (https://developer.mozilla.org/en-US/docs/Web/Accessibility/ARIA/Attributes/aria-selected)\n\t */\n\t@Prop() public _ariaSelected?: boolean;\n\n\t/**\n\t * Defines the custom class attribute if _variant=\"custom\" is set.\n\t */\n\t@Prop() public _customClass?: CustomClassPropType;\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 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 icon classnames (e.g. `_icons=\"fa-solid fa-user\"`).\n\t */\n\t@Prop() public _icons?: IconsPropType;\n\n\t/**\n\t * Defines the internal ID of the primary component element.\n\t */\n\t@Prop() public _id?: string;\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 the technical name of an input field.\n\t */\n\t@Prop() public _name?: string;\n\n\t/**\n\t * Defines the callback functions for button events.\n\t */\n\t@Prop() public _on?: ButtonCallbacksPropType<StencilUnknown>;\n\n\t/**\n\t * Defines the role of the components primary element.\n\t */\n\t@Prop() public _role?: AlternativeButtonLinkRolePropType;\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 which tab-index the primary element of the component has. (https://developer.mozilla.org/en-US/docs/Web/HTML/Global_attributes/tabindex)\n\t */\n\t@Prop() public _tabIndex?: number;\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 * Defines either the type of the component or of the components interactive element.\n\t */\n\t@Prop() public _type?: ButtonTypePropType = 'button';\n\n\t/**\n\t * Defines the value that the button emits on click.\n\t */\n\t@Prop() public _value?: Stringified<StencilUnknown>;\n\n\t/**\n\t * Defines which variant should be used for presentation.\n\t */\n\t@Prop() public _variant?: ButtonVariantPropType = 'normal';\n\n\t@State() public state: SplitButtonStates = {\n\t\t_show: false,\n\t};\n}\n"],"mappings":";;;wGAAA,MAAMA,EAAkB,49IACxB,MAAAC,EAAeD,E,MC4BFE,EAAc,M,yBAITC,KAAAC,mBAAqB,CACrCC,QAAUC,I,QACT,WAAWC,EAAAJ,KAAKK,OAAG,MAAAD,SAAA,SAAAA,EAAEF,WAAY,WAAY,EAE5CI,EAAAN,KAAKK,OAAG,MAAAC,SAAA,SAAAA,EAAEJ,QAAQC,EAAGH,KAAKO,O,KACpB,CACNP,KAAKQ,gB,IAISR,KAAAS,mBAAqB,CAAEP,QAAS,IAAMF,KAAKQ,kBAE3CR,KAAAU,aAAe,KAC/B,GAAIV,KAAKW,UAAYX,KAAKY,gBAAiB,CAC1CZ,KAAKW,SAASE,MAAMC,OAAS,GAAGd,KAAKY,gBAAgBG,iBACrDf,KAAKgB,MAAKC,OAAAC,OAAAD,OAAAC,OAAA,GAAQlB,KAAKgB,OAAK,CAAEG,MAAO,M,GAGtBnB,KAAAoB,cAAgB,KAChC,GAAIpB,KAAKW,UAAYX,KAAKY,gBAAiB,CAC1CZ,KAAKW,SAASE,MAAMC,OAAS,GAC7Bd,KAAKgB,MAAKC,OAAAC,OAAAD,OAAAC,OAAA,GAAQlB,KAAKgB,OAAK,CAAEG,MAAO,O,GAGtBnB,KAAAQ,eAAkBa,IAClC,MAAMC,SAAgBD,IAAU,UAAYA,GAASrB,KAAKgB,MAAMG,MAChE,GAAIG,EAAQtB,KAAKU,oBACZV,KAAKoB,eAAe,EAGTpB,KAAAuB,sBAAyBpB,IACzC,GAAIA,EAAG,CACNH,KAAKW,SAAWR,EAChBqB,YAAW,KACVxB,KAAKY,gBAAkBT,EAAEsB,UAA4B,G,qIA0EnB,M,gBAOC,M,4MA8CgB,M,WAKV,S,oCAUM,S,WAEP,CAC1CN,MAAO,M,CA5ID,MAAAO,GACN,OACCC,EAACC,EAAI,CAAAC,IAAA,2CAACC,MAAM,oBACXH,EAACI,EAAc,CAAAF,IAAA,2CACdC,MAAO,CACN,cAAe,KACfE,OAAQ,KACR,CAAChC,KAAKiC,UAAqBjC,KAAKiC,WAAa,SAC7C,CAACjC,KAAKkC,cAAyBlC,KAAKiC,WAAa,iBAAmBjC,KAAKkC,eAAiB,UAAYlC,KAAKkC,aAAaC,OAAS,GAElIC,cAAepC,KAAKoC,cACpBC,cAAerC,KAAKqC,cACpBC,cAAetC,KAAKsC,cACpBJ,aAAclC,KAAKkC,aACnBK,UAAWvC,KAAKuC,UAChBC,OAAQxC,KAAKwC,OACbC,WAAYzC,KAAKyC,WACjBC,OAAQ1C,KAAK0C,OACbC,MAAO3C,KAAK2C,MACZtC,IAAKL,KAAKC,mBACV2C,MAAO5C,KAAK4C,MACZC,qBAAsB7C,KAAK6C,qBAC3BC,UAAW9C,KAAK8C,UAChBC,cAAe/C,KAAK+C,cACpBC,MAAOhD,KAAKgD,MACZzC,OAAQP,KAAKO,OACb0B,SAAUjC,KAAKiC,WAEhBN,EAAA,OAAAE,IAAA,2CAAKC,MAAM,oBACXH,EAACI,EAAc,CAAAF,IAAA,2CACdC,MAAM,mBACNS,UAAWvC,KAAKuC,UAChBE,WAAU,KACVD,OAAO,gCACPE,OAAQ,YAAY1C,KAAKgB,MAAMG,MAAQ,YAAc,WACrDd,IAAKL,KAAKS,qBAEXkB,EAAA,OAAAE,IAAA,2CAAKC,MAAM,UAAUmB,IAAKjD,KAAKuB,uBAC9BI,EAAA,OAAAE,IAAA,2CAAKC,MAAM,mBACVH,EAAA,QAAAE,IAAA,+C"}
|
1
|
+
{"version":3,"names":["defaultStyleCss","KolSplitButtonDefaultStyle0","KolSplitButton","this","clickButtonHandler","onClick","e","_a","_on","_b","_value","toggleDropdown","clickToggleHandler","openDropdown","dropdown","dropdownContent","style","height","clientHeight","state","Object","assign","_show","closeDropdown","value","openIt","catchDropdownElements","setTimeout","firstChild","render","i18nDropdownLabel","h","Host","key","class","KolButtonWcTag","button","_variant","_customClass","length","_ariaControls","_ariaExpanded","_ariaSelected","_disabled","_icons","_hideLabel","_label","_name","_role","_syncValueBySelector","_tabIndex","_tooltipAlign","_type","translate","ref"],"sources":["src/components/split-button/style.scss?tag=kol-split-button&mode=default&encapsulation=shadow","src/components/split-button/component.tsx"],"sourcesContent":["@import '../@shared/mixins';\n@import '../style';\n\n@layer kol-component {\n\t:host {\n\t\tdisplay: flex;\n\t\tfont-size: rem(16);\n\t\tposition: relative;\n\t}\n\n\t.main-button {\n\t\tflex-grow: 1;\n\t\ttext-align: left;\n\t}\n\n\t/* popover */\n\t.popover {\n\t\theight: 0;\n\t\tleft: 0;\n\t\tmin-width: 100%;\n\t\toverflow: hidden;\n\t\tposition: absolute;\n\t\ttop: 100%;\n\t\ttransition: height 0.3s ease-in-out;\n\t}\n\n\t.popover-content {\n\t\tinset: 0 0 auto 0;\n\t\tmin-width: 100%;\n\t\tposition: absolute;\n\t}\n}\n","import type {\n\tAlternativeButtonLinkRolePropType,\n\tButtonCallbacksPropType,\n\tButtonTypePropType,\n\tButtonVariantPropType,\n\tCustomClassPropType,\n\tIconsPropType,\n\tLabelPropType,\n\tSplitButtonProps,\n\tSplitButtonStates,\n\tStencilUnknown,\n\tStringified,\n\tSyncValueBySelectorPropType,\n\tTooltipAlignPropType,\n} from '@public-ui/schema';\nimport type { JSX } from '@stencil/core';\nimport { Component, h, Host, Prop, State } from '@stencil/core';\n\nimport { translate } from '../../i18n';\nimport { KolButtonWcTag } from '../../core/component-names';\n\n/**\n * @slot - Ermöglicht das Einfügen beliebigen HTMLs in das dropdown.\n */\n@Component({\n\ttag: 'kol-split-button',\n\tstyleUrls: {\n\t\tdefault: './style.scss',\n\t},\n\tshadow: true,\n})\nexport class KolSplitButton implements SplitButtonProps /*, SplitButtonAPI*/ {\n\tprivate dropdown: HTMLDivElement | undefined;\n\tprivate dropdownContent: HTMLDivElement | undefined;\n\n\tprivate readonly clickButtonHandler = {\n\t\tonClick: (e: MouseEvent) => {\n\t\t\tif (typeof this._on?.onClick === 'function') {\n\t\t\t\t// TODO: this._on is not validated\n\t\t\t\tthis._on?.onClick(e, this._value);\n\t\t\t} else {\n\t\t\t\tthis.toggleDropdown();\n\t\t\t}\n\t\t},\n\t};\n\tprivate readonly clickToggleHandler = { onClick: () => this.toggleDropdown() };\n\n\tprivate readonly openDropdown = () => {\n\t\tif (this.dropdown && this.dropdownContent) {\n\t\t\tthis.dropdown.style.height = `${this.dropdownContent.clientHeight}px`;\n\t\t\tthis.state = { ...this.state, _show: true };\n\t\t}\n\t};\n\tprivate readonly closeDropdown = () => {\n\t\tif (this.dropdown && this.dropdownContent) {\n\t\t\tthis.dropdown.style.height = ``;\n\t\t\tthis.state = { ...this.state, _show: false };\n\t\t}\n\t};\n\tprivate readonly toggleDropdown = (value?: boolean) => {\n\t\tconst openIt = typeof value === 'boolean' ? value : !this.state._show;\n\t\tif (openIt) this.openDropdown();\n\t\telse this.closeDropdown();\n\t};\n\n\tprivate readonly catchDropdownElements = (e?: HTMLDivElement | null) => {\n\t\tif (e) {\n\t\t\tthis.dropdown = e;\n\t\t\tsetTimeout(() => {\n\t\t\t\tthis.dropdownContent = e.firstChild as HTMLDivElement;\n\t\t\t});\n\t\t}\n\t};\n\n\tpublic render(): JSX.Element {\n\t\tconst i18nDropdownLabel = 'kol-split-button-dropdown-label';\n\t\treturn (\n\t\t\t<Host class=\"kol-split-button\">\n\t\t\t\t<KolButtonWcTag\n\t\t\t\t\tclass={{\n\t\t\t\t\t\t'main-button': true,\n\t\t\t\t\t\tbutton: true,\n\t\t\t\t\t\t[this._variant as string]: this._variant !== 'custom',\n\t\t\t\t\t\t[this._customClass as string]: this._variant === 'custom' && typeof this._customClass === 'string' && this._customClass.length > 0,\n\t\t\t\t\t}}\n\t\t\t\t\t_ariaControls={this._ariaControls}\n\t\t\t\t\t_ariaExpanded={this._ariaExpanded}\n\t\t\t\t\t_ariaSelected={this._ariaSelected}\n\t\t\t\t\t_customClass={this._customClass}\n\t\t\t\t\t_disabled={this._disabled}\n\t\t\t\t\t_icons={this._icons}\n\t\t\t\t\t_hideLabel={this._hideLabel}\n\t\t\t\t\t_label={this._label}\n\t\t\t\t\t_name={this._name}\n\t\t\t\t\t_on={this.clickButtonHandler}\n\t\t\t\t\t_role={this._role}\n\t\t\t\t\t_syncValueBySelector={this._syncValueBySelector}\n\t\t\t\t\t_tabIndex={this._tabIndex}\n\t\t\t\t\t_tooltipAlign={this._tooltipAlign}\n\t\t\t\t\t_type={this._type}\n\t\t\t\t\t_value={this._value}\n\t\t\t\t\t_variant={this._variant}\n\t\t\t\t></KolButtonWcTag>\n\t\t\t\t<div class=\"horizontal-line\"></div>\n\t\t\t\t<KolButtonWcTag\n\t\t\t\t\tclass=\"secondary-button\"\n\t\t\t\t\t_disabled={this._disabled}\n\t\t\t\t\t_hideLabel\n\t\t\t\t\t_icons=\"codicon codicon-triangle-down\"\n\t\t\t\t\t_label={this.state._show ? translate(`${i18nDropdownLabel}-close`) : translate(`${i18nDropdownLabel}-open`)}\n\t\t\t\t\t_on={this.clickToggleHandler}\n\t\t\t\t></KolButtonWcTag>\n\t\t\t\t<div class=\"popover\" ref={this.catchDropdownElements}>\n\t\t\t\t\t<div class=\"popover-content\">\n\t\t\t\t\t\t<slot />\n\t\t\t\t\t</div>\n\t\t\t\t</div>\n\t\t\t</Host>\n\t\t);\n\t}\n\n\t/**\n\t * Defines which elements are controlled by this component. (https://developer.mozilla.org/en-US/docs/Web/Accessibility/ARIA/Attributes/aria-controls)\n\t */\n\t@Prop() public _ariaControls?: string;\n\n\t/**\n\t * Defines whether the interactive element of the component expanded something. (https://developer.mozilla.org/en-US/docs/Web/Accessibility/ARIA/Attributes/aria-expanded)\n\t */\n\t@Prop() public _ariaExpanded?: boolean;\n\n\t/**\n\t * Defines whether the interactive element of the component is selected (e.g. role=tab). (https://developer.mozilla.org/en-US/docs/Web/Accessibility/ARIA/Attributes/aria-selected)\n\t */\n\t@Prop() public _ariaSelected?: boolean;\n\n\t/**\n\t * Defines the custom class attribute if _variant=\"custom\" is set.\n\t */\n\t@Prop() public _customClass?: CustomClassPropType;\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 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 icon classnames (e.g. `_icons=\"fa-solid fa-user\"`).\n\t */\n\t@Prop() public _icons?: IconsPropType;\n\n\t/**\n\t * Defines the internal ID of the primary component element.\n\t */\n\t@Prop() public _id?: string;\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 the technical name of an input field.\n\t */\n\t@Prop() public _name?: string;\n\n\t/**\n\t * Defines the callback functions for button events.\n\t */\n\t@Prop() public _on?: ButtonCallbacksPropType<StencilUnknown>;\n\n\t/**\n\t * Defines the role of the components primary element.\n\t */\n\t@Prop() public _role?: AlternativeButtonLinkRolePropType;\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 which tab-index the primary element of the component has. (https://developer.mozilla.org/en-US/docs/Web/HTML/Global_attributes/tabindex)\n\t */\n\t@Prop() public _tabIndex?: number;\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 * Defines either the type of the component or of the components interactive element.\n\t */\n\t@Prop() public _type?: ButtonTypePropType = 'button';\n\n\t/**\n\t * Defines the value that the button emits on click.\n\t */\n\t@Prop() public _value?: Stringified<StencilUnknown>;\n\n\t/**\n\t * Defines which variant should be used for presentation.\n\t */\n\t@Prop() public _variant?: ButtonVariantPropType = 'normal';\n\n\t@State() public state: SplitButtonStates = {\n\t\t_show: false,\n\t};\n}\n"],"mappings":";;;sMAAA,MAAMA,EAAkB,6hJACxB,MAAAC,EAAeD,E,MC8BFE,EAAc,M,yBAITC,KAAAC,mBAAqB,CACrCC,QAAUC,I,QACT,WAAWC,EAAAJ,KAAKK,OAAG,MAAAD,SAAA,SAAAA,EAAEF,WAAY,WAAY,EAE5CI,EAAAN,KAAKK,OAAG,MAAAC,SAAA,SAAAA,EAAEJ,QAAQC,EAAGH,KAAKO,O,KACpB,CACNP,KAAKQ,gB,IAISR,KAAAS,mBAAqB,CAAEP,QAAS,IAAMF,KAAKQ,kBAE3CR,KAAAU,aAAe,KAC/B,GAAIV,KAAKW,UAAYX,KAAKY,gBAAiB,CAC1CZ,KAAKW,SAASE,MAAMC,OAAS,GAAGd,KAAKY,gBAAgBG,iBACrDf,KAAKgB,MAAKC,OAAAC,OAAAD,OAAAC,OAAA,GAAQlB,KAAKgB,OAAK,CAAEG,MAAO,M,GAGtBnB,KAAAoB,cAAgB,KAChC,GAAIpB,KAAKW,UAAYX,KAAKY,gBAAiB,CAC1CZ,KAAKW,SAASE,MAAMC,OAAS,GAC7Bd,KAAKgB,MAAKC,OAAAC,OAAAD,OAAAC,OAAA,GAAQlB,KAAKgB,OAAK,CAAEG,MAAO,O,GAGtBnB,KAAAQ,eAAkBa,IAClC,MAAMC,SAAgBD,IAAU,UAAYA,GAASrB,KAAKgB,MAAMG,MAChE,GAAIG,EAAQtB,KAAKU,oBACZV,KAAKoB,eAAe,EAGTpB,KAAAuB,sBAAyBpB,IACzC,GAAIA,EAAG,CACNH,KAAKW,SAAWR,EAChBqB,YAAW,KACVxB,KAAKY,gBAAkBT,EAAEsB,UAA4B,G,qIA2EnB,M,gBAOC,M,4MA8CgB,M,WAKV,S,oCAUM,S,WAEP,CAC1CN,MAAO,M,CA7ID,MAAAO,GACN,MAAMC,EAAoB,kCAC1B,OACCC,EAACC,EAAI,CAAAC,IAAA,2CAACC,MAAM,oBACXH,EAACI,EAAc,CAAAF,IAAA,2CACdC,MAAO,CACN,cAAe,KACfE,OAAQ,KACR,CAACjC,KAAKkC,UAAqBlC,KAAKkC,WAAa,SAC7C,CAAClC,KAAKmC,cAAyBnC,KAAKkC,WAAa,iBAAmBlC,KAAKmC,eAAiB,UAAYnC,KAAKmC,aAAaC,OAAS,GAElIC,cAAerC,KAAKqC,cACpBC,cAAetC,KAAKsC,cACpBC,cAAevC,KAAKuC,cACpBJ,aAAcnC,KAAKmC,aACnBK,UAAWxC,KAAKwC,UAChBC,OAAQzC,KAAKyC,OACbC,WAAY1C,KAAK0C,WACjBC,OAAQ3C,KAAK2C,OACbC,MAAO5C,KAAK4C,MACZvC,IAAKL,KAAKC,mBACV4C,MAAO7C,KAAK6C,MACZC,qBAAsB9C,KAAK8C,qBAC3BC,UAAW/C,KAAK+C,UAChBC,cAAehD,KAAKgD,cACpBC,MAAOjD,KAAKiD,MACZ1C,OAAQP,KAAKO,OACb2B,SAAUlC,KAAKkC,WAEhBN,EAAA,OAAAE,IAAA,2CAAKC,MAAM,oBACXH,EAACI,EAAc,CAAAF,IAAA,2CACdC,MAAM,mBACNS,UAAWxC,KAAKwC,UAChBE,WAAU,KACVD,OAAO,gCACPE,OAAQ3C,KAAKgB,MAAMG,MAAQ+B,EAAU,GAAGvB,WAA6BuB,EAAU,GAAGvB,UAClFtB,IAAKL,KAAKS,qBAEXmB,EAAA,OAAAE,IAAA,2CAAKC,MAAM,UAAUoB,IAAKnD,KAAKuB,uBAC9BK,EAAA,OAAAE,IAAA,2CAAKC,MAAM,mBACVH,EAAA,QAAAE,IAAA,+C"}
|
@@ -1,4 +1,4 @@
|
|
1
1
|
/*!
|
2
2
|
* KoliBri - The accessible HTML-Standard
|
3
3
|
*/
|
4
|
-
import{r as e,h as s,H as
|
4
|
+
import{r as e,h as s,H as t}from"./index-3fbcceca.js";import{v as a,A as i}from"./index-44da6e7f.js";import{t as r}from"./i18n-7bf2bd6f.js";import"./i18n-0c047df5.js";const l=class{constructor(a){e(this,a),this._label=void 0,this._symbol=void 0,this.state={_label:r("kol-warning"),_symbol:""}}render(){return s(t,{key:"ab734cc9e6d2efe073178e7808f770e9bad66587",class:"kol-symbol"},s("span",{key:"fb37efad892479268550fe017b1256c12d6ae468","aria-label":this.state._label,role:"term"},this.state._symbol))}validateLabel(e){a(this,e,{required:!0})}validateSymbol(a){i(this,"_symbol",a,{required:!0})}componentWillLoad(){this.validateLabel(this._label),this.validateSymbol(this._symbol)}static get watchers(){return{_label:["validateLabel"],_symbol:["validateSymbol"]}}};export{l as kol_symbol};
|
@@ -0,0 +1,4 @@
|
|
1
|
+
/*!
|
2
|
+
* KoliBri - The accessible HTML-Standard
|
3
|
+
*/
|
4
|
+
import{r as t,h as i,H as e}from"./index-3fbcceca.js";import{k as s,w as a,ap as n,aq as o,ar as h,as as l,v as r,A as d,r as c,q as f,R as u}from"./index-44da6e7f.js";import{t as p}from"./i18n-7bf2bd6f.js";import{r as b,t as v}from"./component-names-ed22f86e.js";import"./i18n-0c047df5.js";const _="@layer kol-component {\n :root {\n font-size: calc(16rem / var(--kolibri-root-font-size, 16));\n }\n div.pagination .kol-pagination {\n display: flex;\n flex-wrap: wrap;\n }\n div.pagination,\n div.pagination > div:last-child {\n display: grid;\n place-items: center;\n }\n @media (max-width: 1024px) {\n div.pagination .kol-pagination {\n flex-direction: column;\n }\n }\n @media (min-width: 1024px) {\n div.pagination,\n div.pagination > div:last-child {\n grid-auto-flow: column;\n }\n div.pagination .kol-pagination {\n display: flex;\n }\n }\n}",g=_,m=[10,20,50,100],S=t=>!0===t||""===t||"object"==typeof t&&null!==t,y=class{constructor(i){t(this,i),this.sortDirections=new Map,this.sortData=[],this.showPagination=!1,this.pageStartSlice=0,this.pageEndSlice=10,this.disableSort=!1,this.sortedColumnHead={label:"",key:"",sortDirection:"NOS"},this.setSortDirection=(t,i)=>{this.sortDirections.clear(),this.sortDirections.set(t,i),this.sortFunction=t},this.handlePagination={onClick:(t,i)=>{var a;"function"==typeof(null===(a=this.state._pagination._on)||void 0===a?void 0:a.onClick)&&this.state._pagination._on.onClick(t,i),s(this,"_pagination",Object.assign(Object.assign({},this.state._pagination),{_page:i}))},onChangePage:(t,i)=>{var a;"function"==typeof(null===(a=this.state._pagination._on)||void 0===a?void 0:a.onChangePage)&&this.state._pagination._on.onChangePage(t,i),s(this,"_pagination",Object.assign(Object.assign({},this.state._pagination),{_page:i}))},onChangePageSize:(t,i)=>{var a;"function"==typeof(null===(a=this.state._pagination._on)||void 0===a?void 0:a.onChangePageSize)&&this.state._pagination._on.onChangePageSize(t,i),s(this,"_pagination",Object.assign(Object.assign({},this.state._pagination),{_pageSize:i})),s(this,"_pageSize",i)}},this.updateSortedData=(t=this.sortedColumnHead)=>{if(this.disableSort)return void s(this,"_sortedData",this.state._data);let i=this.state._data;if(this.sortData.length>0)i=this.state._data.sort(((t,i)=>{for(let a=0;a<this.sortData.length;a++){const e=this.sortData[a],o=e.compareFn(t,i);if(0!==o)return"ASC"===e.direction?o:-o}return 0}));else if("function"==typeof this.sortFunction)switch(this.sortDirections.get(this.sortFunction)){case"ASC":i=this.sortFunction([...this.state._data]),this.sortedColumnHead={label:t.label,key:t.key,sortDirection:"ASC"};break;case"DESC":i=this.sortFunction([...this.state._data]).reverse(),this.sortedColumnHead={label:t.label,key:t.key,sortDirection:"DESC"};break;default:i=[...this.state._data],this.sortedColumnHead={label:"",key:"",sortDirection:"NOS"}}s(this,"_sortedData",i)},this._allowMultiSort=void 0,this._data=void 0,this._dataFoot=void 0,this._headers=void 0,this._label=void 0,this._minWidth=void 0,this._pagination=void 0,this._paginationPosition="bottom",this.state={_allowMultiSort:!1,_data:[],_dataFoot:[],_headers:{horizontal:[],vertical:[]},_label:"",_pagination:{_page:1,_pageSize:10,_max:0},_sortedData:[],_paginationPosition:"bottom"}}validateAllowMultiSort(t){a(this,"_allowMultiSort",(()=>!0),new Set(["boolean"]),t,{defaultValue:!1})}validateData(t){n(this,t,{afterPatch:()=>{setTimeout(this.updateSortedData)}})}validateDataFoot(t){o(this,t,{afterPatch:()=>{setTimeout(this.updateSortedData)}})}validatePaginationPosition(t){h(this,t)}changeCellSort(t){var i;if("function"==typeof t.compareFn){this.state._allowMultiSort||t.key==(null===(i=this.sortData[0])||void 0===i?void 0:i.key)||(this.sortData=[]);const a=this.sortData.findIndex((i=>i.key===t.key));if(a>=0){const t=this.sortData[a];switch(t.direction){case"ASC":t.direction="DESC";break;case"DESC":this.sortData.splice(a,1);break;default:t.direction="ASC"}}else t.key&&this.sortData.push({label:t.label,key:t.key,compareFn:t.compareFn,direction:"ASC"});this.updateSortedData(t)}else if("function"==typeof t.sort){switch(this.sortFunction=t.sort,this.sortDirections.get(this.sortFunction)){case"ASC":this.setSortDirection(this.sortFunction,"DESC");break;case"DESC":this.setSortDirection(this.sortFunction,"NOS");break;default:this.setSortDirection(this.sortFunction,"ASC")}this.updateSortedData(t)}}validateHeaders(t){l(t,(()=>{f(t,(()=>{try{t=c(t)}catch(t){}a(this,"_headers",(t=>"object"==typeof t&&null!==t),new Set(["KoliBriTableHeaders"]),t,{hooks:{beforePatch:t=>{var i,a,e,o;const s=t=>{let i=!1;t.forEach((t=>{const a=t.key;if(!a)return;const e=t.sortDirection;"ASC"!==e&&"DESC"!==e||("function"==typeof t.compareFn?((this.state._allowMultiSort||0===this.sortData.length)&&this.sortData.push({label:t.label,key:a,compareFn:t.compareFn,direction:e}),i=!0):"function"==typeof t.sort&&(this.setSortDirection(t.sort,e),setTimeout((()=>this.updateSortedData({key:a,label:t.label,sortDirection:e})))))})),i&&setTimeout((()=>this.updateSortedData()))},n=t;null===(i=n.horizontal)||void 0===i||i.forEach(s),null===(a=n.vertical)||void 0===a||a.forEach(s),n.horizontal&&n.vertical&&(null===(e=n.horizontal)||void 0===e?void 0:e.length)>0&&(null===(o=n.vertical)||void 0===o?void 0:o.length)>0&&(this.disableSort=!0,u("Table: You can not sort the table data, if horizontal and vertical headers are defined at the same time. (https://github.com/public-ui/kolibri/issues/2372)"))}}})}))}))}validateLabel(t){r(this,t,{required:!0})}validateMinWidth(t){d(this,"_minWidth",t,{defaultValue:void 0})}validatePagination(t){try{t=c(t)}catch(t){}this.showPagination=S(t),a(this,"_pagination",S,new Set(["boolean","KoliBriTablePagination"]),t,{defaultValue:{_page:1,_pageSize:10,_max:0}})}componentWillLoad(){this.validateAllowMultiSort(this._allowMultiSort),this.validateData(this._data),this.validateDataFoot(this._dataFoot),this.validateHeaders(this._headers),this.validateLabel(this._label),this.validateMinWidth(this._minWidth),this.validatePagination(this._pagination),this.validatePaginationPosition(this._paginationPosition)}selectDisplayedData(t,i,a){return"number"==typeof i&&i>0&&"number"==typeof a&&a>0?(this.pageStartSlice=i*(a-1),this.pageEndSlice=i*a>t.length?t.length:i*a,t.slice(this.pageStartSlice,this.pageEndSlice)):(this.pageStartSlice=0,this.pageEndSlice=t.length,t)}renderPagination(){return i("div",{class:"pagination"},i("span",null,p("kol-table-visible-range",{placeholders:{start:this.pageEndSlice>0?(this.pageStartSlice+1).toString():"0",end:this.pageEndSlice.toString(),total:this.state._pagination&&this.state._pagination._max>0?this.state._pagination._max.toString():Array.isArray(this.state._data)?this.state._data.length.toString():"0"}})),i("div",null,i(b,{_boundaryCount:this.state._pagination._boundaryCount,_customClass:this.state._pagination._customClass,_on:this.handlePagination,_page:this.state._pagination._page,_pageSize:this.state._pagination._pageSize,_pageSizeOptions:this.state._pagination._pageSizeOptions||m,_siblingCount:this.state._pagination._siblingCount,_tooltipAlign:"bottom",_max:this.state._pagination._max||this.state._pagination._max||this.state._data.length,_label:p("kol-table-pagination-label",{placeholders:{label:this.state._label}})})))}getHeaderCellSortState(t){if(!this.disableSort&&("function"==typeof t.compareFn||"function"==typeof t.sort)){if(t.key===this.sortedColumnHead.key)return this.sortedColumnHead.sortDirection;if(t.key){const i=this.sortData.find((i=>i.key===t.key));if(null==i?void 0:i.direction)return i.direction}return"NOS"}}handleSort({key:t}){const i=[...(this.state._headers.horizontal||[]).flat(),...(this.state._headers.vertical||[]).flat()].find((i=>i.key===t));i&&this.changeCellSort(i)}render(){var t,a,o,s;const n=this.selectDisplayedData(this.state._sortedData,this.showPagination?null!==(a=null===(t=this.state._pagination)||void 0===t?void 0:t._pageSize)&&void 0!==a?a:10:this.state._sortedData.length,this.state._pagination._page||1),l="top"===this._paginationPosition||"both"===this._paginationPosition?this.renderPagination():null,r="bottom"===this._paginationPosition||"both"===this._paginationPosition?this.renderPagination():null,h={horizontal:null===(o=this.state._headers.horizontal)||void 0===o?void 0:o.map((t=>t.map((t=>Object.assign(Object.assign({},t),{sortDirection:this.getHeaderCellSortState(t)}))))),vertical:null===(s=this.state._headers.vertical)||void 0===s?void 0:s.map((t=>t.map((t=>Object.assign(Object.assign({},t),{sortDirection:this.getHeaderCellSortState(t)})))))};return i(e,{key:"6beae5b0e089bb81c12eea3d1621a21a547d1fc0",class:"kol-table-stateful"},this.pageEndSlice>0&&this.showPagination&&l,i(v,{key:"e4ffbb145e4484c347ebd03ca93836ab16248b64",_data:n,_headerCells:h,_label:this.state._label,_dataFoot:this.state._dataFoot,_minWidth:this.state._minWidth,_on:{onSort:(t,i)=>{this.handleSort(i)}}}),this.pageEndSlice>0&&this.showPagination&&r)}static get watchers(){return{_allowMultiSort:["validateAllowMultiSort"],_data:["validateData"],_dataFoot:["validateDataFoot"],_paginationPosition:["validatePaginationPosition"],_headers:["validateHeaders"],_label:["validateLabel"],_minWidth:["validateMinWidth"],_pagination:["validatePagination"]}}};y.style={default:g};export{y as kol_table_stateful};
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"names":["defaultStyleCss","KolTableStatefulDefaultStyle0","PAGINATION_OPTIONS","paginationValidator","value","KolTableStateful","this","sortDirections","Map","sortData","showPagination","pageStartSlice","pageEndSlice","disableSort","sortedColumnHead","label","key","sortDirection","setSortDirection","sort","direction","clear","set","sortFunction","handlePagination","onClick","event","page","_a","state","_pagination","_on","setState","Object","assign","_page","onChangePage","onChangePageSize","pageSize","_pageSize","updateSortedData","cell","_data","sortedData","length","a","b","index","data","result","compareFn","get","reverse","_allowMultiSort","_dataFoot","_headers","horizontal","vertical","_label","_max","_sortedData","_paginationPosition","validateAllowMultiSort","watchValidator","Set","defaultValue","validateData","validateTableData","afterPatch","setTimeout","validateDataFoot","validateTableDataFoot","validatePaginationPosition","changeCellSort","headerCell","findIndex","settings","splice","push","validateHeaders","emptyStringByArrayHandler","objectObjectHandler","parseJson","e","hooks","beforePatch","nextValue","applySort","headers","hasSortedCells","forEach","_b","_c","_d","devHint","validateLabel","required","validateMinWidth","watchString","undefined","validatePagination","componentWillLoad","_minWidth","selectDisplayedData","slice","renderPagination","h","class","translate","placeholders","start","toString","end","total","Array","isArray","KolPaginationTag","_boundaryCount","_customClass","_pageSizeOptions","_siblingCount","_tooltipAlign","getHeaderCellSortState","find","handleSort","flat","render","displayedData","paginationTop","paginationBottom","headerCells","map","row","column","Host","KolTableStatelessTag","_headerCells","onSort","_","payload"],"sources":["src/components/table-stateful/style.scss?tag=kol-table-stateful&mode=default&encapsulation=shadow","src/components/table-stateful/component.tsx"],"sourcesContent":["@import '../@shared/mixins';\n\n@layer kol-component {\n\t:root {\n\t\tfont-size: rem(16);\n\t}\n\n\tdiv.pagination .kol-pagination {\n\t\tdisplay: flex;\n\t\tflex-wrap: wrap;\n\t}\n\n\tdiv.pagination,\n\tdiv.pagination > div:last-child {\n\t\tdisplay: grid;\n\t\tplace-items: center;\n\t}\n\n\t@media (max-width: 1024px) {\n\t\tdiv.pagination .kol-pagination {\n\t\t\tflex-direction: column;\n\t\t}\n\t}\n\n\t@media (min-width: 1024px) {\n\t\tdiv.pagination,\n\t\tdiv.pagination > div:last-child {\n\t\t\tgrid-auto-flow: column;\n\t\t}\n\n\t\tdiv.pagination .kol-pagination {\n\t\t\tdisplay: flex;\n\t\t}\n\t}\n}\n","/* eslint-disable jsx-a11y/no-noninteractive-tabindex */\nimport type {\n\tKoliBriDataCompareFn,\n\tKoliBriPaginationButtonCallbacks,\n\tKoliBriSortDirection,\n\tKoliBriSortFunction,\n\tKoliBriTableDataType,\n\tKoliBriTableHeaderCellWithLogic,\n\tKoliBriTableHeaders,\n\tKoliBriTablePaginationProps,\n\tKoliBriTableSelectedHead,\n\tLabelPropType,\n\tPaginationPositionPropType,\n\tStringified,\n\tTableAPI,\n\tTableDataFootPropType,\n\tTableDataPropType,\n\tTableHeaderCells,\n\tTableStates,\n} from '@public-ui/schema';\nimport {\n\tdevHint,\n\temptyStringByArrayHandler,\n\tobjectObjectHandler,\n\tparseJson,\n\tsetState,\n\tvalidateLabel,\n\tvalidatePaginationPosition,\n\tvalidateTableData,\n\tvalidateTableDataFoot,\n\twatchString,\n\twatchValidator,\n} from '@public-ui/schema';\nimport type { JSX } from '@stencil/core';\nimport { Component, h, Host, Prop, State, Watch } from '@stencil/core';\n\nimport { translate } from '../../i18n';\nimport { KolPaginationTag, KolTableStatelessTag } from '../../core/component-names';\nimport type { SortEventPayload } from '@public-ui/schema';\n\nconst PAGINATION_OPTIONS = [10, 20, 50, 100];\n\nconst paginationValidator = (value: unknown) => value === true || value === '' /* true */ || (typeof value === 'object' && value !== null);\n\ntype SortData = {\n\tlabel: string;\n\tkey: string;\n\tcompareFn: KoliBriDataCompareFn;\n\tdirection: KoliBriSortDirection;\n};\n\n@Component({\n\ttag: 'kol-table-stateful',\n\tstyleUrls: {\n\t\tdefault: './style.scss',\n\t},\n\tshadow: true,\n})\nexport class KolTableStateful implements TableAPI {\n\t/**\n\t * @deprecated only for backward compatibility\n\t */\n\tprivate sortFunction?: KoliBriSortFunction;\n\t/**\n\t * @deprecated only for backward compatibility\n\t */\n\tprivate sortDirections: Map<KoliBriSortFunction, KoliBriSortDirection> = new Map();\n\tprivate sortData: SortData[] = [];\n\tprivate showPagination = false;\n\tprivate pageStartSlice = 0;\n\tprivate pageEndSlice = 10;\n\tprivate disableSort = false;\n\n\t/**\n\t * @deprecated only for backward compatibility\n\t */\n\tprivate sortedColumnHead: KoliBriTableSelectedHead = { label: '', key: '', sortDirection: 'NOS' };\n\n\t/**\n\t * Defines whether to allow multi sort.\n\t */\n\t@Prop() public _allowMultiSort?: boolean;\n\n\t/**\n\t * Defines the primary table data.\n\t */\n\t@Prop() public _data!: Stringified<KoliBriTableDataType[]>;\n\n\t/**\n\t * Defines the data for the table footer.\n\t */\n\t@Prop() public _dataFoot?: Stringified<KoliBriTableDataType[]>;\n\n\t/**\n\t * Defines the horizontal and vertical table headers.\n\t */\n\t@Prop() public _headers!: Stringified<KoliBriTableHeaders>;\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!: string;\n\n\t/**\n\t * Defines the table min-width.\n\t */\n\t@Prop() public _minWidth?: string;\n\n\t/**\n\t * Defines whether to show the data distributed over multiple pages.\n\t */\n\t@Prop() public _pagination?: boolean | Stringified<KoliBriTablePaginationProps>;\n\t/**\n\t * Controls the position of the pagination.\n\t */\n\t@Prop() public _paginationPosition?: PaginationPositionPropType = 'bottom';\n\n\t@State() public state: TableStates = {\n\t\t_allowMultiSort: false,\n\t\t_data: [],\n\t\t_dataFoot: [],\n\t\t_headers: {\n\t\t\thorizontal: [],\n\t\t\tvertical: [],\n\t\t},\n\t\t_label: '', // ⚠ required\n\t\t_pagination: {\n\t\t\t_page: 1,\n\t\t\t_pageSize: 10,\n\t\t\t_max: 0,\n\t\t},\n\t\t_sortedData: [],\n\t\t_paginationPosition: 'bottom',\n\t};\n\n\t@Watch('_allowMultiSort')\n\tpublic validateAllowMultiSort(value?: boolean): void {\n\t\twatchValidator(this, '_allowMultiSort', () => true, new Set(['boolean']), value, {\n\t\t\tdefaultValue: false,\n\t\t});\n\t}\n\n\t@Watch('_data')\n\tpublic validateData(value?: TableDataPropType): void {\n\t\tvalidateTableData(this, value, {\n\t\t\tafterPatch: () => {\n\t\t\t\t// TODO: kein guter Hack (endless loop)\n\t\t\t\tsetTimeout(this.updateSortedData);\n\t\t\t},\n\t\t});\n\t}\n\n\t@Watch('_dataFoot')\n\tpublic validateDataFoot(value?: TableDataFootPropType): void {\n\t\tvalidateTableDataFoot(this, value, {\n\t\t\tafterPatch: () => {\n\t\t\t\tsetTimeout(this.updateSortedData);\n\t\t\t},\n\t\t});\n\t}\n\n\t@Watch('_paginationPosition')\n\tpublic validatePaginationPosition(value?: PaginationPositionPropType): void {\n\t\tvalidatePaginationPosition(this, value);\n\t}\n\n\t/**\n\t * @deprecated only for backward compatibility\n\t */\n\tprivate setSortDirection = (sort: KoliBriSortFunction, direction: KoliBriSortDirection) => {\n\t\t/**\n\t\t * Durch des Clearen, ist es nicht möglich eine Mehr-Spalten-Sortierung\n\t\t * darzustellen. Das wäre der Fall, wenn man ggf. Daten in außerhalb der\n\t\t * Komponente sortiert und diese sortiert von außen rein gibt und der\n\t\t * Sortierungsalgorithmus mehrere Spalten zusammen sortierte.\n\t\t *\n\t\t * Beachte auch col.sort !== this.sortFunction\n\t\t */\n\t\tthis.sortDirections.clear();\n\t\tthis.sortDirections.set(sort, direction);\n\t\tthis.sortFunction = sort;\n\t};\n\n\tprivate changeCellSort(headerCell: KoliBriTableHeaderCellWithLogic) {\n\t\tif (typeof headerCell.compareFn === 'function') {\n\t\t\tif (!this.state._allowMultiSort && headerCell.key != this.sortData[0]?.key) {\n\t\t\t\t// clear when another column is sorted and multi sort is not allowed\n\t\t\t\tthis.sortData = [];\n\t\t\t}\n\n\t\t\tconst index = this.sortData.findIndex((value) => value.key === headerCell.key);\n\t\t\tif (index >= 0) {\n\t\t\t\tconst settings = this.sortData[index];\n\t\t\t\tswitch (settings.direction) {\n\t\t\t\t\tcase 'ASC':\n\t\t\t\t\t\tsettings.direction = 'DESC';\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tcase 'DESC':\n\t\t\t\t\t\tthis.sortData.splice(index, 1);\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tdefault:\n\t\t\t\t\t\tsettings.direction = 'ASC';\n\t\t\t\t\t\tbreak;\n\t\t\t\t}\n\t\t\t} else if (headerCell.key) {\n\t\t\t\tthis.sortData.push({\n\t\t\t\t\tlabel: headerCell.label,\n\t\t\t\t\tkey: headerCell.key,\n\t\t\t\t\tcompareFn: headerCell.compareFn,\n\t\t\t\t\tdirection: 'ASC',\n\t\t\t\t});\n\t\t\t}\n\n\t\t\tthis.updateSortedData(headerCell as KoliBriTableSelectedHead);\n\t\t} else if (typeof headerCell.sort === 'function') {\n\t\t\tthis.sortFunction = headerCell.sort;\n\t\t\tswitch (this.sortDirections.get(this.sortFunction)) {\n\t\t\t\tcase 'ASC':\n\t\t\t\t\tthis.setSortDirection(this.sortFunction, 'DESC');\n\t\t\t\t\tbreak;\n\t\t\t\tcase 'DESC':\n\t\t\t\t\tthis.setSortDirection(this.sortFunction, 'NOS');\n\t\t\t\t\tbreak;\n\t\t\t\tdefault:\n\t\t\t\t\tthis.setSortDirection(this.sortFunction, 'ASC');\n\t\t\t}\n\t\t\tthis.updateSortedData(headerCell as KoliBriTableSelectedHead);\n\t\t}\n\t}\n\n\t@Watch('_headers')\n\tpublic validateHeaders(value?: Stringified<KoliBriTableHeaders>): void {\n\t\t/**\n\t\t * - es darf maximal ein Header als primary markiert werden (last win)\n\t\t * - der primary-Header entscheidet implizit über _order und _orientation\n\t\t * - primary-Headers müssen das key-Property setzen\n\t\t * - nicht primary-Headers müssen das key-Property nicht setzen (wird ignoriert)\n\t\t * - _order: wird durch den primary-Header geregelt\n\t\t * - _orientation: wird durch den primary-Header geregelt\n\t\t * - sobald ein Header sortierbar ist, darf es nur noch entweder horizontale\n\t\t * oder vertikale Header geben, aber nicht mehr beides\n\t\t */\n\t\temptyStringByArrayHandler(value, () => {\n\t\t\tobjectObjectHandler(value, () => {\n\t\t\t\ttry {\n\t\t\t\t\tvalue = parseJson<KoliBriTableHeaders>(value);\n\t\t\t\t\t// eslint-disable-next-line no-empty\n\t\t\t\t} catch (e) {\n\t\t\t\t\t// value behält den ursprünglichen Wert\n\t\t\t\t}\n\t\t\t\twatchValidator(this, '_headers', (value): boolean => typeof value === 'object' && value !== null, new Set(['KoliBriTableHeaders']), value, {\n\t\t\t\t\thooks: {\n\t\t\t\t\t\tbeforePatch: (nextValue: unknown) => {\n\t\t\t\t\t\t\tconst applySort = (headers: KoliBriTableHeaderCellWithLogic[]) => {\n\t\t\t\t\t\t\t\tlet hasSortedCells = false;\n\t\t\t\t\t\t\t\theaders.forEach((cell) => {\n\t\t\t\t\t\t\t\t\tconst key = cell.key;\n\t\t\t\t\t\t\t\t\tif (!key) {\n\t\t\t\t\t\t\t\t\t\treturn;\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\tconst sortDirection = cell.sortDirection;\n\t\t\t\t\t\t\t\t\tif (sortDirection === 'ASC' || sortDirection === 'DESC') {\n\t\t\t\t\t\t\t\t\t\tif (typeof cell.compareFn === 'function') {\n\t\t\t\t\t\t\t\t\t\t\tif (this.state._allowMultiSort || this.sortData.length === 0) {\n\t\t\t\t\t\t\t\t\t\t\t\tthis.sortData.push({ label: cell.label, key, compareFn: cell.compareFn, direction: sortDirection });\n\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\thasSortedCells = true;\n\t\t\t\t\t\t\t\t\t\t} else if (typeof cell.sort === 'function') {\n\t\t\t\t\t\t\t\t\t\t\tthis.setSortDirection(cell.sort, sortDirection);\n\t\t\t\t\t\t\t\t\t\t\tsetTimeout(() => this.updateSortedData({ key, label: cell.label, sortDirection }));\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\t\tif (hasSortedCells) {\n\t\t\t\t\t\t\t\t\tsetTimeout(() => this.updateSortedData());\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t};\n\n\t\t\t\t\t\t\tconst headers: KoliBriTableHeaders = nextValue as KoliBriTableHeaders;\n\t\t\t\t\t\t\theaders.horizontal?.forEach(applySort);\n\t\t\t\t\t\t\theaders.vertical?.forEach(applySort);\n\n\t\t\t\t\t\t\tif (headers.horizontal && headers.vertical && headers.horizontal?.length > 0 && headers.vertical?.length > 0) {\n\t\t\t\t\t\t\t\tthis.disableSort = true;\n\t\t\t\t\t\t\t\tdevHint(\n\t\t\t\t\t\t\t\t\t`Table: You can not sort the table data, if horizontal and vertical headers are defined at the same time. (https://github.com/public-ui/kolibri/issues/2372)`,\n\t\t\t\t\t\t\t\t);\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t},\n\t\t\t\t\t},\n\t\t\t\t});\n\t\t\t});\n\t\t});\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('_minWidth')\n\tpublic validateMinWidth(value?: string): void {\n\t\twatchString(this, '_minWidth', value, {\n\t\t\tdefaultValue: undefined,\n\t\t});\n\t}\n\n\tprivate readonly handlePagination: KoliBriPaginationButtonCallbacks = {\n\t\tonClick: (event: Event, page: number) => {\n\t\t\tif (typeof this.state._pagination._on?.onClick === 'function') {\n\t\t\t\tthis.state._pagination._on.onClick(event, page);\n\t\t\t}\n\t\t\tsetState(this, '_pagination', {\n\t\t\t\t...this.state._pagination,\n\t\t\t\t_page: page,\n\t\t\t});\n\t\t},\n\t\tonChangePage: (event: Event, page: number) => {\n\t\t\tif (typeof this.state._pagination._on?.onChangePage === 'function') {\n\t\t\t\tthis.state._pagination._on.onChangePage(event, page);\n\t\t\t}\n\t\t\tsetState(this, '_pagination', {\n\t\t\t\t...this.state._pagination,\n\t\t\t\t_page: page,\n\t\t\t});\n\t\t},\n\t\tonChangePageSize: (event: Event, pageSize: number) => {\n\t\t\tif (typeof this.state._pagination._on?.onChangePageSize === 'function') {\n\t\t\t\tthis.state._pagination._on.onChangePageSize(event, pageSize);\n\t\t\t}\n\t\t\tsetState(this, '_pagination', {\n\t\t\t\t...this.state._pagination,\n\t\t\t\t_pageSize: pageSize,\n\t\t\t});\n\t\t\tsetState(this, '_pageSize', pageSize);\n\t\t},\n\t};\n\n\t@Watch('_pagination')\n\tpublic validatePagination(value?: boolean | Stringified<KoliBriTablePaginationProps>): void {\n\t\ttry {\n\t\t\tvalue = parseJson<boolean | KoliBriTablePaginationProps>(value);\n\t\t\t// eslint-disable-next-line no-empty\n\t\t} catch (e) {\n\t\t\t// value behält den ursprünglichen Wert\n\t\t}\n\n\t\tthis.showPagination = paginationValidator(value);\n\n\t\twatchValidator<boolean | Stringified<KoliBriTablePaginationProps>>(\n\t\t\tthis,\n\t\t\t'_pagination',\n\t\t\tpaginationValidator,\n\t\t\tnew Set(['boolean', 'KoliBriTablePagination']),\n\t\t\tvalue,\n\t\t\t{\n\t\t\t\tdefaultValue: {\n\t\t\t\t\t_page: 1,\n\t\t\t\t\t_pageSize: 10,\n\t\t\t\t\t_max: 0,\n\t\t\t\t},\n\t\t\t},\n\t\t);\n\t}\n\n\tpublic componentWillLoad(): void {\n\t\tthis.validateAllowMultiSort(this._allowMultiSort);\n\t\tthis.validateData(this._data);\n\t\tthis.validateDataFoot(this._dataFoot);\n\t\tthis.validateHeaders(this._headers);\n\t\tthis.validateLabel(this._label);\n\t\tthis.validateMinWidth(this._minWidth);\n\t\tthis.validatePagination(this._pagination);\n\t\tthis.validatePaginationPosition(this._paginationPosition);\n\t}\n\n\tprivate selectDisplayedData(data: KoliBriTableDataType[], pageSize: number, page: number): KoliBriTableDataType[] {\n\t\tif (typeof pageSize === 'number' && pageSize > 0 && typeof page === 'number' && page > 0) {\n\t\t\tthis.pageStartSlice = pageSize * (page - 1);\n\t\t\tthis.pageEndSlice = pageSize * page > data.length ? data.length : pageSize * page;\n\t\t\treturn data.slice(this.pageStartSlice, this.pageEndSlice);\n\t\t} else {\n\t\t\tthis.pageStartSlice = 0;\n\t\t\tthis.pageEndSlice = data.length;\n\t\t\treturn data;\n\t\t}\n\t}\n\n\t/**\n\t *\n\t * @param cell only used for old single sort. Can be removed when sort is removed.\n\t */\n\tprivate updateSortedData = (cell: KoliBriTableSelectedHead = this.sortedColumnHead) => {\n\t\tif (this.disableSort) {\n\t\t\tsetState(this, '_sortedData', this.state._data);\n\t\t\treturn;\n\t\t}\n\n\t\tlet sortedData: KoliBriTableDataType[] = this.state._data;\n\t\tif (this.sortData.length > 0) {\n\t\t\tsortedData = this.state._data.sort((a: KoliBriTableDataType, b: KoliBriTableDataType) => {\n\t\t\t\tfor (let index = 0; index < this.sortData.length; index++) {\n\t\t\t\t\tconst data = this.sortData[index];\n\t\t\t\t\tconst result = data.compareFn(a, b);\n\t\t\t\t\tif (result !== 0) {\n\t\t\t\t\t\treturn data.direction === 'ASC' ? result : -result;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\treturn 0;\n\t\t\t});\n\t\t} else if (typeof this.sortFunction === 'function') {\n\t\t\tswitch (this.sortDirections.get(this.sortFunction)) {\n\t\t\t\tcase 'ASC':\n\t\t\t\t\tsortedData = this.sortFunction([...this.state._data]);\n\t\t\t\t\tthis.sortedColumnHead = { label: cell.label, key: cell.key, sortDirection: 'ASC' };\n\t\t\t\t\tbreak;\n\t\t\t\tcase 'DESC':\n\t\t\t\t\tsortedData = this.sortFunction([...this.state._data]).reverse();\n\t\t\t\t\tthis.sortedColumnHead = { label: cell.label, key: cell.key, sortDirection: 'DESC' };\n\t\t\t\t\tbreak;\n\t\t\t\tcase 'NOS':\n\t\t\t\tdefault:\n\t\t\t\t\tsortedData = [...this.state._data];\n\t\t\t\t\tthis.sortedColumnHead = { label: '', key: '', sortDirection: 'NOS' };\n\t\t\t}\n\t\t}\n\t\tsetState(this, '_sortedData', sortedData);\n\t};\n\n\tprivate renderPagination(): JSX.Element {\n\t\treturn (\n\t\t\t<div class=\"pagination\">\n\t\t\t\t<span>\n\t\t\t\t\t{translate('kol-table-visible-range', {\n\t\t\t\t\t\tplaceholders: {\n\t\t\t\t\t\t\tstart: this.pageEndSlice > 0 ? (this.pageStartSlice + 1).toString() : '0',\n\t\t\t\t\t\t\tend: this.pageEndSlice.toString(),\n\t\t\t\t\t\t\ttotal:\n\t\t\t\t\t\t\t\tthis.state._pagination && this.state._pagination._max > 0\n\t\t\t\t\t\t\t\t\t? this.state._pagination._max.toString()\n\t\t\t\t\t\t\t\t\t: Array.isArray(this.state._data)\n\t\t\t\t\t\t\t\t\t\t? this.state._data.length.toString()\n\t\t\t\t\t\t\t\t\t\t: '0',\n\t\t\t\t\t\t},\n\t\t\t\t\t})}\n\t\t\t\t</span>\n\t\t\t\t<div>\n\t\t\t\t\t<KolPaginationTag\n\t\t\t\t\t\t_boundaryCount={this.state._pagination._boundaryCount}\n\t\t\t\t\t\t_customClass={this.state._pagination._customClass}\n\t\t\t\t\t\t_on={this.handlePagination}\n\t\t\t\t\t\t_page={this.state._pagination._page}\n\t\t\t\t\t\t_pageSize={this.state._pagination._pageSize}\n\t\t\t\t\t\t_pageSizeOptions={this.state._pagination._pageSizeOptions || PAGINATION_OPTIONS}\n\t\t\t\t\t\t_siblingCount={this.state._pagination._siblingCount}\n\t\t\t\t\t\t_tooltipAlign=\"bottom\"\n\t\t\t\t\t\t_max={this.state._pagination._max || this.state._pagination._max || this.state._data.length}\n\t\t\t\t\t\t_label={translate('kol-table-pagination-label', { placeholders: { label: this.state._label } })}\n\t\t\t\t\t></KolPaginationTag>\n\t\t\t\t</div>\n\t\t\t</div>\n\t\t);\n\t}\n\n\tprivate getHeaderCellSortState(headerCell: KoliBriTableHeaderCellWithLogic): KoliBriSortDirection | undefined {\n\t\tif (!this.disableSort && (typeof headerCell.compareFn === 'function' || typeof headerCell.sort === 'function')) {\n\t\t\tif (headerCell.key === this.sortedColumnHead.key) {\n\t\t\t\treturn this.sortedColumnHead.sortDirection;\n\t\t\t}\n\t\t\tif (headerCell.key) {\n\t\t\t\tconst data = this.sortData.find((value) => value.key === headerCell.key);\n\t\t\t\tif (data?.direction) {\n\t\t\t\t\treturn data.direction;\n\t\t\t\t}\n\t\t\t}\n\t\t\treturn 'NOS';\n\t\t}\n\t}\n\n\tprivate handleSort({ key }: SortEventPayload) {\n\t\tconst headerCell = [...(this.state._headers.horizontal || []).flat(), ...(this.state._headers.vertical || []).flat()].find((cell) => cell.key === key);\n\t\tif (headerCell) {\n\t\t\tthis.changeCellSort(headerCell);\n\t\t}\n\t}\n\n\tpublic render(): JSX.Element {\n\t\tconst displayedData: KoliBriTableDataType[] = this.selectDisplayedData(\n\t\t\tthis.state._sortedData,\n\t\t\tthis.showPagination ? this.state._pagination?._pageSize ?? 10 : this.state._sortedData.length,\n\t\t\tthis.state._pagination._page || 1,\n\t\t);\n\t\tconst paginationTop = this._paginationPosition === 'top' || this._paginationPosition === 'both' ? this.renderPagination() : null;\n\t\tconst paginationBottom = this._paginationPosition === 'bottom' || this._paginationPosition === 'both' ? this.renderPagination() : null;\n\n\t\tconst headerCells: TableHeaderCells = {\n\t\t\thorizontal: this.state._headers.horizontal?.map((row) => row.map((cell) => ({ ...cell, sortDirection: this.getHeaderCellSortState(cell) }))),\n\t\t\tvertical: this.state._headers.vertical?.map((column) => column.map((cell) => ({ ...cell, sortDirection: this.getHeaderCellSortState(cell) }))),\n\t\t};\n\n\t\treturn (\n\t\t\t<Host class=\"kol-table-stateful\">\n\t\t\t\t{this.pageEndSlice > 0 && this.showPagination && paginationTop}\n\t\t\t\t<KolTableStatelessTag\n\t\t\t\t\t_data={displayedData}\n\t\t\t\t\t_headerCells={headerCells}\n\t\t\t\t\t_label={this.state._label}\n\t\t\t\t\t_dataFoot={this.state._dataFoot}\n\t\t\t\t\t_minWidth={this.state._minWidth}\n\t\t\t\t\t_on={{\n\t\t\t\t\t\tonSort: (_: MouseEvent, payload: SortEventPayload) => {\n\t\t\t\t\t\t\tthis.handleSort(payload);\n\t\t\t\t\t\t},\n\t\t\t\t\t}}\n\t\t\t\t/>\n\t\t\t\t{this.pageEndSlice > 0 && this.showPagination && paginationBottom}\n\t\t\t</Host>\n\t\t);\n\t}\n}\n"],"mappings":"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"}
|
@@ -0,0 +1,4 @@
|
|
1
|
+
/*!
|
2
|
+
* KoliBri - The accessible HTML-Standard
|
3
|
+
*/
|
4
|
+
import{r as e,h as t,H as i}from"./index-3fbcceca.js";import{ap as s,aq as a,aQ as n,v as o,A as r,aR as d}from"./index-44da6e7f.js";import{c as l}from"./component-names-ed22f86e.js";import{t as f}from"./i18n-7bf2bd6f.js";import"./i18n-0c047df5.js";const c=class{constructor(a){e(this,a),this.horizontal=!0,this.cellsToRenderTimeouts=new Map,this.renderTableRow=(e,a)=>t("tr",{key:`tbody-${a}`},e.map(((t,e)=>this.renderTableCell(t,a,e)))),this.renderTableCell=(e,a,i)=>!1===e.asTd?this.renderHeadingCell(e,a,i):t("td",{key:`tbody-${a}-${i}-${e.label}`,class:{[e.textAlign]:"string"==typeof e.textAlign&&e.textAlign.length>0},colSpan:e.colSpan,rowSpan:e.rowSpan,style:{textAlign:e.textAlign,width:e.width},ref:"function"==typeof e.render?t=>{this.cellRender(e,t)}:void 0},"function"!=typeof e.render?e.label:""),this.state={_data:[],_label:"",_headerCells:{horizontal:[],vertical:[]}},this.tableDivElementHasScrollbar=!1,this._data=void 0,this._dataFoot=void 0,this._headerCells=void 0,this._label=void 0,this._minWidth=void 0,this._on=void 0}validateData(t){s(this,t)}validateDataFoot(t){a(this,t)}validateHeaderCells(t){n(this,t)}validateLabel(t){o(this,t,{required:!0})}validateMinWidth(t){r(this,"_minWidth",t,{defaultValue:void 0})}validateOn(t){d(this,t)}componentDidRender(){this.checkDivElementScrollbar()}componentDidLoad(){this.tableDivElement&&ResizeObserver&&(this.tableDivElementResizeObserver=new ResizeObserver(this.checkDivElementScrollbar.bind(this)),this.tableDivElementResizeObserver.observe(this.tableDivElement))}disconnectedCallback(){var t;null===(t=this.tableDivElementResizeObserver)||void 0===t||t.disconnect()}checkDivElementScrollbar(){this.tableDivElement&&(this.tableDivElementHasScrollbar=this.tableDivElement.scrollWidth>this.tableDivElement.clientWidth)}cellRender(t,e){e&&(clearTimeout(this.cellsToRenderTimeouts.get(e)),this.cellsToRenderTimeouts.set(e,setTimeout((()=>{if("function"==typeof t.render){const a=t.render(e,t,t.data,this.state._data);"string"==typeof a&&(e.textContent=a)}}))))}getNumberOfCols(t,e){let a=0;return t.forEach((t=>{let e=0;t.forEach((t=>{var a;return e+=null!==(a=t.colSpan)&&void 0!==a?a:1})),a<e&&(a=e)})),0===a&&(a=e.length),a}getNumberOfRows(t,e){var a;let i=0;return t.forEach((t=>{let e=0;t.forEach((t=>{var a;return e+=null!==(a=t.rowSpan)&&void 0!==a?a:1})),i<e&&(i=e)})),0===i?i=e.length:i-=(null===(a=this.state._dataFoot)||void 0===a?void 0:a.length)||0,i}filterHeaderKeys(t){const e=[];return t.forEach((t=>{t.forEach((t=>{"string"==typeof t.key&&e.push(t)}))})),e}getPrimaryHeader(t){var e,a;let i=this.filterHeaderKeys(null!==(e=t.horizontal)&&void 0!==e?e:[]);return this.horizontal=!0,0===i.length&&(i=this.filterHeaderKeys(null!==(a=t.vertical)&&void 0!==a?a:[]),i.length>0&&(this.horizontal=!1)),i}createDataField(t,e,a){var i;e.horizontal=Array.isArray(null==e?void 0:e.horizontal)?e.horizontal:[],e.vertical=Array.isArray(null==e?void 0:e.vertical)?e.vertical:[];const l=this.getPrimaryHeader(e),o=this.getNumberOfCols(e.horizontal,t);let r=this.getNumberOfRows(e.vertical,t),s=0;a&&(s=r,r+=(null===(i=this.state._dataFoot)||void 0===i?void 0:i.length)||0);const n=[],d=[],h=[];e.vertical.forEach(((t,e)=>{d[e]=0,h[e]=[]}));for(let i=s;i<r;i++){const r=[];e.vertical.forEach(((t,e)=>{let a=0;if(h[e].forEach((t=>a+=t)),a<=i){const l=t[i-a+d[e]];if("object"==typeof l){r.push(Object.assign(Object.assign({},l),{asTd:!1,data:{}}));let t=1;if("number"==typeof l.rowSpan&&l.rowSpan>1&&(t=l.rowSpan),h[e].push(t),"number"==typeof l.colSpan&&l.colSpan>1)for(let a=1;a<l.colSpan;a++)h[e+a].push(t);d[e]++}}}));for(let e=0;e<o;e++)if(!0===this.horizontal){const o=a&&this.state._dataFoot?this.state._dataFoot[i-s]:t[i];"object"==typeof l[e]&&null!==l[e]&&"string"==typeof l[e].key&&"object"==typeof o&&null!==o&&r.push(Object.assign(Object.assign({},l[e]),{colSpan:void 0,data:o,label:o[l[e].key],rowSpan:void 0}))}else"object"==typeof l[i]&&null!==l[i]&&"string"==typeof l[i].key&&"object"==typeof t[e]&&null!==t[e]&&r.push(Object.assign(Object.assign({},l[i]),{colSpan:void 0,data:t[e],label:t[e][l[i].key],rowSpan:void 0}));n.push(r)}if(0===t.length){let t=0,a=0;Array.isArray(e.horizontal)&&e.horizontal.length>0&&e.horizontal[0].forEach((e=>{t+=e.colSpan||1})),Array.isArray(e.vertical)&&e.vertical.length>0&&(t-=e.vertical.length,e.vertical[0].forEach((t=>{a+=t.rowSpan||1})));const i={colSpan:t,label:f("kol-no-entries"),render:void 0,rowSpan:Math.max(a,1)};0===n.length?n.push([i]):n[0].push(i)}return n}componentWillLoad(){this.validateData(this._data),this.validateDataFoot(this._dataFoot),this.validateHeaderCells(this._headerCells),this.validateLabel(this._label),this.validateMinWidth(this._minWidth),this.validateOn(this._on)}renderHeadingCell(e,a,i){let o,r="codicon codicon-fold";if(e.sortDirection)switch(e.sortDirection){case"ASC":r="codicon codicon-chevron-up",o="ascending";break;case"DESC":r="codicon codicon-chevron-down",o="descending"}return t("th",{key:`${a}-${i}-${e.label}`,class:e.textAlign?`align-${e.textAlign}`:void 0,scope:"number"==typeof e.colSpan&&e.colSpan>1?"colgroup":"col",colSpan:e.colSpan,rowSpan:e.rowSpan,style:{width:e.width},"aria-sort":o,"data-sort":`sort-${e.sortDirection}`},e.sortDirection?t(l,{class:"table-sort-button",exportparts:"icon",_icons:{right:r},_label:e.label,_on:{onClick:t=>{var a;"function"==typeof(null===(a=this.state._on)||void 0===a?void 0:a.onSort)&&e.key&&e.sortDirection&&this.state._on.onSort(t,{key:e.key,currentSortDirection:e.sortDirection})}}}):e.label)}renderFoot(){if(!this.state._dataFoot||0===this.state._dataFoot.length)return"";const e=this.createDataField(this.state._dataFoot,this.state._headerCells,!0);return t("tfoot",null,e.map(this.renderTableRow))}render(){const e=this.createDataField(this.state._data,this.state._headerCells);return t(i,{key:"361f1522f1781a9499491ed2568c385a80b24ac2",class:"kol-table-stateless"},t("div",{key:"a26e21dd976ecfef8e9b0cb2e7f72a7df1111cfb",ref:t=>this.tableDivElement=t,class:"table",tabindex:this.tableDivElementHasScrollbar?"-1":void 0},t("table",{key:"448af685785f16f956526571a290d3b3a5245ceb",style:{minWidth:this.state._minWidth}},t("div",{key:"366e0cb3589af60dfa73a30e7e1ad10f21a0b731",class:"focus-element",tabindex:this.tableDivElementHasScrollbar?"0":void 0,"aria-describedby":"caption"}," "),t("caption",{key:"f4a9ea083af48b6dbaa77ca73f42b7d421165448",id:"caption"},this.state._label),Array.isArray(this.state._headerCells.horizontal)&&t("thead",{key:"aea605830f1e5041003f9168f8c90ea646a81f8e"},this.state._headerCells.horizontal.map(((e,a)=>t("tr",{key:`thead-${a}`},e.map(((e,i)=>!0===e.asTd?t("td",{key:`thead-${a}-${i}-${e.label}`,class:{[e.textAlign]:"string"==typeof e.textAlign&&e.textAlign.length>0},colSpan:e.colSpan,rowSpan:e.rowSpan,style:{textAlign:e.textAlign,width:e.width},ref:"function"==typeof e.render?t=>{this.cellRender(e,t)}:void 0},"function"!=typeof e.render?e.label:""):this.renderHeadingCell(e,a,i))))))),t("tbody",{key:"4f6e9bb613569b8ee24551a7b00aa067225933fd"},e.map(this.renderTableRow)),this.renderFoot())))}static get watchers(){return{_data:["validateData"],_dataFoot:["validateDataFoot"],_headerCells:["validateHeaderCells"],_label:["validateLabel"],_minWidth:["validateMinWidth"],_on:["validateOn"]}}};export{c as kol_table_stateless_wc};
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"names":["KolTableStateless","this","horizontal","cellsToRenderTimeouts","Map","renderTableRow","row","rowIndex","h","key","map","col","colIndex","renderTableCell","cell","asTd","renderHeadingCell","label","class","textAlign","length","colSpan","rowSpan","style","width","ref","render","el","cellRender","undefined","_data","_label","_headerCells","vertical","validateData","value","validateTableData","validateDataFoot","validateTableDataFoot","validateHeaderCells","validateTableHeaderCells","validateLabel","required","validateMinWidth","watchString","defaultValue","validateOn","validateTableCallbacks","componentDidRender","checkDivElementScrollbar","componentDidLoad","tableDivElement","ResizeObserver","tableDivElementResizeObserver","bind","observe","disconnectedCallback","_a","disconnect","tableDivElementHasScrollbar","scrollWidth","clientWidth","clearTimeout","get","set","setTimeout","renderContent","data","state","textContent","getNumberOfCols","horizontalHeaders","max","forEach","count","getNumberOfRows","verticalHeaders","_dataFoot","filterHeaderKeys","headers","primaryHeader","cells","push","getPrimaryHeader","_b","createDataField","isFoot","Array","isArray","maxCols","maxRows","startRow","dataField","rowCount","rowSpans","_row","index","i","dataRow","headerCells","rowsTotal","rows","Object","assign","k","j","colspan","rowspan","emptyCell","translate","Math","componentWillLoad","_minWidth","_on","ariaSort","sortButtonIcon","sortDirection","scope","KolButtonWcTag","exportparts","_icons","right","onClick","event","onSort","currentSortDirection","renderFoot","Host","element","tabindex","minWidth","id","cols"],"sources":["src/components/table-stateless/component.tsx"],"sourcesContent":["import type { JSX } from '@stencil/core';\nimport { Component, h, Host, Prop, State, Watch } from '@stencil/core';\n\nimport type {\n\tKoliBriTableCell,\n\tKoliBriTableDataType,\n\tKoliBriTableHeaderCell,\n\tKoliBriTableHeaderCellAndData,\n\tKoliBriTableHeaders,\n\tKoliBriTableRender,\n\tLabelPropType,\n\tTableCallbacksPropType,\n\tTableDataFootPropType,\n\tTableDataPropType,\n\tTableHeaderCellsPropType,\n\tTableStatelessAPI,\n\tTableStatelessStates,\n} from '@public-ui/schema';\nimport { validateLabel, validateTableCallbacks, validateTableData, validateTableDataFoot, validateTableHeaderCells, watchString } from '@public-ui/schema';\nimport { KolButtonWcTag } from '../../core/component-names';\nimport { translate } from '../../i18n';\n\n@Component({\n\ttag: 'kol-table-stateless-wc',\n\tshadow: false,\n})\nexport class KolTableStateless implements TableStatelessAPI {\n\t@State() public state: TableStatelessStates = {\n\t\t_data: [],\n\t\t_label: '',\n\t\t_headerCells: {\n\t\t\thorizontal: [],\n\t\t\tvertical: [],\n\t\t},\n\t};\n\n\tprivate tableDivElement?: HTMLDivElement;\n\tprivate tableDivElementResizeObserver?: ResizeObserver;\n\tprivate horizontal = true;\n\tprivate cellsToRenderTimeouts = new Map<HTMLElement, ReturnType<typeof setTimeout>>();\n\n\t@State()\n\tprivate tableDivElementHasScrollbar = false;\n\n\t/**\n\t * Defines the primary table data.\n\t */\n\t@Prop() public _data!: TableDataPropType;\n\n\t/**\n\t * Defines the data for the table footer.\n\t */\n\t@Prop() public _dataFoot?: TableDataFootPropType;\n\n\t/**\n\t * Defines the horizontal and vertical table headers.\n\t */\n\t@Prop() public _headerCells!: TableHeaderCellsPropType;\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!: string;\n\n\t/**\n\t * Defines the table min-width.\n\t */\n\t@Prop() public _minWidth?: string;\n\n\t/**\n\t * Defines the callback functions for table events.\n\t */\n\t@Prop() public _on?: TableCallbacksPropType;\n\n\t@Watch('_data')\n\tpublic validateData(value?: TableDataPropType) {\n\t\tvalidateTableData(this, value);\n\t}\n\n\t@Watch('_dataFoot')\n\tpublic validateDataFoot(value?: TableDataFootPropType) {\n\t\tvalidateTableDataFoot(this, value);\n\t}\n\n\t@Watch('_headerCells')\n\tpublic validateHeaderCells(value?: TableHeaderCellsPropType) {\n\t\tvalidateTableHeaderCells(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('_minWidth')\n\tpublic validateMinWidth(value?: string): void {\n\t\twatchString(this, '_minWidth', value, {\n\t\t\tdefaultValue: undefined,\n\t\t});\n\t}\n\n\t@Watch('_on')\n\tpublic validateOn(value?: TableCallbacksPropType): void {\n\t\tvalidateTableCallbacks(this, value);\n\t}\n\n\tpublic componentDidRender(): void {\n\t\tthis.checkDivElementScrollbar();\n\t}\n\n\tpublic componentDidLoad() {\n\t\tif (this.tableDivElement && ResizeObserver) {\n\t\t\tthis.tableDivElementResizeObserver = new ResizeObserver(this.checkDivElementScrollbar.bind(this));\n\t\t\tthis.tableDivElementResizeObserver.observe(this.tableDivElement);\n\t\t}\n\t}\n\n\tpublic disconnectedCallback() {\n\t\tthis.tableDivElementResizeObserver?.disconnect();\n\t}\n\n\tprivate checkDivElementScrollbar() {\n\t\tif (this.tableDivElement) {\n\t\t\tthis.tableDivElementHasScrollbar = this.tableDivElement.scrollWidth > this.tableDivElement.clientWidth;\n\t\t}\n\t}\n\n\tprivate cellRender(\n\t\tcell: KoliBriTableCell & {\n\t\t\tdata?: KoliBriTableDataType;\n\t\t},\n\t\tel?: HTMLElement,\n\t): void {\n\t\tif (el) {\n\t\t\tclearTimeout(this.cellsToRenderTimeouts.get(el));\n\t\t\tthis.cellsToRenderTimeouts.set(\n\t\t\t\tel,\n\t\t\t\tsetTimeout(() => {\n\t\t\t\t\tif (typeof cell.render === 'function') {\n\t\t\t\t\t\tconst renderContent = cell.render(el, cell, cell.data, this.state._data);\n\t\t\t\t\t\tif (typeof renderContent === 'string') {\n\t\t\t\t\t\t\tel.textContent = renderContent;\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}),\n\t\t\t);\n\t\t}\n\t}\n\n\tprivate getNumberOfCols(horizontalHeaders: KoliBriTableHeaderCell[][], data: KoliBriTableDataType[]): number {\n\t\tlet max = 0;\n\t\thorizontalHeaders.forEach((row) => {\n\t\t\tlet count = 0;\n\t\t\trow.forEach((col) => (count += col.colSpan ?? 1));\n\t\t\tif (max < count) {\n\t\t\t\tmax = count;\n\t\t\t}\n\t\t});\n\t\tif (max === 0) {\n\t\t\tmax = data.length;\n\t\t}\n\t\treturn max;\n\t}\n\n\tprivate getNumberOfRows(verticalHeaders: KoliBriTableHeaderCell[][], data: KoliBriTableDataType[]): number {\n\t\tlet max = 0;\n\t\tverticalHeaders.forEach((col) => {\n\t\t\tlet count = 0;\n\t\t\tcol.forEach((row) => (count += row.rowSpan ?? 1));\n\t\t\tif (max < count) {\n\t\t\t\tmax = count;\n\t\t\t}\n\t\t});\n\t\tif (max === 0) {\n\t\t\tmax = data.length;\n\t\t} else {\n\t\t\tmax -= this.state._dataFoot?.length || 0;\n\t\t}\n\t\treturn max;\n\t}\n\n\tprivate filterHeaderKeys(headers: KoliBriTableHeaderCell[][]): KoliBriTableHeaderCell[] {\n\t\tconst primaryHeader: KoliBriTableHeaderCell[] = [];\n\t\theaders.forEach((cells) => {\n\t\t\tcells.forEach((cell) => {\n\t\t\t\tif (typeof cell.key === 'string') {\n\t\t\t\t\tprimaryHeader.push(cell);\n\t\t\t\t}\n\t\t\t});\n\t\t});\n\t\treturn primaryHeader;\n\t}\n\n\tprivate getPrimaryHeader(headers: KoliBriTableHeaders): KoliBriTableHeaderCell[] {\n\t\tlet primaryHeader: KoliBriTableHeaderCell[] = this.filterHeaderKeys(headers.horizontal ?? []);\n\t\tthis.horizontal = true;\n\t\tif (primaryHeader.length === 0) {\n\t\t\tprimaryHeader = this.filterHeaderKeys(headers.vertical ?? []);\n\t\t\tif (primaryHeader.length > 0) {\n\t\t\t\tthis.horizontal = false;\n\t\t\t}\n\t\t}\n\t\treturn primaryHeader;\n\t}\n\n\tprivate createDataField(data: KoliBriTableDataType[], headers: KoliBriTableHeaders, isFoot?: boolean): KoliBriTableCell[][] {\n\t\theaders.horizontal = Array.isArray(headers?.horizontal) ? headers.horizontal : [];\n\t\theaders.vertical = Array.isArray(headers?.vertical) ? headers.vertical : [];\n\t\tconst primaryHeader = this.getPrimaryHeader(headers);\n\t\tconst maxCols = this.getNumberOfCols(headers.horizontal, data);\n\t\tlet maxRows = this.getNumberOfRows(headers.vertical, data);\n\t\tlet startRow = 0;\n\t\tif (isFoot) {\n\t\t\tstartRow = maxRows;\n\t\t\tmaxRows += this.state._dataFoot?.length || 0;\n\t\t}\n\t\tconst dataField: KoliBriTableCell[][] = [];\n\n\t\tconst rowCount: number[] = [];\n\t\tconst rowSpans: number[][] = [];\n\t\theaders.vertical.forEach((_row, index) => {\n\t\t\trowCount[index] = 0;\n\t\t\trowSpans[index] = [];\n\t\t});\n\n\t\tfor (let i = startRow; i < maxRows; i++) {\n\t\t\tconst dataRow: KoliBriTableHeaderCellAndData[] = [];\n\t\t\theaders.vertical.forEach((headerCells, index) => {\n\t\t\t\tlet rowsTotal = 0;\n\t\t\t\trowSpans[index].forEach((value) => (rowsTotal += value));\n\t\t\t\tif (rowsTotal <= i) {\n\t\t\t\t\tconst rows = headerCells[i - rowsTotal + rowCount[index]];\n\t\t\t\t\tif (typeof rows === 'object') {\n\t\t\t\t\t\tdataRow.push({\n\t\t\t\t\t\t\t...rows,\n\t\t\t\t\t\t\tasTd: false,\n\t\t\t\t\t\t\t// eslint-disable-next-line @typescript-eslint/no-unsafe-assignment\n\t\t\t\t\t\t\tdata: {} as KoliBriTableDataType,\n\t\t\t\t\t\t});\n\t\t\t\t\t\tlet rowSpan = 1;\n\t\t\t\t\t\tif (typeof rows.rowSpan === 'number' && rows.rowSpan > 1) {\n\t\t\t\t\t\t\trowSpan = rows.rowSpan;\n\t\t\t\t\t\t}\n\t\t\t\t\t\trowSpans[index].push(rowSpan);\n\t\t\t\t\t\tif (typeof rows.colSpan === 'number' && rows.colSpan > 1) {\n\t\t\t\t\t\t\tfor (let k = 1; k < rows.colSpan; k++) {\n\t\t\t\t\t\t\t\trowSpans[index + k].push(rowSpan);\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t\trowCount[index]++;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t});\n\t\t\tfor (let j = 0; j < maxCols; j++) {\n\t\t\t\tif (this.horizontal === true) {\n\t\t\t\t\tconst row = isFoot && this.state._dataFoot ? this.state._dataFoot[i - startRow] : data[i];\n\t\t\t\t\tif (\n\t\t\t\t\t\ttypeof primaryHeader[j] === 'object' &&\n\t\t\t\t\t\tprimaryHeader[j] !== null &&\n\t\t\t\t\t\ttypeof primaryHeader[j].key === 'string' &&\n\t\t\t\t\t\ttypeof row === 'object' &&\n\t\t\t\t\t\trow !== null\n\t\t\t\t\t) {\n\t\t\t\t\t\tdataRow.push({\n\t\t\t\t\t\t\t...primaryHeader[j],\n\t\t\t\t\t\t\tcolSpan: undefined,\n\t\t\t\t\t\t\t// eslint-disable-next-line @typescript-eslint/no-unsafe-assignment\n\t\t\t\t\t\t\tdata: row,\n\t\t\t\t\t\t\t// eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n\t\t\t\t\t\t\tlabel: row[primaryHeader[j].key as unknown as string] as string,\n\t\t\t\t\t\t\trowSpan: undefined,\n\t\t\t\t\t\t});\n\t\t\t\t\t}\n\t\t\t\t} else {\n\t\t\t\t\tif (\n\t\t\t\t\t\ttypeof primaryHeader[i] === 'object' &&\n\t\t\t\t\t\tprimaryHeader[i] !== null &&\n\t\t\t\t\t\ttypeof primaryHeader[i].key === 'string' &&\n\t\t\t\t\t\ttypeof data[j] === 'object' &&\n\t\t\t\t\t\tdata[j] !== null\n\t\t\t\t\t) {\n\t\t\t\t\t\tdataRow.push({\n\t\t\t\t\t\t\t...primaryHeader[i],\n\t\t\t\t\t\t\tcolSpan: undefined,\n\t\t\t\t\t\t\t// eslint-disable-next-line @typescript-eslint/no-unsafe-assignment\n\t\t\t\t\t\t\tdata: data[j],\n\t\t\t\t\t\t\t// eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n\t\t\t\t\t\t\tlabel: data[j][primaryHeader[i].key as unknown as number] as string,\n\t\t\t\t\t\t\trowSpan: undefined,\n\t\t\t\t\t\t});\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t\tdataField.push(dataRow);\n\t\t}\n\t\tif (data.length === 0) {\n\t\t\tlet colspan = 0;\n\t\t\tlet rowspan = 0;\n\t\t\tif (Array.isArray(headers.horizontal) && headers.horizontal.length > 0) {\n\t\t\t\theaders.horizontal[0].forEach((col) => {\n\t\t\t\t\tcolspan += col.colSpan || 1;\n\t\t\t\t});\n\t\t\t}\n\t\t\tif (Array.isArray(headers.vertical) && headers.vertical.length > 0) {\n\t\t\t\tcolspan -= headers.vertical.length;\n\t\t\t\theaders.vertical[0].forEach((row) => {\n\t\t\t\t\trowspan += row.rowSpan || 1;\n\t\t\t\t});\n\t\t\t}\n\t\t\tconst emptyCell = {\n\t\t\t\tcolSpan: colspan,\n\t\t\t\tlabel: translate('kol-no-entries'),\n\t\t\t\trender: undefined,\n\t\t\t\trowSpan: Math.max(rowspan, 1),\n\t\t\t};\n\t\t\tif (dataField.length === 0) {\n\t\t\t\tdataField.push([emptyCell]);\n\t\t\t} else {\n\t\t\t\tdataField[0].push(emptyCell);\n\t\t\t}\n\t\t}\n\t\treturn dataField;\n\t}\n\n\tpublic componentWillLoad(): void {\n\t\tthis.validateData(this._data);\n\t\tthis.validateDataFoot(this._dataFoot);\n\t\tthis.validateHeaderCells(this._headerCells);\n\t\tthis.validateLabel(this._label);\n\t\tthis.validateMinWidth(this._minWidth);\n\t\tthis.validateOn(this._on);\n\t}\n\n\tprivate readonly renderTableRow = (row: KoliBriTableCell[], rowIndex: number): JSX.Element => {\n\t\treturn <tr key={`tbody-${rowIndex}`}>{row.map((col, colIndex) => this.renderTableCell(col, rowIndex, colIndex))}</tr>;\n\t};\n\n\tprivate readonly renderTableCell = (cell: KoliBriTableCell, rowIndex: number, colIndex: number): JSX.Element => {\n\t\tif (cell.asTd === false) {\n\t\t\treturn this.renderHeadingCell(cell, rowIndex, colIndex);\n\t\t} else {\n\t\t\treturn (\n\t\t\t\t<td\n\t\t\t\t\tkey={`tbody-${rowIndex}-${colIndex}-${cell.label}`}\n\t\t\t\t\tclass={{\n\t\t\t\t\t\t[cell.textAlign as string]: typeof cell.textAlign === 'string' && cell.textAlign.length > 0,\n\t\t\t\t\t}}\n\t\t\t\t\tcolSpan={cell.colSpan}\n\t\t\t\t\trowSpan={cell.rowSpan}\n\t\t\t\t\tstyle={{\n\t\t\t\t\t\ttextAlign: cell.textAlign,\n\t\t\t\t\t\twidth: cell.width,\n\t\t\t\t\t}}\n\t\t\t\t\tref={\n\t\t\t\t\t\ttypeof cell.render === 'function'\n\t\t\t\t\t\t\t? (el) => {\n\t\t\t\t\t\t\t\t\tthis.cellRender(cell as KoliBriTableHeaderCellAndData & { render: KoliBriTableRender }, el);\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t: undefined\n\t\t\t\t\t}\n\t\t\t\t>\n\t\t\t\t\t{typeof cell.render !== 'function' ? cell.label : ''}\n\t\t\t\t</td>\n\t\t\t);\n\t\t}\n\t};\n\n\tprivate renderHeadingCell(cell: KoliBriTableHeaderCell, rowIndex: number, colIndex: number): JSX.Element {\n\t\tlet ariaSort = undefined;\n\t\tlet sortButtonIcon = 'codicon codicon-fold';\n\n\t\tif (cell.sortDirection) {\n\t\t\tswitch (cell.sortDirection) {\n\t\t\t\tcase 'ASC':\n\t\t\t\t\tsortButtonIcon = 'codicon codicon-chevron-up';\n\t\t\t\t\tariaSort = 'ascending';\n\t\t\t\t\tbreak;\n\t\t\t\tcase 'DESC':\n\t\t\t\t\tsortButtonIcon = 'codicon codicon-chevron-down';\n\t\t\t\t\tariaSort = 'descending';\n\t\t\t\t\tbreak;\n\t\t\t}\n\t\t}\n\n\t\treturn (\n\t\t\t<th\n\t\t\t\tkey={`${rowIndex}-${colIndex}-${cell.label}`}\n\t\t\t\tclass={cell.textAlign ? `align-${cell.textAlign}` : undefined}\n\t\t\t\tscope={typeof cell.colSpan === 'number' && cell.colSpan > 1 ? 'colgroup' : 'col'}\n\t\t\t\tcolSpan={cell.colSpan}\n\t\t\t\trowSpan={cell.rowSpan}\n\t\t\t\tstyle={{\n\t\t\t\t\twidth: cell.width,\n\t\t\t\t}}\n\t\t\t\taria-sort={ariaSort}\n\t\t\t\tdata-sort={`sort-${cell.sortDirection}`}\n\t\t\t>\n\t\t\t\t{cell.sortDirection ? (\n\t\t\t\t\t<KolButtonWcTag\n\t\t\t\t\t\tclass=\"table-sort-button\"\n\t\t\t\t\t\texportparts=\"icon\"\n\t\t\t\t\t\t_icons={{ right: sortButtonIcon }}\n\t\t\t\t\t\t_label={cell.label}\n\t\t\t\t\t\t_on={{\n\t\t\t\t\t\t\tonClick: (event: MouseEvent) => {\n\t\t\t\t\t\t\t\tif (typeof this.state._on?.onSort === 'function' && cell.key && cell.sortDirection) {\n\t\t\t\t\t\t\t\t\tthis.state._on.onSort(event, {\n\t\t\t\t\t\t\t\t\t\tkey: cell.key,\n\t\t\t\t\t\t\t\t\t\tcurrentSortDirection: cell.sortDirection,\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\t},\n\t\t\t\t\t\t}}\n\t\t\t\t\t></KolButtonWcTag>\n\t\t\t\t) : (\n\t\t\t\t\tcell.label\n\t\t\t\t)}\n\t\t\t</th>\n\t\t);\n\t}\n\n\tprivate renderFoot(): JSX.Element {\n\t\tif (!this.state._dataFoot || this.state._dataFoot.length === 0) {\n\t\t\treturn '';\n\t\t}\n\n\t\tconst rows: KoliBriTableCell[][] = this.createDataField(this.state._dataFoot, this.state._headerCells, true);\n\t\treturn <tfoot>{rows.map(this.renderTableRow)}</tfoot>;\n\t}\n\n\tpublic render(): JSX.Element {\n\t\tconst dataField = this.createDataField(this.state._data, this.state._headerCells);\n\n\t\treturn (\n\t\t\t<Host class=\"kol-table-stateless\">\n\t\t\t\t{/* Firefox automatically makes the following div focusable when it has a scrollbar. We implement a similar behavior cross-browser by allowing the\n\t\t\t\t * <div class=\"focus-element\"> to receive focus. Hence, we disable focus for the div to avoid having two focusable elements by setting `tabindex=\"-1\"`\n\t\t\t\t */}\n\t\t\t\t{/* eslint-disable-next-line jsx-a11y/no-static-element-interactions */}\n\t\t\t\t<div ref={(element) => (this.tableDivElement = element)} class=\"table\" tabindex={this.tableDivElementHasScrollbar ? '-1' : undefined}>\n\t\t\t\t\t<table\n\t\t\t\t\t\tstyle={{\n\t\t\t\t\t\t\tminWidth: this.state._minWidth,\n\t\t\t\t\t\t}}\n\t\t\t\t\t>\n\t\t\t\t\t\t{/*\n\t\t\t\t\t\t * The following element allows the table to receive focus without providing redundant content to screen readers.\n\t\t\t\t\t\t * The `div` is technically not allowed here. But any allowed element would mutate the table semantics. Additionally, the ` ` is necessary to\n\t\t\t\t\t\t * prevent screen readers from just reading \"blank\".\n\t\t\t\t\t\t */}\n\t\t\t\t\t\t{/* eslint-disable-next-line jsx-a11y/no-noninteractive-tabindex */}\n\t\t\t\t\t\t<div class=\"focus-element\" tabindex={this.tableDivElementHasScrollbar ? '0' : undefined} aria-describedby=\"caption\">\n\t\t\t\t\t\t\t \n\t\t\t\t\t\t</div>\n\n\t\t\t\t\t\t<caption id=\"caption\">{this.state._label}</caption>\n\n\t\t\t\t\t\t{Array.isArray(this.state._headerCells.horizontal) && (\n\t\t\t\t\t\t\t<thead>\n\t\t\t\t\t\t\t\t{this.state._headerCells.horizontal.map((cols, rowIndex) => (\n\t\t\t\t\t\t\t\t\t<tr key={`thead-${rowIndex}`}>\n\t\t\t\t\t\t\t\t\t\t{cols.map((cell, colIndex) => {\n\t\t\t\t\t\t\t\t\t\t\tif (cell.asTd === true) {\n\t\t\t\t\t\t\t\t\t\t\t\treturn (\n\t\t\t\t\t\t\t\t\t\t\t\t\t<td\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tkey={`thead-${rowIndex}-${colIndex}-${cell.label}`}\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tclass={{\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t[cell.textAlign as string]: typeof cell.textAlign === 'string' && cell.textAlign.length > 0,\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t}}\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tcolSpan={cell.colSpan}\n\t\t\t\t\t\t\t\t\t\t\t\t\t\trowSpan={cell.rowSpan}\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tstyle={{\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\ttextAlign: cell.textAlign,\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\twidth: cell.width,\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t}}\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tref={\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\ttypeof cell.render === 'function'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t? (el) => {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tthis.cellRender(cell, el);\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t: undefined\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t{typeof cell.render !== 'function' ? cell.label : ''}\n\t\t\t\t\t\t\t\t\t\t\t\t\t</td>\n\t\t\t\t\t\t\t\t\t\t\t\t);\n\t\t\t\t\t\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t\t\t\t\t\treturn this.renderHeadingCell(cell, rowIndex, colIndex);\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</tr>\n\t\t\t\t\t\t\t\t))}\n\t\t\t\t\t\t\t</thead>\n\t\t\t\t\t\t)}\n\t\t\t\t\t\t<tbody>{dataField.map(this.renderTableRow)}</tbody>\n\t\t\t\t\t\t{this.renderFoot()}\n\t\t\t\t\t</table>\n\t\t\t\t</div>\n\t\t\t</Host>\n\t\t);\n\t}\n}\n"],"mappings":"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"}
|
@@ -0,0 +1,4 @@
|
|
1
|
+
/*!
|
2
|
+
* KoliBri - The accessible HTML-Standard
|
3
|
+
*/
|
4
|
+
import{r as n,h as e,H as t}from"./index-3fbcceca.js";import{q as i}from"./component-names-ed22f86e.js";const o="/*\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: 44px;\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 * Verdana is an accessible font that can be used without requiring additional loading time.\n */\n font-family: Verdana;\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 * 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 44px.\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%; /* 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}\n@layer kol-global {\n :host {\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 /* KolSpan is a layout component with icons in all directions and a label text in the middle. */\n .kol-span-wc {\n display: grid;\n place-items: center;\n }\n /* The sub span in KolSpan is the horizontal span with icon left and right and the label text in the middle. */\n .kol-span-wc > span {\n display: flex;\n place-items: center;\n }\n a,\n button {\n cursor: pointer;\n }\n .hidden {\n display: none;\n visibility: hidden;\n }\n /* This is the text label. */\n .hide-label > .kol-span-wc > span > span {\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-wc,\n [disabled]:focus .kol-span-wc {\n outline: none !important;\n }\n}\n@layer kol-component {\n :host {\n display: block;\n }\n}\n@layer kol-component {\n :host {\n display: block;\n font-size: calc(16rem / var(--kolibri-root-font-size, 16));\n }\n .table {\n max-width: 100%;\n overflow-x: auto;\n overflow-y: hidden;\n }\n table {\n width: 100%;\n }\n caption {\n text-align: start;\n }\n .focus-element {\n font-size: 0;\n }\n .focus-element:focus {\n outline: 0 !important;\n }\n .table:has(.focus-element:focus) {\n /* @see https://remysharp.com/til/css/focus-ring-default-styles */\n outline: 5px auto Highlight;\n outline: 5px auto -webkit-focus-ring-color;\n outline-offset: 2px;\n }\n .table-sort-button .button {\n color: inherit;\n }\n tbody th,\n th.align-left {\n text-align: left;\n }\n tbody th .table-sort-button .button-inner,\n th.align-left .table-sort-button .button-inner {\n justify-items: start;\n }\n th.align-center {\n text-align: center;\n }\n th.align-center .table-sort-button .button-inner {\n justify-items: center;\n }\n th.align-right {\n text-align: right;\n }\n th.align-right .table-sort-button .button-inner {\n justify-items: end;\n }\n}",a=o,s=class{constructor(t){n(this,t),this._data=void 0,this._dataFoot=void 0,this._headerCells=void 0,this._label=void 0,this._minWidth=void 0,this._on=void 0}render(){return e(t,{key:"4f1ac19dd85205d12ce291d06978889039b5b7b7",class:"kol-table-stateless"},e(i,{key:"07818093c07afa376810b5d2d4b3518e2c531226",_data:this._data,_dataFoot:this._dataFoot,_headerCells:this._headerCells,_label:this._label,_minWidth:this._minWidth,_on:this._on}))}};s.style={default:a};export{s as kol_table_stateless};
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"names":["defaultStyleCss","KolTableStatelessDefaultStyle0","KolTableStateless","render","h","Host","key","class","KolTableStatelessWcTag","_data","this","_dataFoot","_headerCells","_label","_minWidth","_on"],"sources":["src/components/table-stateless/style.scss?tag=kol-table-stateless&mode=default&encapsulation=shadow","src/components/table-stateless/shadow.tsx"],"sourcesContent":["@import '../@shared/mixins';\n@import '../style';\n@import '../host-display-block';\n\n@layer kol-component {\n\t:host {\n\t\tdisplay: block;\n\t\tfont-size: rem(16);\n\t}\n\n\t.table {\n\t\tmax-width: 100%;\n\t\toverflow-x: auto;\n\t\toverflow-y: hidden;\n\t}\n\n\ttable {\n\t\twidth: 100%;\n\t}\n\n\tcaption {\n\t\ttext-align: start;\n\t}\n\n\t.focus-element {\n\t\tfont-size: 0;\n\t}\n\n\t.focus-element:focus {\n\t\toutline: 0 !important;\n\t}\n\n\t.table:has(.focus-element:focus) {\n\t\t/* @see https://remysharp.com/til/css/focus-ring-default-styles */\n\t\toutline: 5px auto Highlight;\n\t\toutline: 5px auto -webkit-focus-ring-color;\n\t\toutline-offset: 2px;\n\t}\n\n\t.table-sort-button .button {\n\t\tcolor: inherit;\n\t}\n\n\ttbody th, // headings in table body default to text-align left, unless defined otherwise.\n\tth.align-left {\n\t\ttext-align: left;\n\n\t\t& .table-sort-button .button-inner {\n\t\t\tjustify-items: start;\n\t\t}\n\t}\n\n\tth.align-center {\n\t\ttext-align: center;\n\n\t\t& .table-sort-button .button-inner {\n\t\t\tjustify-items: center;\n\t\t}\n\t}\n\n\tth.align-right {\n\t\ttext-align: right;\n\n\t\t& .table-sort-button .button-inner {\n\t\t\tjustify-items: end;\n\t\t}\n\t}\n}\n","import type { JSX } from '@stencil/core';\nimport { Component, h, Host, Prop } from '@stencil/core';\n\nimport { KolTableStatelessWcTag } from '../../core/component-names';\nimport type { TableDataFootPropType, TableDataPropType, TableHeaderCellsPropType, TableStatelessProps, TableCallbacksPropType } from '@public-ui/schema';\n\n@Component({\n\ttag: 'kol-table-stateless',\n\tstyleUrls: {\n\t\tdefault: './style.scss',\n\t},\n\tshadow: true,\n})\nexport class KolTableStateless implements TableStatelessProps {\n\t/**\n\t * Defines the primary table data.\n\t */\n\t@Prop() public _data!: TableDataPropType;\n\n\t/**\n\t * Defines the data for the table footer.\n\t */\n\t@Prop() public _dataFoot?: TableDataFootPropType;\n\n\t/**\n\t * Defines the horizontal and vertical table headers.\n\t */\n\t@Prop() public _headerCells!: TableHeaderCellsPropType;\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!: string;\n\n\t/**\n\t * Defines the table min-width.\n\t */\n\t@Prop() public _minWidth?: string;\n\n\t/**\n\t * Defines the callback functions for table events.\n\t */\n\t@Prop() public _on?: TableCallbacksPropType;\n\n\tpublic render(): JSX.Element {\n\t\treturn (\n\t\t\t<Host class=\"kol-table-stateless\">\n\t\t\t\t<KolTableStatelessWcTag\n\t\t\t\t\t_data={this._data}\n\t\t\t\t\t_dataFoot={this._dataFoot}\n\t\t\t\t\t_headerCells={this._headerCells}\n\t\t\t\t\t_label={this._label}\n\t\t\t\t\t_minWidth={this._minWidth}\n\t\t\t\t\t_on={this._on}\n\t\t\t\t/>\n\t\t\t</Host>\n\t\t);\n\t}\n}\n"],"mappings":";;;wGAAA,MAAMA,EAAkB,gtKACxB,MAAAC,EAAeD,E,MCYFE,EAAiB,M,qKA+BtB,MAAAC,GACN,OACCC,EAACC,EAAI,CAAAC,IAAA,2CAACC,MAAM,uBACXH,EAACI,EAAsB,CAAAF,IAAA,2CACtBG,MAAOC,KAAKD,MACZE,UAAWD,KAAKC,UAChBC,aAAcF,KAAKE,aACnBC,OAAQH,KAAKG,OACbC,UAAWJ,KAAKI,UAChBC,IAAKL,KAAKK,M"}
|
@@ -1,4 +1,4 @@
|
|
1
1
|
/*!
|
2
2
|
* KoliBri - The accessible HTML-Standard
|
3
3
|
*/
|
4
|
-
import{r as t,h as e,H as n}from"./index-59e9528b.js";import{k as i,w as o,ap as s,aq as a,v as l,A as r,r as h,q as d,R as c}from"./index-fbc0a5be.js";import{t as f}from"./i18n-1e6a70ea.js";import{n as u,p,c as b}from"./component-names-61247f2f.js";import"./i18n-fddf0324.js";const y="/*\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: 44px;\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 * Verdana is an accessible font that can be used without requiring additional loading time.\n */\n font-family: Verdana;\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 * 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 44px.\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%; /* 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}\n@layer kol-global {\n :host {\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 /* KolSpan is a layout component with icons in all directions and a label text in the middle. */\n .kol-span-wc {\n display: grid;\n place-items: center;\n }\n /* The sub span in KolSpan is the horizontal span with icon left and right and the label text in the middle. */\n .kol-span-wc > span {\n display: flex;\n place-items: center;\n }\n a,\n button {\n cursor: pointer;\n }\n .hidden {\n display: none;\n visibility: hidden;\n }\n /* This is the text label. */\n .hide-label > .kol-span-wc > span > span {\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-wc,\n [disabled]:focus .kol-span-wc {\n outline: none !important;\n }\n}\n@layer kol-component {\n :host {\n display: block;\n }\n}\n@layer kol-component {\n :host {\n display: grid;\n }\n :host > div.table {\n max-width: 100%;\n overflow-x: auto;\n overflow-y: hidden;\n }\n :host > div.table table {\n width: 100%;\n }\n caption {\n text-align: start;\n }\n .focus-element {\n font-size: 0;\n }\n .focus-element:focus {\n outline: 0 !important;\n }\n .table:has(.focus-element:focus) {\n /* @see https://remysharp.com/til/css/focus-ring-default-styles */\n outline: 5px auto Highlight;\n outline: 5px auto -webkit-focus-ring-color;\n outline-offset: 2px;\n }\n .table-sort-button .button {\n color: inherit;\n }\n th.align-left {\n text-align: left;\n }\n th.align-left .table-sort-button .button-inner {\n justify-items: start;\n }\n th.align-center {\n text-align: center;\n }\n th.align-center .table-sort-button .button-inner {\n justify-items: center;\n }\n th.align-right {\n text-align: right;\n }\n th.align-right .table-sort-button .button-inner {\n justify-items: end;\n }\n div.pagination .kol-pagination {\n display: flex;\n flex-wrap: wrap;\n }\n div.pagination,\n div.pagination > div:last-child {\n display: grid;\n place-items: center;\n }\n @media (max-width: 1024px) {\n div.pagination .kol-pagination {\n flex-direction: column;\n }\n }\n @media (min-width: 1024px) {\n div.pagination,\n div.pagination > div:last-child {\n grid-auto-flow: column;\n }\n div.pagination .kol-pagination {\n display: flex;\n }\n }\n}",g=y,m=[10,20,50,100],v=new Map,w=t=>!0===t||""===t||"object"==typeof t&&null!==t,k=class{constructor(n){t(this,n),this.horizontal=!0,this.sortDirections=new Map,this.sortData=[],this.showPagination=!1,this.pageStartSlice=0,this.pageEndSlice=10,this.disableSort=!1,this.sortedColumnHead={label:"",key:"",sortDirection:"NOS"},this.setSortDirection=(t,e)=>{this.sortDirections.clear(),this.sortDirections.set(t,e),this.sortFunction=t},this.handlePagination={onClick:(t,e)=>{var n;"function"==typeof(null===(n=this.state._pagination._on)||void 0===n?void 0:n.onClick)&&this.state._pagination._on.onClick(t,e),i(this,"_pagination",Object.assign(Object.assign({},this.state._pagination),{_page:e}))},onChangePage:(t,e)=>{var n;"function"==typeof(null===(n=this.state._pagination._on)||void 0===n?void 0:n.onChangePage)&&this.state._pagination._on.onChangePage(t,e),i(this,"_pagination",Object.assign(Object.assign({},this.state._pagination),{_page:e}))},onChangePageSize:(t,e)=>{var n;"function"==typeof(null===(n=this.state._pagination._on)||void 0===n?void 0:n.onChangePageSize)&&this.state._pagination._on.onChangePageSize(t,e),i(this,"_pagination",Object.assign(Object.assign({},this.state._pagination),{_pageSize:e})),i(this,"_pageSize",e)}},this.updateSortedData=(t=this.sortedColumnHead)=>{if(this.disableSort)return void i(this,"_sortedData",this.state._data);let e=this.state._data;if(this.sortData.length>0)e=this.state._data.sort(((t,e)=>{for(let i=0;i<this.sortData.length;i++){const n=this.sortData[i],a=n.compareFn(t,e);if(0!==a)return"ASC"===n.direction?a:-a}return 0}));else if("function"==typeof this.sortFunction)switch(this.sortDirections.get(this.sortFunction)){case"ASC":e=this.sortFunction([...this.state._data]),this.sortedColumnHead={label:t.label,key:t.key,sortDirection:"ASC"};break;case"DESC":e=this.sortFunction([...this.state._data]).reverse(),this.sortedColumnHead={label:t.label,key:t.key,sortDirection:"DESC"};break;default:e=[...this.state._data],this.sortedColumnHead={label:"",key:"",sortDirection:"NOS"}}i(this,"_sortedData",e)},this.renderTableRow=(t,i)=>e("tr",{key:`tbody-${i}`},t.map(((t,e)=>this.renderTableCell(t,i,e)))),this.renderTableCell=(t,i,n)=>{if(!1===t.asTd){const a=t;let o,s="NOS",l="codicon codicon-fold";if(!this.disableSort){if(a.key){const t=this.sortData.find((t=>t.key===a.key));if(t)switch(s=t.direction,t.direction){case"ASC":l="codicon codicon-chevron-up",o="ascending";break;case"DESC":l="codicon codicon-chevron-down",o="descending"}}if(a.key===this.sortedColumnHead.key)switch(s=this.sortedColumnHead.sortDirection,this.sortedColumnHead.sortDirection){case"ASC":l="codicon codicon-chevron-up",o="ascending";break;case"DESC":l="codicon codicon-chevron-down",o="descending"}}return e("th",{key:`tbody-${i}-${n}-${a.label}`,scope:"number"==typeof a.rowSpan&&a.rowSpan>1?"rowgroup":"row",colSpan:a.colSpan,rowSpan:a.rowSpan,style:{textAlign:a.textAlign,width:a.width},"aria-sort":o,"data-sort":`sort-${s}`},e("div",{class:"w-full flex gap-1 items-center"},e("div",{class:{"w-full":!0,[a.textAlign]:"string"==typeof a.textAlign&&a.textAlign.length>0},style:{textAlign:a.textAlign}},a.label),!this.disableSort&&("function"==typeof a.compareFn||"function"==typeof a.sort)&&e(u,{exportparts:"icon",_icons:l,_hideLabel:!0,_label:f("kol-change-order",{placeholders:{colLabel:a.label}}),_on:{onClick:()=>this.changeCellSort(a)},_variant:"ghost"})))}return e("td",{key:`tbody-${i}-${n}-${t.label}`,class:{[t.textAlign]:"string"==typeof t.textAlign&&t.textAlign.length>0},colSpan:t.colSpan,rowSpan:t.rowSpan,style:{textAlign:t.textAlign,width:t.width},ref:"function"==typeof t.render?e=>{this.cellRender(t,e)}:void 0},"function"!=typeof t.render?t.label:"")},this.renderFoot=()=>{const t=this.createDataField(this.state._dataFoot,this.state._headers,!0);return e("tfoot",null,t.map(this.renderTableRow))},this.tableDivElementHasScrollbar=!1,this._allowMultiSort=void 0,this._data=void 0,this._dataFoot=void 0,this._headers=void 0,this._label=void 0,this._minWidth=void 0,this._pagination=void 0,this._paginationPosition="bottom",this.state={_allowMultiSort:!1,_data:[],_dataFoot:[],_headers:{horizontal:[],vertical:[]},_label:"",_pagination:{_page:1,_pageSize:10,_max:0},_sortedData:[],_paginationPosition:"bottom"}}validateAllowMultiSort(t){o(this,"_allowMultiSort",(()=>!0),new Set(["boolean"]),t,{defaultValue:!1})}validateData(t){s(t,(()=>{d(t,(()=>{void 0===t&&(t=[]);try{t=h(t)}catch(t){}Array.isArray(t)&&void 0===t.find((t=>!("object"==typeof t&&null!==t)))&&i(this,"_data",t,{afterPatch:()=>{setTimeout(this.updateSortedData)}})}))}))}validateDataFoot(t){s(t,(()=>{d(t,(()=>{void 0===t&&(t=[]);try{t=h(t)}catch(t){}Array.isArray(t)&&void 0===t.find((t=>!("object"==typeof t&&null!==t)))&&i(this,"_dataFoot",t,{afterPatch:()=>{setTimeout(this.updateSortedData)}})}))}))}validatePaginationPosition(t){a(this,t)}changeCellSort(t){var e;if("function"==typeof t.compareFn){this.state._allowMultiSort||t.key==(null===(e=this.sortData[0])||void 0===e?void 0:e.key)||(this.sortData=[]);const i=this.sortData.findIndex((e=>e.key===t.key));if(i>=0){const t=this.sortData[i];switch(t.direction){case"ASC":t.direction="DESC";break;case"DESC":this.sortData.splice(i,1);break;default:t.direction="ASC"}}else t.key&&this.sortData.push({label:t.label,key:t.key,compareFn:t.compareFn,direction:"ASC"});this.updateSortedData(t)}else if("function"==typeof t.sort){switch(this.sortFunction=t.sort,this.sortDirections.get(this.sortFunction)){case"ASC":this.setSortDirection(this.sortFunction,"DESC");break;case"DESC":this.setSortDirection(this.sortFunction,"NOS");break;default:this.setSortDirection(this.sortFunction,"ASC")}this.updateSortedData(t)}}validateHeaders(t){s(t,(()=>{d(t,(()=>{try{t=h(t)}catch(t){}o(this,"_headers",(t=>"object"==typeof t&&null!==t),new Set(["KoliBriTableHeaders"]),t,{hooks:{beforePatch:t=>{var e,i,n,a;const o=t=>{let e=!1;t.forEach((t=>{const i=t.key;if(!i)return;const n=t.sortDirection;"ASC"!==n&&"DESC"!==n||("function"==typeof t.compareFn?((this.state._allowMultiSort||0===this.sortData.length)&&this.sortData.push({label:t.label,key:i,compareFn:t.compareFn,direction:n}),e=!0):"function"==typeof t.sort&&(this.setSortDirection(t.sort,n),setTimeout((()=>this.updateSortedData({key:i,label:t.label,sortDirection:n})))))})),e&&setTimeout((()=>this.updateSortedData()))},s=t;null===(e=s.horizontal)||void 0===e||e.forEach(o),null===(i=s.vertical)||void 0===i||i.forEach(o),s.horizontal&&s.vertical&&(null===(n=s.horizontal)||void 0===n?void 0:n.length)>0&&(null===(a=s.vertical)||void 0===a?void 0:a.length)>0&&(this.disableSort=!0,c("Table: You can not sort the table data, if horizontal and vertical headers are defined at the same time. (https://github.com/public-ui/kolibri/issues/2372)"))}}})}))}))}validateLabel(t){l(this,t,{required:!0})}validateMinWidth(t){r(this,"_minWidth",t,{defaultValue:void 0})}validatePagination(t){try{t=h(t)}catch(t){}this.showPagination=w(t),o(this,"_pagination",w,new Set(["boolean","KoliBriTablePagination"]),t,{defaultValue:{_page:1,_pageSize:10,_max:0}})}componentDidRender(){this.checkDivElementScrollbar()}componentDidLoad(){this.tableDivElement&&ResizeObserver&&(this.tableDivElementResizeObserver=new ResizeObserver(this.checkDivElementScrollbar.bind(this)),this.tableDivElementResizeObserver.observe(this.tableDivElement))}disconnectedCallback(){var t;null===(t=this.tableDivElementResizeObserver)||void 0===t||t.disconnect()}checkDivElementScrollbar(){this.tableDivElement&&(this.tableDivElementHasScrollbar=this.tableDivElement.scrollWidth>this.tableDivElement.clientWidth)}componentWillLoad(){this.validateAllowMultiSort(this._allowMultiSort),this.validateData(this._data),this.validateDataFoot(this._dataFoot),this.validateHeaders(this._headers),this.validateLabel(this._label),this.validateMinWidth(this._minWidth),this.validatePagination(this._pagination),this.validatePaginationPosition(this._paginationPosition)}getNumberOfCols(t,e){let i=0;return t.forEach((t=>{let e=0;t.forEach((t=>{var i;return e+=null!==(i=t.colSpan)&&void 0!==i?i:1})),i<e&&(i=e)})),0===i&&(i=e.length),i}getNumberOfRows(t,e){let i=0;return t.forEach((t=>{let e=0;t.forEach((t=>{var i;return e+=null!==(i=t.rowSpan)&&void 0!==i?i:1})),i<e&&(i=e)})),0===i?i=e.length:i-=this.state._dataFoot.length,i}filterHeaderKeys(t){const e=[];return t.forEach((t=>{t.forEach((t=>{"string"==typeof t.key&&e.push(t)}))})),e}getPrimaryHeader(t){var e,i;let n=this.filterHeaderKeys(null!==(e=t.horizontal)&&void 0!==e?e:[]);return this.horizontal=!0,0===n.length&&(n=this.filterHeaderKeys(null!==(i=t.vertical)&&void 0!==i?i:[]),n.length>0&&(this.horizontal=!1)),n}createDataField(t,e,i){e.horizontal=Array.isArray(null==e?void 0:e.horizontal)?e.horizontal:[],e.vertical=Array.isArray(null==e?void 0:e.vertical)?e.vertical:[];const n=this.getPrimaryHeader(e),a=this.getNumberOfCols(e.horizontal,t);let o=this.getNumberOfRows(e.vertical,t),s=0;i&&(s=o,o+=this.state._dataFoot.length);const l=[],r=[],h=[];e.vertical.forEach(((t,e)=>{r[e]=0,h[e]=[]}));for(let d=s;d<o;d++){const o=[];e.vertical.forEach(((t,e)=>{let i=0;if(h[e].forEach((t=>i+=t)),i<=d){const n=t[d-i+r[e]];if("object"==typeof n){o.push(Object.assign(Object.assign({},n),{asTd:!1,data:{}}));let t=1;if("number"==typeof n.rowSpan&&n.rowSpan>1&&(t=n.rowSpan),h[e].push(t),"number"==typeof n.colSpan&&n.colSpan>1)for(let i=1;i<n.colSpan;i++)h[e+i].push(t);r[e]++}}}));for(let e=0;e<a;e++)if(!0===this.horizontal){const a=i?this.state._dataFoot[d-s]:t[d];"object"==typeof n[e]&&null!==n[e]&&"string"==typeof n[e].key&&"object"==typeof a&&null!==a&&o.push(Object.assign(Object.assign({},n[e]),{colSpan:void 0,data:a,label:a[n[e].key],rowSpan:void 0}))}else"object"==typeof n[d]&&null!==n[d]&&"string"==typeof n[d].key&&"object"==typeof t[e]&&null!==t[e]&&o.push(Object.assign(Object.assign({},n[d]),{colSpan:void 0,data:t[e],label:t[e][n[d].key],rowSpan:void 0}));l.push(o)}if(0===t.length){let t=0,i=0;Array.isArray(e.horizontal)&&e.horizontal.length>0&&e.horizontal[0].forEach((e=>{t+=e.colSpan||1})),Array.isArray(e.vertical)&&e.vertical.length>0&&(t-=e.vertical.length,e.vertical[0].forEach((t=>{i+=t.rowSpan||1})));const n={colSpan:t,label:f("kol-no-entries"),render:void 0,rowSpan:Math.max(i,1)};0===l.length?l.push([n]):l[0].push(n)}return l}selectDisplayedData(t,e,i){return"number"==typeof e&&e>0&&"number"==typeof i&&i>0?(this.pageStartSlice=e*(i-1),this.pageEndSlice=e*i>t.length?t.length:e*i,t.slice(this.pageStartSlice,this.pageEndSlice)):(this.pageStartSlice=0,this.pageEndSlice=t.length,t)}cellRender(t,e){e&&(clearTimeout(v.get(e)),v.set(e,setTimeout((()=>{clearTimeout(v.get(e));const i=t.render(e,{asTd:t.asTd,label:t.label,textAlign:t.textAlign,width:t.width},t.data,this.state._data);"string"==typeof i&&(e.textContent=i)}))))}renderPagination(){return e("div",{class:"pagination"},e("span",null,f("kol-table-visible-range",{placeholders:{start:this.pageEndSlice>0?(this.pageStartSlice+1).toString():"0",end:this.pageEndSlice.toString(),total:this.state._pagination&&this.state._pagination._max>0?this.state._pagination._max.toString():Array.isArray(this.state._data)?this.state._data.length.toString():"0"}})),e("div",null,e(p,{_boundaryCount:this.state._pagination._boundaryCount,_customClass:this.state._pagination._customClass,_on:this.handlePagination,_page:this.state._pagination._page,_pageSize:this.state._pagination._pageSize,_pageSizeOptions:this.state._pagination._pageSizeOptions||m,_siblingCount:this.state._pagination._siblingCount,_tooltipAlign:"bottom",_max:this.state._pagination._max||this.state._pagination._max||this.state._data.length,_label:f("kol-table-pagination-label",{placeholders:{label:this.state._label}})})))}render(){var t,i;const a=this.selectDisplayedData(this.state._sortedData,this.showPagination?null!==(i=null===(t=this.state._pagination)||void 0===t?void 0:t._pageSize)&&void 0!==i?i:10:this.state._sortedData.length,this.state._pagination._page||1),o=this.createDataField(a,this.state._headers),s="top"===this._paginationPosition||"both"===this._paginationPosition?this.renderPagination():null,l="bottom"===this._paginationPosition||"both"===this._paginationPosition?this.renderPagination():null;return e(n,{key:"2b05c0fcb4ff1576d9e31a517910e2126bcd3354",class:"kol-table"},this.pageEndSlice>0&&this.showPagination&&s,e("div",{key:"c361cb54593621e925e56e24d90cf0944a011699",ref:t=>this.tableDivElement=t,class:"table",tabindex:this.tableDivElementHasScrollbar?"-1":void 0},e("table",{key:"85e471dddaf9aa95cd698c014ff3e00bca5dc6e4",style:{minWidth:this.state._minWidth}},e("div",{key:"72557a01697e6de00f088f6c853fc600d52b0615",class:"focus-element",tabindex:this.tableDivElementHasScrollbar?"0":void 0,"aria-describedby":"caption"}," "),e("caption",{key:"c8c35eea8ae078be986e74d815282f6db952599f",id:"caption"},this.state._label),Array.isArray(this.state._headers.horizontal)&&e("thead",{key:"5bf87f24164ed0784997395c397aed64f9052a1a"},this.state._headers.horizontal.map(((t,i)=>e("tr",{key:`thead-${i}`},t.map(((t,n)=>{if(!0===t.asTd)return e("td",{key:`thead-${i}-${n}-${t.label}`,class:{[t.textAlign]:"string"==typeof t.textAlign&&t.textAlign.length>0},colSpan:t.colSpan,rowSpan:t.rowSpan,style:{textAlign:t.textAlign,width:t.width},ref:"function"==typeof t.render?e=>{this.cellRender(t,e)}:void 0},"function"!=typeof t.render?t.label:"");{const a=t;let o,s="NOS",l="codicon codicon-fold";if(a.key){const t=this.sortData.find((t=>t.key===a.key));if(t)switch(s=t.direction,t.direction){case"ASC":l="codicon codicon-chevron-up",o="ascending";break;case"DESC":l="codicon codicon-chevron-down",o="descending"}}if(a.key===this.sortedColumnHead.key)switch(s=this.sortedColumnHead.sortDirection,this.sortedColumnHead.sortDirection){case"ASC":l="codicon codicon-chevron-up",o="ascending";break;case"DESC":l="codicon codicon-chevron-down",o="descending"}return e("th",{class:t.textAlign?`align-${t.textAlign}`:void 0,key:`thead-${i}-${n}-${a.label}`,scope:"number"==typeof a.colSpan&&a.colSpan>1?"colgroup":"col",colSpan:a.colSpan,rowSpan:a.rowSpan,style:{width:t.width},"aria-sort":o,"data-sort":`sort-${s}`},this.disableSort||"function"!=typeof a.compareFn&&"function"!=typeof a.sort?t.label:e(b,{class:"table-sort-button",exportparts:"icon",_icons:{right:l},_label:t.label,_on:{onClick:()=>this.changeCellSort(a)}}))}})))))),e("tbody",{key:"0f56a29c8542cad9a6558009e3a4684fc822a44f"},o.map(this.renderTableRow)),this.state._dataFoot.length>0?this.renderFoot():"")),this.pageEndSlice>0&&this.showPagination&&l)}static get watchers(){return{_allowMultiSort:["validateAllowMultiSort"],_data:["validateData"],_dataFoot:["validateDataFoot"],_paginationPosition:["validatePaginationPosition"],_headers:["validateHeaders"],_label:["validateLabel"],_minWidth:["validateMinWidth"],_pagination:["validatePagination"]}}};k.style={default:g};export{k as kol_table};
|
4
|
+
import{r as t,h as i}from"./index-3fbcceca.js";import{p as e}from"./component-names-ed22f86e.js";const s=class{constructor(i){t(this,i),this._allowMultiSort=void 0,this._data=void 0,this._dataFoot=void 0,this._headers=void 0,this._label=void 0,this._minWidth=void 0,this._pagination=void 0,this._paginationPosition="bottom"}render(){return i(e,{key:"94800c6fdc5cfe781fa9edfe7e4c5fe366ff052b",_allowMultiSort:this._allowMultiSort,_data:this._data,_dataFoot:this._dataFoot,_headers:this._headers,_label:this._label,_minWidth:this._minWidth,_pagination:this._pagination,_paginationPosition:this._paginationPosition})}};export{s as kol_table};
|