@vielzeug/buildit 2.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +124 -0
- package/dist/accordion-item.cjs +32 -0
- package/dist/accordion-item.cjs.map +1 -0
- package/dist/accordion-item.js +72 -0
- package/dist/accordion-item.js.map +1 -0
- package/dist/accordion.cjs +2 -0
- package/dist/accordion.cjs.map +1 -0
- package/dist/accordion.js +37 -0
- package/dist/accordion.js.map +1 -0
- package/dist/alert.cjs +31 -0
- package/dist/alert.cjs.map +1 -0
- package/dist/alert.js +85 -0
- package/dist/alert.js.map +1 -0
- package/dist/avatar.cjs +37 -0
- package/dist/avatar.cjs.map +1 -0
- package/dist/avatar.js +123 -0
- package/dist/avatar.js.map +1 -0
- package/dist/badge.cjs +7 -0
- package/dist/badge.cjs.map +1 -0
- package/dist/badge.js +60 -0
- package/dist/badge.js.map +1 -0
- package/dist/box.cjs +2 -0
- package/dist/box.cjs.map +1 -0
- package/dist/box.js +22 -0
- package/dist/box.js.map +1 -0
- package/dist/breadcrumb.cjs +21 -0
- package/dist/breadcrumb.cjs.map +1 -0
- package/dist/breadcrumb.js +58 -0
- package/dist/breadcrumb.js.map +1 -0
- package/dist/buildit.cjs +1892 -0
- package/dist/buildit.cjs.map +1 -0
- package/dist/buildit.js +1892 -0
- package/dist/buildit.js.map +1 -0
- package/dist/button-group.cjs +6 -0
- package/dist/button-group.cjs.map +1 -0
- package/dist/button-group.js +31 -0
- package/dist/button-group.js.map +1 -0
- package/dist/button.cjs +30 -0
- package/dist/button.cjs.map +1 -0
- package/dist/button.js +115 -0
- package/dist/button.js.map +1 -0
- package/dist/card.cjs +23 -0
- package/dist/card.cjs.map +1 -0
- package/dist/card.js +99 -0
- package/dist/card.js.map +1 -0
- package/dist/checkbox-group.cjs +20 -0
- package/dist/checkbox-group.cjs.map +1 -0
- package/dist/checkbox-group.js +88 -0
- package/dist/checkbox-group.js.map +1 -0
- package/dist/checkbox.cjs +37 -0
- package/dist/checkbox.cjs.map +1 -0
- package/dist/checkbox.js +115 -0
- package/dist/checkbox.js.map +1 -0
- package/dist/chip.cjs +56 -0
- package/dist/chip.cjs.map +1 -0
- package/dist/chip.js +140 -0
- package/dist/chip.js.map +1 -0
- package/dist/combobox.cjs +93 -0
- package/dist/combobox.cjs.map +1 -0
- package/dist/combobox.js +401 -0
- package/dist/combobox.js.map +1 -0
- package/dist/content/avatar/avatar-group.css?inline.cjs +2 -0
- package/dist/content/avatar/avatar-group.css?inline.cjs.map +1 -0
- package/dist/content/avatar/avatar-group.css?inline.js +6 -0
- package/dist/content/avatar/avatar-group.css?inline.js.map +1 -0
- package/dist/content/avatar/avatar.css?inline.cjs +2 -0
- package/dist/content/avatar/avatar.css?inline.cjs.map +1 -0
- package/dist/content/avatar/avatar.css?inline.js +6 -0
- package/dist/content/avatar/avatar.css?inline.js.map +1 -0
- package/dist/content/avatar/avatar.d.ts +78 -0
- package/dist/content/avatar/avatar.d.ts.map +1 -0
- package/dist/content/breadcrumb/breadcrumb-item.css?inline.cjs +2 -0
- package/dist/content/breadcrumb/breadcrumb-item.css?inline.cjs.map +1 -0
- package/dist/content/breadcrumb/breadcrumb-item.css?inline.js +6 -0
- package/dist/content/breadcrumb/breadcrumb-item.css?inline.js.map +1 -0
- package/dist/content/breadcrumb/breadcrumb.css?inline.cjs +2 -0
- package/dist/content/breadcrumb/breadcrumb.css?inline.cjs.map +1 -0
- package/dist/content/breadcrumb/breadcrumb.css?inline.js +6 -0
- package/dist/content/breadcrumb/breadcrumb.css?inline.js.map +1 -0
- package/dist/content/breadcrumb/breadcrumb.d.ts +36 -0
- package/dist/content/breadcrumb/breadcrumb.d.ts.map +1 -0
- package/dist/content/card/card.css?inline.cjs +2 -0
- package/dist/content/card/card.css?inline.cjs.map +1 -0
- package/dist/content/card/card.css?inline.js +6 -0
- package/dist/content/card/card.css?inline.js.map +1 -0
- package/dist/content/card/card.d.ts +66 -0
- package/dist/content/card/card.d.ts.map +1 -0
- package/dist/content/index.cjs +1 -0
- package/dist/content/index.d.ts +15 -0
- package/dist/content/index.d.ts.map +1 -0
- package/dist/content/index.js +7 -0
- package/dist/content/pagination/pagination.css?inline.cjs +2 -0
- package/dist/content/pagination/pagination.css?inline.cjs.map +1 -0
- package/dist/content/pagination/pagination.css?inline.js +6 -0
- package/dist/content/pagination/pagination.css?inline.js.map +1 -0
- package/dist/content/pagination/pagination.d.ts +56 -0
- package/dist/content/pagination/pagination.d.ts.map +1 -0
- package/dist/content/separator/separator.css?inline.cjs +2 -0
- package/dist/content/separator/separator.css?inline.cjs.map +1 -0
- package/dist/content/separator/separator.css?inline.js +6 -0
- package/dist/content/separator/separator.css?inline.js.map +1 -0
- package/dist/content/separator/separator.d.ts +35 -0
- package/dist/content/separator/separator.d.ts.map +1 -0
- package/dist/content/table/table.css?inline.cjs +2 -0
- package/dist/content/table/table.css?inline.cjs.map +1 -0
- package/dist/content/table/table.css?inline.js +6 -0
- package/dist/content/table/table.css?inline.js.map +1 -0
- package/dist/content/table/table.d.ts +69 -0
- package/dist/content/table/table.d.ts.map +1 -0
- package/dist/content/text/text.css?inline.cjs +2 -0
- package/dist/content/text/text.css?inline.cjs.map +1 -0
- package/dist/content/text/text.css?inline.js +6 -0
- package/dist/content/text/text.css?inline.js.map +1 -0
- package/dist/content/text/text.d.ts +55 -0
- package/dist/content/text/text.d.ts.map +1 -0
- package/dist/craftit/dist/core/internal.cjs +2 -0
- package/dist/craftit/dist/core/internal.cjs.map +1 -0
- package/dist/craftit/dist/core/internal.js +25 -0
- package/dist/craftit/dist/core/internal.js.map +1 -0
- package/dist/craftit/dist/core/runtime-bindings.cjs +2 -0
- package/dist/craftit/dist/core/runtime-bindings.cjs.map +1 -0
- package/dist/craftit/dist/core/runtime-bindings.js +38 -0
- package/dist/craftit/dist/core/runtime-bindings.js.map +1 -0
- package/dist/craftit/dist/core/runtime-lifecycle.cjs +2 -0
- package/dist/craftit/dist/core/runtime-lifecycle.cjs.map +1 -0
- package/dist/craftit/dist/core/runtime-lifecycle.js +68 -0
- package/dist/craftit/dist/core/runtime-lifecycle.js.map +1 -0
- package/dist/craftit/dist/core/runtime.cjs +1 -0
- package/dist/craftit/dist/core/runtime.js +2 -0
- package/dist/craftit/dist/core/utilities.cjs +2 -0
- package/dist/craftit/dist/core/utilities.cjs.map +1 -0
- package/dist/craftit/dist/core/utilities.js +12 -0
- package/dist/craftit/dist/core/utilities.js.map +1 -0
- package/dist/craftit/dist/directives/attr.cjs +2 -0
- package/dist/craftit/dist/directives/attr.cjs.map +1 -0
- package/dist/craftit/dist/directives/attr.js +13 -0
- package/dist/craftit/dist/directives/attr.js.map +1 -0
- package/dist/craftit/dist/directives/bind.cjs +1 -0
- package/dist/craftit/dist/directives/bind.js +3 -0
- package/dist/craftit/dist/directives/choose.cjs +1 -0
- package/dist/craftit/dist/directives/choose.js +1 -0
- package/dist/craftit/dist/directives/classes.cjs +2 -0
- package/dist/craftit/dist/directives/classes.cjs.map +1 -0
- package/dist/craftit/dist/directives/classes.js +12 -0
- package/dist/craftit/dist/directives/classes.js.map +1 -0
- package/dist/craftit/dist/directives/each.cjs +2 -0
- package/dist/craftit/dist/directives/each.cjs.map +1 -0
- package/dist/craftit/dist/directives/each.js +96 -0
- package/dist/craftit/dist/directives/each.js.map +1 -0
- package/dist/craftit/dist/directives/index.cjs +1 -0
- package/dist/craftit/dist/directives/index.js +12 -0
- package/dist/craftit/dist/directives/match.cjs +1 -0
- package/dist/craftit/dist/directives/match.js +1 -0
- package/dist/craftit/dist/directives/memo.cjs +1 -0
- package/dist/craftit/dist/directives/memo.js +1 -0
- package/dist/craftit/dist/directives/raw.cjs +1 -0
- package/dist/craftit/dist/directives/raw.js +2 -0
- package/dist/craftit/dist/directives/spread.cjs +2 -0
- package/dist/craftit/dist/directives/spread.cjs.map +1 -0
- package/dist/craftit/dist/directives/spread.js +30 -0
- package/dist/craftit/dist/directives/spread.js.map +1 -0
- package/dist/craftit/dist/directives/style.cjs +1 -0
- package/dist/craftit/dist/directives/style.js +1 -0
- package/dist/craftit/dist/directives/until.cjs +1 -0
- package/dist/craftit/dist/directives/until.js +1 -0
- package/dist/craftit/dist/directives/when.cjs +2 -0
- package/dist/craftit/dist/directives/when.cjs.map +1 -0
- package/dist/craftit/dist/directives/when.js +14 -0
- package/dist/craftit/dist/directives/when.js.map +1 -0
- package/dist/craftit/dist/labs/a11y.cjs +2 -0
- package/dist/craftit/dist/labs/a11y.cjs.map +1 -0
- package/dist/craftit/dist/labs/a11y.js +38 -0
- package/dist/craftit/dist/labs/a11y.js.map +1 -0
- package/dist/craftit/dist/labs/list.cjs +2 -0
- package/dist/craftit/dist/labs/list.cjs.map +1 -0
- package/dist/craftit/dist/labs/list.js +87 -0
- package/dist/craftit/dist/labs/list.js.map +1 -0
- package/dist/craftit/dist/labs/observers.cjs +2 -0
- package/dist/craftit/dist/labs/observers.cjs.map +1 -0
- package/dist/craftit/dist/labs/observers.js +28 -0
- package/dist/craftit/dist/labs/observers.js.map +1 -0
- package/dist/craftit/dist/labs/overlay.cjs +2 -0
- package/dist/craftit/dist/labs/overlay.cjs.map +1 -0
- package/dist/craftit/dist/labs/overlay.js +49 -0
- package/dist/craftit/dist/labs/overlay.js.map +1 -0
- package/dist/craftit/dist/labs/selectable.cjs +2 -0
- package/dist/craftit/dist/labs/selectable.cjs.map +1 -0
- package/dist/craftit/dist/labs/selectable.js +29 -0
- package/dist/craftit/dist/labs/selectable.js.map +1 -0
- package/dist/craftit/dist/labs/selection.cjs +2 -0
- package/dist/craftit/dist/labs/selection.cjs.map +1 -0
- package/dist/craftit/dist/labs/selection.js +42 -0
- package/dist/craftit/dist/labs/selection.js.map +1 -0
- package/dist/craftit/dist/labs.cjs +1 -0
- package/dist/craftit/dist/labs.js +6 -0
- package/dist/custom-elements.json +2321 -0
- package/dist/dialog.cjs +33 -0
- package/dist/dialog.cjs.map +1 -0
- package/dist/dialog.js +94 -0
- package/dist/dialog.js.map +1 -0
- package/dist/disclosure/accordion/accordion.css?inline.cjs +2 -0
- package/dist/disclosure/accordion/accordion.css?inline.cjs.map +1 -0
- package/dist/disclosure/accordion/accordion.css?inline.js +6 -0
- package/dist/disclosure/accordion/accordion.css?inline.js.map +1 -0
- package/dist/disclosure/accordion/accordion.d.ts +47 -0
- package/dist/disclosure/accordion/accordion.d.ts.map +1 -0
- package/dist/disclosure/accordion-item/accordion-item.css?inline.cjs +2 -0
- package/dist/disclosure/accordion-item/accordion-item.css?inline.cjs.map +1 -0
- package/dist/disclosure/accordion-item/accordion-item.css?inline.js +6 -0
- package/dist/disclosure/accordion-item/accordion-item.css?inline.js.map +1 -0
- package/dist/disclosure/accordion-item/accordion-item.d.ts +62 -0
- package/dist/disclosure/accordion-item/accordion-item.d.ts.map +1 -0
- package/dist/disclosure/index.cjs +1 -0
- package/dist/disclosure/index.d.ts +11 -0
- package/dist/disclosure/index.d.ts.map +1 -0
- package/dist/disclosure/index.js +5 -0
- package/dist/disclosure/tab-item/tab-item.css?inline.cjs +2 -0
- package/dist/disclosure/tab-item/tab-item.css?inline.cjs.map +1 -0
- package/dist/disclosure/tab-item/tab-item.css?inline.js +6 -0
- package/dist/disclosure/tab-item/tab-item.css?inline.js.map +1 -0
- package/dist/disclosure/tab-item/tab-item.d.ts +39 -0
- package/dist/disclosure/tab-item/tab-item.d.ts.map +1 -0
- package/dist/disclosure/tab-panel/tab-panel.css?inline.cjs +2 -0
- package/dist/disclosure/tab-panel/tab-panel.css?inline.cjs.map +1 -0
- package/dist/disclosure/tab-panel/tab-panel.css?inline.js +6 -0
- package/dist/disclosure/tab-panel/tab-panel.css?inline.js.map +1 -0
- package/dist/disclosure/tab-panel/tab-panel.d.ts +30 -0
- package/dist/disclosure/tab-panel/tab-panel.d.ts.map +1 -0
- package/dist/disclosure/tabs/tabs.css?inline.cjs +2 -0
- package/dist/disclosure/tabs/tabs.css?inline.cjs.map +1 -0
- package/dist/disclosure/tabs/tabs.css?inline.js +6 -0
- package/dist/disclosure/tabs/tabs.css?inline.js.map +1 -0
- package/dist/disclosure/tabs/tabs.d.ts +64 -0
- package/dist/disclosure/tabs/tabs.d.ts.map +1 -0
- package/dist/drawer.cjs +31 -0
- package/dist/drawer.cjs.map +1 -0
- package/dist/drawer.js +98 -0
- package/dist/drawer.js.map +1 -0
- package/dist/feedback/alert/alert.css?inline.cjs +2 -0
- package/dist/feedback/alert/alert.css?inline.cjs.map +1 -0
- package/dist/feedback/alert/alert.css?inline.js +6 -0
- package/dist/feedback/alert/alert.css?inline.js.map +1 -0
- package/dist/feedback/alert/alert.d.ts +63 -0
- package/dist/feedback/alert/alert.d.ts.map +1 -0
- package/dist/feedback/badge/badge.css?inline.cjs +2 -0
- package/dist/feedback/badge/badge.css?inline.cjs.map +1 -0
- package/dist/feedback/badge/badge.css?inline.js +6 -0
- package/dist/feedback/badge/badge.css?inline.js.map +1 -0
- package/dist/feedback/badge/badge.d.ts +67 -0
- package/dist/feedback/badge/badge.d.ts.map +1 -0
- package/dist/feedback/chip/chip.css?inline.cjs +2 -0
- package/dist/feedback/chip/chip.css?inline.cjs.map +1 -0
- package/dist/feedback/chip/chip.css?inline.js +6 -0
- package/dist/feedback/chip/chip.css?inline.js.map +1 -0
- package/dist/feedback/chip/chip.d.ts +124 -0
- package/dist/feedback/chip/chip.d.ts.map +1 -0
- package/dist/feedback/index.cjs +1 -0
- package/dist/feedback/index.d.ts +13 -0
- package/dist/feedback/index.d.ts.map +1 -0
- package/dist/feedback/index.js +6 -0
- package/dist/feedback/progress/progress.css?inline.cjs +2 -0
- package/dist/feedback/progress/progress.css?inline.cjs.map +1 -0
- package/dist/feedback/progress/progress.css?inline.js +6 -0
- package/dist/feedback/progress/progress.css?inline.js.map +1 -0
- package/dist/feedback/progress/progress.d.ts +64 -0
- package/dist/feedback/progress/progress.d.ts.map +1 -0
- package/dist/feedback/skeleton/skeleton.css?inline.cjs +2 -0
- package/dist/feedback/skeleton/skeleton.css?inline.cjs.map +1 -0
- package/dist/feedback/skeleton/skeleton.css?inline.js +6 -0
- package/dist/feedback/skeleton/skeleton.css?inline.js.map +1 -0
- package/dist/feedback/skeleton/skeleton.d.ts +61 -0
- package/dist/feedback/skeleton/skeleton.d.ts.map +1 -0
- package/dist/feedback/toast/index.d.ts +2 -0
- package/dist/feedback/toast/index.d.ts.map +1 -0
- package/dist/feedback/toast/toast.css?inline.cjs +2 -0
- package/dist/feedback/toast/toast.css?inline.cjs.map +1 -0
- package/dist/feedback/toast/toast.css?inline.js +6 -0
- package/dist/feedback/toast/toast.css?inline.js.map +1 -0
- package/dist/feedback/toast/toast.d.ts +95 -0
- package/dist/feedback/toast/toast.d.ts.map +1 -0
- package/dist/file-input.cjs +66 -0
- package/dist/file-input.cjs.map +1 -0
- package/dist/file-input.js +210 -0
- package/dist/file-input.js.map +1 -0
- package/dist/form.cjs +11 -0
- package/dist/form.cjs.map +1 -0
- package/dist/form.js +49 -0
- package/dist/form.js.map +1 -0
- package/dist/grid-item.cjs +2 -0
- package/dist/grid-item.cjs.map +1 -0
- package/dist/grid-item.js +28 -0
- package/dist/grid-item.js.map +1 -0
- package/dist/grid.cjs +2 -0
- package/dist/grid.cjs.map +1 -0
- package/dist/grid.js +90 -0
- package/dist/grid.js.map +1 -0
- package/dist/icons.cjs +176 -0
- package/dist/icons.cjs.map +1 -0
- package/dist/icons.d.ts +15 -0
- package/dist/icons.d.ts.map +1 -0
- package/dist/icons.js +181 -0
- package/dist/icons.js.map +1 -0
- package/dist/index.cjs +1 -0
- package/dist/index.d.ts +9 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +53 -0
- package/dist/input.cjs +48 -0
- package/dist/input.cjs.map +1 -0
- package/dist/input.js +182 -0
- package/dist/input.js.map +1 -0
- package/dist/inputs/button/button.css?inline.cjs +2 -0
- package/dist/inputs/button/button.css?inline.cjs.map +1 -0
- package/dist/inputs/button/button.css?inline.js +6 -0
- package/dist/inputs/button/button.css?inline.js.map +1 -0
- package/dist/inputs/button/button.d.ts +73 -0
- package/dist/inputs/button/button.d.ts.map +1 -0
- package/dist/inputs/button-group/button-group.css?inline.cjs +2 -0
- package/dist/inputs/button-group/button-group.css?inline.cjs.map +1 -0
- package/dist/inputs/button-group/button-group.css?inline.js +6 -0
- package/dist/inputs/button-group/button-group.css?inline.js.map +1 -0
- package/dist/inputs/button-group/button-group.d.ts +52 -0
- package/dist/inputs/button-group/button-group.d.ts.map +1 -0
- package/dist/inputs/checkbox/checkbox.css?inline.cjs +2 -0
- package/dist/inputs/checkbox/checkbox.css?inline.cjs.map +1 -0
- package/dist/inputs/checkbox/checkbox.css?inline.js +6 -0
- package/dist/inputs/checkbox/checkbox.css?inline.js.map +1 -0
- package/dist/inputs/checkbox/checkbox.d.ts +43 -0
- package/dist/inputs/checkbox/checkbox.d.ts.map +1 -0
- package/dist/inputs/checkbox-group/checkbox-group.css?inline.cjs +2 -0
- package/dist/inputs/checkbox-group/checkbox-group.css?inline.cjs.map +1 -0
- package/dist/inputs/checkbox-group/checkbox-group.css?inline.js +6 -0
- package/dist/inputs/checkbox-group/checkbox-group.css?inline.js.map +1 -0
- package/dist/inputs/checkbox-group/checkbox-group.d.ts +56 -0
- package/dist/inputs/checkbox-group/checkbox-group.d.ts.map +1 -0
- package/dist/inputs/combobox/combobox-options.cjs +2 -0
- package/dist/inputs/combobox/combobox-options.cjs.map +1 -0
- package/dist/inputs/combobox/combobox-options.d.ts +7 -0
- package/dist/inputs/combobox/combobox-options.d.ts.map +1 -0
- package/dist/inputs/combobox/combobox-options.js +36 -0
- package/dist/inputs/combobox/combobox-options.js.map +1 -0
- package/dist/inputs/combobox/combobox-virtualizer.cjs +2 -0
- package/dist/inputs/combobox/combobox-virtualizer.cjs.map +1 -0
- package/dist/inputs/combobox/combobox-virtualizer.d.ts +20 -0
- package/dist/inputs/combobox/combobox-virtualizer.d.ts.map +1 -0
- package/dist/inputs/combobox/combobox-virtualizer.js +71 -0
- package/dist/inputs/combobox/combobox-virtualizer.js.map +1 -0
- package/dist/inputs/combobox/combobox.css?inline.cjs +2 -0
- package/dist/inputs/combobox/combobox.css?inline.cjs.map +1 -0
- package/dist/inputs/combobox/combobox.css?inline.js +6 -0
- package/dist/inputs/combobox/combobox.css?inline.js.map +1 -0
- package/dist/inputs/combobox/combobox.d.ts +28 -0
- package/dist/inputs/combobox/combobox.d.ts.map +1 -0
- package/dist/inputs/combobox/combobox.types.d.ts +36 -0
- package/dist/inputs/combobox/combobox.types.d.ts.map +1 -0
- package/dist/inputs/file-input/file-input.css?inline.cjs +2 -0
- package/dist/inputs/file-input/file-input.css?inline.cjs.map +1 -0
- package/dist/inputs/file-input/file-input.css?inline.js +6 -0
- package/dist/inputs/file-input/file-input.css?inline.js.map +1 -0
- package/dist/inputs/file-input/file-input.d.ts +94 -0
- package/dist/inputs/file-input/file-input.d.ts.map +1 -0
- package/dist/inputs/form/form.css?inline.cjs +2 -0
- package/dist/inputs/form/form.css?inline.cjs.map +1 -0
- package/dist/inputs/form/form.css?inline.js +6 -0
- package/dist/inputs/form/form.css?inline.js.map +1 -0
- package/dist/inputs/form/form.d.ts +61 -0
- package/dist/inputs/form/form.d.ts.map +1 -0
- package/dist/inputs/index.cjs +1 -0
- package/dist/inputs/index.d.ts +38 -0
- package/dist/inputs/index.d.ts.map +1 -0
- package/dist/inputs/index.js +18 -0
- package/dist/inputs/input/input.css?inline.cjs +2 -0
- package/dist/inputs/input/input.css?inline.cjs.map +1 -0
- package/dist/inputs/input/input.css?inline.js +6 -0
- package/dist/inputs/input/input.css?inline.js.map +1 -0
- package/dist/inputs/input/input.d.ts +82 -0
- package/dist/inputs/input/input.d.ts.map +1 -0
- package/dist/inputs/number-input/number-input.css?inline.cjs +2 -0
- package/dist/inputs/number-input/number-input.css?inline.cjs.map +1 -0
- package/dist/inputs/number-input/number-input.css?inline.js +6 -0
- package/dist/inputs/number-input/number-input.css?inline.js.map +1 -0
- package/dist/inputs/number-input/number-input.d.ts +76 -0
- package/dist/inputs/number-input/number-input.d.ts.map +1 -0
- package/dist/inputs/otp-input/otp-input.css?inline.cjs +2 -0
- package/dist/inputs/otp-input/otp-input.css?inline.cjs.map +1 -0
- package/dist/inputs/otp-input/otp-input.css?inline.js +6 -0
- package/dist/inputs/otp-input/otp-input.css?inline.js.map +1 -0
- package/dist/inputs/otp-input/otp-input.d.ts +71 -0
- package/dist/inputs/otp-input/otp-input.d.ts.map +1 -0
- package/dist/inputs/radio/radio.css?inline.cjs +2 -0
- package/dist/inputs/radio/radio.css?inline.cjs.map +1 -0
- package/dist/inputs/radio/radio.css?inline.js +6 -0
- package/dist/inputs/radio/radio.css?inline.js.map +1 -0
- package/dist/inputs/radio/radio.d.ts +41 -0
- package/dist/inputs/radio/radio.d.ts.map +1 -0
- package/dist/inputs/radio-group/radio-group.css?inline.cjs +2 -0
- package/dist/inputs/radio-group/radio-group.css?inline.cjs.map +1 -0
- package/dist/inputs/radio-group/radio-group.css?inline.js +6 -0
- package/dist/inputs/radio-group/radio-group.css?inline.js.map +1 -0
- package/dist/inputs/radio-group/radio-group.d.ts +61 -0
- package/dist/inputs/radio-group/radio-group.d.ts.map +1 -0
- package/dist/inputs/rating/rating.css?inline.cjs +2 -0
- package/dist/inputs/rating/rating.css?inline.cjs.map +1 -0
- package/dist/inputs/rating/rating.css?inline.js +6 -0
- package/dist/inputs/rating/rating.css?inline.js.map +1 -0
- package/dist/inputs/rating/rating.d.ts +48 -0
- package/dist/inputs/rating/rating.d.ts.map +1 -0
- package/dist/inputs/select/select.css?inline.cjs +2 -0
- package/dist/inputs/select/select.css?inline.cjs.map +1 -0
- package/dist/inputs/select/select.css?inline.js +6 -0
- package/dist/inputs/select/select.css?inline.js.map +1 -0
- package/dist/inputs/select/select.d.ts +79 -0
- package/dist/inputs/select/select.d.ts.map +1 -0
- package/dist/inputs/shared/base-props.d.ts +39 -0
- package/dist/inputs/shared/base-props.d.ts.map +1 -0
- package/dist/inputs/shared/composables/index.cjs +1 -0
- package/dist/inputs/shared/composables/index.d.ts +3 -0
- package/dist/inputs/shared/composables/index.d.ts.map +1 -0
- package/dist/inputs/shared/composables/index.js +2 -0
- package/dist/inputs/shared/composables/use-text-field.cjs +2 -0
- package/dist/inputs/shared/composables/use-text-field.cjs.map +1 -0
- package/dist/inputs/shared/composables/use-text-field.d.ts +33 -0
- package/dist/inputs/shared/composables/use-text-field.d.ts.map +1 -0
- package/dist/inputs/shared/composables/use-text-field.js +41 -0
- package/dist/inputs/shared/composables/use-text-field.js.map +1 -0
- package/dist/inputs/shared/composables/use-toggle-field.cjs +2 -0
- package/dist/inputs/shared/composables/use-toggle-field.cjs.map +1 -0
- package/dist/inputs/shared/composables/use-toggle-field.d.ts +18 -0
- package/dist/inputs/shared/composables/use-toggle-field.d.ts.map +1 -0
- package/dist/inputs/shared/composables/use-toggle-field.js +26 -0
- package/dist/inputs/shared/composables/use-toggle-field.js.map +1 -0
- package/dist/inputs/shared/design-presets.cjs +2 -0
- package/dist/inputs/shared/design-presets.cjs.map +1 -0
- package/dist/inputs/shared/design-presets.d.ts +97 -0
- package/dist/inputs/shared/design-presets.d.ts.map +1 -0
- package/dist/inputs/shared/design-presets.js +92 -0
- package/dist/inputs/shared/design-presets.js.map +1 -0
- package/dist/inputs/shared/dom-sync/dropdown.cjs +2 -0
- package/dist/inputs/shared/dom-sync/dropdown.cjs.map +1 -0
- package/dist/inputs/shared/dom-sync/dropdown.d.ts +7 -0
- package/dist/inputs/shared/dom-sync/dropdown.d.ts.map +1 -0
- package/dist/inputs/shared/dom-sync/dropdown.js +30 -0
- package/dist/inputs/shared/dom-sync/dropdown.js.map +1 -0
- package/dist/inputs/shared/dom-sync/field-sync.cjs +2 -0
- package/dist/inputs/shared/dom-sync/field-sync.cjs.map +1 -0
- package/dist/inputs/shared/dom-sync/field-sync.d.ts +36 -0
- package/dist/inputs/shared/dom-sync/field-sync.d.ts.map +1 -0
- package/dist/inputs/shared/dom-sync/field-sync.js +37 -0
- package/dist/inputs/shared/dom-sync/field-sync.js.map +1 -0
- package/dist/inputs/shared/dom-sync/form-context.cjs +2 -0
- package/dist/inputs/shared/dom-sync/form-context.cjs.map +1 -0
- package/dist/inputs/shared/dom-sync/form-context.d.ts +18 -0
- package/dist/inputs/shared/dom-sync/form-context.d.ts.map +1 -0
- package/dist/inputs/shared/dom-sync/form-context.js +20 -0
- package/dist/inputs/shared/dom-sync/form-context.js.map +1 -0
- package/dist/inputs/shared/dom-sync/index.cjs +1 -0
- package/dist/inputs/shared/dom-sync/index.d.ts +5 -0
- package/dist/inputs/shared/dom-sync/index.d.ts.map +1 -0
- package/dist/inputs/shared/dom-sync/index.js +4 -0
- package/dist/inputs/shared/dom-sync/label-sync.cjs +2 -0
- package/dist/inputs/shared/dom-sync/label-sync.cjs.map +1 -0
- package/dist/inputs/shared/dom-sync/label-sync.d.ts +16 -0
- package/dist/inputs/shared/dom-sync/label-sync.d.ts.map +1 -0
- package/dist/inputs/shared/dom-sync/label-sync.js +12 -0
- package/dist/inputs/shared/dom-sync/label-sync.js.map +1 -0
- package/dist/inputs/shared/form-context.cjs +2 -0
- package/dist/inputs/shared/form-context.cjs.map +1 -0
- package/dist/inputs/shared/form-context.d.ts +19 -0
- package/dist/inputs/shared/form-context.d.ts.map +1 -0
- package/dist/inputs/shared/form-context.js +7 -0
- package/dist/inputs/shared/form-context.js.map +1 -0
- package/dist/inputs/shared/utils/assistive-text.cjs +2 -0
- package/dist/inputs/shared/utils/assistive-text.cjs.map +1 -0
- package/dist/inputs/shared/utils/assistive-text.d.ts +24 -0
- package/dist/inputs/shared/utils/assistive-text.d.ts.map +1 -0
- package/dist/inputs/shared/utils/assistive-text.js +37 -0
- package/dist/inputs/shared/utils/assistive-text.js.map +1 -0
- package/dist/inputs/shared/utils/choice-change.cjs +2 -0
- package/dist/inputs/shared/utils/choice-change.cjs.map +1 -0
- package/dist/inputs/shared/utils/choice-change.d.ts +8 -0
- package/dist/inputs/shared/utils/choice-change.d.ts.map +1 -0
- package/dist/inputs/shared/utils/choice-change.js +13 -0
- package/dist/inputs/shared/utils/choice-change.js.map +1 -0
- package/dist/inputs/shared/utils/controlled-csv.cjs +2 -0
- package/dist/inputs/shared/utils/controlled-csv.cjs.map +1 -0
- package/dist/inputs/shared/utils/controlled-csv.d.ts +8 -0
- package/dist/inputs/shared/utils/controlled-csv.d.ts.map +1 -0
- package/dist/inputs/shared/utils/controlled-csv.js +15 -0
- package/dist/inputs/shared/utils/controlled-csv.js.map +1 -0
- package/dist/inputs/shared/utils/field-values.cjs +2 -0
- package/dist/inputs/shared/utils/field-values.cjs.map +1 -0
- package/dist/inputs/shared/utils/field-values.d.ts +5 -0
- package/dist/inputs/shared/utils/field-values.d.ts.map +1 -0
- package/dist/inputs/shared/utils/field-values.js +13 -0
- package/dist/inputs/shared/utils/field-values.js.map +1 -0
- package/dist/inputs/shared/utils/index.d.ts +5 -0
- package/dist/inputs/shared/utils/index.d.ts.map +1 -0
- package/dist/inputs/shared/validation/index.cjs +2 -0
- package/dist/inputs/shared/validation/index.cjs.map +1 -0
- package/dist/inputs/shared/validation/index.d.ts +14 -0
- package/dist/inputs/shared/validation/index.d.ts.map +1 -0
- package/dist/inputs/shared/validation/index.js +13 -0
- package/dist/inputs/shared/validation/index.js.map +1 -0
- package/dist/inputs/slider/slider.css?inline.cjs +2 -0
- package/dist/inputs/slider/slider.css?inline.cjs.map +1 -0
- package/dist/inputs/slider/slider.css?inline.js +6 -0
- package/dist/inputs/slider/slider.css?inline.js.map +1 -0
- package/dist/inputs/slider/slider.d.ts +82 -0
- package/dist/inputs/slider/slider.d.ts.map +1 -0
- package/dist/inputs/switch/switch.css?inline.cjs +2 -0
- package/dist/inputs/switch/switch.css?inline.cjs.map +1 -0
- package/dist/inputs/switch/switch.css?inline.js +6 -0
- package/dist/inputs/switch/switch.css?inline.js.map +1 -0
- package/dist/inputs/switch/switch.d.ts +40 -0
- package/dist/inputs/switch/switch.d.ts.map +1 -0
- package/dist/inputs/textarea/textarea.css?inline.cjs +2 -0
- package/dist/inputs/textarea/textarea.css?inline.cjs.map +1 -0
- package/dist/inputs/textarea/textarea.css?inline.js +6 -0
- package/dist/inputs/textarea/textarea.css?inline.js.map +1 -0
- package/dist/inputs/textarea/textarea.d.ts +57 -0
- package/dist/inputs/textarea/textarea.d.ts.map +1 -0
- package/dist/layout/box/box.css?inline.cjs +2 -0
- package/dist/layout/box/box.css?inline.cjs.map +1 -0
- package/dist/layout/box/box.css?inline.js +6 -0
- package/dist/layout/box/box.css?inline.js.map +1 -0
- package/dist/layout/box/box.d.ts +52 -0
- package/dist/layout/box/box.d.ts.map +1 -0
- package/dist/layout/grid/grid.css?inline.cjs +2 -0
- package/dist/layout/grid/grid.css?inline.cjs.map +1 -0
- package/dist/layout/grid/grid.css?inline.js +6 -0
- package/dist/layout/grid/grid.css?inline.js.map +1 -0
- package/dist/layout/grid/grid.d.ts +105 -0
- package/dist/layout/grid/grid.d.ts.map +1 -0
- package/dist/layout/grid-item/grid-item.css?inline.cjs +2 -0
- package/dist/layout/grid-item/grid-item.css?inline.cjs.map +1 -0
- package/dist/layout/grid-item/grid-item.css?inline.js +6 -0
- package/dist/layout/grid-item/grid-item.css?inline.js.map +1 -0
- package/dist/layout/grid-item/grid-item.d.ts +47 -0
- package/dist/layout/grid-item/grid-item.d.ts.map +1 -0
- package/dist/layout/index.cjs +1 -0
- package/dist/layout/index.d.ts +9 -0
- package/dist/layout/index.d.ts.map +1 -0
- package/dist/layout/index.js +4 -0
- package/dist/layout/sidebar/sidebar-group.css?inline.cjs +2 -0
- package/dist/layout/sidebar/sidebar-group.css?inline.cjs.map +1 -0
- package/dist/layout/sidebar/sidebar-group.css?inline.js +6 -0
- package/dist/layout/sidebar/sidebar-group.css?inline.js.map +1 -0
- package/dist/layout/sidebar/sidebar-item.css?inline.cjs +2 -0
- package/dist/layout/sidebar/sidebar-item.css?inline.cjs.map +1 -0
- package/dist/layout/sidebar/sidebar-item.css?inline.js +6 -0
- package/dist/layout/sidebar/sidebar-item.css?inline.js.map +1 -0
- package/dist/layout/sidebar/sidebar.css?inline.cjs +2 -0
- package/dist/layout/sidebar/sidebar.css?inline.cjs.map +1 -0
- package/dist/layout/sidebar/sidebar.css?inline.js +6 -0
- package/dist/layout/sidebar/sidebar.css?inline.js.map +1 -0
- package/dist/layout/sidebar/sidebar.d.ts +190 -0
- package/dist/layout/sidebar/sidebar.d.ts.map +1 -0
- package/dist/menu.cjs +133 -0
- package/dist/menu.cjs.map +1 -0
- package/dist/menu.js +296 -0
- package/dist/menu.js.map +1 -0
- package/dist/number-input.cjs +55 -0
- package/dist/number-input.cjs.map +1 -0
- package/dist/number-input.js +158 -0
- package/dist/number-input.js.map +1 -0
- package/dist/otp-input.cjs +22 -0
- package/dist/otp-input.cjs.map +1 -0
- package/dist/otp-input.js +120 -0
- package/dist/otp-input.js.map +1 -0
- package/dist/overlay/dialog/dialog.css?inline.cjs +2 -0
- package/dist/overlay/dialog/dialog.css?inline.cjs.map +1 -0
- package/dist/overlay/dialog/dialog.css?inline.js +6 -0
- package/dist/overlay/dialog/dialog.css?inline.js.map +1 -0
- package/dist/overlay/dialog/dialog.d.ts +98 -0
- package/dist/overlay/dialog/dialog.d.ts.map +1 -0
- package/dist/overlay/drawer/drawer.css?inline.cjs +2 -0
- package/dist/overlay/drawer/drawer.css?inline.cjs.map +1 -0
- package/dist/overlay/drawer/drawer.css?inline.js +6 -0
- package/dist/overlay/drawer/drawer.css?inline.js.map +1 -0
- package/dist/overlay/drawer/drawer.d.ts +98 -0
- package/dist/overlay/drawer/drawer.d.ts.map +1 -0
- package/dist/overlay/index.cjs +1 -0
- package/dist/overlay/index.d.ts +11 -0
- package/dist/overlay/index.d.ts.map +1 -0
- package/dist/overlay/index.js +5 -0
- package/dist/overlay/menu/menu.css?inline.cjs +2 -0
- package/dist/overlay/menu/menu.css?inline.cjs.map +1 -0
- package/dist/overlay/menu/menu.css?inline.js +6 -0
- package/dist/overlay/menu/menu.css?inline.js.map +1 -0
- package/dist/overlay/menu/menu.d.ts +45 -0
- package/dist/overlay/menu/menu.d.ts.map +1 -0
- package/dist/overlay/popover/popover.css?inline.cjs +2 -0
- package/dist/overlay/popover/popover.css?inline.cjs.map +1 -0
- package/dist/overlay/popover/popover.css?inline.js +6 -0
- package/dist/overlay/popover/popover.css?inline.js.map +1 -0
- package/dist/overlay/popover/popover.d.ts +56 -0
- package/dist/overlay/popover/popover.d.ts.map +1 -0
- package/dist/overlay/tooltip/tooltip.css?inline.cjs +2 -0
- package/dist/overlay/tooltip/tooltip.css?inline.cjs.map +1 -0
- package/dist/overlay/tooltip/tooltip.css?inline.js +6 -0
- package/dist/overlay/tooltip/tooltip.css?inline.js.map +1 -0
- package/dist/overlay/tooltip/tooltip.d.ts +55 -0
- package/dist/overlay/tooltip/tooltip.d.ts.map +1 -0
- package/dist/pagination.cjs +102 -0
- package/dist/pagination.cjs.map +1 -0
- package/dist/pagination.js +168 -0
- package/dist/pagination.js.map +1 -0
- package/dist/popover.cjs +16 -0
- package/dist/popover.cjs.map +1 -0
- package/dist/popover.js +110 -0
- package/dist/popover.js.map +1 -0
- package/dist/progress.cjs +51 -0
- package/dist/progress.cjs.map +1 -0
- package/dist/progress.js +90 -0
- package/dist/progress.js.map +1 -0
- package/dist/radio-group.cjs +20 -0
- package/dist/radio-group.cjs.map +1 -0
- package/dist/radio-group.js +104 -0
- package/dist/radio-group.js.map +1 -0
- package/dist/radio.cjs +16 -0
- package/dist/radio.cjs.map +1 -0
- package/dist/radio.js +135 -0
- package/dist/radio.js.map +1 -0
- package/dist/rating.cjs +37 -0
- package/dist/rating.cjs.map +1 -0
- package/dist/rating.js +123 -0
- package/dist/rating.js.map +1 -0
- package/dist/select.cjs +77 -0
- package/dist/select.cjs.map +1 -0
- package/dist/select.js +317 -0
- package/dist/select.js.map +1 -0
- package/dist/separator.cjs +26 -0
- package/dist/separator.cjs.map +1 -0
- package/dist/separator.js +46 -0
- package/dist/separator.js.map +1 -0
- package/dist/sidebar.cjs +69 -0
- package/dist/sidebar.cjs.map +1 -0
- package/dist/sidebar.js +202 -0
- package/dist/sidebar.js.map +1 -0
- package/dist/skeleton.cjs +10 -0
- package/dist/skeleton.cjs.map +1 -0
- package/dist/skeleton.js +56 -0
- package/dist/skeleton.js.map +1 -0
- package/dist/slider.cjs +24 -0
- package/dist/slider.cjs.map +1 -0
- package/dist/slider.js +209 -0
- package/dist/slider.js.map +1 -0
- package/dist/stateit/dist/computed.cjs +2 -0
- package/dist/stateit/dist/computed.cjs.map +1 -0
- package/dist/stateit/dist/computed.js +65 -0
- package/dist/stateit/dist/computed.js.map +1 -0
- package/dist/stateit/dist/effect.cjs +2 -0
- package/dist/stateit/dist/effect.cjs.map +1 -0
- package/dist/stateit/dist/effect.js +53 -0
- package/dist/stateit/dist/effect.js.map +1 -0
- package/dist/stateit/dist/index.cjs +1 -0
- package/dist/stateit/dist/index.js +5 -0
- package/dist/stateit/dist/runtime.cjs +2 -0
- package/dist/stateit/dist/runtime.cjs.map +1 -0
- package/dist/stateit/dist/runtime.js +43 -0
- package/dist/stateit/dist/runtime.js.map +1 -0
- package/dist/stateit/dist/signal.cjs +2 -0
- package/dist/stateit/dist/signal.cjs.map +1 -0
- package/dist/stateit/dist/signal.js +27 -0
- package/dist/stateit/dist/signal.js.map +1 -0
- package/dist/stateit/dist/store.cjs +2 -0
- package/dist/stateit/dist/store.cjs.map +1 -0
- package/dist/stateit/dist/store.js +17 -0
- package/dist/stateit/dist/store.js.map +1 -0
- package/dist/stateit/dist/types.cjs +2 -0
- package/dist/stateit/dist/types.cjs.map +1 -0
- package/dist/stateit/dist/types.js +6 -0
- package/dist/stateit/dist/types.js.map +1 -0
- package/dist/styles/animation.css +87 -0
- package/dist/styles/index.cjs +2 -0
- package/dist/styles/index.cjs.map +1 -0
- package/dist/styles/index.d.ts +48 -0
- package/dist/styles/index.d.ts.map +1 -0
- package/dist/styles/index.js +26 -0
- package/dist/styles/index.js.map +1 -0
- package/dist/styles/layer.css +18 -0
- package/dist/styles/mixins/accessibility.css.cjs +15 -0
- package/dist/styles/mixins/accessibility.css.cjs.map +1 -0
- package/dist/styles/mixins/accessibility.css.d.ts +46 -0
- package/dist/styles/mixins/accessibility.css.d.ts.map +1 -0
- package/dist/styles/mixins/accessibility.css.js +20 -0
- package/dist/styles/mixins/accessibility.css.js.map +1 -0
- package/dist/styles/mixins/animation.css.cjs +71 -0
- package/dist/styles/mixins/animation.css.cjs.map +1 -0
- package/dist/styles/mixins/animation.css.d.ts +22 -0
- package/dist/styles/mixins/animation.css.d.ts.map +1 -0
- package/dist/styles/mixins/animation.css.js +90 -0
- package/dist/styles/mixins/animation.css.js.map +1 -0
- package/dist/styles/mixins/shape.css.cjs +72 -0
- package/dist/styles/mixins/shape.css.cjs.map +1 -0
- package/dist/styles/mixins/shape.css.d.ts +97 -0
- package/dist/styles/mixins/shape.css.d.ts.map +1 -0
- package/dist/styles/mixins/shape.css.js +104 -0
- package/dist/styles/mixins/shape.css.js.map +1 -0
- package/dist/styles/mixins/states.css.cjs +18 -0
- package/dist/styles/mixins/states.css.cjs.map +1 -0
- package/dist/styles/mixins/states.css.d.ts +61 -0
- package/dist/styles/mixins/states.css.d.ts.map +1 -0
- package/dist/styles/mixins/states.css.js +26 -0
- package/dist/styles/mixins/states.css.js.map +1 -0
- package/dist/styles/mixins/theme.css.cjs +146 -0
- package/dist/styles/mixins/theme.css.cjs.map +1 -0
- package/dist/styles/mixins/theme.css.d.ts +93 -0
- package/dist/styles/mixins/theme.css.d.ts.map +1 -0
- package/dist/styles/mixins/theme.css.js +151 -0
- package/dist/styles/mixins/theme.css.js.map +1 -0
- package/dist/styles/mixins/variants.css.cjs +84 -0
- package/dist/styles/mixins/variants.css.cjs.map +1 -0
- package/dist/styles/mixins/variants.css.d.ts +22 -0
- package/dist/styles/mixins/variants.css.d.ts.map +1 -0
- package/dist/styles/mixins/variants.css.js +89 -0
- package/dist/styles/mixins/variants.css.js.map +1 -0
- package/dist/styles/preflight.css +237 -0
- package/dist/styles/styles.css +5 -0
- package/dist/styles/theme.css +457 -0
- package/dist/switch.cjs +16 -0
- package/dist/switch.cjs.map +1 -0
- package/dist/switch.js +82 -0
- package/dist/switch.js.map +1 -0
- package/dist/tab-item.cjs +17 -0
- package/dist/tab-item.cjs.map +1 -0
- package/dist/tab-item.js +57 -0
- package/dist/tab-item.js.map +1 -0
- package/dist/tab-panel.cjs +14 -0
- package/dist/tab-panel.cjs.map +1 -0
- package/dist/tab-panel.js +51 -0
- package/dist/tab-panel.js.map +1 -0
- package/dist/table.cjs +2 -0
- package/dist/table.cjs.map +1 -0
- package/dist/table.js +101 -0
- package/dist/table.js.map +1 -0
- package/dist/tabs.cjs +17 -0
- package/dist/tabs.cjs.map +1 -0
- package/dist/tabs.js +98 -0
- package/dist/tabs.js.map +1 -0
- package/dist/text.cjs +2 -0
- package/dist/text.cjs.map +1 -0
- package/dist/text.js +30 -0
- package/dist/text.js.map +1 -0
- package/dist/textarea.cjs +16 -0
- package/dist/textarea.cjs.map +1 -0
- package/dist/textarea.js +122 -0
- package/dist/textarea.js.map +1 -0
- package/dist/toast.cjs +63 -0
- package/dist/toast.cjs.map +1 -0
- package/dist/toast.js +221 -0
- package/dist/toast.js.map +1 -0
- package/dist/tooltip.cjs +15 -0
- package/dist/tooltip.cjs.map +1 -0
- package/dist/tooltip.js +111 -0
- package/dist/tooltip.js.map +1 -0
- package/dist/types/index.d.ts +7 -0
- package/dist/types/index.d.ts.map +1 -0
- package/dist/types/shared.d.ts +120 -0
- package/dist/types/shared.d.ts.map +1 -0
- package/dist/utils/animation.cjs +2 -0
- package/dist/utils/animation.cjs.map +1 -0
- package/dist/utils/animation.d.ts +2 -0
- package/dist/utils/animation.d.ts.map +1 -0
- package/dist/utils/animation.js +29 -0
- package/dist/utils/animation.js.map +1 -0
- package/dist/utils/background-lock.cjs +2 -0
- package/dist/utils/background-lock.cjs.map +1 -0
- package/dist/utils/background-lock.d.ts +20 -0
- package/dist/utils/background-lock.d.ts.map +1 -0
- package/dist/utils/background-lock.js +21 -0
- package/dist/utils/background-lock.js.map +1 -0
- package/dist/utils/index.cjs +1 -0
- package/dist/utils/index.d.ts +4 -0
- package/dist/utils/index.d.ts.map +1 -0
- package/dist/utils/index.js +3 -0
- package/dist/utils/use-overlay.cjs +2 -0
- package/dist/utils/use-overlay.cjs.map +1 -0
- package/dist/utils/use-overlay.d.ts +26 -0
- package/dist/utils/use-overlay.d.ts.map +1 -0
- package/dist/utils/use-overlay.js +34 -0
- package/dist/utils/use-overlay.js.map +1 -0
- package/dist/virtualit/dist/dom/dom.cjs +2 -0
- package/dist/virtualit/dist/dom/dom.cjs.map +1 -0
- package/dist/virtualit/dist/dom/dom.js +47 -0
- package/dist/virtualit/dist/dom/dom.js.map +1 -0
- package/dist/virtualit/dist/dom.cjs +1 -0
- package/dist/virtualit/dist/dom.js +2 -0
- package/dist/virtualit/dist/virtualit.cjs +2 -0
- package/dist/virtualit/dist/virtualit.cjs.map +1 -0
- package/dist/virtualit/dist/virtualit.js +129 -0
- package/dist/virtualit/dist/virtualit.js.map +1 -0
- package/package.json +282 -0
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
/** Grid item component properties */
|
|
2
|
+
export type BitGridItemProps = {
|
|
3
|
+
/** Align self vertically within the grid cell */
|
|
4
|
+
align?: 'start' | 'center' | 'end' | 'stretch';
|
|
5
|
+
/** Explicit grid-column value — overrides col-span (e.g. '2 / 5', 'span 3', '1 / -1'). */
|
|
6
|
+
col?: string;
|
|
7
|
+
/** Span N columns. Use 'full' to span all columns (1 / -1). */
|
|
8
|
+
colSpan?: '1' | '2' | '3' | '4' | '5' | '6' | '7' | '8' | '9' | '10' | '11' | '12' | 'full';
|
|
9
|
+
/** Justify self horizontally within the grid cell */
|
|
10
|
+
justify?: 'start' | 'center' | 'end' | 'stretch';
|
|
11
|
+
/** Explicit grid-row value — overrides row-span (e.g. '1 / 3', 'span 2'). */
|
|
12
|
+
row?: string;
|
|
13
|
+
/** Span N rows. Use 'full' to span all rows (1 / -1). */
|
|
14
|
+
rowSpan?: '1' | '2' | '3' | '4' | '5' | '6' | 'full';
|
|
15
|
+
};
|
|
16
|
+
/**
|
|
17
|
+
* bit-grid-item — A grid cell with declarative placement and span control.
|
|
18
|
+
*
|
|
19
|
+
* Use `col-span` / `row-span` for the common case of spanning columns/rows.
|
|
20
|
+
* Use `col` / `row` for full CSS grid-column / grid-row shorthand power
|
|
21
|
+
* (e.g. explicit placement, mixed span + start, negative lines).
|
|
22
|
+
*
|
|
23
|
+
* @element bit-grid-item
|
|
24
|
+
*
|
|
25
|
+
* @attr {string} col-span - Columns to span: '1'–'12' | 'full'
|
|
26
|
+
* @attr {string} row-span - Rows to span: '1'–'6' | 'full'
|
|
27
|
+
* @attr {string} col - CSS grid-column value (overrides col-span)
|
|
28
|
+
* @attr {string} row - CSS grid-row value (overrides row-span)
|
|
29
|
+
* @attr {string} align - align-self: 'start' | 'center' | 'end' | 'stretch'
|
|
30
|
+
* @attr {string} justify - justify-self: 'start' | 'center' | 'end' | 'stretch'
|
|
31
|
+
*
|
|
32
|
+
* @slot - Grid item content
|
|
33
|
+
*
|
|
34
|
+
* @example
|
|
35
|
+
* <!-- Span 2 columns -->
|
|
36
|
+
* <bit-grid-item col-span="2">Wide</bit-grid-item>
|
|
37
|
+
*
|
|
38
|
+
* @example
|
|
39
|
+
* <!-- Full-width row -->
|
|
40
|
+
* <bit-grid-item col-span="full">Banner</bit-grid-item>
|
|
41
|
+
*
|
|
42
|
+
* @example
|
|
43
|
+
* <!-- Explicit placement -->
|
|
44
|
+
* <bit-grid-item col="2 / 5" row="1 / 3">Placed</bit-grid-item>
|
|
45
|
+
*/
|
|
46
|
+
export declare const GRID_ITEM_TAG: string;
|
|
47
|
+
//# sourceMappingURL=grid-item.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"grid-item.d.ts","sourceRoot":"","sources":["../../../src/layout/grid-item/grid-item.ts"],"names":[],"mappings":"AAIA,qCAAqC;AACrC,MAAM,MAAM,gBAAgB,GAAG;IAC7B,iDAAiD;IACjD,KAAK,CAAC,EAAE,OAAO,GAAG,QAAQ,GAAG,KAAK,GAAG,SAAS,CAAC;IAC/C,0FAA0F;IAC1F,GAAG,CAAC,EAAE,MAAM,CAAC;IACb,+DAA+D;IAC/D,OAAO,CAAC,EAAE,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,GAAG,IAAI,GAAG,IAAI,GAAG,MAAM,CAAC;IAC5F,qDAAqD;IACrD,OAAO,CAAC,EAAE,OAAO,GAAG,QAAQ,GAAG,KAAK,GAAG,SAAS,CAAC;IACjD,6EAA6E;IAC7E,GAAG,CAAC,EAAE,MAAM,CAAC;IACb,yDAAyD;IACzD,OAAO,CAAC,EAAE,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,MAAM,CAAC;CACtD,CAAC;AAEF;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA6BG;AACH,eAAO,MAAM,aAAa,QA2CxB,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
require(`../box.cjs`),require(`../grid-item.cjs`),require(`../grid.cjs`),require(`../sidebar.cjs`);
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
export { BOX_TAG } from './box/box';
|
|
2
|
+
export type { BitBoxProps } from './box/box';
|
|
3
|
+
export { GRID_ITEM_TAG } from './grid-item/grid-item';
|
|
4
|
+
export type { BitGridItemProps } from './grid-item/grid-item';
|
|
5
|
+
export { GRID_TAG } from './grid/grid';
|
|
6
|
+
export type { BitGridProps } from './grid/grid';
|
|
7
|
+
export { SIDEBAR_CTX, SIDEBAR_GROUP_TAG, SIDEBAR_ITEM_TAG, SIDEBAR_TAG } from './sidebar/sidebar';
|
|
8
|
+
export type { BitSidebarEvents, BitSidebarGroupEvents, BitSidebarGroupProps, BitSidebarItemProps, BitSidebarProps, SidebarContext, SidebarElement, } from './sidebar/sidebar';
|
|
9
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/layout/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AACpC,YAAY,EAAE,WAAW,EAAE,MAAM,WAAW,CAAC;AAC7C,OAAO,EAAE,aAAa,EAAE,MAAM,uBAAuB,CAAC;AACtD,YAAY,EAAE,gBAAgB,EAAE,MAAM,uBAAuB,CAAC;AAC9D,OAAO,EAAE,QAAQ,EAAE,MAAM,aAAa,CAAC;AACvC,YAAY,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AAChD,OAAO,EAAE,WAAW,EAAE,iBAAiB,EAAE,gBAAgB,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AAClG,YAAY,EACV,gBAAgB,EAChB,qBAAqB,EACrB,oBAAoB,EACpB,mBAAmB,EACnB,eAAe,EACf,cAAc,EACd,cAAc,GACf,MAAM,mBAAmB,CAAC"}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
var e=`@layer buildit.base{:host{width:100%;display:block}.group{display:block}.group-header{all:unset;box-sizing:border-box;gap:var(--size-2);width:100%;min-height:var(--size-8);padding:var(--size-1) var(--size-2);color:inherit;cursor:pointer;-webkit-user-select:none;user-select:none;border-radius:var(--rounded-sm);transition:background var(--transition-fast);outline:none;justify-content:flex-start;align-items:center;display:flex;position:relative}.group-header::-webkit-details-marker{display:none}:host([collapsible]) .group-header:hover{background:var(--color-contrast-100)}:host([collapsible]) .group-header:focus-visible{outline:var(--focus-ring)}:host(:not([collapsible])) .group-header{cursor:default}.group-label{text-overflow:ellipsis;font-size:var(--text-xs);font-weight:var(--font-semibold);color:var(--color-contrast-500);text-transform:uppercase;letter-spacing:.06em;white-space:nowrap;transition:opacity var(--transition-fast);flex:1;overflow:hidden}.group-icon{color:var(--color-contrast-400);flex-shrink:0;justify-content:center;align-items:center;display:flex}.chevron{color:var(--color-contrast-400);transition:var(--_motion-transition,transform var(--transition-normal));flex-shrink:0;justify-content:center;align-items:center;display:flex}:host([collapsible][open]) .chevron{transform:rotate(90deg)}.group-items{gap:var(--size-0-5);grid-template-columns:minmax(0,1fr);min-width:0;display:grid}:host([sidebar-collapsed]) .group-label,:host([sidebar-collapsed]) .chevron{pointer-events:none;opacity:0}}@layer buildit.variants{:host([sidebar-collapsed]) .group-header{padding-inline:var(--size-2);justify-content:center}}`;exports.default=e;
|
|
2
|
+
//# sourceMappingURL=sidebar-group.css?inline.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sidebar-group.css?inline.cjs","names":[],"sources":["../../../src/layout/sidebar/sidebar-group.css?inline"],"sourcesContent":["@layer buildit.base {\n :host {\n display: block;\n width: 100%;\n }\n\n .group {\n display: block;\n }\n\n .group-header {\n all: unset;\n position: relative;\n box-sizing: border-box;\n display: flex;\n gap: var(--size-2);\n align-items: center;\n justify-content: flex-start;\n width: 100%;\n min-height: var(--size-8);\n padding: var(--size-1) var(--size-2);\n color: inherit;\n cursor: pointer;\n user-select: none;\n outline: none;\n border-radius: var(--rounded-sm);\n transition: background var(--transition-fast);\n }\n\n .group-header::-webkit-details-marker {\n display: none;\n }\n\n /* Only show hover & focus when the group is collapsible */\n :host([collapsible]) .group-header:hover {\n background: var(--color-contrast-100);\n }\n\n :host([collapsible]) .group-header:focus-visible {\n outline: var(--focus-ring);\n }\n\n :host(:not([collapsible])) .group-header {\n cursor: default;\n }\n\n .group-label {\n flex: 1;\n overflow: hidden;\n text-overflow: ellipsis;\n font-size: var(--text-xs);\n font-weight: var(--font-semibold);\n color: var(--color-contrast-500);\n text-transform: uppercase;\n letter-spacing: 0.06em;\n white-space: nowrap;\n transition: opacity var(--transition-fast);\n }\n\n .group-icon {\n display: flex;\n flex-shrink: 0;\n align-items: center;\n justify-content: center;\n color: var(--color-contrast-400);\n }\n\n .chevron {\n display: flex;\n flex-shrink: 0;\n align-items: center;\n justify-content: center;\n color: var(--color-contrast-400);\n transition: var(--_motion-transition, transform var(--transition-normal));\n }\n\n :host([collapsible][open]) .chevron {\n transform: rotate(90deg);\n }\n\n .group-items {\n display: grid;\n grid-template-columns: minmax(0, 1fr);\n gap: var(--size-0-5);\n min-width: 0;\n }\n\n /* Collapsed-sidebar: hide label text but keep icon */\n :host([sidebar-collapsed]) .group-label,\n :host([sidebar-collapsed]) .chevron {\n pointer-events: none;\n opacity: 0;\n }\n}\n\n@layer buildit.variants {\n /* When the parent sidebar is collapsed, center the group icon */\n :host([sidebar-collapsed]) .group-header {\n justify-content: center;\n padding-inline: var(--size-2);\n }\n}\n"],"mappings":""}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
//#region src/layout/sidebar/sidebar-group.css?inline
|
|
2
|
+
var e = "@layer buildit.base{:host{width:100%;display:block}.group{display:block}.group-header{all:unset;box-sizing:border-box;gap:var(--size-2);width:100%;min-height:var(--size-8);padding:var(--size-1) var(--size-2);color:inherit;cursor:pointer;-webkit-user-select:none;user-select:none;border-radius:var(--rounded-sm);transition:background var(--transition-fast);outline:none;justify-content:flex-start;align-items:center;display:flex;position:relative}.group-header::-webkit-details-marker{display:none}:host([collapsible]) .group-header:hover{background:var(--color-contrast-100)}:host([collapsible]) .group-header:focus-visible{outline:var(--focus-ring)}:host(:not([collapsible])) .group-header{cursor:default}.group-label{text-overflow:ellipsis;font-size:var(--text-xs);font-weight:var(--font-semibold);color:var(--color-contrast-500);text-transform:uppercase;letter-spacing:.06em;white-space:nowrap;transition:opacity var(--transition-fast);flex:1;overflow:hidden}.group-icon{color:var(--color-contrast-400);flex-shrink:0;justify-content:center;align-items:center;display:flex}.chevron{color:var(--color-contrast-400);transition:var(--_motion-transition,transform var(--transition-normal));flex-shrink:0;justify-content:center;align-items:center;display:flex}:host([collapsible][open]) .chevron{transform:rotate(90deg)}.group-items{gap:var(--size-0-5);grid-template-columns:minmax(0,1fr);min-width:0;display:grid}:host([sidebar-collapsed]) .group-label,:host([sidebar-collapsed]) .chevron{pointer-events:none;opacity:0}}@layer buildit.variants{:host([sidebar-collapsed]) .group-header{padding-inline:var(--size-2);justify-content:center}}";
|
|
3
|
+
//#endregion
|
|
4
|
+
export { e as default };
|
|
5
|
+
|
|
6
|
+
//# sourceMappingURL=sidebar-group.css?inline.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sidebar-group.css?inline.js","names":[],"sources":["../../../src/layout/sidebar/sidebar-group.css?inline"],"sourcesContent":["@layer buildit.base {\n :host {\n display: block;\n width: 100%;\n }\n\n .group {\n display: block;\n }\n\n .group-header {\n all: unset;\n position: relative;\n box-sizing: border-box;\n display: flex;\n gap: var(--size-2);\n align-items: center;\n justify-content: flex-start;\n width: 100%;\n min-height: var(--size-8);\n padding: var(--size-1) var(--size-2);\n color: inherit;\n cursor: pointer;\n user-select: none;\n outline: none;\n border-radius: var(--rounded-sm);\n transition: background var(--transition-fast);\n }\n\n .group-header::-webkit-details-marker {\n display: none;\n }\n\n /* Only show hover & focus when the group is collapsible */\n :host([collapsible]) .group-header:hover {\n background: var(--color-contrast-100);\n }\n\n :host([collapsible]) .group-header:focus-visible {\n outline: var(--focus-ring);\n }\n\n :host(:not([collapsible])) .group-header {\n cursor: default;\n }\n\n .group-label {\n flex: 1;\n overflow: hidden;\n text-overflow: ellipsis;\n font-size: var(--text-xs);\n font-weight: var(--font-semibold);\n color: var(--color-contrast-500);\n text-transform: uppercase;\n letter-spacing: 0.06em;\n white-space: nowrap;\n transition: opacity var(--transition-fast);\n }\n\n .group-icon {\n display: flex;\n flex-shrink: 0;\n align-items: center;\n justify-content: center;\n color: var(--color-contrast-400);\n }\n\n .chevron {\n display: flex;\n flex-shrink: 0;\n align-items: center;\n justify-content: center;\n color: var(--color-contrast-400);\n transition: var(--_motion-transition, transform var(--transition-normal));\n }\n\n :host([collapsible][open]) .chevron {\n transform: rotate(90deg);\n }\n\n .group-items {\n display: grid;\n grid-template-columns: minmax(0, 1fr);\n gap: var(--size-0-5);\n min-width: 0;\n }\n\n /* Collapsed-sidebar: hide label text but keep icon */\n :host([sidebar-collapsed]) .group-label,\n :host([sidebar-collapsed]) .chevron {\n pointer-events: none;\n opacity: 0;\n }\n}\n\n@layer buildit.variants {\n /* When the parent sidebar is collapsed, center the group icon */\n :host([sidebar-collapsed]) .group-header {\n justify-content: center;\n padding-inline: var(--size-2);\n }\n}\n"],"mappings":""}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
var e=`@layer buildit.base{:host{min-width:0;max-width:100%;display:block}.item{box-sizing:border-box;gap:var(--size-2);min-width:0;min-height:var(--_touch-target);padding:var(--size-1-5) var(--size-2);font-size:var(--sidebar-item-font-size,var(--text-sm));font-weight:var(--font-medium);color:var(--sidebar-item-color,var(--color-contrast-700));cursor:pointer;-webkit-user-select:none;user-select:none;border-radius:var(--rounded-sm);transition:background var(--transition-fast), color var(--transition-fast);outline:none;align-items:center;text-decoration:none;display:flex;position:relative}a.item{text-decoration:none}.item:hover{color:var(--sidebar-item-hover-color,var(--color-contrast-900));background:var(--sidebar-item-hover-bg,var(--color-contrast-100))}.item:focus-visible{outline:var(--focus-ring);outline-offset:1px}:host([active]) .item{font-weight:var(--font-semibold);color:var(--sidebar-item-active-color,var(--color-primary));background:var(--sidebar-item-active-bg,var(--color-primary-100,color-mix(in srgb, var(--color-primary) 12%, transparent)))}:host([active]) .item:before{inset-block:var(--size-1);content:"";background:var(--sidebar-item-indicator,var(--color-primary));border-radius:var(--rounded-full);width:3px;position:absolute}:host([active]) .item:not(:is(:lang(ae),:lang(ar),:lang(arc),:lang(bcc),:lang(bqi),:lang(ckb),:lang(dv),:lang(fa),:lang(glk),:lang(he),:lang(ku),:lang(mzn),:lang(nqo),:lang(pnb),:lang(ps),:lang(sd),:lang(ug),:lang(ur),:lang(yi))):before{left:0}:host([active]) .item:is(:lang(ae),:lang(ar),:lang(arc),:lang(bcc),:lang(bqi),:lang(ckb),:lang(dv),:lang(fa),:lang(glk),:lang(he),:lang(ku),:lang(mzn),:lang(nqo),:lang(pnb),:lang(ps),:lang(sd),:lang(ug),:lang(ur),:lang(yi)):before{right:0}:host([disabled]) .item{pointer-events:none;cursor:not-allowed;opacity:.5}.item-icon{width:var(--size-5);height:var(--size-5);flex-shrink:0;justify-content:center;align-items:center;display:flex}.item-label{text-overflow:ellipsis;white-space:nowrap;min-width:0;transition:opacity var(--transition-fast);flex:1;overflow:hidden}.item-end{gap:var(--size-1);transition:opacity var(--transition-fast);flex-shrink:0;align-items:center;display:flex}:host([sidebar-collapsed]) .item-label,:host([sidebar-collapsed]) .item-end{pointer-events:none;opacity:0;width:0;overflow:hidden}:host([sidebar-collapsed]) .item{padding:var(--size-2) var(--size-4);justify-content:center;gap:0}:host([sidebar-collapsed][active]) .item:before{inset-block:var(--size-2)}}`;exports.default=e;
|
|
2
|
+
//# sourceMappingURL=sidebar-item.css?inline.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sidebar-item.css?inline.cjs","names":[],"sources":["../../../src/layout/sidebar/sidebar-item.css?inline"],"sourcesContent":["@layer buildit.base {\n :host {\n display: block;\n min-width: 0;\n max-width: 100%;\n }\n\n .item {\n position: relative;\n box-sizing: border-box;\n display: flex;\n gap: var(--size-2);\n align-items: center;\n min-width: 0;\n min-height: var(--_touch-target);\n padding: var(--size-1-5) var(--size-2);\n font-size: var(--sidebar-item-font-size, var(--text-sm));\n font-weight: var(--font-medium);\n color: var(--sidebar-item-color, var(--color-contrast-700));\n text-decoration: none;\n cursor: pointer;\n user-select: none;\n outline: none;\n border-radius: var(--rounded-sm);\n transition:\n background var(--transition-fast),\n color var(--transition-fast);\n }\n\n /* Make <a> items look like the container */\n a.item {\n text-decoration: none;\n }\n\n .item:hover {\n color: var(--sidebar-item-hover-color, var(--color-contrast-900));\n background: var(--sidebar-item-hover-bg, var(--color-contrast-100));\n }\n\n .item:focus-visible {\n outline: var(--focus-ring);\n outline-offset: 1px;\n }\n\n :host([active]) .item {\n font-weight: var(--font-semibold);\n color: var(--sidebar-item-active-color, var(--color-primary));\n background: var(\n --sidebar-item-active-bg,\n var(--color-primary-100, color-mix(in srgb, var(--color-primary) 12%, transparent))\n );\n }\n\n :host([active]) .item::before {\n position: absolute;\n inset-block: var(--size-1);\n inset-inline-start: 0;\n width: 3px;\n content: '';\n background: var(--sidebar-item-indicator, var(--color-primary));\n border-radius: var(--rounded-full);\n }\n\n :host([disabled]) .item {\n pointer-events: none;\n cursor: not-allowed;\n opacity: 0.5;\n }\n\n .item-icon {\n display: flex;\n flex-shrink: 0;\n align-items: center;\n justify-content: center;\n width: var(--size-5);\n height: var(--size-5);\n }\n\n .item-label {\n flex: 1;\n min-width: 0;\n overflow: hidden;\n text-overflow: ellipsis;\n white-space: nowrap;\n transition: opacity var(--transition-fast);\n }\n\n .item-end {\n display: flex;\n flex-shrink: 0;\n gap: var(--size-1);\n align-items: center;\n transition: opacity var(--transition-fast);\n }\n\n /* Collapsed sidebar: hide text/end content */\n :host([sidebar-collapsed]) .item-label,\n :host([sidebar-collapsed]) .item-end {\n width: 0;\n overflow: hidden;\n pointer-events: none;\n opacity: 0;\n }\n\n :host([sidebar-collapsed]) .item {\n gap: 0;\n justify-content: center;\n padding: var(--size-2) var(--size-4);\n }\n\n :host([sidebar-collapsed][active]) .item::before {\n inset-block: var(--size-2);\n }\n}\n"],"mappings":""}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
//#region src/layout/sidebar/sidebar-item.css?inline
|
|
2
|
+
var e = "@layer buildit.base{:host{min-width:0;max-width:100%;display:block}.item{box-sizing:border-box;gap:var(--size-2);min-width:0;min-height:var(--_touch-target);padding:var(--size-1-5) var(--size-2);font-size:var(--sidebar-item-font-size,var(--text-sm));font-weight:var(--font-medium);color:var(--sidebar-item-color,var(--color-contrast-700));cursor:pointer;-webkit-user-select:none;user-select:none;border-radius:var(--rounded-sm);transition:background var(--transition-fast), color var(--transition-fast);outline:none;align-items:center;text-decoration:none;display:flex;position:relative}a.item{text-decoration:none}.item:hover{color:var(--sidebar-item-hover-color,var(--color-contrast-900));background:var(--sidebar-item-hover-bg,var(--color-contrast-100))}.item:focus-visible{outline:var(--focus-ring);outline-offset:1px}:host([active]) .item{font-weight:var(--font-semibold);color:var(--sidebar-item-active-color,var(--color-primary));background:var(--sidebar-item-active-bg,var(--color-primary-100,color-mix(in srgb, var(--color-primary) 12%, transparent)))}:host([active]) .item:before{inset-block:var(--size-1);content:\"\";background:var(--sidebar-item-indicator,var(--color-primary));border-radius:var(--rounded-full);width:3px;position:absolute}:host([active]) .item:not(:is(:lang(ae),:lang(ar),:lang(arc),:lang(bcc),:lang(bqi),:lang(ckb),:lang(dv),:lang(fa),:lang(glk),:lang(he),:lang(ku),:lang(mzn),:lang(nqo),:lang(pnb),:lang(ps),:lang(sd),:lang(ug),:lang(ur),:lang(yi))):before{left:0}:host([active]) .item:is(:lang(ae),:lang(ar),:lang(arc),:lang(bcc),:lang(bqi),:lang(ckb),:lang(dv),:lang(fa),:lang(glk),:lang(he),:lang(ku),:lang(mzn),:lang(nqo),:lang(pnb),:lang(ps),:lang(sd),:lang(ug),:lang(ur),:lang(yi)):before{right:0}:host([disabled]) .item{pointer-events:none;cursor:not-allowed;opacity:.5}.item-icon{width:var(--size-5);height:var(--size-5);flex-shrink:0;justify-content:center;align-items:center;display:flex}.item-label{text-overflow:ellipsis;white-space:nowrap;min-width:0;transition:opacity var(--transition-fast);flex:1;overflow:hidden}.item-end{gap:var(--size-1);transition:opacity var(--transition-fast);flex-shrink:0;align-items:center;display:flex}:host([sidebar-collapsed]) .item-label,:host([sidebar-collapsed]) .item-end{pointer-events:none;opacity:0;width:0;overflow:hidden}:host([sidebar-collapsed]) .item{padding:var(--size-2) var(--size-4);justify-content:center;gap:0}:host([sidebar-collapsed][active]) .item:before{inset-block:var(--size-2)}}";
|
|
3
|
+
//#endregion
|
|
4
|
+
export { e as default };
|
|
5
|
+
|
|
6
|
+
//# sourceMappingURL=sidebar-item.css?inline.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sidebar-item.css?inline.js","names":[],"sources":["../../../src/layout/sidebar/sidebar-item.css?inline"],"sourcesContent":["@layer buildit.base {\n :host {\n display: block;\n min-width: 0;\n max-width: 100%;\n }\n\n .item {\n position: relative;\n box-sizing: border-box;\n display: flex;\n gap: var(--size-2);\n align-items: center;\n min-width: 0;\n min-height: var(--_touch-target);\n padding: var(--size-1-5) var(--size-2);\n font-size: var(--sidebar-item-font-size, var(--text-sm));\n font-weight: var(--font-medium);\n color: var(--sidebar-item-color, var(--color-contrast-700));\n text-decoration: none;\n cursor: pointer;\n user-select: none;\n outline: none;\n border-radius: var(--rounded-sm);\n transition:\n background var(--transition-fast),\n color var(--transition-fast);\n }\n\n /* Make <a> items look like the container */\n a.item {\n text-decoration: none;\n }\n\n .item:hover {\n color: var(--sidebar-item-hover-color, var(--color-contrast-900));\n background: var(--sidebar-item-hover-bg, var(--color-contrast-100));\n }\n\n .item:focus-visible {\n outline: var(--focus-ring);\n outline-offset: 1px;\n }\n\n :host([active]) .item {\n font-weight: var(--font-semibold);\n color: var(--sidebar-item-active-color, var(--color-primary));\n background: var(\n --sidebar-item-active-bg,\n var(--color-primary-100, color-mix(in srgb, var(--color-primary) 12%, transparent))\n );\n }\n\n :host([active]) .item::before {\n position: absolute;\n inset-block: var(--size-1);\n inset-inline-start: 0;\n width: 3px;\n content: '';\n background: var(--sidebar-item-indicator, var(--color-primary));\n border-radius: var(--rounded-full);\n }\n\n :host([disabled]) .item {\n pointer-events: none;\n cursor: not-allowed;\n opacity: 0.5;\n }\n\n .item-icon {\n display: flex;\n flex-shrink: 0;\n align-items: center;\n justify-content: center;\n width: var(--size-5);\n height: var(--size-5);\n }\n\n .item-label {\n flex: 1;\n min-width: 0;\n overflow: hidden;\n text-overflow: ellipsis;\n white-space: nowrap;\n transition: opacity var(--transition-fast);\n }\n\n .item-end {\n display: flex;\n flex-shrink: 0;\n gap: var(--size-1);\n align-items: center;\n transition: opacity var(--transition-fast);\n }\n\n /* Collapsed sidebar: hide text/end content */\n :host([sidebar-collapsed]) .item-label,\n :host([sidebar-collapsed]) .item-end {\n width: 0;\n overflow: hidden;\n pointer-events: none;\n opacity: 0;\n }\n\n :host([sidebar-collapsed]) .item {\n gap: 0;\n justify-content: center;\n padding: var(--size-2) var(--size-4);\n }\n\n :host([sidebar-collapsed][active]) .item::before {\n inset-block: var(--size-2);\n }\n}\n"],"mappings":""}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
var e=`@layer buildit.base{:host{--_sidebar-width:var(--sidebar-width,16rem);--_sidebar-collapsed-width:var(--sidebar-collapsed-width,3.5rem);--_sidebar-transition:var(--transition-normal);--_panel-bg:var(--sidebar-bg,var(--lightningcss-light,color-mix(in srgb, var(--color-contrast-50) 85%, transparent))var(--lightningcss-dark,color-mix(in srgb, var(--color-contrast-100) 85%, transparent)));--_panel-blur:var(--sidebar-panel-blur,var(--blur-md));--_panel-border-color:var(--sidebar-border-color,var(--lightningcss-light,color-mix(in srgb, var(--color-contrast-900) 8%, transparent))var(--lightningcss-dark,color-mix(in srgb, var(--color-contrast-100) 8%, transparent)));--_panel-radius:var(--sidebar-radius,0);--_panel-shadow:var(--sidebar-shadow,var(--shadow-xl));box-sizing:border-box;width:100%;min-width:var(--size-2xs);max-width:var(--_sidebar-width);height:100%;min-height:0;transition:var(--_motion-transition,width var(--_sidebar-transition), min-width var(--_sidebar-transition));display:block;overflow:visible}:host>nav{box-sizing:border-box;background:var(--_panel-bg);border:var(--border) solid var(--_panel-border-color);border-radius:var(--_panel-radius);width:100%;height:100%;min-height:0;box-shadow:var(--_panel-shadow);-webkit-backdrop-filter:blur(var(--_panel-blur));backdrop-filter:blur(var(--_panel-blur));flex-direction:column;display:flex;position:relative;overflow:hidden}:host([data-collapsed]){width:var(--_sidebar-collapsed-width);min-width:var(--_sidebar-collapsed-width);max-width:var(--_sidebar-collapsed-width)}.sidebar-header{gap:var(--size-2);min-height:var(--size-14);padding:var(--size-2);border-bottom:var(--border) solid var(--color-contrast-200);flex-shrink:0;align-items:center;display:flex;overflow:hidden}.sidebar-header slot{flex:1;min-width:0;display:block;overflow:hidden}.sidebar-content{gap:var(--size-2);min-width:0;padding:var(--size-4);scrollbar-width:thin;flex:1;grid-template-columns:minmax(0,1fr);align-content:start;display:grid;overflow:clip auto}.sidebar-footer{padding:var(--size-4);border-top:var(--border) solid var(--color-contrast-200);flex-shrink:0}.toggle-btn{all:unset;box-sizing:border-box;width:var(--size-8);height:var(--size-8);color:var(--color-contrast-500);cursor:pointer;border-radius:var(--rounded-sm);transition:color var(--transition-fast), background var(--transition-fast);flex-shrink:0;justify-content:center;align-items:center;display:inline-flex}.toggle-btn:not(:is(:lang(ae),:lang(ar),:lang(arc),:lang(bcc),:lang(bqi),:lang(ckb),:lang(dv),:lang(fa),:lang(glk),:lang(he),:lang(ku),:lang(mzn),:lang(nqo),:lang(pnb),:lang(ps),:lang(sd),:lang(ug),:lang(ur),:lang(yi))){margin-left:auto}.toggle-btn:is(:lang(ae),:lang(ar),:lang(arc),:lang(bcc),:lang(bqi),:lang(ckb),:lang(dv),:lang(fa),:lang(glk),:lang(he),:lang(ku),:lang(mzn),:lang(nqo),:lang(pnb),:lang(ps),:lang(sd),:lang(ug),:lang(ur),:lang(yi)){margin-right:auto}.toggle-btn:hover{color:var(--color-contrast-800);background:var(--color-contrast-200)}.toggle-btn:focus-visible{outline:var(--focus-ring)}.toggle-icon{transition:var(--_motion-transition,transform var(--_sidebar-transition));justify-content:center;align-items:center;display:flex}:host([data-collapsed]) .toggle-icon,:host(:not([dir=rtl])[data-collapsed]) .toggle-icon,:host(:dir(ltr)[data-collapsed]) .toggle-icon,:host(:dir(rtl)) .toggle-icon{transform:rotate(180deg)}:host(:dir(rtl)[data-collapsed]) .toggle-icon{transform:rotate(0)}}@layer buildit.variants{:host([variant=floating]){height:calc(100% - var(--size-4));margin:var(--size-2);--_panel-radius:var(--rounded-xl)}:host([variant=inset]){--_panel-bg:var(--color-contrast-50);--_panel-shadow:none;--_panel-border-color:transparent}}`;exports.default=e;
|
|
2
|
+
//# sourceMappingURL=sidebar.css?inline.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sidebar.css?inline.cjs","names":[],"sources":["../../../src/layout/sidebar/sidebar.css?inline"],"sourcesContent":["@layer buildit.base {\n :host {\n --_sidebar-width: var(--sidebar-width, 16rem);\n --_sidebar-collapsed-width: var(--sidebar-collapsed-width, 3.5rem);\n --_sidebar-transition: var(--transition-normal);\n --_panel-bg: var(\n --sidebar-bg,\n light-dark(\n color-mix(in srgb, var(--color-contrast-50) 85%, transparent),\n color-mix(in srgb, var(--color-contrast-100) 85%, transparent)\n )\n );\n --_panel-blur: var(--sidebar-panel-blur, var(--blur-md));\n --_panel-border-color: var(\n --sidebar-border-color,\n light-dark(\n color-mix(in srgb, var(--color-contrast-900) 8%, transparent),\n color-mix(in srgb, var(--color-contrast-100) 8%, transparent)\n )\n );\n --_panel-radius: var(--sidebar-radius, 0);\n --_panel-shadow: var(--sidebar-shadow, var(--shadow-xl));\n\n box-sizing: border-box;\n display: block;\n width: 100%;\n min-width: var(--size-2xs);\n max-width: var(--_sidebar-width);\n height: 100%;\n min-height: 0;\n overflow: visible;\n transition: var(--_motion-transition, width var(--_sidebar-transition), min-width var(--_sidebar-transition));\n }\n\n :host > nav {\n position: relative;\n box-sizing: border-box;\n display: flex;\n flex-direction: column;\n width: 100%;\n height: 100%;\n min-height: 0;\n overflow: hidden;\n background: var(--_panel-bg);\n border: var(--border) solid var(--_panel-border-color);\n border-radius: var(--_panel-radius);\n box-shadow: var(--_panel-shadow);\n backdrop-filter: blur(var(--_panel-blur));\n }\n\n :host([data-collapsed]) {\n width: var(--_sidebar-collapsed-width);\n min-width: var(--_sidebar-collapsed-width);\n max-width: var(--_sidebar-collapsed-width);\n }\n\n .sidebar-header {\n display: flex;\n flex-shrink: 0;\n gap: var(--size-2);\n align-items: center;\n min-height: var(--size-14);\n padding: var(--size-2);\n overflow: hidden;\n border-bottom: var(--border) solid var(--color-contrast-200);\n }\n\n .sidebar-header slot {\n display: block;\n flex: 1;\n min-width: 0;\n overflow: hidden;\n }\n\n .sidebar-content {\n display: grid;\n flex: 1;\n grid-template-columns: minmax(0, 1fr);\n gap: var(--size-2);\n align-content: start;\n min-width: 0;\n padding: var(--size-4);\n overflow: clip auto;\n scrollbar-width: thin;\n }\n\n .sidebar-footer {\n flex-shrink: 0;\n padding: var(--size-4);\n border-top: var(--border) solid var(--color-contrast-200);\n }\n\n .toggle-btn {\n all: unset;\n box-sizing: border-box;\n display: inline-flex;\n flex-shrink: 0;\n align-items: center;\n justify-content: center;\n width: var(--size-8);\n height: var(--size-8);\n margin-inline-start: auto;\n color: var(--color-contrast-500);\n cursor: pointer;\n border-radius: var(--rounded-sm);\n transition:\n color var(--transition-fast),\n background var(--transition-fast);\n }\n\n .toggle-btn:hover {\n color: var(--color-contrast-800);\n background: var(--color-contrast-200);\n }\n\n .toggle-btn:focus-visible {\n outline: var(--focus-ring);\n }\n\n .toggle-icon {\n display: flex;\n align-items: center;\n justify-content: center;\n transition: var(--_motion-transition, transform var(--_sidebar-transition));\n }\n\n :host([data-collapsed]) .toggle-icon {\n transform: rotate(180deg);\n }\n\n :host(:not([dir='rtl'])[data-collapsed]) .toggle-icon,\n :host(:dir(ltr)[data-collapsed]) .toggle-icon {\n transform: rotate(180deg);\n }\n\n :host(:dir(rtl)) .toggle-icon {\n transform: rotate(180deg);\n }\n\n :host(:dir(rtl)[data-collapsed]) .toggle-icon {\n transform: rotate(0deg);\n }\n}\n\n@layer buildit.variants {\n /* ── floating ── */\n :host([variant='floating']) {\n height: calc(100% - var(--size-4));\n margin: var(--size-2);\n\n --_panel-radius: var(--rounded-xl);\n }\n\n /* ── inset ── */\n :host([variant='inset']) {\n --_panel-bg: var(--color-contrast-50);\n --_panel-shadow: none;\n --_panel-border-color: transparent;\n }\n}\n"],"mappings":""}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
//#region src/layout/sidebar/sidebar.css?inline
|
|
2
|
+
var e = "@layer buildit.base{:host{--_sidebar-width:var(--sidebar-width,16rem);--_sidebar-collapsed-width:var(--sidebar-collapsed-width,3.5rem);--_sidebar-transition:var(--transition-normal);--_panel-bg:var(--sidebar-bg,var(--lightningcss-light,color-mix(in srgb, var(--color-contrast-50) 85%, transparent))var(--lightningcss-dark,color-mix(in srgb, var(--color-contrast-100) 85%, transparent)));--_panel-blur:var(--sidebar-panel-blur,var(--blur-md));--_panel-border-color:var(--sidebar-border-color,var(--lightningcss-light,color-mix(in srgb, var(--color-contrast-900) 8%, transparent))var(--lightningcss-dark,color-mix(in srgb, var(--color-contrast-100) 8%, transparent)));--_panel-radius:var(--sidebar-radius,0);--_panel-shadow:var(--sidebar-shadow,var(--shadow-xl));box-sizing:border-box;width:100%;min-width:var(--size-2xs);max-width:var(--_sidebar-width);height:100%;min-height:0;transition:var(--_motion-transition,width var(--_sidebar-transition), min-width var(--_sidebar-transition));display:block;overflow:visible}:host>nav{box-sizing:border-box;background:var(--_panel-bg);border:var(--border) solid var(--_panel-border-color);border-radius:var(--_panel-radius);width:100%;height:100%;min-height:0;box-shadow:var(--_panel-shadow);-webkit-backdrop-filter:blur(var(--_panel-blur));backdrop-filter:blur(var(--_panel-blur));flex-direction:column;display:flex;position:relative;overflow:hidden}:host([data-collapsed]){width:var(--_sidebar-collapsed-width);min-width:var(--_sidebar-collapsed-width);max-width:var(--_sidebar-collapsed-width)}.sidebar-header{gap:var(--size-2);min-height:var(--size-14);padding:var(--size-2);border-bottom:var(--border) solid var(--color-contrast-200);flex-shrink:0;align-items:center;display:flex;overflow:hidden}.sidebar-header slot{flex:1;min-width:0;display:block;overflow:hidden}.sidebar-content{gap:var(--size-2);min-width:0;padding:var(--size-4);scrollbar-width:thin;flex:1;grid-template-columns:minmax(0,1fr);align-content:start;display:grid;overflow:clip auto}.sidebar-footer{padding:var(--size-4);border-top:var(--border) solid var(--color-contrast-200);flex-shrink:0}.toggle-btn{all:unset;box-sizing:border-box;width:var(--size-8);height:var(--size-8);color:var(--color-contrast-500);cursor:pointer;border-radius:var(--rounded-sm);transition:color var(--transition-fast), background var(--transition-fast);flex-shrink:0;justify-content:center;align-items:center;display:inline-flex}.toggle-btn:not(:is(:lang(ae),:lang(ar),:lang(arc),:lang(bcc),:lang(bqi),:lang(ckb),:lang(dv),:lang(fa),:lang(glk),:lang(he),:lang(ku),:lang(mzn),:lang(nqo),:lang(pnb),:lang(ps),:lang(sd),:lang(ug),:lang(ur),:lang(yi))){margin-left:auto}.toggle-btn:is(:lang(ae),:lang(ar),:lang(arc),:lang(bcc),:lang(bqi),:lang(ckb),:lang(dv),:lang(fa),:lang(glk),:lang(he),:lang(ku),:lang(mzn),:lang(nqo),:lang(pnb),:lang(ps),:lang(sd),:lang(ug),:lang(ur),:lang(yi)){margin-right:auto}.toggle-btn:hover{color:var(--color-contrast-800);background:var(--color-contrast-200)}.toggle-btn:focus-visible{outline:var(--focus-ring)}.toggle-icon{transition:var(--_motion-transition,transform var(--_sidebar-transition));justify-content:center;align-items:center;display:flex}:host([data-collapsed]) .toggle-icon,:host(:not([dir=rtl])[data-collapsed]) .toggle-icon,:host(:dir(ltr)[data-collapsed]) .toggle-icon,:host(:dir(rtl)) .toggle-icon{transform:rotate(180deg)}:host(:dir(rtl)[data-collapsed]) .toggle-icon{transform:rotate(0)}}@layer buildit.variants{:host([variant=floating]){height:calc(100% - var(--size-4));margin:var(--size-2);--_panel-radius:var(--rounded-xl)}:host([variant=inset]){--_panel-bg:var(--color-contrast-50);--_panel-shadow:none;--_panel-border-color:transparent}}";
|
|
3
|
+
//#endregion
|
|
4
|
+
export { e as default };
|
|
5
|
+
|
|
6
|
+
//# sourceMappingURL=sidebar.css?inline.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sidebar.css?inline.js","names":[],"sources":["../../../src/layout/sidebar/sidebar.css?inline"],"sourcesContent":["@layer buildit.base {\n :host {\n --_sidebar-width: var(--sidebar-width, 16rem);\n --_sidebar-collapsed-width: var(--sidebar-collapsed-width, 3.5rem);\n --_sidebar-transition: var(--transition-normal);\n --_panel-bg: var(\n --sidebar-bg,\n light-dark(\n color-mix(in srgb, var(--color-contrast-50) 85%, transparent),\n color-mix(in srgb, var(--color-contrast-100) 85%, transparent)\n )\n );\n --_panel-blur: var(--sidebar-panel-blur, var(--blur-md));\n --_panel-border-color: var(\n --sidebar-border-color,\n light-dark(\n color-mix(in srgb, var(--color-contrast-900) 8%, transparent),\n color-mix(in srgb, var(--color-contrast-100) 8%, transparent)\n )\n );\n --_panel-radius: var(--sidebar-radius, 0);\n --_panel-shadow: var(--sidebar-shadow, var(--shadow-xl));\n\n box-sizing: border-box;\n display: block;\n width: 100%;\n min-width: var(--size-2xs);\n max-width: var(--_sidebar-width);\n height: 100%;\n min-height: 0;\n overflow: visible;\n transition: var(--_motion-transition, width var(--_sidebar-transition), min-width var(--_sidebar-transition));\n }\n\n :host > nav {\n position: relative;\n box-sizing: border-box;\n display: flex;\n flex-direction: column;\n width: 100%;\n height: 100%;\n min-height: 0;\n overflow: hidden;\n background: var(--_panel-bg);\n border: var(--border) solid var(--_panel-border-color);\n border-radius: var(--_panel-radius);\n box-shadow: var(--_panel-shadow);\n backdrop-filter: blur(var(--_panel-blur));\n }\n\n :host([data-collapsed]) {\n width: var(--_sidebar-collapsed-width);\n min-width: var(--_sidebar-collapsed-width);\n max-width: var(--_sidebar-collapsed-width);\n }\n\n .sidebar-header {\n display: flex;\n flex-shrink: 0;\n gap: var(--size-2);\n align-items: center;\n min-height: var(--size-14);\n padding: var(--size-2);\n overflow: hidden;\n border-bottom: var(--border) solid var(--color-contrast-200);\n }\n\n .sidebar-header slot {\n display: block;\n flex: 1;\n min-width: 0;\n overflow: hidden;\n }\n\n .sidebar-content {\n display: grid;\n flex: 1;\n grid-template-columns: minmax(0, 1fr);\n gap: var(--size-2);\n align-content: start;\n min-width: 0;\n padding: var(--size-4);\n overflow: clip auto;\n scrollbar-width: thin;\n }\n\n .sidebar-footer {\n flex-shrink: 0;\n padding: var(--size-4);\n border-top: var(--border) solid var(--color-contrast-200);\n }\n\n .toggle-btn {\n all: unset;\n box-sizing: border-box;\n display: inline-flex;\n flex-shrink: 0;\n align-items: center;\n justify-content: center;\n width: var(--size-8);\n height: var(--size-8);\n margin-inline-start: auto;\n color: var(--color-contrast-500);\n cursor: pointer;\n border-radius: var(--rounded-sm);\n transition:\n color var(--transition-fast),\n background var(--transition-fast);\n }\n\n .toggle-btn:hover {\n color: var(--color-contrast-800);\n background: var(--color-contrast-200);\n }\n\n .toggle-btn:focus-visible {\n outline: var(--focus-ring);\n }\n\n .toggle-icon {\n display: flex;\n align-items: center;\n justify-content: center;\n transition: var(--_motion-transition, transform var(--_sidebar-transition));\n }\n\n :host([data-collapsed]) .toggle-icon {\n transform: rotate(180deg);\n }\n\n :host(:not([dir='rtl'])[data-collapsed]) .toggle-icon,\n :host(:dir(ltr)[data-collapsed]) .toggle-icon {\n transform: rotate(180deg);\n }\n\n :host(:dir(rtl)) .toggle-icon {\n transform: rotate(180deg);\n }\n\n :host(:dir(rtl)[data-collapsed]) .toggle-icon {\n transform: rotate(0deg);\n }\n}\n\n@layer buildit.variants {\n /* ── floating ── */\n :host([variant='floating']) {\n height: calc(100% - var(--size-4));\n margin: var(--size-2);\n\n --_panel-radius: var(--rounded-xl);\n }\n\n /* ── inset ── */\n :host([variant='inset']) {\n --_panel-bg: var(--color-contrast-50);\n --_panel-shadow: none;\n --_panel-border-color: transparent;\n }\n}\n"],"mappings":""}
|
|
@@ -0,0 +1,190 @@
|
|
|
1
|
+
import { type ReadonlySignal } from '@vielzeug/craftit';
|
|
2
|
+
type SidebarVariant = 'floating' | 'inset';
|
|
3
|
+
type SidebarCollapseSource = 'api' | 'responsive' | 'toggle';
|
|
4
|
+
/** Context provided by `bit-sidebar` to its `bit-sidebar-group` and `bit-sidebar-item` children. */
|
|
5
|
+
export type SidebarContext = {
|
|
6
|
+
collapsed: ReadonlySignal<boolean>;
|
|
7
|
+
variant: ReadonlySignal<SidebarVariant | undefined>;
|
|
8
|
+
};
|
|
9
|
+
/** Injection key for the sidebar context. */
|
|
10
|
+
export declare const SIDEBAR_CTX: import("@vielzeug/craftit").InjectionKey<SidebarContext>;
|
|
11
|
+
/** bit-sidebar element interface */
|
|
12
|
+
export type SidebarElement = HTMLElement & BitSidebarProps & {
|
|
13
|
+
/** Set collapsed state imperatively. */
|
|
14
|
+
setCollapsed(next: boolean): void;
|
|
15
|
+
/** Toggle between collapsed and expanded. */
|
|
16
|
+
toggle(): void;
|
|
17
|
+
};
|
|
18
|
+
/** Sidebar component properties */
|
|
19
|
+
export type BitSidebarEvents = {
|
|
20
|
+
'collapsed-change': {
|
|
21
|
+
collapsed: boolean;
|
|
22
|
+
source: SidebarCollapseSource;
|
|
23
|
+
};
|
|
24
|
+
};
|
|
25
|
+
export type BitSidebarGroupEvents = {
|
|
26
|
+
'open-change': {
|
|
27
|
+
open: boolean;
|
|
28
|
+
};
|
|
29
|
+
};
|
|
30
|
+
export type BitSidebarProps = {
|
|
31
|
+
/** Controlled collapsed state */
|
|
32
|
+
collapsed?: boolean;
|
|
33
|
+
/** Whether the sidebar supports collapsing */
|
|
34
|
+
collapsible?: boolean;
|
|
35
|
+
/** Initial collapsed state in uncontrolled mode */
|
|
36
|
+
'default-collapsed'?: boolean;
|
|
37
|
+
/**
|
|
38
|
+
* Accessible label for the navigation landmark.
|
|
39
|
+
* Use to distinguish multiple navigation regions on a page.
|
|
40
|
+
* @default 'Sidebar navigation'
|
|
41
|
+
*/
|
|
42
|
+
label?: string;
|
|
43
|
+
/**
|
|
44
|
+
* CSS media query that, when it matches, automatically collapses the sidebar.
|
|
45
|
+
* Unset by default — no automatic collapse.
|
|
46
|
+
* @example 'responsive="(max-width: 768px)"'
|
|
47
|
+
*/
|
|
48
|
+
responsive?: string;
|
|
49
|
+
/** Visual style variant */
|
|
50
|
+
variant?: SidebarVariant;
|
|
51
|
+
};
|
|
52
|
+
/**
|
|
53
|
+
* `bit-sidebar` — A collapsible navigation sidebar with group and item support.
|
|
54
|
+
*
|
|
55
|
+
* @element bit-sidebar
|
|
56
|
+
*
|
|
57
|
+
* @attr {boolean} collapsed - Controlled collapsed state
|
|
58
|
+
* @attr {boolean} default-collapsed - Initial collapsed state for uncontrolled sidebars
|
|
59
|
+
* @attr {boolean} collapsible - Show the collapse toggle button
|
|
60
|
+
* @attr {string} variant - Visual variant: 'floating' | 'inset'
|
|
61
|
+
* @attr {string} label - Accessible aria-label for the nav landmark
|
|
62
|
+
*
|
|
63
|
+
* @slot header - Branding or logo content above the nav
|
|
64
|
+
* @slot - Navigation content (bit-sidebar-group / bit-sidebar-item)
|
|
65
|
+
* @slot footer - Footer content below the nav (user info, settings, etc.)
|
|
66
|
+
*
|
|
67
|
+
* @fires collapsed-change - Fired when collapsed state changes
|
|
68
|
+
*
|
|
69
|
+
* @cssprop --sidebar-width - Expanded sidebar width (default: 16rem)
|
|
70
|
+
* @cssprop --sidebar-collapsed-width - Collapsed sidebar width (default: 3.5rem)
|
|
71
|
+
* @cssprop --sidebar-bg - Sidebar background color
|
|
72
|
+
* @cssprop --sidebar-border-color - Border color
|
|
73
|
+
*
|
|
74
|
+
* @attr {string} responsive - CSS media query that auto-collapses the sidebar when it matches (e.g. '(max-width: 768px)')
|
|
75
|
+
*
|
|
76
|
+
* @example
|
|
77
|
+
* ```html
|
|
78
|
+
* <bit-sidebar collapsible label="App navigation">
|
|
79
|
+
* <span slot="header">My App</span>
|
|
80
|
+
* <bit-sidebar-group label="Main">
|
|
81
|
+
* <bit-sidebar-item href="/dashboard" active>Dashboard</bit-sidebar-item>
|
|
82
|
+
* <bit-sidebar-item href="/settings">Settings</bit-sidebar-item>
|
|
83
|
+
* </bit-sidebar-group>
|
|
84
|
+
* </bit-sidebar>
|
|
85
|
+
*
|
|
86
|
+
* <!-- Auto-collapse on mobile -->
|
|
87
|
+
* <bit-sidebar collapsible responsive="(max-width: 768px)">...</bit-sidebar>
|
|
88
|
+
* ```
|
|
89
|
+
*/
|
|
90
|
+
export declare const SIDEBAR_TAG: string;
|
|
91
|
+
/** Sidebar group properties */
|
|
92
|
+
export type BitSidebarGroupProps = {
|
|
93
|
+
/** Whether this group can be collapsed */
|
|
94
|
+
collapsible?: boolean;
|
|
95
|
+
/** Initial open state in uncontrolled mode */
|
|
96
|
+
'default-open'?: boolean;
|
|
97
|
+
/** Accessible label for the group */
|
|
98
|
+
label?: string;
|
|
99
|
+
/** Controlled open state */
|
|
100
|
+
open?: boolean;
|
|
101
|
+
};
|
|
102
|
+
/**
|
|
103
|
+
* `bit-sidebar-group` — A labelled section within `bit-sidebar`.
|
|
104
|
+
*
|
|
105
|
+
* @element bit-sidebar-group
|
|
106
|
+
*
|
|
107
|
+
* @attr {string} label - Group label text
|
|
108
|
+
* @attr {boolean} collapsible - Whether this group can be toggled open/closed
|
|
109
|
+
* @attr {boolean} open - Controlled expanded state
|
|
110
|
+
* @attr {boolean} default-open - Initial expanded state in uncontrolled mode
|
|
111
|
+
*
|
|
112
|
+
* @slot - Navigation items (`bit-sidebar-item`)
|
|
113
|
+
* @slot icon - Icon displayed before the label
|
|
114
|
+
*
|
|
115
|
+
* @fires open-change - Fired when the group open state changes (collapsible groups only)
|
|
116
|
+
*
|
|
117
|
+
* @example
|
|
118
|
+
* ```html
|
|
119
|
+
* <bit-sidebar-group label="Main" collapsible open>
|
|
120
|
+
* <bit-sidebar-item href="/home">Home</bit-sidebar-item>
|
|
121
|
+
* </bit-sidebar-group>
|
|
122
|
+
* ```
|
|
123
|
+
*/
|
|
124
|
+
export declare const SIDEBAR_GROUP_TAG: string;
|
|
125
|
+
/** Sidebar item properties */
|
|
126
|
+
export type BitSidebarItemProps = {
|
|
127
|
+
/** Whether this item represents the current page/section */
|
|
128
|
+
active?: boolean;
|
|
129
|
+
/** Whether this item is disabled */
|
|
130
|
+
disabled?: boolean;
|
|
131
|
+
/** Navigation href — renders an `<a>` when set, otherwise a `<button>` */
|
|
132
|
+
href?: string;
|
|
133
|
+
/**
|
|
134
|
+
* Relationship of the linked URL (`rel` attribute on the inner `<a>`).
|
|
135
|
+
* Only applies when `href` is set.
|
|
136
|
+
*/
|
|
137
|
+
rel?: string;
|
|
138
|
+
/**
|
|
139
|
+
* Browsing context for the link (`target` attribute on the inner `<a>`).
|
|
140
|
+
* Only applies when `href` is set.
|
|
141
|
+
*/
|
|
142
|
+
target?: string;
|
|
143
|
+
};
|
|
144
|
+
/**
|
|
145
|
+
* `bit-sidebar-item` — An individual navigation item in a `bit-sidebar`.
|
|
146
|
+
*
|
|
147
|
+
* Renders as an `<a>` when `href` is provided, otherwise as a `<button>`.
|
|
148
|
+
* Marks the active page via `aria-current="page"` when the `active` attribute is set.
|
|
149
|
+
*
|
|
150
|
+
* @element bit-sidebar-item
|
|
151
|
+
*
|
|
152
|
+
* @attr {string} href - Link URL; renders an anchor when set
|
|
153
|
+
* @attr {boolean} active - Marks the item as the current page
|
|
154
|
+
* @attr {boolean} disabled - Disables the item
|
|
155
|
+
* @attr {string} rel - Anchor `rel` attribute (links only)
|
|
156
|
+
* @attr {string} target - Anchor `target` attribute (links only)
|
|
157
|
+
*
|
|
158
|
+
* @slot - Label text
|
|
159
|
+
* @slot icon - Leading icon
|
|
160
|
+
* @slot end - Trailing content (badge, shortcut, arrow, etc.)
|
|
161
|
+
*
|
|
162
|
+
* @part item - The inner anchor or button element
|
|
163
|
+
* @part item-icon - The icon wrapper
|
|
164
|
+
* @part item-label - The label wrapper
|
|
165
|
+
* @part item-end - The trailing content wrapper
|
|
166
|
+
*
|
|
167
|
+
* @cssprop --sidebar-item-color - Default text color
|
|
168
|
+
* @cssprop --sidebar-item-hover-bg - Hover background
|
|
169
|
+
* @cssprop --sidebar-item-hover-color - Hover text color
|
|
170
|
+
* @cssprop --sidebar-item-active-bg - Active background
|
|
171
|
+
* @cssprop --sidebar-item-active-color - Active text color
|
|
172
|
+
* @cssprop --sidebar-item-indicator - Active indicator bar color
|
|
173
|
+
*
|
|
174
|
+
* @example
|
|
175
|
+
* ```html
|
|
176
|
+
* <bit-sidebar-item href="/dashboard" active>
|
|
177
|
+
* <span slot="icon">🏠</span>
|
|
178
|
+
* Dashboard
|
|
179
|
+
* </bit-sidebar-item>
|
|
180
|
+
*
|
|
181
|
+
* <bit-sidebar-item href="/users">
|
|
182
|
+
* <span slot="icon">👤</span>
|
|
183
|
+
* Users
|
|
184
|
+
* <bit-badge slot="end" color="primary">3</bit-badge>
|
|
185
|
+
* </bit-sidebar-item>
|
|
186
|
+
* ```
|
|
187
|
+
*/
|
|
188
|
+
export declare const SIDEBAR_ITEM_TAG: string;
|
|
189
|
+
export {};
|
|
190
|
+
//# sourceMappingURL=sidebar.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sidebar.d.ts","sourceRoot":"","sources":["../../../src/layout/sidebar/sidebar.ts"],"names":[],"mappings":"AAAA,OAAO,EAUL,KAAK,cAAc,EAEpB,MAAM,mBAAmB,CAAC;AAO3B,KAAK,cAAc,GAAG,UAAU,GAAG,OAAO,CAAC;AAC3C,KAAK,qBAAqB,GAAG,KAAK,GAAG,YAAY,GAAG,QAAQ,CAAC;AAE7D,oGAAoG;AACpG,MAAM,MAAM,cAAc,GAAG;IAC3B,SAAS,EAAE,cAAc,CAAC,OAAO,CAAC,CAAC;IACnC,OAAO,EAAE,cAAc,CAAC,cAAc,GAAG,SAAS,CAAC,CAAC;CACrD,CAAC;AAEF,6CAA6C;AAC7C,eAAO,MAAM,WAAW,0DAAkD,CAAC;AAM3E,oCAAoC;AACpC,MAAM,MAAM,cAAc,GAAG,WAAW,GACtC,eAAe,GAAG;IAChB,wCAAwC;IACxC,YAAY,CAAC,IAAI,EAAE,OAAO,GAAG,IAAI,CAAC;IAClC,6CAA6C;IAC7C,MAAM,IAAI,IAAI,CAAC;CAChB,CAAC;AAEJ,mCAAmC;AAEnC,MAAM,MAAM,gBAAgB,GAAG;IAC7B,kBAAkB,EAAE;QAAE,SAAS,EAAE,OAAO,CAAC;QAAC,MAAM,EAAE,qBAAqB,CAAA;KAAE,CAAC;CAC3E,CAAC;AAEF,MAAM,MAAM,qBAAqB,GAAG;IAClC,aAAa,EAAE;QAAE,IAAI,EAAE,OAAO,CAAA;KAAE,CAAC;CAClC,CAAC;AAEF,MAAM,MAAM,eAAe,GAAG;IAC5B,iCAAiC;IACjC,SAAS,CAAC,EAAE,OAAO,CAAC;IACpB,8CAA8C;IAC9C,WAAW,CAAC,EAAE,OAAO,CAAC;IACtB,mDAAmD;IACnD,mBAAmB,CAAC,EAAE,OAAO,CAAC;IAC9B;;;;OAIG;IACH,KAAK,CAAC,EAAE,MAAM,CAAC;IACf;;;;OAIG;IACH,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,2BAA2B;IAC3B,OAAO,CAAC,EAAE,cAAc,CAAC;CAC1B,CAAC;AAEF;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAqCG;AACH,eAAO,MAAM,WAAW,QAsHtB,CAAC;AAMH,+BAA+B;AAC/B,MAAM,MAAM,oBAAoB,GAAG;IACjC,0CAA0C;IAC1C,WAAW,CAAC,EAAE,OAAO,CAAC;IACtB,8CAA8C;IAC9C,cAAc,CAAC,EAAE,OAAO,CAAC;IACzB,qCAAqC;IACrC,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,4BAA4B;IAC5B,IAAI,CAAC,EAAE,OAAO,CAAC;CAChB,CAAC;AAEF;;;;;;;;;;;;;;;;;;;;;GAqBG;AACH,eAAO,MAAM,iBAAiB,QA4E5B,CAAC;AAMH,8BAA8B;AAC9B,MAAM,MAAM,mBAAmB,GAAG;IAChC,4DAA4D;IAC5D,MAAM,CAAC,EAAE,OAAO,CAAC;IACjB,oCAAoC;IACpC,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,0EAA0E;IAC1E,IAAI,CAAC,EAAE,MAAM,CAAC;IACd;;;OAGG;IACH,GAAG,CAAC,EAAE,MAAM,CAAC;IACb;;;OAGG;IACH,MAAM,CAAC,EAAE,MAAM,CAAC;CACjB,CAAC;AAEF;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA2CG;AACH,eAAO,MAAM,gBAAgB,QAwD3B,CAAC"}
|
package/dist/menu.cjs
ADDED
|
@@ -0,0 +1,133 @@
|
|
|
1
|
+
Object.defineProperty(exports,Symbol.toStringTag,{value:`Module`});const e=require(`./styles/mixins/accessibility.css.cjs`),t=require(`./styles/mixins/shape.css.cjs`),n=require(`./styles/mixins/theme.css.cjs`);require(`./styles/index.cjs`);const r=require(`./craftit/dist/labs/list.cjs`),i=require(`./craftit/dist/labs/overlay.cjs`);require(`./craftit/dist/labs.cjs`);const a=require(`./overlay/menu/menu.css?inline.cjs`);let o=require(`@vielzeug/craftit`),s=require(`@vielzeug/floatit`);var c=o.css`
|
|
2
|
+
${n.colorThemeMixin}
|
|
3
|
+
${t.sizeVariantMixin}
|
|
4
|
+
${n.forcedColorsMixin}
|
|
5
|
+
`,l=(0,o.defineComponent)({props:{checked:{default:!1,type:Boolean},disabled:{default:!1,type:Boolean},type:{default:void 0},value:{default:void 0}},setup({props:t}){let n=o.css`
|
|
6
|
+
@layer buildit.base {
|
|
7
|
+
:host {
|
|
8
|
+
display: block;
|
|
9
|
+
outline: none;
|
|
10
|
+
}
|
|
11
|
+
|
|
12
|
+
.item {
|
|
13
|
+
align-items: center;
|
|
14
|
+
border-radius: 0;
|
|
15
|
+
cursor: pointer;
|
|
16
|
+
display: flex;
|
|
17
|
+
font-size: var(--text-sm);
|
|
18
|
+
gap: var(--size-2);
|
|
19
|
+
line-height: var(--leading-normal);
|
|
20
|
+
padding: var(--size-1-5) var(--size-3);
|
|
21
|
+
transition:
|
|
22
|
+
background var(--transition-fast),
|
|
23
|
+
color var(--transition-fast);
|
|
24
|
+
user-select: none;
|
|
25
|
+
white-space: nowrap;
|
|
26
|
+
}
|
|
27
|
+
|
|
28
|
+
:host(:first-of-type) .item {
|
|
29
|
+
border-radius: var(--rounded-sm) var(--rounded-sm) 0 0;
|
|
30
|
+
}
|
|
31
|
+
|
|
32
|
+
:host(:last-child) .item {
|
|
33
|
+
border-radius: 0 0 var(--rounded-sm) var(--rounded-sm);
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
:host(:first-of-type:last-child) .item {
|
|
37
|
+
border-radius: var(--rounded-sm);
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
:host(:not([disabled])) .item:hover {
|
|
41
|
+
background: var(--color-contrast-100);
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
:host(:focus-visible) .item {
|
|
45
|
+
background: color-mix(in srgb, var(--color-primary) 12%, var(--color-contrast-100));
|
|
46
|
+
color: var(--color-primary);
|
|
47
|
+
}
|
|
48
|
+
|
|
49
|
+
/* Driven by JS via sync() — avoids :host() attribute selector edge-cases */
|
|
50
|
+
.item.is-checkable {
|
|
51
|
+
background: color-mix(in srgb, var(--color-contrast-900) 5%, var(--color-canvas));
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
.item.is-checked {
|
|
55
|
+
background: color-mix(in srgb, var(--color-primary) 18%, var(--color-canvas));
|
|
56
|
+
color: var(--color-primary);
|
|
57
|
+
font-weight: var(--font-medium);
|
|
58
|
+
}
|
|
59
|
+
|
|
60
|
+
:host([disabled]) .item {
|
|
61
|
+
color: var(--color-contrast-400);
|
|
62
|
+
cursor: not-allowed;
|
|
63
|
+
opacity: 0.6;
|
|
64
|
+
pointer-events: none;
|
|
65
|
+
}
|
|
66
|
+
|
|
67
|
+
.icon-slot {
|
|
68
|
+
display: contents;
|
|
69
|
+
}
|
|
70
|
+
|
|
71
|
+
.item-check {
|
|
72
|
+
align-items: center;
|
|
73
|
+
color: currentColor;
|
|
74
|
+
display: inline-flex;
|
|
75
|
+
flex-shrink: 0;
|
|
76
|
+
justify-content: center;
|
|
77
|
+
width: 1.25rem;
|
|
78
|
+
}
|
|
79
|
+
|
|
80
|
+
.item-label {
|
|
81
|
+
flex: 1;
|
|
82
|
+
min-width: 0;
|
|
83
|
+
overflow: hidden;
|
|
84
|
+
text-overflow: ellipsis;
|
|
85
|
+
white-space: nowrap;
|
|
86
|
+
}
|
|
87
|
+
}
|
|
88
|
+
${e.coarsePointerMixin}
|
|
89
|
+
`,r=(0,o.computed)(()=>t.type.value===`checkbox`||t.type.value===`radio`),i=(0,o.computed)(()=>r.value&&t.checked.value),a=(0,o.computed)(()=>t.type.value===`checkbox`?`menuitemcheckbox`:t.type.value===`radio`?`menuitemradio`:`menuitem`),s=(0,o.computed)(()=>t.type.value===`checkbox`?t.checked.value?`☑`:`☐`:t.type.value===`radio`?t.checked.value?`◉`:`◯`:``),c=(0,o.computed)(()=>`item${r.value?` is-checkable`:``}${i.value?` is-checked`:``}`),l=()=>o.html`
|
|
90
|
+
<span class="item-check" aria-hidden="true">${()=>s.value}</span>
|
|
91
|
+
<span class="icon-slot"><slot name="icon"></slot></span>
|
|
92
|
+
<span class="item-label"><slot></slot></span>
|
|
93
|
+
`;return o.html`
|
|
94
|
+
<style>
|
|
95
|
+
${n}
|
|
96
|
+
</style>
|
|
97
|
+
${()=>r.value?o.html`
|
|
98
|
+
<div
|
|
99
|
+
class="${()=>c.value}"
|
|
100
|
+
tabindex="-1"
|
|
101
|
+
role="${()=>a.value}"
|
|
102
|
+
aria-checked="${()=>String(i.value)}"
|
|
103
|
+
aria-disabled="${()=>String(t.disabled.value)}">
|
|
104
|
+
${l()}
|
|
105
|
+
</div>
|
|
106
|
+
`:o.html`
|
|
107
|
+
<div
|
|
108
|
+
class="${()=>c.value}"
|
|
109
|
+
tabindex="-1"
|
|
110
|
+
role="menuitem"
|
|
111
|
+
aria-disabled="${()=>String(t.disabled.value)}">
|
|
112
|
+
<span class="icon-slot"><slot name="icon"></slot></span>
|
|
113
|
+
<span class="item-label"><slot></slot></span>
|
|
114
|
+
</div>
|
|
115
|
+
`}
|
|
116
|
+
`},tag:`bit-menu-item`}),u=(0,o.defineComponent)({setup(){return o.html`<style>
|
|
117
|
+
@layer buildit.base {
|
|
118
|
+
:host {
|
|
119
|
+
display: block;
|
|
120
|
+
margin: var(--size-1) 0;
|
|
121
|
+
border-top: var(--border) solid var(--color-contrast-200);
|
|
122
|
+
}
|
|
123
|
+
}
|
|
124
|
+
</style>`},tag:`bit-menu-separator`}),d=(0,o.defineComponent)({props:{color:{default:void 0},disabled:{default:!1},placement:{default:`bottom-start`},size:{default:void 0}},setup({emit:e,host:t,props:n}){let l=(0,o.createId)(`menu`),u=(0,o.signal)(!1),d=null,f=null;function p(){return Array.from(t.querySelectorAll(`bit-menu-item:not([disabled])`))}let m=-1,h=r.e({getIndex:()=>m,getItems:p,isItemDisabled:e=>e.hasAttribute(`disabled`),setIndex:e=>{m=e,p()[e]?.focus()}});function g(){!f||!d||(0,s.positionFloat)(d,f,{middleware:[(0,s.offset)(4),(0,s.flip)({padding:6}),(0,s.shift)({padding:6})],placement:n.placement.value})}let _=i.t({getBoundaryElement:()=>t,getPanelElement:()=>f,getTriggerElement:()=>d,isDisabled:()=>!!n.disabled.value,isOpen:()=>u.value,onClose:t=>e(`close`,{reason:t}),onOpen:t=>e(`open`,{reason:t}),positioner:{floating:()=>f,reference:()=>d,update:g},setOpen:e=>{u.value=e,e||h.reset()}}),v=n=>{let r=n.getAttribute(`type`);if(r===`checkbox`)n.hasAttribute(`checked`)?n.removeAttribute(`checked`):n.setAttribute(`checked`,``);else if(r===`radio`){for(let e of t.querySelectorAll(`bit-menu-item[type="radio"]`))e.removeAttribute(`checked`);n.setAttribute(`checked`,``)}let i=n.getAttribute(`value`)??``;e(`select`,{checked:r===`checkbox`||r===`radio`?n.hasAttribute(`checked`):void 0,value:i}),r!==`checkbox`&&r!==`radio`&&_.close({reason:`programmatic`})};function y(e){if(!u.value){(e.key===`Enter`||e.key===` `||e.key===`ArrowDown`)&&(e.preventDefault(),_.open(),requestAnimationFrame(()=>h.first()));return}switch(e.key){case` `:{e.preventDefault();let t=h.getActiveItem();t&&v(t);break}case`ArrowDown`:e.preventDefault(),h.next();break;case`ArrowUp`:e.preventDefault(),h.prev();break;case`End`:e.preventDefault(),h.last();break;case`Enter`:{e.preventDefault();let t=h.getActiveItem();t&&v(t);break}case`Escape`:e.preventDefault(),_.close({reason:`escape`});break;case`Home`:e.preventDefault(),h.first();break;case`Tab`:_.close({reason:`programmatic`});break}}return(0,o.onMount)(()=>{let e=t.shadowRoot?.querySelector(`slot[name="trigger"]`);f=t.shadowRoot?.querySelector(`.menu-panel`)??null;let r=null;function i(){r&&(r.removeEventListener(`click`,a),r.removeEventListener(`keydown`,y)),d=e?.assignedElements({flatten:!0})?.[0]??null,r=d,d&&((0,o.aria)(d,{controls:()=>l,disabled:()=>n.disabled.value,expanded:()=>u.value?`true`:`false`,haspopup:`menu`}),d.addEventListener(`click`,a),d.addEventListener(`keydown`,y))}function a(){_.toggle()}(0,o.onSlotChange)(`trigger`,i),(0,o.handle)(t,`click`,(e=>{if(!u.value)return;let t=e,n=t.composedPath().find(e=>e instanceof HTMLElement&&e.tagName===`BIT-MENU-ITEM`)??t.target?.closest(`bit-menu-item`)??null;!n||n.hasAttribute(`disabled`)||v(n)}));let s=_.bindOutsideClick(document);return(0,o.effect)(()=>{f?.toggleAttribute(`data-open`,u.value)}),(0,o.handle)(f,`keydown`,y),()=>{s(),r&&(r.removeEventListener(`click`,a),r.removeEventListener(`keydown`,y))}}),o.html`
|
|
125
|
+
<style>
|
|
126
|
+
${a.default}${c}
|
|
127
|
+
</style>
|
|
128
|
+
<slot name="trigger"></slot>
|
|
129
|
+
<div class="menu-panel" id="${l}" role="menu" aria-orientation="vertical">
|
|
130
|
+
<slot></slot>
|
|
131
|
+
</div>
|
|
132
|
+
`},tag:`bit-menu`});exports.MENU_ITEM_TAG=l,exports.MENU_TAG=d,exports.SEPARATOR_TAG=u;
|
|
133
|
+
//# sourceMappingURL=menu.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"menu.cjs","names":[],"sources":["../src/overlay/menu/menu.ts"],"sourcesContent":["import {\n aria,\n computed,\n createId,\n css,\n defineComponent,\n effect,\n handle,\n html,\n onMount,\n onSlotChange,\n signal,\n} from '@vielzeug/craftit';\nimport {\n createListNavigation,\n createOverlayControl,\n type OverlayOpenReason,\n type OverlayCloseReason,\n} from '@vielzeug/craftit/labs';\nimport { flip, offset, positionFloat, shift } from '@vielzeug/floatit';\n\nimport type { AddEventListeners, ComponentSize, ThemeColor } from '../../types';\n\nimport { coarsePointerMixin, colorThemeMixin, forcedColorsMixin, sizeVariantMixin } from '../../styles';\n\n// ============================================\n// Types\n// ============================================\n\nexport interface MenuSelectDetail {\n value: string;\n checked?: boolean;\n}\n\nexport type BitMenuItemType = 'checkbox' | 'radio';\n\nexport type BitMenuEvents = {\n close: { reason: OverlayCloseReason };\n open: { reason: OverlayOpenReason };\n select: MenuSelectDetail;\n};\n\nexport type BitMenuItemProps = {\n checked?: boolean;\n disabled?: boolean;\n type?: BitMenuItemType;\n value?: string;\n};\n\nexport type BitMenuProps = {\n color?: ThemeColor;\n disabled?: boolean;\n placement?: 'bottom' | 'bottom-start' | 'bottom-end' | 'top' | 'top-start' | 'top-end';\n size?: ComponentSize;\n};\n\n// ============================================\n// Styles\n// ============================================\n\nimport componentStyles from './menu.css?inline';\n\nconst themeStyles = /* css */ css`\n ${colorThemeMixin}\n ${sizeVariantMixin}\n ${forcedColorsMixin}\n`;\n\n// ============================================\n// Menu Item Component\n// ============================================\n\nexport const MENU_ITEM_TAG = defineComponent<BitMenuItemProps>({\n props: {\n checked: { default: false, type: Boolean },\n disabled: { default: false, type: Boolean },\n type: { default: undefined },\n value: { default: undefined },\n },\n setup({ props }) {\n const itemStyles = /* css */ css`\n @layer buildit.base {\n :host {\n display: block;\n outline: none;\n }\n\n .item {\n align-items: center;\n border-radius: 0;\n cursor: pointer;\n display: flex;\n font-size: var(--text-sm);\n gap: var(--size-2);\n line-height: var(--leading-normal);\n padding: var(--size-1-5) var(--size-3);\n transition:\n background var(--transition-fast),\n color var(--transition-fast);\n user-select: none;\n white-space: nowrap;\n }\n\n :host(:first-of-type) .item {\n border-radius: var(--rounded-sm) var(--rounded-sm) 0 0;\n }\n\n :host(:last-child) .item {\n border-radius: 0 0 var(--rounded-sm) var(--rounded-sm);\n }\n\n :host(:first-of-type:last-child) .item {\n border-radius: var(--rounded-sm);\n }\n\n :host(:not([disabled])) .item:hover {\n background: var(--color-contrast-100);\n }\n\n :host(:focus-visible) .item {\n background: color-mix(in srgb, var(--color-primary) 12%, var(--color-contrast-100));\n color: var(--color-primary);\n }\n\n /* Driven by JS via sync() — avoids :host() attribute selector edge-cases */\n .item.is-checkable {\n background: color-mix(in srgb, var(--color-contrast-900) 5%, var(--color-canvas));\n }\n\n .item.is-checked {\n background: color-mix(in srgb, var(--color-primary) 18%, var(--color-canvas));\n color: var(--color-primary);\n font-weight: var(--font-medium);\n }\n\n :host([disabled]) .item {\n color: var(--color-contrast-400);\n cursor: not-allowed;\n opacity: 0.6;\n pointer-events: none;\n }\n\n .icon-slot {\n display: contents;\n }\n\n .item-check {\n align-items: center;\n color: currentColor;\n display: inline-flex;\n flex-shrink: 0;\n justify-content: center;\n width: 1.25rem;\n }\n\n .item-label {\n flex: 1;\n min-width: 0;\n overflow: hidden;\n text-overflow: ellipsis;\n white-space: nowrap;\n }\n }\n ${coarsePointerMixin}\n `;\n\n const isCheckable = computed(() => props.type.value === 'checkbox' || props.type.value === 'radio');\n const isChecked = computed(() => isCheckable.value && props.checked.value);\n const itemRole = computed(() => {\n if (props.type.value === 'checkbox') return 'menuitemcheckbox';\n\n if (props.type.value === 'radio') return 'menuitemradio';\n\n return 'menuitem';\n });\n const checkIndicator = computed(() => {\n if (props.type.value === 'checkbox') return props.checked.value ? '☑' : '☐';\n\n if (props.type.value === 'radio') return props.checked.value ? '◉' : '◯';\n\n return '';\n });\n const itemClass = computed(\n () => `item${isCheckable.value ? ' is-checkable' : ''}${isChecked.value ? ' is-checked' : ''}`,\n );\n const renderContent = () => html`\n <span class=\"item-check\" aria-hidden=\"true\">${() => checkIndicator.value}</span>\n <span class=\"icon-slot\"><slot name=\"icon\"></slot></span>\n <span class=\"item-label\"><slot></slot></span>\n `;\n\n return html`\n <style>\n ${itemStyles}\n </style>\n ${() =>\n isCheckable.value\n ? html`\n <div\n class=\"${() => itemClass.value}\"\n tabindex=\"-1\"\n role=\"${() => itemRole.value}\"\n aria-checked=\"${() => String(isChecked.value)}\"\n aria-disabled=\"${() => String(props.disabled.value)}\">\n ${renderContent()}\n </div>\n `\n : html`\n <div\n class=\"${() => itemClass.value}\"\n tabindex=\"-1\"\n role=\"menuitem\"\n aria-disabled=\"${() => String(props.disabled.value)}\">\n <span class=\"icon-slot\"><slot name=\"icon\"></slot></span>\n <span class=\"item-label\"><slot></slot></span>\n </div>\n `}\n `;\n },\n tag: 'bit-menu-item',\n});\n\n// ============================================\n// Menu Separator\n// ============================================\n\nexport const SEPARATOR_TAG = defineComponent({\n setup() {\n return html`<style>\n @layer buildit.base {\n :host {\n display: block;\n margin: var(--size-1) 0;\n border-top: var(--border) solid var(--color-contrast-200);\n }\n }\n </style>`;\n },\n tag: 'bit-menu-separator',\n});\n\n// ============================================\n// Menu Component\n// ============================================\n\n/**\n * `bit-menu` — Action dropdown menu triggered by a slotted trigger element.\n * Nest `<bit-menu-item>` elements inside for menu options.\n *\n * @example\n * ```html\n * <bit-menu>\n * <button slot=\"trigger\">Actions</button>\n * <bit-menu-item value=\"edit\">Edit</bit-menu-item>\n * <bit-menu-item value=\"delete\">Delete</bit-menu-item>\n * </bit-menu>\n * ```\n */\nexport const MENU_TAG = defineComponent<BitMenuProps, BitMenuEvents>({\n props: {\n color: { default: undefined },\n disabled: { default: false },\n placement: { default: 'bottom-start' },\n size: { default: undefined },\n },\n setup({ emit, host, props }) {\n const menuId = createId('menu');\n const isOpen = signal(false);\n let triggerEl: HTMLElement | null = null;\n let panelEl: HTMLElement | null = null;\n\n // ── Helpers ───────────────────────────────────────────────────────────────\n function getItems(): HTMLElement[] {\n return Array.from(host.querySelectorAll<HTMLElement>('bit-menu-item:not([disabled])'));\n }\n\n let focusedIndex = -1;\n\n const listNavigation = createListNavigation<HTMLElement>({\n getIndex: () => focusedIndex,\n getItems,\n isItemDisabled: (item) => item.hasAttribute('disabled'),\n setIndex: (index) => {\n focusedIndex = index;\n getItems()[index]?.focus();\n },\n });\n\n function updatePosition() {\n if (!panelEl || !triggerEl) return;\n\n positionFloat(triggerEl, panelEl, {\n middleware: [offset(4), flip({ padding: 6 }), shift({ padding: 6 })],\n placement: props.placement.value,\n });\n }\n\n const overlay = createOverlayControl({\n getBoundaryElement: () => host,\n getPanelElement: () => panelEl,\n getTriggerElement: () => triggerEl,\n isDisabled: () => Boolean(props.disabled.value),\n isOpen: () => isOpen.value,\n onClose: (reason) => emit('close', { reason }),\n onOpen: (reason) => emit('open', { reason }),\n positioner: {\n floating: () => panelEl,\n reference: () => triggerEl,\n update: updatePosition,\n },\n setOpen: (next) => {\n isOpen.value = next;\n\n if (!next) listNavigation.reset();\n },\n });\n\n const activateItem = (item: HTMLElement): void => {\n const type = item.getAttribute('type');\n\n if (type === 'checkbox') {\n const next = !item.hasAttribute('checked');\n\n if (next) item.setAttribute('checked', '');\n else item.removeAttribute('checked');\n } else if (type === 'radio') {\n for (const radio of host.querySelectorAll<HTMLElement>('bit-menu-item[type=\"radio\"]')) {\n radio.removeAttribute('checked');\n }\n item.setAttribute('checked', '');\n }\n\n const value = item.getAttribute('value') ?? '';\n const checked = type === 'checkbox' || type === 'radio' ? item.hasAttribute('checked') : undefined;\n\n emit('select', { checked, value });\n\n if (type !== 'checkbox' && type !== 'radio') {\n overlay.close({ reason: 'programmatic' });\n }\n };\n\n // ── Keyboard Navigation ───────────────────────────────────────────────────\n function handleMenuKeydown(e: KeyboardEvent) {\n const open = isOpen.value;\n\n // When closed: open on Enter / Space / ArrowDown\n if (!open) {\n if (e.key === 'Enter' || e.key === ' ' || e.key === 'ArrowDown') {\n e.preventDefault();\n overlay.open();\n requestAnimationFrame(() => listNavigation.first());\n }\n\n return;\n }\n\n // When open: navigate and activate\n switch (e.key) {\n case ' ': {\n e.preventDefault();\n\n const focused = listNavigation.getActiveItem();\n\n if (focused) activateItem(focused);\n\n break;\n }\n case 'ArrowDown':\n e.preventDefault();\n listNavigation.next();\n break;\n case 'ArrowUp':\n e.preventDefault();\n listNavigation.prev();\n break;\n case 'End':\n e.preventDefault();\n listNavigation.last();\n break;\n case 'Enter': {\n e.preventDefault();\n\n const focused = listNavigation.getActiveItem();\n\n if (focused) activateItem(focused);\n\n break;\n }\n case 'Escape':\n e.preventDefault();\n overlay.close({ reason: 'escape' });\n break;\n case 'Home':\n e.preventDefault();\n listNavigation.first();\n break;\n case 'Tab':\n overlay.close({ reason: 'programmatic' });\n break;\n }\n }\n\n // ── Lifecycle ─────────────────────────────────────────────────────────────\n onMount(() => {\n const triggerSlot = host.shadowRoot?.querySelector<HTMLSlotElement>('slot[name=\"trigger\"]');\n\n panelEl = host.shadowRoot?.querySelector<HTMLElement>('.menu-panel') ?? null;\n\n let prevTriggerEl: HTMLElement | null = null;\n\n function resolveTrigger() {\n if (prevTriggerEl) {\n prevTriggerEl.removeEventListener('click', toggleMenu);\n prevTriggerEl.removeEventListener('keydown', handleMenuKeydown);\n }\n\n const assigned = triggerSlot?.assignedElements({ flatten: true });\n\n triggerEl = (assigned?.[0] as HTMLElement | undefined) ?? null;\n prevTriggerEl = triggerEl;\n\n if (triggerEl) {\n aria(triggerEl, {\n controls: () => menuId,\n disabled: () => props.disabled.value,\n expanded: () => (isOpen.value ? 'true' : 'false'),\n haspopup: 'menu',\n });\n triggerEl.addEventListener('click', toggleMenu);\n triggerEl.addEventListener('keydown', handleMenuKeydown);\n }\n }\n\n function toggleMenu() {\n overlay.toggle();\n }\n\n onSlotChange('trigger', resolveTrigger);\n\n // Item activation via click\n handle(host, 'click', ((e: Event) => {\n if (!isOpen.value) return;\n\n const me = e as MouseEvent;\n const path = me.composedPath();\n const itemFromPath = path.find(\n (node): node is HTMLElement => node instanceof HTMLElement && node.tagName === 'BIT-MENU-ITEM',\n );\n const item = itemFromPath ?? (me.target as HTMLElement | null)?.closest<HTMLElement>('bit-menu-item') ?? null;\n\n if (!item || item.hasAttribute('disabled')) return;\n\n activateItem(item);\n }) as EventListener);\n\n const removeOutsideClick = overlay.bindOutsideClick(document);\n\n effect(() => {\n panelEl?.toggleAttribute('data-open', isOpen.value);\n });\n\n handle(panelEl, 'keydown', handleMenuKeydown as EventListener);\n\n return () => {\n removeOutsideClick();\n\n if (prevTriggerEl) {\n prevTriggerEl.removeEventListener('click', toggleMenu);\n prevTriggerEl.removeEventListener('keydown', handleMenuKeydown);\n }\n };\n });\n\n return html`\n <style>\n ${componentStyles}${themeStyles}\n </style>\n <slot name=\"trigger\"></slot>\n <div class=\"menu-panel\" id=\"${menuId}\" role=\"menu\" aria-orientation=\"vertical\">\n <slot></slot>\n </div>\n `;\n },\n tag: 'bit-menu',\n}) as unknown as AddEventListeners<BitMenuEvents>;\n"],"mappings":"weA8DA,IAAM,EAAwB,EAAA,GAAG;IAC7B,EAAA,gBAAgB;IAChB,EAAA,iBAAiB;IACjB,EAAA,kBAAkB;EAOT,GAAA,EAAA,EAAA,iBAAkD,CAC7D,MAAO,CACL,QAAS,CAAE,QAAS,GAAO,KAAM,QAAS,CAC1C,SAAU,CAAE,QAAS,GAAO,KAAM,QAAS,CAC3C,KAAM,CAAE,QAAS,IAAA,GAAW,CAC5B,MAAO,CAAE,QAAS,IAAA,GAAW,CAC9B,CACD,MAAM,CAAE,SAAS,CACf,IAAM,EAAuB,EAAA,GAAG;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;QAmF5B,EAAA,mBAAmB;MAGjB,GAAA,EAAA,EAAA,cAA6B,EAAM,KAAK,QAAU,YAAc,EAAM,KAAK,QAAU,QAAQ,CAC7F,GAAA,EAAA,EAAA,cAA2B,EAAY,OAAS,EAAM,QAAQ,MAAM,CACpE,GAAA,EAAA,EAAA,cACA,EAAM,KAAK,QAAU,WAAmB,mBAExC,EAAM,KAAK,QAAU,QAAgB,gBAElC,WACP,CACI,GAAA,EAAA,EAAA,cACA,EAAM,KAAK,QAAU,WAAmB,EAAM,QAAQ,MAAQ,IAAM,IAEpE,EAAM,KAAK,QAAU,QAAgB,EAAM,QAAQ,MAAQ,IAAM,IAE9D,GACP,CACI,GAAA,EAAA,EAAA,cACE,OAAO,EAAY,MAAQ,gBAAkB,KAAK,EAAU,MAAQ,cAAgB,KAC3F,CACK,MAAsB,EAAA,IAAI;wDACsB,EAAe,MAAM;;;MAK3E,MAAO,GAAA,IAAI;;UAEL,EAAW;;YAGb,EAAY,MACR,EAAA,IAAI;;6BAEe,EAAU,MAAM;;4BAEjB,EAAS,MAAM;oCACP,OAAO,EAAU,MAAM,CAAC;qCACvB,OAAO,EAAM,SAAS,MAAM,CAAC;kBAClD,GAAe,CAAC;;cAGtB,EAAA,IAAI;;6BAEe,EAAU,MAAM;;;qCAGR,OAAO,EAAM,SAAS,MAAM,CAAC;;;;cAItD;OAGZ,IAAK,gBACN,CAAC,CAMW,GAAA,EAAA,EAAA,iBAAgC,CAC3C,OAAQ,CACN,MAAO,GAAA,IAAI;;;;;;;;eAUb,IAAK,qBACN,CAAC,CAmBW,GAAA,EAAA,EAAA,iBAAwD,CACnE,MAAO,CACL,MAAO,CAAE,QAAS,IAAA,GAAW,CAC7B,SAAU,CAAE,QAAS,GAAO,CAC5B,UAAW,CAAE,QAAS,eAAgB,CACtC,KAAM,CAAE,QAAS,IAAA,GAAW,CAC7B,CACD,MAAM,CAAE,OAAM,OAAM,SAAS,CAC3B,IAAM,GAAA,EAAA,EAAA,UAAkB,OAAO,CACzB,GAAA,EAAA,EAAA,QAAgB,GAAM,CACxB,EAAgC,KAChC,EAA8B,KAGlC,SAAS,GAA0B,CACjC,OAAO,MAAM,KAAK,EAAK,iBAA8B,gCAAgC,CAAC,CAGxF,IAAI,EAAe,GAEb,EAAiB,EAAA,EAAkC,CACvD,aAAgB,EAChB,WACA,eAAiB,GAAS,EAAK,aAAa,WAAW,CACvD,SAAW,GAAU,CACnB,EAAe,EACf,GAAU,CAAC,IAAQ,OAAO,EAE7B,CAAC,CAEF,SAAS,GAAiB,CACpB,CAAC,GAAW,CAAC,IAEjB,EAAA,EAAA,eAAc,EAAW,EAAS,CAChC,WAAY,cAAQ,EAAE,YAAO,CAAE,QAAS,EAAG,CAAC,aAAQ,CAAE,QAAS,EAAG,CAAC,CAAC,CACpE,UAAW,EAAM,UAAU,MAC5B,CAAC,CAGJ,IAAM,EAAU,EAAA,EAAqB,CACnC,uBAA0B,EAC1B,oBAAuB,EACvB,sBAAyB,EACzB,eAAkB,EAAQ,EAAM,SAAS,MACzC,WAAc,EAAO,MACrB,QAAU,GAAW,EAAK,QAAS,CAAE,SAAQ,CAAC,CAC9C,OAAS,GAAW,EAAK,OAAQ,CAAE,SAAQ,CAAC,CAC5C,WAAY,CACV,aAAgB,EAChB,cAAiB,EACjB,OAAQ,EACT,CACD,QAAU,GAAS,CACjB,EAAO,MAAQ,EAEV,GAAM,EAAe,OAAO,EAEpC,CAAC,CAEI,EAAgB,GAA4B,CAChD,IAAM,EAAO,EAAK,aAAa,OAAO,CAEtC,GAAI,IAAS,WACG,EAAK,aAAa,UAAU,CAGrC,EAAK,gBAAgB,UAAU,CAD1B,EAAK,aAAa,UAAW,GAAG,SAEjC,IAAS,QAAS,CAC3B,IAAK,IAAM,KAAS,EAAK,iBAA8B,8BAA8B,CACnF,EAAM,gBAAgB,UAAU,CAElC,EAAK,aAAa,UAAW,GAAG,CAGlC,IAAM,EAAQ,EAAK,aAAa,QAAQ,EAAI,GAG5C,EAAK,SAAU,CAAE,QAFD,IAAS,YAAc,IAAS,QAAU,EAAK,aAAa,UAAU,CAAG,IAAA,GAE/D,QAAO,CAAC,CAE9B,IAAS,YAAc,IAAS,SAClC,EAAQ,MAAM,CAAE,OAAQ,eAAgB,CAAC,EAK7C,SAAS,EAAkB,EAAkB,CAI3C,GAAI,CAHS,EAAO,MAGT,EACL,EAAE,MAAQ,SAAW,EAAE,MAAQ,KAAO,EAAE,MAAQ,eAClD,EAAE,gBAAgB,CAClB,EAAQ,MAAM,CACd,0BAA4B,EAAe,OAAO,CAAC,EAGrD,OAIF,OAAQ,EAAE,IAAV,CACE,IAAK,IAAK,CACR,EAAE,gBAAgB,CAElB,IAAM,EAAU,EAAe,eAAe,CAE1C,GAAS,EAAa,EAAQ,CAElC,MAEF,IAAK,YACH,EAAE,gBAAgB,CAClB,EAAe,MAAM,CACrB,MACF,IAAK,UACH,EAAE,gBAAgB,CAClB,EAAe,MAAM,CACrB,MACF,IAAK,MACH,EAAE,gBAAgB,CAClB,EAAe,MAAM,CACrB,MACF,IAAK,QAAS,CACZ,EAAE,gBAAgB,CAElB,IAAM,EAAU,EAAe,eAAe,CAE1C,GAAS,EAAa,EAAQ,CAElC,MAEF,IAAK,SACH,EAAE,gBAAgB,CAClB,EAAQ,MAAM,CAAE,OAAQ,SAAU,CAAC,CACnC,MACF,IAAK,OACH,EAAE,gBAAgB,CAClB,EAAe,OAAO,CACtB,MACF,IAAK,MACH,EAAQ,MAAM,CAAE,OAAQ,eAAgB,CAAC,CACzC,OA2EN,OAtEA,EAAA,EAAA,aAAc,CACZ,IAAM,EAAc,EAAK,YAAY,cAA+B,uBAAuB,CAE3F,EAAU,EAAK,YAAY,cAA2B,cAAc,EAAI,KAExE,IAAI,EAAoC,KAExC,SAAS,GAAiB,CACpB,IACF,EAAc,oBAAoB,QAAS,EAAW,CACtD,EAAc,oBAAoB,UAAW,EAAkB,EAKjE,EAFiB,GAAa,iBAAiB,CAAE,QAAS,GAAM,CAAC,GAEzC,IAAkC,KAC1D,EAAgB,EAEZ,KACF,EAAA,EAAA,MAAK,EAAW,CACd,aAAgB,EAChB,aAAgB,EAAM,SAAS,MAC/B,aAAiB,EAAO,MAAQ,OAAS,QACzC,SAAU,OACX,CAAC,CACF,EAAU,iBAAiB,QAAS,EAAW,CAC/C,EAAU,iBAAiB,UAAW,EAAkB,EAI5D,SAAS,GAAa,CACpB,EAAQ,QAAQ,EAGlB,EAAA,EAAA,cAAa,UAAW,EAAe,EAGvC,EAAA,EAAA,QAAO,EAAM,SAAW,GAAa,CACnC,GAAI,CAAC,EAAO,MAAO,OAEnB,IAAM,EAAK,EAKL,EAJO,EAAG,cAAc,CACJ,KACvB,GAA8B,aAAgB,aAAe,EAAK,UAAY,gBAChF,EAC6B,EAAG,QAA+B,QAAqB,gBAAgB,EAAI,KAErG,CAAC,GAAQ,EAAK,aAAa,WAAW,EAE1C,EAAa,EAAK,GACA,CAEpB,IAAM,EAAqB,EAAQ,iBAAiB,SAAS,CAQ7D,OANA,EAAA,EAAA,YAAa,CACX,GAAS,gBAAgB,YAAa,EAAO,MAAM,EACnD,EAEF,EAAA,EAAA,QAAO,EAAS,UAAW,EAAmC,KAEjD,CACX,GAAoB,CAEhB,IACF,EAAc,oBAAoB,QAAS,EAAW,CACtD,EAAc,oBAAoB,UAAW,EAAkB,IAGnE,CAEK,EAAA,IAAI;;UAEL,EAAA,UAAkB,EAAY;;;oCAGJ,EAAO;;;OAKzC,IAAK,WACN,CAAC"}
|