@uifn/core 0.0.1
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/CHANGELOG.md +8 -0
- package/README.md +46 -0
- package/dist/aria/index.d.mts +1 -0
- package/dist/aria/index.d.ts +1 -0
- package/dist/aria/index.js +13 -0
- package/dist/aria/index.js.map +1 -0
- package/dist/aria/index.mjs +4 -0
- package/dist/aria/index.mjs.map +1 -0
- package/dist/aria/keys.d.mts +17 -0
- package/dist/aria/keys.d.ts +17 -0
- package/dist/aria/keys.js +12 -0
- package/dist/aria/keys.js.map +1 -0
- package/dist/aria/keys.mjs +3 -0
- package/dist/aria/keys.mjs.map +1 -0
- package/dist/chunk-2HLCA7I5.mjs +42 -0
- package/dist/chunk-2HLCA7I5.mjs.map +1 -0
- package/dist/chunk-2S7OX5K7.mjs +143 -0
- package/dist/chunk-2S7OX5K7.mjs.map +1 -0
- package/dist/chunk-2ZNFHW2P.js +125 -0
- package/dist/chunk-2ZNFHW2P.js.map +1 -0
- package/dist/chunk-3DNFBRAZ.mjs +49 -0
- package/dist/chunk-3DNFBRAZ.mjs.map +1 -0
- package/dist/chunk-3U3PAOFD.mjs +3 -0
- package/dist/chunk-3U3PAOFD.mjs.map +1 -0
- package/dist/chunk-4J6CNDHI.js +109 -0
- package/dist/chunk-4J6CNDHI.js.map +1 -0
- package/dist/chunk-4KISNBSY.mjs +403 -0
- package/dist/chunk-4KISNBSY.mjs.map +1 -0
- package/dist/chunk-4QGZXLQV.js +13 -0
- package/dist/chunk-4QGZXLQV.js.map +1 -0
- package/dist/chunk-4YPFHTID.js +136 -0
- package/dist/chunk-4YPFHTID.js.map +1 -0
- package/dist/chunk-5C57AF3A.js +247 -0
- package/dist/chunk-5C57AF3A.js.map +1 -0
- package/dist/chunk-5DK6IIIL.mjs +209 -0
- package/dist/chunk-5DK6IIIL.mjs.map +1 -0
- package/dist/chunk-6RG3QJLI.mjs +347 -0
- package/dist/chunk-6RG3QJLI.mjs.map +1 -0
- package/dist/chunk-6Y53W77O.mjs +101 -0
- package/dist/chunk-6Y53W77O.mjs.map +1 -0
- package/dist/chunk-75SPLZPF.js +192 -0
- package/dist/chunk-75SPLZPF.js.map +1 -0
- package/dist/chunk-7OJWGNKW.js +211 -0
- package/dist/chunk-7OJWGNKW.js.map +1 -0
- package/dist/chunk-7PJQFLC4.mjs +107 -0
- package/dist/chunk-7PJQFLC4.mjs.map +1 -0
- package/dist/chunk-A662QRP2.js +63 -0
- package/dist/chunk-A662QRP2.js.map +1 -0
- package/dist/chunk-AAUYPAHO.js +4 -0
- package/dist/chunk-AAUYPAHO.js.map +1 -0
- package/dist/chunk-ACCONS6L.mjs +245 -0
- package/dist/chunk-ACCONS6L.mjs.map +1 -0
- package/dist/chunk-ARTLWFX3.js +51 -0
- package/dist/chunk-ARTLWFX3.js.map +1 -0
- package/dist/chunk-B2LLTIQ3.js +27 -0
- package/dist/chunk-B2LLTIQ3.js.map +1 -0
- package/dist/chunk-BFYV3H52.mjs +236 -0
- package/dist/chunk-BFYV3H52.mjs.map +1 -0
- package/dist/chunk-BIIT67Q2.mjs +377 -0
- package/dist/chunk-BIIT67Q2.mjs.map +1 -0
- package/dist/chunk-CH6WMHOM.mjs +216 -0
- package/dist/chunk-CH6WMHOM.mjs.map +1 -0
- package/dist/chunk-CIAQQ7JN.js +209 -0
- package/dist/chunk-CIAQQ7JN.js.map +1 -0
- package/dist/chunk-CMK53PYC.mjs +125 -0
- package/dist/chunk-CMK53PYC.mjs.map +1 -0
- package/dist/chunk-CQIXWQ3S.js +59 -0
- package/dist/chunk-CQIXWQ3S.js.map +1 -0
- package/dist/chunk-DB2757V5.mjs +3 -0
- package/dist/chunk-DB2757V5.mjs.map +1 -0
- package/dist/chunk-DJ2J36FP.js +44 -0
- package/dist/chunk-DJ2J36FP.js.map +1 -0
- package/dist/chunk-EKEJS6NR.js +4 -0
- package/dist/chunk-EKEJS6NR.js.map +1 -0
- package/dist/chunk-EKMJ2G7A.js +149 -0
- package/dist/chunk-EKMJ2G7A.js.map +1 -0
- package/dist/chunk-EXE4FKQZ.js +349 -0
- package/dist/chunk-EXE4FKQZ.js.map +1 -0
- package/dist/chunk-FXWTTAZE.mjs +155 -0
- package/dist/chunk-FXWTTAZE.mjs.map +1 -0
- package/dist/chunk-GBZEXGFI.mjs +261 -0
- package/dist/chunk-GBZEXGFI.mjs.map +1 -0
- package/dist/chunk-HFNYFUZ3.mjs +207 -0
- package/dist/chunk-HFNYFUZ3.mjs.map +1 -0
- package/dist/chunk-HTTKRX7S.mjs +139 -0
- package/dist/chunk-HTTKRX7S.mjs.map +1 -0
- package/dist/chunk-II5OGIRE.mjs +179 -0
- package/dist/chunk-II5OGIRE.mjs.map +1 -0
- package/dist/chunk-JBMGXJ55.js +136 -0
- package/dist/chunk-JBMGXJ55.js.map +1 -0
- package/dist/chunk-K3WYDUIN.js +60 -0
- package/dist/chunk-K3WYDUIN.js.map +1 -0
- package/dist/chunk-K626K7M2.mjs +3 -0
- package/dist/chunk-K626K7M2.mjs.map +1 -0
- package/dist/chunk-KUFZSXA5.js +149 -0
- package/dist/chunk-KUFZSXA5.js.map +1 -0
- package/dist/chunk-KW66AOEN.mjs +134 -0
- package/dist/chunk-KW66AOEN.mjs.map +1 -0
- package/dist/chunk-L67UQEPI.js +98 -0
- package/dist/chunk-L67UQEPI.js.map +1 -0
- package/dist/chunk-LJHGAEQO.mjs +243 -0
- package/dist/chunk-LJHGAEQO.mjs.map +1 -0
- package/dist/chunk-LNJ2UKA3.mjs +54 -0
- package/dist/chunk-LNJ2UKA3.mjs.map +1 -0
- package/dist/chunk-LYO42ETL.mjs +147 -0
- package/dist/chunk-LYO42ETL.mjs.map +1 -0
- package/dist/chunk-LZYTPMPO.js +174 -0
- package/dist/chunk-LZYTPMPO.js.map +1 -0
- package/dist/chunk-N4UTITU6.mjs +61 -0
- package/dist/chunk-N4UTITU6.mjs.map +1 -0
- package/dist/chunk-O5IWF7DZ.js +238 -0
- package/dist/chunk-O5IWF7DZ.js.map +1 -0
- package/dist/chunk-OLT6LMNW.js +4 -0
- package/dist/chunk-OLT6LMNW.js.map +1 -0
- package/dist/chunk-ONDX6FX7.js +225 -0
- package/dist/chunk-ONDX6FX7.js.map +1 -0
- package/dist/chunk-PMZEYBN3.mjs +167 -0
- package/dist/chunk-PMZEYBN3.mjs.map +1 -0
- package/dist/chunk-QHZXEKPJ.mjs +123 -0
- package/dist/chunk-QHZXEKPJ.mjs.map +1 -0
- package/dist/chunk-QT3WNPTI.js +157 -0
- package/dist/chunk-QT3WNPTI.js.map +1 -0
- package/dist/chunk-RFARH4U4.js +105 -0
- package/dist/chunk-RFARH4U4.js.map +1 -0
- package/dist/chunk-RISAMVRI.mjs +3 -0
- package/dist/chunk-RISAMVRI.mjs.map +1 -0
- package/dist/chunk-RIUSFFXM.mjs +34 -0
- package/dist/chunk-RIUSFFXM.mjs.map +1 -0
- package/dist/chunk-RK5FMDPE.mjs +172 -0
- package/dist/chunk-RK5FMDPE.mjs.map +1 -0
- package/dist/chunk-RMSI52UT.js +263 -0
- package/dist/chunk-RMSI52UT.js.map +1 -0
- package/dist/chunk-RPH4AAZZ.mjs +94 -0
- package/dist/chunk-RPH4AAZZ.mjs.map +1 -0
- package/dist/chunk-RR4UBSEY.js +128 -0
- package/dist/chunk-RR4UBSEY.js.map +1 -0
- package/dist/chunk-T5JIC6TN.js +36 -0
- package/dist/chunk-T5JIC6TN.js.map +1 -0
- package/dist/chunk-TC53AKSZ.mjs +11 -0
- package/dist/chunk-TC53AKSZ.mjs.map +1 -0
- package/dist/chunk-TWTQ2Y7N.mjs +254 -0
- package/dist/chunk-TWTQ2Y7N.mjs.map +1 -0
- package/dist/chunk-TXH2KTET.js +256 -0
- package/dist/chunk-TXH2KTET.js.map +1 -0
- package/dist/chunk-U7PMCTVQ.js +4 -0
- package/dist/chunk-U7PMCTVQ.js.map +1 -0
- package/dist/chunk-UCVUVOZA.mjs +57 -0
- package/dist/chunk-UCVUVOZA.mjs.map +1 -0
- package/dist/chunk-UF33V3RN.mjs +130 -0
- package/dist/chunk-UF33V3RN.mjs.map +1 -0
- package/dist/chunk-UJI3VD2G.mjs +19 -0
- package/dist/chunk-UJI3VD2G.mjs.map +1 -0
- package/dist/chunk-UYK6N72M.js +169 -0
- package/dist/chunk-UYK6N72M.js.map +1 -0
- package/dist/chunk-VIEGALP5.js +46 -0
- package/dist/chunk-VIEGALP5.js.map +1 -0
- package/dist/chunk-W3EUJ2EQ.mjs +132 -0
- package/dist/chunk-W3EUJ2EQ.mjs.map +1 -0
- package/dist/chunk-WEMPFMHX.js +379 -0
- package/dist/chunk-WEMPFMHX.js.map +1 -0
- package/dist/chunk-WJKHFUXF.js +245 -0
- package/dist/chunk-WJKHFUXF.js.map +1 -0
- package/dist/chunk-WV2D7BZS.js +221 -0
- package/dist/chunk-WV2D7BZS.js.map +1 -0
- package/dist/chunk-YUHQTWI5.js +145 -0
- package/dist/chunk-YUHQTWI5.js.map +1 -0
- package/dist/chunk-Z4Q2AFMC.js +21 -0
- package/dist/chunk-Z4Q2AFMC.js.map +1 -0
- package/dist/chunk-ZBIA3D6U.js +137 -0
- package/dist/chunk-ZBIA3D6U.js.map +1 -0
- package/dist/chunk-ZGNMHRPN.mjs +25 -0
- package/dist/chunk-ZGNMHRPN.mjs.map +1 -0
- package/dist/chunk-ZL6VCAWV.mjs +223 -0
- package/dist/chunk-ZL6VCAWV.mjs.map +1 -0
- package/dist/chunk-ZMGHFIKQ.mjs +43 -0
- package/dist/chunk-ZMGHFIKQ.mjs.map +1 -0
- package/dist/chunk-ZWRLJ63J.js +405 -0
- package/dist/chunk-ZWRLJ63J.js.map +1 -0
- package/dist/errors.d.mts +45 -0
- package/dist/errors.d.ts +45 -0
- package/dist/errors.js +44 -0
- package/dist/errors.js.map +1 -0
- package/dist/errors.mjs +3 -0
- package/dist/errors.mjs.map +1 -0
- package/dist/index.d.mts +37 -0
- package/dist/index.d.ts +37 -0
- package/dist/index.js +332 -0
- package/dist/index.js.map +1 -0
- package/dist/index.mjs +43 -0
- package/dist/index.mjs.map +1 -0
- package/dist/primitives/accordion.d.mts +44 -0
- package/dist/primitives/accordion.d.ts +44 -0
- package/dist/primitives/accordion.js +17 -0
- package/dist/primitives/accordion.js.map +1 -0
- package/dist/primitives/accordion.mjs +8 -0
- package/dist/primitives/accordion.mjs.map +1 -0
- package/dist/primitives/alert-dialog.d.mts +19 -0
- package/dist/primitives/alert-dialog.d.ts +19 -0
- package/dist/primitives/alert-dialog.js +19 -0
- package/dist/primitives/alert-dialog.js.map +1 -0
- package/dist/primitives/alert-dialog.mjs +10 -0
- package/dist/primitives/alert-dialog.mjs.map +1 -0
- package/dist/primitives/avatar.d.mts +17 -0
- package/dist/primitives/avatar.d.ts +17 -0
- package/dist/primitives/avatar.js +12 -0
- package/dist/primitives/avatar.js.map +1 -0
- package/dist/primitives/avatar.mjs +3 -0
- package/dist/primitives/avatar.mjs.map +1 -0
- package/dist/primitives/checkbox.d.mts +41 -0
- package/dist/primitives/checkbox.d.ts +41 -0
- package/dist/primitives/checkbox.js +16 -0
- package/dist/primitives/checkbox.js.map +1 -0
- package/dist/primitives/checkbox.mjs +7 -0
- package/dist/primitives/checkbox.mjs.map +1 -0
- package/dist/primitives/collapsible.d.mts +42 -0
- package/dist/primitives/collapsible.d.ts +42 -0
- package/dist/primitives/collapsible.js +19 -0
- package/dist/primitives/collapsible.js.map +1 -0
- package/dist/primitives/collapsible.mjs +6 -0
- package/dist/primitives/collapsible.mjs.map +1 -0
- package/dist/primitives/combobox.d.mts +83 -0
- package/dist/primitives/combobox.d.ts +83 -0
- package/dist/primitives/combobox.js +18 -0
- package/dist/primitives/combobox.js.map +1 -0
- package/dist/primitives/combobox.mjs +9 -0
- package/dist/primitives/combobox.mjs.map +1 -0
- package/dist/primitives/context-menu.d.mts +48 -0
- package/dist/primitives/context-menu.d.ts +48 -0
- package/dist/primitives/context-menu.js +19 -0
- package/dist/primitives/context-menu.js.map +1 -0
- package/dist/primitives/context-menu.mjs +10 -0
- package/dist/primitives/context-menu.mjs.map +1 -0
- package/dist/primitives/dialog.d.mts +69 -0
- package/dist/primitives/dialog.d.ts +69 -0
- package/dist/primitives/dialog.js +18 -0
- package/dist/primitives/dialog.js.map +1 -0
- package/dist/primitives/dialog.mjs +9 -0
- package/dist/primitives/dialog.mjs.map +1 -0
- package/dist/primitives/dropdown-menu.d.mts +66 -0
- package/dist/primitives/dropdown-menu.d.ts +66 -0
- package/dist/primitives/dropdown-menu.js +18 -0
- package/dist/primitives/dropdown-menu.js.map +1 -0
- package/dist/primitives/dropdown-menu.mjs +9 -0
- package/dist/primitives/dropdown-menu.mjs.map +1 -0
- package/dist/primitives/hover-card.d.mts +73 -0
- package/dist/primitives/hover-card.d.ts +73 -0
- package/dist/primitives/hover-card.js +18 -0
- package/dist/primitives/hover-card.js.map +1 -0
- package/dist/primitives/hover-card.mjs +9 -0
- package/dist/primitives/hover-card.mjs.map +1 -0
- package/dist/primitives/index.d.mts +28 -0
- package/dist/primitives/index.d.ts +28 -0
- package/dist/primitives/index.js +146 -0
- package/dist/primitives/index.js.map +1 -0
- package/dist/primitives/index.mjs +37 -0
- package/dist/primitives/index.mjs.map +1 -0
- package/dist/primitives/menu-bar.d.mts +39 -0
- package/dist/primitives/menu-bar.d.ts +39 -0
- package/dist/primitives/menu-bar.js +16 -0
- package/dist/primitives/menu-bar.js.map +1 -0
- package/dist/primitives/menu-bar.mjs +7 -0
- package/dist/primitives/menu-bar.mjs.map +1 -0
- package/dist/primitives/popover.d.mts +89 -0
- package/dist/primitives/popover.d.ts +89 -0
- package/dist/primitives/popover.js +20 -0
- package/dist/primitives/popover.js.map +1 -0
- package/dist/primitives/popover.mjs +11 -0
- package/dist/primitives/popover.mjs.map +1 -0
- package/dist/primitives/progress.d.mts +28 -0
- package/dist/primitives/progress.d.ts +28 -0
- package/dist/primitives/progress.js +13 -0
- package/dist/primitives/progress.js.map +1 -0
- package/dist/primitives/progress.mjs +4 -0
- package/dist/primitives/progress.mjs.map +1 -0
- package/dist/primitives/radio-group.d.mts +45 -0
- package/dist/primitives/radio-group.d.ts +45 -0
- package/dist/primitives/radio-group.js +17 -0
- package/dist/primitives/radio-group.js.map +1 -0
- package/dist/primitives/radio-group.mjs +8 -0
- package/dist/primitives/radio-group.mjs.map +1 -0
- package/dist/primitives/scroll-area.d.mts +53 -0
- package/dist/primitives/scroll-area.d.ts +53 -0
- package/dist/primitives/scroll-area.js +14 -0
- package/dist/primitives/scroll-area.js.map +1 -0
- package/dist/primitives/scroll-area.mjs +5 -0
- package/dist/primitives/scroll-area.mjs.map +1 -0
- package/dist/primitives/select.d.mts +78 -0
- package/dist/primitives/select.d.ts +78 -0
- package/dist/primitives/select.js +18 -0
- package/dist/primitives/select.js.map +1 -0
- package/dist/primitives/select.mjs +9 -0
- package/dist/primitives/select.mjs.map +1 -0
- package/dist/primitives/separator.d.mts +16 -0
- package/dist/primitives/separator.d.ts +16 -0
- package/dist/primitives/separator.js +12 -0
- package/dist/primitives/separator.js.map +1 -0
- package/dist/primitives/separator.mjs +3 -0
- package/dist/primitives/separator.mjs.map +1 -0
- package/dist/primitives/slider.d.mts +46 -0
- package/dist/primitives/slider.d.ts +46 -0
- package/dist/primitives/slider.js +15 -0
- package/dist/primitives/slider.js.map +1 -0
- package/dist/primitives/slider.mjs +6 -0
- package/dist/primitives/slider.mjs.map +1 -0
- package/dist/primitives/switch.d.mts +41 -0
- package/dist/primitives/switch.d.ts +41 -0
- package/dist/primitives/switch.js +16 -0
- package/dist/primitives/switch.js.map +1 -0
- package/dist/primitives/switch.mjs +7 -0
- package/dist/primitives/switch.mjs.map +1 -0
- package/dist/primitives/tabs.d.mts +44 -0
- package/dist/primitives/tabs.d.ts +44 -0
- package/dist/primitives/tabs.js +17 -0
- package/dist/primitives/tabs.js.map +1 -0
- package/dist/primitives/tabs.mjs +8 -0
- package/dist/primitives/tabs.mjs.map +1 -0
- package/dist/primitives/toast.d.mts +24 -0
- package/dist/primitives/toast.d.ts +24 -0
- package/dist/primitives/toast.js +12 -0
- package/dist/primitives/toast.js.map +1 -0
- package/dist/primitives/toast.mjs +3 -0
- package/dist/primitives/toast.mjs.map +1 -0
- package/dist/primitives/toggle-group.d.mts +42 -0
- package/dist/primitives/toggle-group.d.ts +42 -0
- package/dist/primitives/toggle-group.js +16 -0
- package/dist/primitives/toggle-group.js.map +1 -0
- package/dist/primitives/toggle-group.mjs +7 -0
- package/dist/primitives/toggle-group.mjs.map +1 -0
- package/dist/primitives/toggle.d.mts +30 -0
- package/dist/primitives/toggle.d.ts +30 -0
- package/dist/primitives/toggle.js +15 -0
- package/dist/primitives/toggle.js.map +1 -0
- package/dist/primitives/toggle.mjs +6 -0
- package/dist/primitives/toggle.mjs.map +1 -0
- package/dist/primitives/toolbar.d.mts +34 -0
- package/dist/primitives/toolbar.d.ts +34 -0
- package/dist/primitives/toolbar.js +16 -0
- package/dist/primitives/toolbar.js.map +1 -0
- package/dist/primitives/toolbar.mjs +7 -0
- package/dist/primitives/toolbar.mjs.map +1 -0
- package/dist/primitives/tooltip.d.mts +63 -0
- package/dist/primitives/tooltip.d.ts +63 -0
- package/dist/primitives/tooltip.js +16 -0
- package/dist/primitives/tooltip.js.map +1 -0
- package/dist/primitives/tooltip.mjs +7 -0
- package/dist/primitives/tooltip.mjs.map +1 -0
- package/dist/shared-Sdeyo6Vu.d.mts +10 -0
- package/dist/shared-Sdeyo6Vu.d.ts +10 -0
- package/dist/state/index.d.mts +1 -0
- package/dist/state/index.d.ts +1 -0
- package/dist/state/index.js +21 -0
- package/dist/state/index.js.map +1 -0
- package/dist/state/index.mjs +4 -0
- package/dist/state/index.mjs.map +1 -0
- package/dist/state/machine.d.mts +62 -0
- package/dist/state/machine.d.ts +62 -0
- package/dist/state/machine.js +20 -0
- package/dist/state/machine.js.map +1 -0
- package/dist/state/machine.mjs +3 -0
- package/dist/state/machine.mjs.map +1 -0
- package/dist/utils/escape-key.d.mts +12 -0
- package/dist/utils/escape-key.d.ts +12 -0
- package/dist/utils/escape-key.js +13 -0
- package/dist/utils/escape-key.js.map +1 -0
- package/dist/utils/escape-key.mjs +4 -0
- package/dist/utils/escape-key.mjs.map +1 -0
- package/dist/utils/focus-trap.d.mts +39 -0
- package/dist/utils/focus-trap.d.ts +39 -0
- package/dist/utils/focus-trap.js +25 -0
- package/dist/utils/focus-trap.js.map +1 -0
- package/dist/utils/focus-trap.mjs +4 -0
- package/dist/utils/focus-trap.mjs.map +1 -0
- package/dist/utils/id.d.mts +54 -0
- package/dist/utils/id.d.ts +54 -0
- package/dist/utils/id.js +57 -0
- package/dist/utils/id.js.map +1 -0
- package/dist/utils/id.mjs +4 -0
- package/dist/utils/id.mjs.map +1 -0
- package/dist/utils/index.d.mts +9 -0
- package/dist/utils/index.d.ts +9 -0
- package/dist/utils/index.js +147 -0
- package/dist/utils/index.js.map +1 -0
- package/dist/utils/index.mjs +14 -0
- package/dist/utils/index.mjs.map +1 -0
- package/dist/utils/outside-click.d.mts +15 -0
- package/dist/utils/outside-click.d.ts +15 -0
- package/dist/utils/outside-click.js +12 -0
- package/dist/utils/outside-click.js.map +1 -0
- package/dist/utils/outside-click.mjs +3 -0
- package/dist/utils/outside-click.mjs.map +1 -0
- package/dist/utils/portal.d.mts +10 -0
- package/dist/utils/portal.d.ts +10 -0
- package/dist/utils/portal.js +16 -0
- package/dist/utils/portal.js.map +1 -0
- package/dist/utils/portal.mjs +3 -0
- package/dist/utils/portal.mjs.map +1 -0
- package/dist/utils/position.d.mts +46 -0
- package/dist/utils/position.d.ts +46 -0
- package/dist/utils/position.js +25 -0
- package/dist/utils/position.js.map +1 -0
- package/dist/utils/position.mjs +4 -0
- package/dist/utils/position.mjs.map +1 -0
- package/dist/utils/presence.d.mts +40 -0
- package/dist/utils/presence.d.ts +40 -0
- package/dist/utils/presence.js +28 -0
- package/dist/utils/presence.js.map +1 -0
- package/dist/utils/presence.mjs +3 -0
- package/dist/utils/presence.mjs.map +1 -0
- package/dist/utils/roving-focus.d.mts +27 -0
- package/dist/utils/roving-focus.d.ts +27 -0
- package/dist/utils/roving-focus.js +21 -0
- package/dist/utils/roving-focus.js.map +1 -0
- package/dist/utils/roving-focus.mjs +4 -0
- package/dist/utils/roving-focus.mjs.map +1 -0
- package/package.json +118 -0
|
@@ -0,0 +1,149 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var chunkL67UQEPI_js = require('./chunk-L67UQEPI.js');
|
|
4
|
+
var chunkK3WYDUIN_js = require('./chunk-K3WYDUIN.js');
|
|
5
|
+
var chunkEKMJ2G7A_js = require('./chunk-EKMJ2G7A.js');
|
|
6
|
+
var chunkZ4Q2AFMC_js = require('./chunk-Z4Q2AFMC.js');
|
|
7
|
+
|
|
8
|
+
// src/primitives/checkbox.ts
|
|
9
|
+
function getAriaChecked(checked) {
|
|
10
|
+
if (checked === "indeterminate") {
|
|
11
|
+
return "mixed";
|
|
12
|
+
}
|
|
13
|
+
return checked ? "true" : "false";
|
|
14
|
+
}
|
|
15
|
+
function getFormValue(name, value, checked) {
|
|
16
|
+
if (!name || checked !== true) {
|
|
17
|
+
return {};
|
|
18
|
+
}
|
|
19
|
+
return {
|
|
20
|
+
[name]: value
|
|
21
|
+
};
|
|
22
|
+
}
|
|
23
|
+
function createCheckbox(props) {
|
|
24
|
+
props.checked ?? props.defaultChecked ?? false;
|
|
25
|
+
const disabled = props.disabled ?? false;
|
|
26
|
+
const required = props.required ?? false;
|
|
27
|
+
const value = props.value ?? "on";
|
|
28
|
+
const name = props.name;
|
|
29
|
+
const controlledState = chunkL67UQEPI_js.createControllableStateController({
|
|
30
|
+
value: props.checked,
|
|
31
|
+
defaultValue: props.defaultChecked ?? false,
|
|
32
|
+
onChange: props.onCheckedChange
|
|
33
|
+
});
|
|
34
|
+
const store = chunkK3WYDUIN_js.createStore({
|
|
35
|
+
checked: controlledState.getValue(),
|
|
36
|
+
controlled: controlledState.isControlled(),
|
|
37
|
+
disabled,
|
|
38
|
+
required,
|
|
39
|
+
name,
|
|
40
|
+
value,
|
|
41
|
+
ariaChecked: getAriaChecked(controlledState.getValue()),
|
|
42
|
+
formValue: getFormValue(name, value, controlledState.getValue()),
|
|
43
|
+
lastError: null
|
|
44
|
+
});
|
|
45
|
+
const emitChecked = (nextChecked, meta) => {
|
|
46
|
+
const result = meta.source === "controlled-sync" ? controlledState.syncValue(nextChecked) : controlledState.requestValue(nextChecked);
|
|
47
|
+
store.patchState(
|
|
48
|
+
{
|
|
49
|
+
checked: result.value,
|
|
50
|
+
ariaChecked: getAriaChecked(result.value),
|
|
51
|
+
formValue: getFormValue(name, value, result.value),
|
|
52
|
+
lastChangeMeta: meta,
|
|
53
|
+
lastError: null
|
|
54
|
+
},
|
|
55
|
+
meta
|
|
56
|
+
);
|
|
57
|
+
};
|
|
58
|
+
const ensureEnabled = () => {
|
|
59
|
+
const state = store.getState();
|
|
60
|
+
if (!state.disabled) {
|
|
61
|
+
return true;
|
|
62
|
+
}
|
|
63
|
+
store.patchState({
|
|
64
|
+
lastError: chunkEKMJ2G7A_js.createUIFnError({
|
|
65
|
+
code: "UIFN_ERR_DISABLED_INTERACTION",
|
|
66
|
+
package: "@uifn/core",
|
|
67
|
+
component: "Checkbox",
|
|
68
|
+
message: "Disabled controls MUST ignore state-changing input.",
|
|
69
|
+
recoverable: true
|
|
70
|
+
})
|
|
71
|
+
});
|
|
72
|
+
return false;
|
|
73
|
+
};
|
|
74
|
+
const actions = {
|
|
75
|
+
setChecked(checked) {
|
|
76
|
+
if (!ensureEnabled()) {
|
|
77
|
+
return;
|
|
78
|
+
}
|
|
79
|
+
const state = store.getState();
|
|
80
|
+
if (state.checked === checked) {
|
|
81
|
+
return;
|
|
82
|
+
}
|
|
83
|
+
emitChecked(checked, {
|
|
84
|
+
source: "programmatic",
|
|
85
|
+
reason: "set-checked",
|
|
86
|
+
previousValue: state.checked,
|
|
87
|
+
nextValue: checked
|
|
88
|
+
});
|
|
89
|
+
},
|
|
90
|
+
toggle() {
|
|
91
|
+
if (!ensureEnabled()) {
|
|
92
|
+
return;
|
|
93
|
+
}
|
|
94
|
+
const state = store.getState();
|
|
95
|
+
const nextChecked = state.checked === "indeterminate" ? true : !state.checked;
|
|
96
|
+
emitChecked(nextChecked, {
|
|
97
|
+
source: "user",
|
|
98
|
+
reason: "toggle",
|
|
99
|
+
previousValue: state.checked,
|
|
100
|
+
nextValue: nextChecked,
|
|
101
|
+
inputModality: "pointer"
|
|
102
|
+
});
|
|
103
|
+
},
|
|
104
|
+
handleKeyDown(key) {
|
|
105
|
+
if (key !== chunkZ4Q2AFMC_js.K.SPACE) {
|
|
106
|
+
return;
|
|
107
|
+
}
|
|
108
|
+
if (!ensureEnabled()) {
|
|
109
|
+
return;
|
|
110
|
+
}
|
|
111
|
+
const state = store.getState();
|
|
112
|
+
const nextChecked = state.checked === "indeterminate" ? true : !state.checked;
|
|
113
|
+
emitChecked(nextChecked, {
|
|
114
|
+
source: "user",
|
|
115
|
+
reason: "keyboard-toggle",
|
|
116
|
+
previousValue: state.checked,
|
|
117
|
+
nextValue: nextChecked,
|
|
118
|
+
inputModality: "keyboard"
|
|
119
|
+
});
|
|
120
|
+
},
|
|
121
|
+
syncChecked(checked) {
|
|
122
|
+
const state = store.getState();
|
|
123
|
+
if (state.checked === checked) {
|
|
124
|
+
return;
|
|
125
|
+
}
|
|
126
|
+
emitChecked(checked, {
|
|
127
|
+
source: "controlled-sync",
|
|
128
|
+
reason: "sync-checked",
|
|
129
|
+
previousValue: state.checked,
|
|
130
|
+
nextValue: checked
|
|
131
|
+
});
|
|
132
|
+
},
|
|
133
|
+
getFormValue() {
|
|
134
|
+
return store.getState().formValue;
|
|
135
|
+
}
|
|
136
|
+
};
|
|
137
|
+
return {
|
|
138
|
+
get state() {
|
|
139
|
+
return store.getState();
|
|
140
|
+
},
|
|
141
|
+
actions,
|
|
142
|
+
getState: store.getState,
|
|
143
|
+
subscribe: store.subscribe
|
|
144
|
+
};
|
|
145
|
+
}
|
|
146
|
+
|
|
147
|
+
exports.createCheckbox = createCheckbox;
|
|
148
|
+
//# sourceMappingURL=chunk-KUFZSXA5.js.map
|
|
149
|
+
//# sourceMappingURL=chunk-KUFZSXA5.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/primitives/checkbox.ts"],"names":["createControllableStateController","createStore","createUIFnError","K"],"mappings":"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","file":"chunk-KUFZSXA5.js","sourcesContent":["import { createUIFnError, type UIFnError } from '../errors';\nimport { K } from '../aria/keys';\nimport { createControllableStateController } from '../state/machine';\nimport { type ChangeMeta, createStore } from './shared';\n\nexport type CheckedState = boolean | 'indeterminate';\n\nexport interface CheckboxProps {\n checked?: CheckedState;\n defaultChecked?: CheckedState;\n required?: boolean;\n disabled?: boolean;\n name?: string;\n value?: string;\n onCheckedChange?: (checked: CheckedState) => void;\n}\n\nexport interface CheckboxState {\n checked: CheckedState;\n controlled: boolean;\n disabled: boolean;\n required: boolean;\n name?: string;\n value: string;\n ariaChecked: 'true' | 'false' | 'mixed';\n formValue: Record<string, string>;\n lastChangeMeta?: ChangeMeta<CheckedState>;\n lastError: UIFnError | null;\n}\n\nexport interface CheckboxActions {\n setChecked: (checked: CheckedState) => void;\n toggle: () => void;\n handleKeyDown: (key: string) => void;\n syncChecked: (checked: CheckedState) => void;\n getFormValue: () => Record<string, string>;\n}\n\nexport interface CheckboxMachine {\n readonly state: CheckboxState;\n readonly actions: CheckboxActions;\n getState: () => CheckboxState;\n subscribe: (callback: (state: CheckboxState, meta?: ChangeMeta<CheckedState>) => void) => () => void;\n}\n\nfunction getAriaChecked(checked: CheckedState): 'true' | 'false' | 'mixed' {\n if (checked === 'indeterminate') {\n return 'mixed';\n }\n return checked ? 'true' : 'false';\n}\n\nfunction getFormValue(name: string | undefined, value: string, checked: CheckedState): Record<string, string> {\n if (!name || checked !== true) {\n return {};\n }\n\n return {\n [name]: value,\n };\n}\n\nexport function createCheckbox(props: CheckboxProps): CheckboxMachine {\n const initialChecked = props.checked ?? props.defaultChecked ?? false;\n const disabled = props.disabled ?? false;\n const required = props.required ?? false;\n const value = props.value ?? 'on';\n const name = props.name;\n const controlledState = createControllableStateController<CheckedState>({\n value: props.checked,\n defaultValue: props.defaultChecked ?? false,\n onChange: props.onCheckedChange,\n });\n\n const store = createStore<CheckboxState, CheckedState>({\n checked: controlledState.getValue(),\n controlled: controlledState.isControlled(),\n disabled,\n required,\n name,\n value,\n ariaChecked: getAriaChecked(controlledState.getValue()),\n formValue: getFormValue(name, value, controlledState.getValue()),\n lastError: null,\n });\n\n const emitChecked = (nextChecked: CheckedState, meta: ChangeMeta<CheckedState>) => {\n const result =\n meta.source === 'controlled-sync'\n ? controlledState.syncValue(nextChecked)\n : controlledState.requestValue(nextChecked);\n store.patchState(\n {\n checked: result.value,\n ariaChecked: getAriaChecked(result.value),\n formValue: getFormValue(name, value, result.value),\n lastChangeMeta: meta,\n lastError: null,\n },\n meta\n );\n };\n\n const ensureEnabled = (): boolean => {\n const state = store.getState();\n if (!state.disabled) {\n return true;\n }\n\n store.patchState({\n lastError: createUIFnError({\n code: 'UIFN_ERR_DISABLED_INTERACTION',\n package: '@uifn/core',\n component: 'Checkbox',\n message: 'Disabled controls MUST ignore state-changing input.',\n recoverable: true,\n }),\n });\n return false;\n };\n\n const actions: CheckboxActions = {\n setChecked(checked) {\n if (!ensureEnabled()) {\n return;\n }\n const state = store.getState();\n if (state.checked === checked) {\n return;\n }\n emitChecked(checked, {\n source: 'programmatic',\n reason: 'set-checked',\n previousValue: state.checked,\n nextValue: checked,\n });\n },\n toggle() {\n if (!ensureEnabled()) {\n return;\n }\n\n const state = store.getState();\n const nextChecked = state.checked === 'indeterminate' ? true : !state.checked;\n emitChecked(nextChecked, {\n source: 'user',\n reason: 'toggle',\n previousValue: state.checked,\n nextValue: nextChecked,\n inputModality: 'pointer',\n });\n },\n handleKeyDown(key) {\n if (key !== K.SPACE) {\n return;\n }\n\n if (!ensureEnabled()) {\n return;\n }\n\n const state = store.getState();\n const nextChecked = state.checked === 'indeterminate' ? true : !state.checked;\n emitChecked(nextChecked, {\n source: 'user',\n reason: 'keyboard-toggle',\n previousValue: state.checked,\n nextValue: nextChecked,\n inputModality: 'keyboard',\n });\n },\n syncChecked(checked) {\n const state = store.getState();\n if (state.checked === checked) {\n return;\n }\n\n emitChecked(checked, {\n source: 'controlled-sync',\n reason: 'sync-checked',\n previousValue: state.checked,\n nextValue: checked,\n });\n },\n getFormValue() {\n return store.getState().formValue;\n },\n };\n\n return {\n get state() {\n return store.getState();\n },\n actions,\n getState: store.getState,\n subscribe: store.subscribe,\n };\n}\n"]}
|
|
@@ -0,0 +1,134 @@
|
|
|
1
|
+
import { getNextRovingFocusIndex } from './chunk-6Y53W77O.mjs';
|
|
2
|
+
import { createStore } from './chunk-LNJ2UKA3.mjs';
|
|
3
|
+
import { createUIFnError } from './chunk-HTTKRX7S.mjs';
|
|
4
|
+
|
|
5
|
+
// src/primitives/toolbar.ts
|
|
6
|
+
function normalizeItems(items) {
|
|
7
|
+
const dedupe = /* @__PURE__ */ new Map();
|
|
8
|
+
(items ?? []).forEach((item) => {
|
|
9
|
+
dedupe.set(item.id, item);
|
|
10
|
+
});
|
|
11
|
+
return Array.from(dedupe.values());
|
|
12
|
+
}
|
|
13
|
+
function resolveGroups(items) {
|
|
14
|
+
return items.reduce((acc, item) => {
|
|
15
|
+
if (!item.group) {
|
|
16
|
+
return acc;
|
|
17
|
+
}
|
|
18
|
+
const existing = acc[item.group] ?? [];
|
|
19
|
+
acc[item.group] = [...existing, item.id];
|
|
20
|
+
return acc;
|
|
21
|
+
}, {});
|
|
22
|
+
}
|
|
23
|
+
function getEnabledItemIds(items) {
|
|
24
|
+
return items.filter((item) => !item.disabled).map((item) => item.id);
|
|
25
|
+
}
|
|
26
|
+
function createToolbar(props) {
|
|
27
|
+
const items = normalizeItems(props.items);
|
|
28
|
+
const enabledItems = getEnabledItemIds(items);
|
|
29
|
+
const store = createStore({
|
|
30
|
+
orientation: props.orientation ?? "horizontal",
|
|
31
|
+
items,
|
|
32
|
+
focusedItem: enabledItems[0] ?? null,
|
|
33
|
+
groups: resolveGroups(items),
|
|
34
|
+
lastError: null
|
|
35
|
+
});
|
|
36
|
+
const actions = {
|
|
37
|
+
registerItem(item) {
|
|
38
|
+
const state = store.getState();
|
|
39
|
+
if (state.items.some((entry) => entry.id === item.id)) {
|
|
40
|
+
return;
|
|
41
|
+
}
|
|
42
|
+
const nextItems = [...state.items, item];
|
|
43
|
+
const nextEnabled = getEnabledItemIds(nextItems);
|
|
44
|
+
store.patchState({
|
|
45
|
+
items: nextItems,
|
|
46
|
+
groups: resolveGroups(nextItems),
|
|
47
|
+
focusedItem: state.focusedItem ?? nextEnabled[0] ?? null
|
|
48
|
+
});
|
|
49
|
+
},
|
|
50
|
+
setItems(nextItems) {
|
|
51
|
+
const normalized = normalizeItems(nextItems);
|
|
52
|
+
const nextEnabled = getEnabledItemIds(normalized);
|
|
53
|
+
const state = store.getState();
|
|
54
|
+
store.patchState({
|
|
55
|
+
items: normalized,
|
|
56
|
+
groups: resolveGroups(normalized),
|
|
57
|
+
focusedItem: nextEnabled.includes(state.focusedItem ?? "") ? state.focusedItem : nextEnabled[0] ?? null
|
|
58
|
+
});
|
|
59
|
+
},
|
|
60
|
+
focusItem(itemId) {
|
|
61
|
+
const state = store.getState();
|
|
62
|
+
if (itemId === null) {
|
|
63
|
+
store.patchState({
|
|
64
|
+
focusedItem: null
|
|
65
|
+
});
|
|
66
|
+
return;
|
|
67
|
+
}
|
|
68
|
+
if (!getEnabledItemIds(state.items).includes(itemId)) {
|
|
69
|
+
return;
|
|
70
|
+
}
|
|
71
|
+
store.patchState({
|
|
72
|
+
focusedItem: itemId
|
|
73
|
+
});
|
|
74
|
+
},
|
|
75
|
+
handleKeyDown(key, currentItem) {
|
|
76
|
+
const state = store.getState();
|
|
77
|
+
const enabled = getEnabledItemIds(state.items);
|
|
78
|
+
if (enabled.length === 0) {
|
|
79
|
+
return null;
|
|
80
|
+
}
|
|
81
|
+
const current = currentItem ?? state.focusedItem ?? enabled[0];
|
|
82
|
+
const currentIndex = Math.max(0, enabled.indexOf(current));
|
|
83
|
+
const nextIndex = getNextRovingFocusIndex({
|
|
84
|
+
key,
|
|
85
|
+
itemCount: enabled.length,
|
|
86
|
+
currentIndex,
|
|
87
|
+
orientation: state.orientation
|
|
88
|
+
});
|
|
89
|
+
if (nextIndex < 0) {
|
|
90
|
+
return null;
|
|
91
|
+
}
|
|
92
|
+
const nextItem = enabled[nextIndex] ?? null;
|
|
93
|
+
if (!nextItem) {
|
|
94
|
+
return null;
|
|
95
|
+
}
|
|
96
|
+
store.patchState({
|
|
97
|
+
focusedItem: nextItem
|
|
98
|
+
});
|
|
99
|
+
return nextItem;
|
|
100
|
+
},
|
|
101
|
+
getGroupItems(group) {
|
|
102
|
+
const state = store.getState();
|
|
103
|
+
const groupItems = state.groups[group];
|
|
104
|
+
if (!groupItems) {
|
|
105
|
+
store.patchState({
|
|
106
|
+
lastError: createUIFnError({
|
|
107
|
+
code: "UIFN_ERR_INVALID_VALUE",
|
|
108
|
+
package: "@uifn/core",
|
|
109
|
+
component: "Toolbar",
|
|
110
|
+
message: "Toolbar orientation and grouping semantics are documented and tested.",
|
|
111
|
+
recoverable: true,
|
|
112
|
+
details: {
|
|
113
|
+
group
|
|
114
|
+
}
|
|
115
|
+
})
|
|
116
|
+
});
|
|
117
|
+
return [];
|
|
118
|
+
}
|
|
119
|
+
return groupItems;
|
|
120
|
+
}
|
|
121
|
+
};
|
|
122
|
+
return {
|
|
123
|
+
get state() {
|
|
124
|
+
return store.getState();
|
|
125
|
+
},
|
|
126
|
+
actions,
|
|
127
|
+
getState: store.getState,
|
|
128
|
+
subscribe: store.subscribe
|
|
129
|
+
};
|
|
130
|
+
}
|
|
131
|
+
|
|
132
|
+
export { createToolbar };
|
|
133
|
+
//# sourceMappingURL=chunk-KW66AOEN.mjs.map
|
|
134
|
+
//# sourceMappingURL=chunk-KW66AOEN.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/primitives/toolbar.ts"],"names":[],"mappings":"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","file":"chunk-KW66AOEN.mjs","sourcesContent":["import { createUIFnError, type UIFnError } from '../errors';\nimport { getNextRovingFocusIndex } from '../utils/roving-focus';\nimport { createStore } from './shared';\n\nexport interface ToolbarItem {\n id: string;\n group?: string;\n disabled?: boolean;\n}\n\nexport interface ToolbarProps {\n orientation?: 'horizontal' | 'vertical';\n items?: ToolbarItem[];\n}\n\nexport interface ToolbarState {\n orientation: 'horizontal' | 'vertical';\n items: ToolbarItem[];\n focusedItem: string | null;\n groups: Record<string, string[]>;\n lastError: UIFnError | null;\n}\n\nexport interface ToolbarActions {\n registerItem: (item: ToolbarItem) => void;\n setItems: (items: ToolbarItem[]) => void;\n focusItem: (itemId: string | null) => void;\n handleKeyDown: (key: string, currentItem?: string | null) => string | null;\n getGroupItems: (group: string) => string[];\n}\n\nexport interface ToolbarMachine {\n readonly state: ToolbarState;\n readonly actions: ToolbarActions;\n getState: () => ToolbarState;\n subscribe: (callback: (state: ToolbarState) => void) => () => void;\n}\n\nfunction normalizeItems(items: ToolbarItem[] | undefined): ToolbarItem[] {\n const dedupe = new Map<string, ToolbarItem>();\n (items ?? []).forEach((item) => {\n dedupe.set(item.id, item);\n });\n\n return Array.from(dedupe.values());\n}\n\nfunction resolveGroups(items: ToolbarItem[]): Record<string, string[]> {\n return items.reduce<Record<string, string[]>>((acc, item) => {\n if (!item.group) {\n return acc;\n }\n\n const existing = acc[item.group] ?? [];\n acc[item.group] = [...existing, item.id];\n return acc;\n }, {});\n}\n\nfunction getEnabledItemIds(items: ToolbarItem[]): string[] {\n return items.filter((item) => !item.disabled).map((item) => item.id);\n}\n\nexport function createToolbar(props: ToolbarProps): ToolbarMachine {\n const items = normalizeItems(props.items);\n const enabledItems = getEnabledItemIds(items);\n const store = createStore<ToolbarState>({\n orientation: props.orientation ?? 'horizontal',\n items,\n focusedItem: enabledItems[0] ?? null,\n groups: resolveGroups(items),\n lastError: null,\n });\n\n const actions: ToolbarActions = {\n registerItem(item) {\n const state = store.getState();\n if (state.items.some((entry) => entry.id === item.id)) {\n return;\n }\n\n const nextItems = [...state.items, item];\n const nextEnabled = getEnabledItemIds(nextItems);\n store.patchState({\n items: nextItems,\n groups: resolveGroups(nextItems),\n focusedItem: state.focusedItem ?? nextEnabled[0] ?? null,\n });\n },\n setItems(nextItems) {\n const normalized = normalizeItems(nextItems);\n const nextEnabled = getEnabledItemIds(normalized);\n const state = store.getState();\n store.patchState({\n items: normalized,\n groups: resolveGroups(normalized),\n focusedItem: nextEnabled.includes(state.focusedItem ?? '')\n ? state.focusedItem\n : nextEnabled[0] ?? null,\n });\n },\n focusItem(itemId) {\n const state = store.getState();\n if (itemId === null) {\n store.patchState({\n focusedItem: null,\n });\n return;\n }\n\n if (!getEnabledItemIds(state.items).includes(itemId)) {\n return;\n }\n\n store.patchState({\n focusedItem: itemId,\n });\n },\n handleKeyDown(key, currentItem) {\n const state = store.getState();\n const enabled = getEnabledItemIds(state.items);\n if (enabled.length === 0) {\n return null;\n }\n\n const current = currentItem ?? state.focusedItem ?? enabled[0];\n const currentIndex = Math.max(0, enabled.indexOf(current));\n const nextIndex = getNextRovingFocusIndex({\n key,\n itemCount: enabled.length,\n currentIndex,\n orientation: state.orientation,\n });\n\n if (nextIndex < 0) {\n return null;\n }\n\n const nextItem = enabled[nextIndex] ?? null;\n if (!nextItem) {\n return null;\n }\n\n store.patchState({\n focusedItem: nextItem,\n });\n return nextItem;\n },\n getGroupItems(group) {\n const state = store.getState();\n const groupItems = state.groups[group];\n if (!groupItems) {\n store.patchState({\n lastError: createUIFnError({\n code: 'UIFN_ERR_INVALID_VALUE',\n package: '@uifn/core',\n component: 'Toolbar',\n message: 'Toolbar orientation and grouping semantics are documented and tested.',\n recoverable: true,\n details: {\n group,\n },\n }),\n });\n return [];\n }\n\n return groupItems;\n },\n };\n\n return {\n get state() {\n return store.getState();\n },\n actions,\n getState: store.getState,\n subscribe: store.subscribe,\n };\n}\n"]}
|
|
@@ -0,0 +1,98 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
// src/state/machine.ts
|
|
4
|
+
var StateMachine = class {
|
|
5
|
+
constructor(config) {
|
|
6
|
+
this._listeners = /* @__PURE__ */ new Set();
|
|
7
|
+
this._config = config;
|
|
8
|
+
this._state = config.initial;
|
|
9
|
+
this._context = { ...config.context };
|
|
10
|
+
}
|
|
11
|
+
get state() {
|
|
12
|
+
return this._state;
|
|
13
|
+
}
|
|
14
|
+
get context() {
|
|
15
|
+
return this._context;
|
|
16
|
+
}
|
|
17
|
+
send(event) {
|
|
18
|
+
const currentStateConfig = this._config.states[this._state];
|
|
19
|
+
const transition = currentStateConfig.on?.[event.type];
|
|
20
|
+
if (!transition) return;
|
|
21
|
+
let target = this._state;
|
|
22
|
+
let actions = [];
|
|
23
|
+
if (typeof transition === "string") {
|
|
24
|
+
target = transition;
|
|
25
|
+
} else {
|
|
26
|
+
if (transition.cond && !transition.cond(this._context, event)) {
|
|
27
|
+
return;
|
|
28
|
+
}
|
|
29
|
+
if (transition.target) target = transition.target;
|
|
30
|
+
if (transition.actions) actions = transition.actions;
|
|
31
|
+
}
|
|
32
|
+
actions.forEach((action) => action(this._context, event));
|
|
33
|
+
if (target !== this._state) {
|
|
34
|
+
currentStateConfig.exit?.forEach((action) => action(this._context, event));
|
|
35
|
+
this._state = target;
|
|
36
|
+
const nextStateConfig = this._config.states[target];
|
|
37
|
+
nextStateConfig.entry?.forEach((action) => action(this._context, event));
|
|
38
|
+
this._notify();
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
subscribe(listener) {
|
|
42
|
+
this._listeners.add(listener);
|
|
43
|
+
listener(this._state, this._context);
|
|
44
|
+
return () => {
|
|
45
|
+
this._listeners.delete(listener);
|
|
46
|
+
};
|
|
47
|
+
}
|
|
48
|
+
_notify() {
|
|
49
|
+
this._listeners.forEach((listener) => listener(this._state, this._context));
|
|
50
|
+
}
|
|
51
|
+
};
|
|
52
|
+
function createMachine(config) {
|
|
53
|
+
return new StateMachine(config);
|
|
54
|
+
}
|
|
55
|
+
function createControllableStateController(options) {
|
|
56
|
+
const controlled = options.value !== void 0;
|
|
57
|
+
const isEqual = options.isEqual ?? Object.is;
|
|
58
|
+
let currentValue = controlled ? options.value : options.defaultValue;
|
|
59
|
+
return {
|
|
60
|
+
isControlled() {
|
|
61
|
+
return controlled;
|
|
62
|
+
},
|
|
63
|
+
getValue() {
|
|
64
|
+
return currentValue;
|
|
65
|
+
},
|
|
66
|
+
requestValue(nextValue) {
|
|
67
|
+
const previousValue = currentValue;
|
|
68
|
+
const changed = !isEqual(previousValue, nextValue);
|
|
69
|
+
if (!controlled) {
|
|
70
|
+
currentValue = nextValue;
|
|
71
|
+
}
|
|
72
|
+
if (changed) {
|
|
73
|
+
options.onChange?.(nextValue);
|
|
74
|
+
}
|
|
75
|
+
return {
|
|
76
|
+
value: controlled ? previousValue : currentValue,
|
|
77
|
+
changed,
|
|
78
|
+
controlled
|
|
79
|
+
};
|
|
80
|
+
},
|
|
81
|
+
syncValue(nextValue) {
|
|
82
|
+
const previousValue = currentValue;
|
|
83
|
+
const changed = !isEqual(previousValue, nextValue);
|
|
84
|
+
currentValue = nextValue;
|
|
85
|
+
return {
|
|
86
|
+
value: currentValue,
|
|
87
|
+
changed,
|
|
88
|
+
controlled
|
|
89
|
+
};
|
|
90
|
+
}
|
|
91
|
+
};
|
|
92
|
+
}
|
|
93
|
+
|
|
94
|
+
exports.StateMachine = StateMachine;
|
|
95
|
+
exports.createControllableStateController = createControllableStateController;
|
|
96
|
+
exports.createMachine = createMachine;
|
|
97
|
+
//# sourceMappingURL=chunk-L67UQEPI.js.map
|
|
98
|
+
//# sourceMappingURL=chunk-L67UQEPI.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/state/machine.ts"],"names":[],"mappings":"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","file":"chunk-L67UQEPI.js","sourcesContent":["export type EventObject = { type: string; [key: string]: any };\nexport type StateConfig<TContext, TEvent extends EventObject> = {\n value: string;\n context: TContext;\n event: TEvent;\n};\n\nexport type Transition<TContext, TEvent extends EventObject> = \n | string // Target state\n | {\n target?: string;\n actions?: Array<(context: TContext, event: TEvent) => void>;\n cond?: (context: TContext, event: TEvent) => boolean;\n };\n\nexport type MachineConfig<TContext, TEvent extends EventObject> = {\n initial: string;\n context: TContext;\n states: {\n [key: string]: {\n on?: {\n [K in TEvent['type']]?: Transition<TContext, TEvent & { type: K }>;\n };\n entry?: Array<(context: TContext, event: TEvent) => void>;\n exit?: Array<(context: TContext, event: TEvent) => void>;\n };\n };\n};\n\nexport class StateMachine<TContext, TEvent extends EventObject> {\n private _state: string;\n private _context: TContext;\n private _config: MachineConfig<TContext, TEvent>;\n private _listeners: Set<(state: string, context: TContext) => void> = new Set();\n\n constructor(config: MachineConfig<TContext, TEvent>) {\n this._config = config;\n this._state = config.initial;\n this._context = { ...config.context };\n }\n\n get state() {\n return this._state;\n }\n\n get context() {\n return this._context;\n }\n\n send(event: TEvent) {\n const currentStateConfig = this._config.states[this._state];\n const transition = currentStateConfig.on?.[event.type as keyof typeof currentStateConfig.on] as Transition<TContext, TEvent> | undefined;\n\n if (!transition) return;\n\n // Resolve transition\n let target = this._state;\n let actions: Array<(context: TContext, event: TEvent) => void> = [];\n\n if (typeof transition === 'string') {\n target = transition;\n } else {\n if (transition.cond && !transition.cond(this._context, event)) {\n return;\n }\n if (transition.target) target = transition.target;\n if (transition.actions) actions = transition.actions;\n }\n\n // Execute actions\n actions.forEach(action => action(this._context, event));\n\n // Transition if state changed\n if (target !== this._state) {\n // Exit current\n currentStateConfig.exit?.forEach(action => action(this._context, event));\n \n this._state = target;\n \n // Entry next\n const nextStateConfig = this._config.states[target];\n nextStateConfig.entry?.forEach(action => action(this._context, event));\n \n this._notify();\n }\n }\n\n subscribe(listener: (state: string, context: TContext) => void) {\n this._listeners.add(listener);\n listener(this._state, this._context);\n return () => {\n this._listeners.delete(listener);\n };\n }\n\n private _notify() {\n this._listeners.forEach(listener => listener(this._state, this._context));\n }\n}\n\nexport function createMachine<TContext, TEvent extends EventObject>(\n config: MachineConfig<TContext, TEvent>\n) {\n return new StateMachine(config);\n}\n\nexport interface ControllableStateControllerOptions<TValue> {\n value?: TValue;\n defaultValue: TValue;\n onChange?: (value: TValue) => void;\n isEqual?: (a: TValue, b: TValue) => boolean;\n}\n\nexport interface ControllableStateRequestResult<TValue> {\n value: TValue;\n changed: boolean;\n controlled: boolean;\n}\n\nexport interface ControllableStateController<TValue> {\n isControlled: () => boolean;\n getValue: () => TValue;\n requestValue: (nextValue: TValue) => ControllableStateRequestResult<TValue>;\n syncValue: (nextValue: TValue) => ControllableStateRequestResult<TValue>;\n}\n\nexport function createControllableStateController<TValue>(\n options: ControllableStateControllerOptions<TValue>\n): ControllableStateController<TValue> {\n const controlled = options.value !== undefined;\n const isEqual = options.isEqual ?? Object.is;\n let currentValue = controlled ? (options.value as TValue) : options.defaultValue;\n\n return {\n isControlled() {\n return controlled;\n },\n getValue() {\n return currentValue;\n },\n requestValue(nextValue) {\n const previousValue = currentValue;\n const changed = !isEqual(previousValue, nextValue);\n\n if (!controlled) {\n currentValue = nextValue;\n }\n\n if (changed) {\n options.onChange?.(nextValue);\n }\n\n return {\n value: controlled ? previousValue : currentValue,\n changed,\n controlled,\n };\n },\n syncValue(nextValue) {\n const previousValue = currentValue;\n const changed = !isEqual(previousValue, nextValue);\n currentValue = nextValue;\n\n return {\n value: currentValue,\n changed,\n controlled,\n };\n },\n };\n}\n"]}
|
|
@@ -0,0 +1,243 @@
|
|
|
1
|
+
import { getNextEnabledRovingFocusIndex } from './chunk-6Y53W77O.mjs';
|
|
2
|
+
import { createControllableStateController } from './chunk-RPH4AAZZ.mjs';
|
|
3
|
+
import { uniqueStrings, createStore } from './chunk-LNJ2UKA3.mjs';
|
|
4
|
+
import { createUIFnError } from './chunk-HTTKRX7S.mjs';
|
|
5
|
+
|
|
6
|
+
// src/primitives/tabs.ts
|
|
7
|
+
function getEnabledTabsItems(items, disabledItems) {
|
|
8
|
+
return items.filter((item) => !disabledItems.includes(item));
|
|
9
|
+
}
|
|
10
|
+
function validateTabsValue(value, items, disabledItems) {
|
|
11
|
+
if (!value || items.length === 0) {
|
|
12
|
+
return;
|
|
13
|
+
}
|
|
14
|
+
if (!items.includes(value) || disabledItems.includes(value)) {
|
|
15
|
+
throw createUIFnError({
|
|
16
|
+
code: "UIFN_ERR_INVALID_VALUE",
|
|
17
|
+
package: "@uifn/core",
|
|
18
|
+
component: "Tabs",
|
|
19
|
+
message: "Invalid external values MUST be handled deterministically.",
|
|
20
|
+
details: {
|
|
21
|
+
value,
|
|
22
|
+
items,
|
|
23
|
+
disabledItems
|
|
24
|
+
}
|
|
25
|
+
});
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
function createTabs(props) {
|
|
29
|
+
const orientation = props.orientation ?? "horizontal";
|
|
30
|
+
const activationMode = props.activationMode ?? "automatic";
|
|
31
|
+
const disabled = props.disabled ?? false;
|
|
32
|
+
const items = uniqueStrings(props.items ?? []);
|
|
33
|
+
const disabledItems = uniqueStrings(props.disabledItems ?? []).filter(
|
|
34
|
+
(item) => items.includes(item)
|
|
35
|
+
);
|
|
36
|
+
const initialValue = props.value ?? props.defaultValue ?? "";
|
|
37
|
+
const controlledState = createControllableStateController({
|
|
38
|
+
value: props.value,
|
|
39
|
+
defaultValue: props.defaultValue ?? "",
|
|
40
|
+
onChange: props.onValueChange
|
|
41
|
+
});
|
|
42
|
+
const initialFocusedItem = initialValue || getEnabledTabsItems(items, disabledItems)[0] || items[0] || null;
|
|
43
|
+
validateTabsValue(initialValue, items, disabledItems);
|
|
44
|
+
const store = createStore({
|
|
45
|
+
value: controlledState.getValue(),
|
|
46
|
+
orientation,
|
|
47
|
+
activationMode,
|
|
48
|
+
controlled: controlledState.isControlled(),
|
|
49
|
+
disabled,
|
|
50
|
+
items,
|
|
51
|
+
disabledItems,
|
|
52
|
+
focusedItem: initialFocusedItem,
|
|
53
|
+
lastError: null
|
|
54
|
+
});
|
|
55
|
+
const emitValue = (nextValue, meta, options = {}) => {
|
|
56
|
+
const state = store.getState();
|
|
57
|
+
validateTabsValue(nextValue, state.items, state.disabledItems);
|
|
58
|
+
const result = options.preserveValue ? {
|
|
59
|
+
value: state.value,
|
|
60
|
+
controlled: controlledState.isControlled()
|
|
61
|
+
} : meta.source === "controlled-sync" ? controlledState.syncValue(nextValue) : controlledState.requestValue(nextValue);
|
|
62
|
+
store.patchState(
|
|
63
|
+
{
|
|
64
|
+
value: result.value,
|
|
65
|
+
focusedItem: options.focusedItem === void 0 ? nextValue || state.focusedItem : options.focusedItem,
|
|
66
|
+
lastChangeMeta: meta,
|
|
67
|
+
lastError: null
|
|
68
|
+
},
|
|
69
|
+
meta
|
|
70
|
+
);
|
|
71
|
+
};
|
|
72
|
+
const actions = {
|
|
73
|
+
setValue(nextValue) {
|
|
74
|
+
const state = store.getState();
|
|
75
|
+
if (state.disabled) {
|
|
76
|
+
store.patchState({
|
|
77
|
+
lastError: createUIFnError({
|
|
78
|
+
code: "UIFN_ERR_DISABLED_INTERACTION",
|
|
79
|
+
package: "@uifn/core",
|
|
80
|
+
component: "Tabs",
|
|
81
|
+
message: "Disabled controls MUST ignore state-changing input.",
|
|
82
|
+
recoverable: true
|
|
83
|
+
})
|
|
84
|
+
});
|
|
85
|
+
return;
|
|
86
|
+
}
|
|
87
|
+
if (state.disabledItems.includes(nextValue)) {
|
|
88
|
+
store.patchState({
|
|
89
|
+
lastError: createUIFnError({
|
|
90
|
+
code: "UIFN_ERR_DISABLED_INTERACTION",
|
|
91
|
+
package: "@uifn/core",
|
|
92
|
+
component: "Tabs",
|
|
93
|
+
message: "Disabled controls MUST ignore state-changing input.",
|
|
94
|
+
recoverable: true
|
|
95
|
+
})
|
|
96
|
+
});
|
|
97
|
+
return;
|
|
98
|
+
}
|
|
99
|
+
if (state.value === nextValue) {
|
|
100
|
+
return;
|
|
101
|
+
}
|
|
102
|
+
emitValue(nextValue, {
|
|
103
|
+
source: "programmatic",
|
|
104
|
+
reason: "set-value",
|
|
105
|
+
previousValue: state.value,
|
|
106
|
+
nextValue
|
|
107
|
+
});
|
|
108
|
+
},
|
|
109
|
+
registerItem(value, itemDisabled = false) {
|
|
110
|
+
const state = store.getState();
|
|
111
|
+
if (state.items.includes(value)) {
|
|
112
|
+
if (itemDisabled !== state.disabledItems.includes(value)) {
|
|
113
|
+
actions.setItemDisabled(value, itemDisabled);
|
|
114
|
+
}
|
|
115
|
+
return;
|
|
116
|
+
}
|
|
117
|
+
const nextItems = [...state.items, value];
|
|
118
|
+
const nextDisabledItems = itemDisabled ? uniqueStrings([...state.disabledItems, value]) : state.disabledItems;
|
|
119
|
+
validateTabsValue(state.value, nextItems, nextDisabledItems);
|
|
120
|
+
store.patchState({
|
|
121
|
+
items: nextItems,
|
|
122
|
+
disabledItems: nextDisabledItems,
|
|
123
|
+
focusedItem: state.focusedItem ?? (itemDisabled ? null : value),
|
|
124
|
+
lastError: null
|
|
125
|
+
});
|
|
126
|
+
},
|
|
127
|
+
unregisterItem(value) {
|
|
128
|
+
const state = store.getState();
|
|
129
|
+
const nextItems = state.items.filter((entry) => entry !== value);
|
|
130
|
+
const nextDisabledItems = state.disabledItems.filter((entry) => entry !== value);
|
|
131
|
+
const enabledItems = getEnabledTabsItems(nextItems, nextDisabledItems);
|
|
132
|
+
const nextValue = state.value === value ? enabledItems[0] ?? nextItems[0] ?? "" : state.value;
|
|
133
|
+
if (nextValue !== state.value) {
|
|
134
|
+
controlledState.syncValue(nextValue);
|
|
135
|
+
}
|
|
136
|
+
store.patchState({
|
|
137
|
+
items: nextItems,
|
|
138
|
+
disabledItems: nextDisabledItems,
|
|
139
|
+
value: nextValue,
|
|
140
|
+
focusedItem: state.focusedItem === value ? enabledItems[0] ?? nextItems[0] ?? null : state.focusedItem
|
|
141
|
+
});
|
|
142
|
+
},
|
|
143
|
+
setItemDisabled(value, itemDisabled) {
|
|
144
|
+
const state = store.getState();
|
|
145
|
+
if (!state.items.includes(value)) {
|
|
146
|
+
return;
|
|
147
|
+
}
|
|
148
|
+
const nextDisabledItems = itemDisabled ? uniqueStrings([...state.disabledItems, value]) : state.disabledItems.filter((entry) => entry !== value);
|
|
149
|
+
const enabledItems = getEnabledTabsItems(state.items, nextDisabledItems);
|
|
150
|
+
const nextValue = itemDisabled && state.value === value ? "" : state.value;
|
|
151
|
+
const nextFocusedItem = itemDisabled && state.focusedItem === value ? enabledItems[0] ?? state.items[0] ?? null : state.focusedItem;
|
|
152
|
+
if (nextValue !== state.value) {
|
|
153
|
+
controlledState.syncValue(nextValue);
|
|
154
|
+
}
|
|
155
|
+
store.patchState({
|
|
156
|
+
disabledItems: nextDisabledItems,
|
|
157
|
+
value: nextValue,
|
|
158
|
+
focusedItem: nextFocusedItem
|
|
159
|
+
});
|
|
160
|
+
},
|
|
161
|
+
focusItem(value) {
|
|
162
|
+
const state = store.getState();
|
|
163
|
+
if (!state.items.includes(value) || state.disabledItems.includes(value)) {
|
|
164
|
+
return;
|
|
165
|
+
}
|
|
166
|
+
store.patchState({
|
|
167
|
+
focusedItem: value
|
|
168
|
+
});
|
|
169
|
+
},
|
|
170
|
+
handleKeyDown(key, currentItem) {
|
|
171
|
+
const state = store.getState();
|
|
172
|
+
const enabledItems = getEnabledTabsItems(state.items, state.disabledItems);
|
|
173
|
+
if (enabledItems.length === 0) {
|
|
174
|
+
return null;
|
|
175
|
+
}
|
|
176
|
+
const current = enabledItems.includes(currentItem) ? currentItem : enabledItems.includes(state.focusedItem ?? "") ? state.focusedItem : enabledItems[0];
|
|
177
|
+
const currentIndex = Math.max(0, enabledItems.indexOf(current));
|
|
178
|
+
const nextIndex = getNextEnabledRovingFocusIndex({
|
|
179
|
+
key,
|
|
180
|
+
itemCount: enabledItems.length,
|
|
181
|
+
currentIndex,
|
|
182
|
+
orientation: state.orientation
|
|
183
|
+
});
|
|
184
|
+
if (nextIndex < 0 || nextIndex === currentIndex) {
|
|
185
|
+
return null;
|
|
186
|
+
}
|
|
187
|
+
const nextItem = enabledItems[nextIndex] ?? null;
|
|
188
|
+
if (!nextItem) {
|
|
189
|
+
return null;
|
|
190
|
+
}
|
|
191
|
+
if (state.activationMode === "automatic") {
|
|
192
|
+
emitValue(nextItem, {
|
|
193
|
+
source: "user",
|
|
194
|
+
reason: "keyboard-navigation",
|
|
195
|
+
previousValue: state.value,
|
|
196
|
+
nextValue: nextItem,
|
|
197
|
+
inputModality: "keyboard"
|
|
198
|
+
});
|
|
199
|
+
} else {
|
|
200
|
+
emitValue(
|
|
201
|
+
state.value,
|
|
202
|
+
{
|
|
203
|
+
source: "user",
|
|
204
|
+
reason: "keyboard-navigation",
|
|
205
|
+
previousValue: state.value,
|
|
206
|
+
nextValue: state.value,
|
|
207
|
+
inputModality: "keyboard"
|
|
208
|
+
},
|
|
209
|
+
{
|
|
210
|
+
preserveValue: true,
|
|
211
|
+
focusedItem: nextItem
|
|
212
|
+
}
|
|
213
|
+
);
|
|
214
|
+
}
|
|
215
|
+
return nextItem;
|
|
216
|
+
},
|
|
217
|
+
syncValue(value) {
|
|
218
|
+
const state = store.getState();
|
|
219
|
+
if (state.value === value) {
|
|
220
|
+
return;
|
|
221
|
+
}
|
|
222
|
+
emitValue(value, {
|
|
223
|
+
source: "controlled-sync",
|
|
224
|
+
reason: "sync-value",
|
|
225
|
+
previousValue: state.value,
|
|
226
|
+
nextValue: value
|
|
227
|
+
});
|
|
228
|
+
}
|
|
229
|
+
};
|
|
230
|
+
return {
|
|
231
|
+
get state() {
|
|
232
|
+
return store.getState();
|
|
233
|
+
},
|
|
234
|
+
actions,
|
|
235
|
+
setValue: actions.setValue,
|
|
236
|
+
getState: store.getState,
|
|
237
|
+
subscribe: store.subscribe
|
|
238
|
+
};
|
|
239
|
+
}
|
|
240
|
+
|
|
241
|
+
export { createTabs };
|
|
242
|
+
//# sourceMappingURL=chunk-LJHGAEQO.mjs.map
|
|
243
|
+
//# sourceMappingURL=chunk-LJHGAEQO.mjs.map
|