@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,128 @@
|
|
|
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
|
+
|
|
7
|
+
// src/primitives/collapsible.ts
|
|
8
|
+
function createCollapsible(props = {}) {
|
|
9
|
+
props.open ?? props.defaultOpen ?? false;
|
|
10
|
+
const disabled = props.disabled ?? false;
|
|
11
|
+
const controlledState = chunkL67UQEPI_js.createControllableStateController({
|
|
12
|
+
value: props.open,
|
|
13
|
+
defaultValue: props.defaultOpen ?? false,
|
|
14
|
+
onChange: props.onOpenChange
|
|
15
|
+
});
|
|
16
|
+
const store = chunkK3WYDUIN_js.createStore({
|
|
17
|
+
open: controlledState.getValue(),
|
|
18
|
+
controlled: controlledState.isControlled(),
|
|
19
|
+
disabled,
|
|
20
|
+
lastError: null
|
|
21
|
+
});
|
|
22
|
+
const emitOpen = (nextOpen, meta) => {
|
|
23
|
+
const result = meta.source === "controlled-sync" ? controlledState.syncValue(nextOpen) : controlledState.requestValue(nextOpen);
|
|
24
|
+
store.patchState(
|
|
25
|
+
{
|
|
26
|
+
open: result.value,
|
|
27
|
+
lastChangeMeta: meta,
|
|
28
|
+
lastError: null
|
|
29
|
+
},
|
|
30
|
+
meta
|
|
31
|
+
);
|
|
32
|
+
};
|
|
33
|
+
const actions = {
|
|
34
|
+
setOpen(open) {
|
|
35
|
+
const state = store.getState();
|
|
36
|
+
if (state.open === open) {
|
|
37
|
+
return;
|
|
38
|
+
}
|
|
39
|
+
if (state.disabled) {
|
|
40
|
+
store.patchState({
|
|
41
|
+
lastError: chunkEKMJ2G7A_js.createUIFnError({
|
|
42
|
+
code: "UIFN_ERR_DISABLED_INTERACTION",
|
|
43
|
+
package: "@uifn/core",
|
|
44
|
+
component: "Collapsible",
|
|
45
|
+
message: "Disabled controls MUST ignore state-changing input.",
|
|
46
|
+
recoverable: true
|
|
47
|
+
})
|
|
48
|
+
});
|
|
49
|
+
return;
|
|
50
|
+
}
|
|
51
|
+
emitOpen(open, {
|
|
52
|
+
source: "programmatic",
|
|
53
|
+
reason: "set-open",
|
|
54
|
+
previousValue: state.open,
|
|
55
|
+
nextValue: open
|
|
56
|
+
});
|
|
57
|
+
},
|
|
58
|
+
toggle() {
|
|
59
|
+
const state = store.getState();
|
|
60
|
+
if (state.disabled) {
|
|
61
|
+
store.patchState({
|
|
62
|
+
lastError: chunkEKMJ2G7A_js.createUIFnError({
|
|
63
|
+
code: "UIFN_ERR_DISABLED_INTERACTION",
|
|
64
|
+
package: "@uifn/core",
|
|
65
|
+
component: "Collapsible",
|
|
66
|
+
message: "Disabled controls MUST ignore state-changing input.",
|
|
67
|
+
recoverable: true
|
|
68
|
+
})
|
|
69
|
+
});
|
|
70
|
+
return;
|
|
71
|
+
}
|
|
72
|
+
const nextOpen = !state.open;
|
|
73
|
+
emitOpen(nextOpen, {
|
|
74
|
+
source: "user",
|
|
75
|
+
reason: "toggle",
|
|
76
|
+
previousValue: state.open,
|
|
77
|
+
nextValue: nextOpen,
|
|
78
|
+
inputModality: "pointer"
|
|
79
|
+
});
|
|
80
|
+
},
|
|
81
|
+
syncOpen(open) {
|
|
82
|
+
const state = store.getState();
|
|
83
|
+
if (state.open === open) {
|
|
84
|
+
return;
|
|
85
|
+
}
|
|
86
|
+
emitOpen(open, {
|
|
87
|
+
source: "controlled-sync",
|
|
88
|
+
reason: "sync-open",
|
|
89
|
+
previousValue: state.open,
|
|
90
|
+
nextValue: open
|
|
91
|
+
});
|
|
92
|
+
}
|
|
93
|
+
};
|
|
94
|
+
return {
|
|
95
|
+
get state() {
|
|
96
|
+
return store.getState();
|
|
97
|
+
},
|
|
98
|
+
actions,
|
|
99
|
+
getState: store.getState,
|
|
100
|
+
subscribe: store.subscribe
|
|
101
|
+
};
|
|
102
|
+
}
|
|
103
|
+
function createCollapsibleMachine(initialOpen = false, initialDisabled = false) {
|
|
104
|
+
const machine = createCollapsible({
|
|
105
|
+
defaultOpen: initialOpen,
|
|
106
|
+
disabled: initialDisabled
|
|
107
|
+
});
|
|
108
|
+
return {
|
|
109
|
+
get state() {
|
|
110
|
+
return machine.state.open ? "open" : "closed";
|
|
111
|
+
},
|
|
112
|
+
send(event) {
|
|
113
|
+
if (event.type === "TOGGLE") {
|
|
114
|
+
machine.actions.toggle();
|
|
115
|
+
} else if (event.type === "OPEN") {
|
|
116
|
+
machine.actions.setOpen(true);
|
|
117
|
+
} else {
|
|
118
|
+
machine.actions.setOpen(false);
|
|
119
|
+
}
|
|
120
|
+
},
|
|
121
|
+
subscribe: machine.subscribe
|
|
122
|
+
};
|
|
123
|
+
}
|
|
124
|
+
|
|
125
|
+
exports.createCollapsible = createCollapsible;
|
|
126
|
+
exports.createCollapsibleMachine = createCollapsibleMachine;
|
|
127
|
+
//# sourceMappingURL=chunk-RR4UBSEY.js.map
|
|
128
|
+
//# sourceMappingURL=chunk-RR4UBSEY.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/primitives/collapsible.ts"],"names":["createControllableStateController","createStore","createUIFnError"],"mappings":"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","file":"chunk-RR4UBSEY.js","sourcesContent":["import { createUIFnError, type UIFnError } from '../errors';\nimport { createControllableStateController } from '../state/machine';\nimport { type ChangeMeta, createStore } from './shared';\n\nexport interface CollapsibleProps {\n open?: boolean;\n defaultOpen?: boolean;\n disabled?: boolean;\n onOpenChange?: (open: boolean) => void;\n}\n\nexport interface CollapsibleState {\n open: boolean;\n controlled: boolean;\n disabled: boolean;\n lastChangeMeta?: ChangeMeta<boolean>;\n lastError: UIFnError | null;\n}\n\nexport interface CollapsibleActions {\n setOpen: (open: boolean) => void;\n toggle: () => void;\n syncOpen: (open: boolean) => void;\n}\n\nexport interface CollapsibleMachine {\n readonly state: CollapsibleState;\n readonly actions: CollapsibleActions;\n getState: () => CollapsibleState;\n subscribe: (callback: (state: CollapsibleState, meta?: ChangeMeta<boolean>) => void) => () => void;\n}\n\nexport function createCollapsible(props: CollapsibleProps = {}): CollapsibleMachine {\n const initialOpen = props.open ?? props.defaultOpen ?? false;\n const disabled = props.disabled ?? false;\n const controlledState = createControllableStateController({\n value: props.open,\n defaultValue: props.defaultOpen ?? false,\n onChange: props.onOpenChange,\n });\n const store = createStore<CollapsibleState, boolean>({\n open: controlledState.getValue(),\n controlled: controlledState.isControlled(),\n disabled,\n lastError: null,\n });\n\n const emitOpen = (nextOpen: boolean, meta: ChangeMeta<boolean>) => {\n const result =\n meta.source === 'controlled-sync'\n ? controlledState.syncValue(nextOpen)\n : controlledState.requestValue(nextOpen);\n store.patchState(\n {\n open: result.value,\n lastChangeMeta: meta,\n lastError: null,\n },\n meta\n );\n };\n\n const actions: CollapsibleActions = {\n setOpen(open) {\n const state = store.getState();\n if (state.open === open) {\n return;\n }\n\n if (state.disabled) {\n store.patchState({\n lastError: createUIFnError({\n code: 'UIFN_ERR_DISABLED_INTERACTION',\n package: '@uifn/core',\n component: 'Collapsible',\n message: 'Disabled controls MUST ignore state-changing input.',\n recoverable: true,\n }),\n });\n return;\n }\n\n emitOpen(open, {\n source: 'programmatic',\n reason: 'set-open',\n previousValue: state.open,\n nextValue: open,\n });\n },\n toggle() {\n const state = store.getState();\n if (state.disabled) {\n store.patchState({\n lastError: createUIFnError({\n code: 'UIFN_ERR_DISABLED_INTERACTION',\n package: '@uifn/core',\n component: 'Collapsible',\n message: 'Disabled controls MUST ignore state-changing input.',\n recoverable: true,\n }),\n });\n return;\n }\n\n const nextOpen = !state.open;\n emitOpen(nextOpen, {\n source: 'user',\n reason: 'toggle',\n previousValue: state.open,\n nextValue: nextOpen,\n inputModality: 'pointer',\n });\n },\n syncOpen(open) {\n const state = store.getState();\n if (state.open === open) {\n return;\n }\n\n emitOpen(open, {\n source: 'controlled-sync',\n reason: 'sync-open',\n previousValue: state.open,\n nextValue: open,\n });\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\nexport type CollapsibleMachineEvent =\n | { type: 'TOGGLE' }\n | { type: 'OPEN' }\n | { type: 'CLOSE' };\n\nexport function createCollapsibleMachine(initialOpen = false, initialDisabled = false) {\n const machine = createCollapsible({\n defaultOpen: initialOpen,\n disabled: initialDisabled,\n });\n\n return {\n get state() {\n return machine.state.open ? 'open' : 'closed';\n },\n send(event: CollapsibleMachineEvent) {\n if (event.type === 'TOGGLE') {\n machine.actions.toggle();\n } else if (event.type === 'OPEN') {\n machine.actions.setOpen(true);\n } else {\n machine.actions.setOpen(false);\n }\n },\n subscribe: machine.subscribe,\n };\n}\n"]}
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
// src/primitives/avatar.ts
|
|
4
|
+
function createAvatar() {
|
|
5
|
+
let state = { status: "idle" };
|
|
6
|
+
const listeners = /* @__PURE__ */ new Set();
|
|
7
|
+
const notify = () => {
|
|
8
|
+
listeners.forEach((l) => l({ ...state }));
|
|
9
|
+
};
|
|
10
|
+
const actions = {
|
|
11
|
+
setLoading: () => {
|
|
12
|
+
state.status = "loading";
|
|
13
|
+
notify();
|
|
14
|
+
},
|
|
15
|
+
setLoaded: () => {
|
|
16
|
+
state.status = "loaded";
|
|
17
|
+
notify();
|
|
18
|
+
},
|
|
19
|
+
setError: () => {
|
|
20
|
+
state.status = "error";
|
|
21
|
+
notify();
|
|
22
|
+
}
|
|
23
|
+
};
|
|
24
|
+
return {
|
|
25
|
+
state,
|
|
26
|
+
actions,
|
|
27
|
+
subscribe: (callback) => {
|
|
28
|
+
listeners.add(callback);
|
|
29
|
+
return () => listeners.delete(callback);
|
|
30
|
+
}
|
|
31
|
+
};
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
exports.createAvatar = createAvatar;
|
|
35
|
+
//# sourceMappingURL=chunk-T5JIC6TN.js.map
|
|
36
|
+
//# sourceMappingURL=chunk-T5JIC6TN.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/primitives/avatar.ts"],"names":[],"mappings":";;;AAkBO,SAAS,YAAA,GAA8B;AAC5C,EAAA,IAAI,KAAA,GAAqB,EAAE,MAAA,EAAQ,MAAA,EAAO;AAC1C,EAAA,MAAM,SAAA,uBAAgB,GAAA,EAAkC;AAExD,EAAA,MAAM,SAAS,MAAM;AACnB,IAAA,SAAA,CAAU,QAAQ,CAAA,CAAA,KAAK,CAAA,CAAE,EAAE,GAAG,KAAA,EAAO,CAAC,CAAA;AAAA,EACxC,CAAA;AAEA,EAAA,MAAM,OAAA,GAAyB;AAAA,IAC7B,YAAY,MAAM;AAAE,MAAA,KAAA,CAAM,MAAA,GAAS,SAAA;AAAW,MAAA,MAAA,EAAO;AAAA,IAAG,CAAA;AAAA,IACxD,WAAW,MAAM;AAAE,MAAA,KAAA,CAAM,MAAA,GAAS,QAAA;AAAU,MAAA,MAAA,EAAO;AAAA,IAAG,CAAA;AAAA,IACtD,UAAU,MAAM;AAAE,MAAA,KAAA,CAAM,MAAA,GAAS,OAAA;AAAS,MAAA,MAAA,EAAO;AAAA,IAAG;AAAA,GACtD;AAEA,EAAA,OAAO;AAAA,IACL,KAAA;AAAA,IACA,OAAA;AAAA,IACA,SAAA,EAAW,CAAC,QAAA,KAAa;AACvB,MAAA,SAAA,CAAU,IAAI,QAAQ,CAAA;AACtB,MAAA,OAAO,MAAM,SAAA,CAAU,MAAA,CAAO,QAAQ,CAAA;AAAA,IACxC;AAAA,GACF;AACF","file":"chunk-T5JIC6TN.js","sourcesContent":["export type AvatarStatus = 'idle' | 'loading' | 'loaded' | 'error';\n\nexport interface AvatarState {\n status: AvatarStatus;\n}\n\nexport interface AvatarActions {\n setLoading: () => void;\n setLoaded: () => void;\n setError: () => void;\n}\n\nexport interface AvatarMachine {\n state: AvatarState;\n actions: AvatarActions;\n subscribe: (callback: (state: AvatarState) => void) => () => void;\n}\n\nexport function createAvatar(): AvatarMachine {\n let state: AvatarState = { status: 'idle' };\n const listeners = new Set<(state: AvatarState) => void>();\n\n const notify = () => {\n listeners.forEach(l => l({ ...state }));\n };\n\n const actions: AvatarActions = {\n setLoading: () => { state.status = 'loading'; notify(); },\n setLoaded: () => { state.status = 'loaded'; notify(); },\n setError: () => { state.status = 'error'; notify(); },\n };\n\n return {\n state,\n actions,\n subscribe: (callback) => {\n listeners.add(callback);\n return () => listeners.delete(callback);\n }\n };\n}\n"]}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
// src/primitives/separator.ts
|
|
2
|
+
function createSeparator(props) {
|
|
3
|
+
const { orientation = "horizontal", decorative = false } = props;
|
|
4
|
+
return {
|
|
5
|
+
state: { orientation, decorative }
|
|
6
|
+
};
|
|
7
|
+
}
|
|
8
|
+
|
|
9
|
+
export { createSeparator };
|
|
10
|
+
//# sourceMappingURL=chunk-TC53AKSZ.mjs.map
|
|
11
|
+
//# sourceMappingURL=chunk-TC53AKSZ.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/primitives/separator.ts"],"names":[],"mappings":";AAUO,SAAS,gBAAgB,KAAA,EAAuB;AACrD,EAAA,MAAM,EAAE,WAAA,GAAc,YAAA,EAAc,UAAA,GAAa,OAAM,GAAI,KAAA;AAE3D,EAAA,OAAO;AAAA,IACL,KAAA,EAAO,EAAE,WAAA,EAAa,UAAA;AAAW,GACnC;AACF","file":"chunk-TC53AKSZ.mjs","sourcesContent":["export interface SeparatorProps {\n orientation?: 'horizontal' | 'vertical';\n decorative?: boolean;\n}\n\nexport interface SeparatorState {\n orientation: 'horizontal' | 'vertical';\n decorative: boolean;\n}\n\nexport function createSeparator(props: SeparatorProps) {\n const { orientation = 'horizontal', decorative = false } = props;\n \n return {\n state: { orientation, decorative }\n };\n}\n"]}
|
|
@@ -0,0 +1,254 @@
|
|
|
1
|
+
import { createStore, clamp } from './chunk-LNJ2UKA3.mjs';
|
|
2
|
+
import { createUIFnError } from './chunk-HTTKRX7S.mjs';
|
|
3
|
+
|
|
4
|
+
// src/primitives/scroll-area.ts
|
|
5
|
+
function createDefaultViewport() {
|
|
6
|
+
return {
|
|
7
|
+
scrollTop: 0,
|
|
8
|
+
scrollLeft: 0,
|
|
9
|
+
scrollHeight: 0,
|
|
10
|
+
scrollWidth: 0,
|
|
11
|
+
clientHeight: 0,
|
|
12
|
+
clientWidth: 0
|
|
13
|
+
};
|
|
14
|
+
}
|
|
15
|
+
function toAxisState(scrollSize, clientSize, scrollOffset) {
|
|
16
|
+
const visible = scrollSize > clientSize && clientSize > 0;
|
|
17
|
+
if (!visible) {
|
|
18
|
+
return {
|
|
19
|
+
visible: false,
|
|
20
|
+
thumbSizePercent: 100,
|
|
21
|
+
thumbPositionPercent: 0
|
|
22
|
+
};
|
|
23
|
+
}
|
|
24
|
+
const maxScroll = Math.max(1, scrollSize - clientSize);
|
|
25
|
+
const thumbSizePercent = clamp(clientSize / scrollSize * 100, 5, 100);
|
|
26
|
+
const thumbPositionPercent = clamp(scrollOffset / maxScroll * 100, 0, 100);
|
|
27
|
+
return {
|
|
28
|
+
visible: true,
|
|
29
|
+
thumbSizePercent,
|
|
30
|
+
thumbPositionPercent
|
|
31
|
+
};
|
|
32
|
+
}
|
|
33
|
+
function resolveStateFromViewport(viewport) {
|
|
34
|
+
const vertical = toAxisState(viewport.scrollHeight, viewport.clientHeight, viewport.scrollTop);
|
|
35
|
+
const horizontal = toAxisState(viewport.scrollWidth, viewport.clientWidth, viewport.scrollLeft);
|
|
36
|
+
return {
|
|
37
|
+
vertical,
|
|
38
|
+
horizontal,
|
|
39
|
+
cornerVisible: vertical.visible && horizontal.visible
|
|
40
|
+
};
|
|
41
|
+
}
|
|
42
|
+
function toScrollOffset(positionPercent, scrollSize, clientSize) {
|
|
43
|
+
const maxScroll = Math.max(0, scrollSize - clientSize);
|
|
44
|
+
if (maxScroll === 0) {
|
|
45
|
+
return 0;
|
|
46
|
+
}
|
|
47
|
+
return clamp(positionPercent, 0, 100) / 100 * maxScroll;
|
|
48
|
+
}
|
|
49
|
+
function clampViewport(viewport) {
|
|
50
|
+
return {
|
|
51
|
+
...viewport,
|
|
52
|
+
scrollTop: clamp(
|
|
53
|
+
viewport.scrollTop,
|
|
54
|
+
0,
|
|
55
|
+
Math.max(0, viewport.scrollHeight - viewport.clientHeight)
|
|
56
|
+
),
|
|
57
|
+
scrollLeft: clamp(
|
|
58
|
+
viewport.scrollLeft,
|
|
59
|
+
0,
|
|
60
|
+
Math.max(0, viewport.scrollWidth - viewport.clientWidth)
|
|
61
|
+
)
|
|
62
|
+
};
|
|
63
|
+
}
|
|
64
|
+
function createScrollArea(props) {
|
|
65
|
+
const viewport = createDefaultViewport();
|
|
66
|
+
const computed = resolveStateFromViewport(viewport);
|
|
67
|
+
const store = createStore({
|
|
68
|
+
type: props.type ?? "hover",
|
|
69
|
+
scrollHideDelay: props.scrollHideDelay ?? 600,
|
|
70
|
+
viewport,
|
|
71
|
+
vertical: computed.vertical,
|
|
72
|
+
horizontal: computed.horizontal,
|
|
73
|
+
cornerVisible: computed.cornerVisible,
|
|
74
|
+
lastInteraction: null,
|
|
75
|
+
lastError: null
|
|
76
|
+
});
|
|
77
|
+
const actions = {
|
|
78
|
+
setViewportMetrics(metrics) {
|
|
79
|
+
const state = store.getState();
|
|
80
|
+
const nextViewport = clampViewport({
|
|
81
|
+
...state.viewport,
|
|
82
|
+
...metrics
|
|
83
|
+
});
|
|
84
|
+
const nextComputed = resolveStateFromViewport(nextViewport);
|
|
85
|
+
store.patchState({
|
|
86
|
+
viewport: nextViewport,
|
|
87
|
+
vertical: nextComputed.vertical,
|
|
88
|
+
horizontal: nextComputed.horizontal,
|
|
89
|
+
cornerVisible: nextComputed.cornerVisible
|
|
90
|
+
});
|
|
91
|
+
},
|
|
92
|
+
onViewportScroll(position) {
|
|
93
|
+
const state = store.getState();
|
|
94
|
+
const nextViewport = clampViewport({
|
|
95
|
+
...state.viewport,
|
|
96
|
+
scrollTop: position.top !== void 0 ? position.top : state.viewport.scrollTop,
|
|
97
|
+
scrollLeft: position.left !== void 0 ? position.left : state.viewport.scrollLeft
|
|
98
|
+
});
|
|
99
|
+
const nextComputed = resolveStateFromViewport(nextViewport);
|
|
100
|
+
const meta = {
|
|
101
|
+
source: "user",
|
|
102
|
+
reason: "viewport-scroll",
|
|
103
|
+
previousValue: state.viewport.scrollTop,
|
|
104
|
+
nextValue: nextViewport.scrollTop,
|
|
105
|
+
inputModality: "pointer"
|
|
106
|
+
};
|
|
107
|
+
store.patchState(
|
|
108
|
+
{
|
|
109
|
+
viewport: nextViewport,
|
|
110
|
+
vertical: nextComputed.vertical,
|
|
111
|
+
horizontal: nextComputed.horizontal,
|
|
112
|
+
cornerVisible: nextComputed.cornerVisible,
|
|
113
|
+
lastInteraction: "viewport",
|
|
114
|
+
lastChangeMeta: meta,
|
|
115
|
+
lastError: null
|
|
116
|
+
},
|
|
117
|
+
meta
|
|
118
|
+
);
|
|
119
|
+
},
|
|
120
|
+
scrollTo(position) {
|
|
121
|
+
const state = store.getState();
|
|
122
|
+
const nextViewport = clampViewport({
|
|
123
|
+
...state.viewport,
|
|
124
|
+
scrollTop: position.top !== void 0 ? position.top : state.viewport.scrollTop,
|
|
125
|
+
scrollLeft: position.left !== void 0 ? position.left : state.viewport.scrollLeft
|
|
126
|
+
});
|
|
127
|
+
const nextComputed = resolveStateFromViewport(nextViewport);
|
|
128
|
+
const meta = {
|
|
129
|
+
source: "programmatic",
|
|
130
|
+
reason: "programmatic-scroll",
|
|
131
|
+
previousValue: state.viewport.scrollTop,
|
|
132
|
+
nextValue: nextViewport.scrollTop
|
|
133
|
+
};
|
|
134
|
+
store.patchState(
|
|
135
|
+
{
|
|
136
|
+
viewport: nextViewport,
|
|
137
|
+
vertical: nextComputed.vertical,
|
|
138
|
+
horizontal: nextComputed.horizontal,
|
|
139
|
+
cornerVisible: nextComputed.cornerVisible,
|
|
140
|
+
lastInteraction: "viewport",
|
|
141
|
+
lastChangeMeta: meta,
|
|
142
|
+
lastError: null
|
|
143
|
+
},
|
|
144
|
+
meta
|
|
145
|
+
);
|
|
146
|
+
},
|
|
147
|
+
dragVerticalThumb(positionPercent) {
|
|
148
|
+
const state = store.getState();
|
|
149
|
+
if (!state.vertical.visible) {
|
|
150
|
+
store.patchState({
|
|
151
|
+
lastError: createUIFnError({
|
|
152
|
+
code: "UIFN_ERR_SCROLL_SYNC",
|
|
153
|
+
package: "@uifn/core",
|
|
154
|
+
component: "ScrollArea",
|
|
155
|
+
message: "ScrollArea viewport and thumb state MUST remain synchronized.",
|
|
156
|
+
recoverable: true
|
|
157
|
+
})
|
|
158
|
+
});
|
|
159
|
+
return;
|
|
160
|
+
}
|
|
161
|
+
const nextScrollTop = toScrollOffset(
|
|
162
|
+
positionPercent,
|
|
163
|
+
state.viewport.scrollHeight,
|
|
164
|
+
state.viewport.clientHeight
|
|
165
|
+
);
|
|
166
|
+
const nextViewport = clampViewport({
|
|
167
|
+
...state.viewport,
|
|
168
|
+
scrollTop: nextScrollTop
|
|
169
|
+
});
|
|
170
|
+
const nextComputed = resolveStateFromViewport(nextViewport);
|
|
171
|
+
const meta = {
|
|
172
|
+
source: "user",
|
|
173
|
+
reason: "vertical-thumb-drag",
|
|
174
|
+
previousValue: state.viewport.scrollTop,
|
|
175
|
+
nextValue: nextScrollTop,
|
|
176
|
+
inputModality: "pointer"
|
|
177
|
+
};
|
|
178
|
+
store.patchState(
|
|
179
|
+
{
|
|
180
|
+
viewport: nextViewport,
|
|
181
|
+
vertical: {
|
|
182
|
+
...nextComputed.vertical,
|
|
183
|
+
thumbPositionPercent: clamp(positionPercent, 0, 100)
|
|
184
|
+
},
|
|
185
|
+
horizontal: nextComputed.horizontal,
|
|
186
|
+
cornerVisible: nextComputed.cornerVisible,
|
|
187
|
+
lastInteraction: "vertical-thumb",
|
|
188
|
+
lastChangeMeta: meta,
|
|
189
|
+
lastError: null
|
|
190
|
+
},
|
|
191
|
+
meta
|
|
192
|
+
);
|
|
193
|
+
},
|
|
194
|
+
dragHorizontalThumb(positionPercent) {
|
|
195
|
+
const state = store.getState();
|
|
196
|
+
if (!state.horizontal.visible) {
|
|
197
|
+
store.patchState({
|
|
198
|
+
lastError: createUIFnError({
|
|
199
|
+
code: "UIFN_ERR_SCROLL_SYNC",
|
|
200
|
+
package: "@uifn/core",
|
|
201
|
+
component: "ScrollArea",
|
|
202
|
+
message: "ScrollArea viewport and thumb state MUST remain synchronized.",
|
|
203
|
+
recoverable: true
|
|
204
|
+
})
|
|
205
|
+
});
|
|
206
|
+
return;
|
|
207
|
+
}
|
|
208
|
+
const nextScrollLeft = toScrollOffset(
|
|
209
|
+
positionPercent,
|
|
210
|
+
state.viewport.scrollWidth,
|
|
211
|
+
state.viewport.clientWidth
|
|
212
|
+
);
|
|
213
|
+
const nextViewport = clampViewport({
|
|
214
|
+
...state.viewport,
|
|
215
|
+
scrollLeft: nextScrollLeft
|
|
216
|
+
});
|
|
217
|
+
const nextComputed = resolveStateFromViewport(nextViewport);
|
|
218
|
+
const meta = {
|
|
219
|
+
source: "user",
|
|
220
|
+
reason: "horizontal-thumb-drag",
|
|
221
|
+
previousValue: state.viewport.scrollLeft,
|
|
222
|
+
nextValue: nextScrollLeft,
|
|
223
|
+
inputModality: "pointer"
|
|
224
|
+
};
|
|
225
|
+
store.patchState(
|
|
226
|
+
{
|
|
227
|
+
viewport: nextViewport,
|
|
228
|
+
horizontal: {
|
|
229
|
+
...nextComputed.horizontal,
|
|
230
|
+
thumbPositionPercent: clamp(positionPercent, 0, 100)
|
|
231
|
+
},
|
|
232
|
+
vertical: nextComputed.vertical,
|
|
233
|
+
cornerVisible: nextComputed.cornerVisible,
|
|
234
|
+
lastInteraction: "horizontal-thumb",
|
|
235
|
+
lastChangeMeta: meta,
|
|
236
|
+
lastError: null
|
|
237
|
+
},
|
|
238
|
+
meta
|
|
239
|
+
);
|
|
240
|
+
}
|
|
241
|
+
};
|
|
242
|
+
return {
|
|
243
|
+
get state() {
|
|
244
|
+
return store.getState();
|
|
245
|
+
},
|
|
246
|
+
actions,
|
|
247
|
+
getState: store.getState,
|
|
248
|
+
subscribe: store.subscribe
|
|
249
|
+
};
|
|
250
|
+
}
|
|
251
|
+
|
|
252
|
+
export { createScrollArea };
|
|
253
|
+
//# sourceMappingURL=chunk-TWTQ2Y7N.mjs.map
|
|
254
|
+
//# sourceMappingURL=chunk-TWTQ2Y7N.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/primitives/scroll-area.ts"],"names":[],"mappings":";;;;AAoDA,SAAS,qBAAA,GAAuC;AAC9C,EAAA,OAAO;AAAA,IACL,SAAA,EAAW,CAAA;AAAA,IACX,UAAA,EAAY,CAAA;AAAA,IACZ,YAAA,EAAc,CAAA;AAAA,IACd,WAAA,EAAa,CAAA;AAAA,IACb,YAAA,EAAc,CAAA;AAAA,IACd,WAAA,EAAa;AAAA,GACf;AACF;AAEA,SAAS,WAAA,CACP,UAAA,EACA,UAAA,EACA,YAAA,EACiB;AACjB,EAAA,MAAM,OAAA,GAAU,UAAA,GAAa,UAAA,IAAc,UAAA,GAAa,CAAA;AACxD,EAAA,IAAI,CAAC,OAAA,EAAS;AACZ,IAAA,OAAO;AAAA,MACL,OAAA,EAAS,KAAA;AAAA,MACT,gBAAA,EAAkB,GAAA;AAAA,MAClB,oBAAA,EAAsB;AAAA,KACxB;AAAA,EACF;AAEA,EAAA,MAAM,SAAA,GAAY,IAAA,CAAK,GAAA,CAAI,CAAA,EAAG,aAAa,UAAU,CAAA;AACrD,EAAA,MAAM,mBAAmB,KAAA,CAAO,UAAA,GAAa,UAAA,GAAc,GAAA,EAAK,GAAG,GAAG,CAAA;AACtE,EAAA,MAAM,uBAAuB,KAAA,CAAO,YAAA,GAAe,SAAA,GAAa,GAAA,EAAK,GAAG,GAAG,CAAA;AAE3E,EAAA,OAAO;AAAA,IACL,OAAA,EAAS,IAAA;AAAA,IACT,gBAAA;AAAA,IACA;AAAA,GACF;AACF;AAEA,SAAS,yBACP,QAAA,EACoE;AACpE,EAAA,MAAM,WAAW,WAAA,CAAY,QAAA,CAAS,cAAc,QAAA,CAAS,YAAA,EAAc,SAAS,SAAS,CAAA;AAC7F,EAAA,MAAM,aAAa,WAAA,CAAY,QAAA,CAAS,aAAa,QAAA,CAAS,WAAA,EAAa,SAAS,UAAU,CAAA;AAE9F,EAAA,OAAO;AAAA,IACL,QAAA;AAAA,IACA,UAAA;AAAA,IACA,aAAA,EAAe,QAAA,CAAS,OAAA,IAAW,UAAA,CAAW;AAAA,GAChD;AACF;AAEA,SAAS,cAAA,CAAe,eAAA,EAAyB,UAAA,EAAoB,UAAA,EAA4B;AAC/F,EAAA,MAAM,SAAA,GAAY,IAAA,CAAK,GAAA,CAAI,CAAA,EAAG,aAAa,UAAU,CAAA;AACrD,EAAA,IAAI,cAAc,CAAA,EAAG;AACnB,IAAA,OAAO,CAAA;AAAA,EACT;AAEA,EAAA,OAAQ,KAAA,CAAM,eAAA,EAAiB,CAAA,EAAG,GAAG,IAAI,GAAA,GAAO,SAAA;AAClD;AAEA,SAAS,cAAc,QAAA,EAAwC;AAC7D,EAAA,OAAO;AAAA,IACL,GAAG,QAAA;AAAA,IACH,SAAA,EAAW,KAAA;AAAA,MACT,QAAA,CAAS,SAAA;AAAA,MACT,CAAA;AAAA,MACA,KAAK,GAAA,CAAI,CAAA,EAAG,QAAA,CAAS,YAAA,GAAe,SAAS,YAAY;AAAA,KAC3D;AAAA,IACA,UAAA,EAAY,KAAA;AAAA,MACV,QAAA,CAAS,UAAA;AAAA,MACT,CAAA;AAAA,MACA,KAAK,GAAA,CAAI,CAAA,EAAG,QAAA,CAAS,WAAA,GAAc,SAAS,WAAW;AAAA;AACzD,GACF;AACF;AAEO,SAAS,iBAAiB,KAAA,EAA2C;AAC1E,EAAA,MAAM,WAAW,qBAAA,EAAsB;AACvC,EAAA,MAAM,QAAA,GAAW,yBAAyB,QAAQ,CAAA;AAClD,EAAA,MAAM,QAAQ,WAAA,CAAqC;AAAA,IACjD,IAAA,EAAM,MAAM,IAAA,IAAQ,OAAA;AAAA,IACpB,eAAA,EAAiB,MAAM,eAAA,IAAmB,GAAA;AAAA,IAC1C,QAAA;AAAA,IACA,UAAU,QAAA,CAAS,QAAA;AAAA,IACnB,YAAY,QAAA,CAAS,UAAA;AAAA,IACrB,eAAe,QAAA,CAAS,aAAA;AAAA,IACxB,eAAA,EAAiB,IAAA;AAAA,IACjB,SAAA,EAAW;AAAA,GACZ,CAAA;AAED,EAAA,MAAM,OAAA,GAA6B;AAAA,IACjC,mBAAmB,OAAA,EAAS;AAC1B,MAAA,MAAM,KAAA,GAAQ,MAAM,QAAA,EAAS;AAC7B,MAAA,MAAM,eAAe,aAAA,CAAc;AAAA,QACjC,GAAG,KAAA,CAAM,QAAA;AAAA,QACT,GAAG;AAAA,OACJ,CAAA;AACD,MAAA,MAAM,YAAA,GAAe,yBAAyB,YAAY,CAAA;AAC1D,MAAA,KAAA,CAAM,UAAA,CAAW;AAAA,QACf,QAAA,EAAU,YAAA;AAAA,QACV,UAAU,YAAA,CAAa,QAAA;AAAA,QACvB,YAAY,YAAA,CAAa,UAAA;AAAA,QACzB,eAAe,YAAA,CAAa;AAAA,OAC7B,CAAA;AAAA,IACH,CAAA;AAAA,IACA,iBAAiB,QAAA,EAAU;AACzB,MAAA,MAAM,KAAA,GAAQ,MAAM,QAAA,EAAS;AAC7B,MAAA,MAAM,eAAe,aAAA,CAAc;AAAA,QACjC,GAAG,KAAA,CAAM,QAAA;AAAA,QACT,WAAW,QAAA,CAAS,GAAA,KAAQ,SAAY,QAAA,CAAS,GAAA,GAAM,MAAM,QAAA,CAAS,SAAA;AAAA,QACtE,YAAY,QAAA,CAAS,IAAA,KAAS,SAAY,QAAA,CAAS,IAAA,GAAO,MAAM,QAAA,CAAS;AAAA,OAC1E,CAAA;AACD,MAAA,MAAM,YAAA,GAAe,yBAAyB,YAAY,CAAA;AAC1D,MAAA,MAAM,IAAA,GAA2B;AAAA,QAC/B,MAAA,EAAQ,MAAA;AAAA,QACR,MAAA,EAAQ,iBAAA;AAAA,QACR,aAAA,EAAe,MAAM,QAAA,CAAS,SAAA;AAAA,QAC9B,WAAW,YAAA,CAAa,SAAA;AAAA,QACxB,aAAA,EAAe;AAAA,OACjB;AACA,MAAA,KAAA,CAAM,UAAA;AAAA,QACJ;AAAA,UACE,QAAA,EAAU,YAAA;AAAA,UACV,UAAU,YAAA,CAAa,QAAA;AAAA,UACvB,YAAY,YAAA,CAAa,UAAA;AAAA,UACzB,eAAe,YAAA,CAAa,aAAA;AAAA,UAC5B,eAAA,EAAiB,UAAA;AAAA,UACjB,cAAA,EAAgB,IAAA;AAAA,UAChB,SAAA,EAAW;AAAA,SACb;AAAA,QACA;AAAA,OACF;AAAA,IACF,CAAA;AAAA,IACA,SAAS,QAAA,EAAU;AACjB,MAAA,MAAM,KAAA,GAAQ,MAAM,QAAA,EAAS;AAC7B,MAAA,MAAM,eAAe,aAAA,CAAc;AAAA,QACjC,GAAG,KAAA,CAAM,QAAA;AAAA,QACT,WAAW,QAAA,CAAS,GAAA,KAAQ,SAAY,QAAA,CAAS,GAAA,GAAM,MAAM,QAAA,CAAS,SAAA;AAAA,QACtE,YAAY,QAAA,CAAS,IAAA,KAAS,SAAY,QAAA,CAAS,IAAA,GAAO,MAAM,QAAA,CAAS;AAAA,OAC1E,CAAA;AACD,MAAA,MAAM,YAAA,GAAe,yBAAyB,YAAY,CAAA;AAC1D,MAAA,MAAM,IAAA,GAA2B;AAAA,QAC/B,MAAA,EAAQ,cAAA;AAAA,QACR,MAAA,EAAQ,qBAAA;AAAA,QACR,aAAA,EAAe,MAAM,QAAA,CAAS,SAAA;AAAA,QAC9B,WAAW,YAAA,CAAa;AAAA,OAC1B;AACA,MAAA,KAAA,CAAM,UAAA;AAAA,QACJ;AAAA,UACE,QAAA,EAAU,YAAA;AAAA,UACV,UAAU,YAAA,CAAa,QAAA;AAAA,UACvB,YAAY,YAAA,CAAa,UAAA;AAAA,UACzB,eAAe,YAAA,CAAa,aAAA;AAAA,UAC5B,eAAA,EAAiB,UAAA;AAAA,UACjB,cAAA,EAAgB,IAAA;AAAA,UAChB,SAAA,EAAW;AAAA,SACb;AAAA,QACA;AAAA,OACF;AAAA,IACF,CAAA;AAAA,IACA,kBAAkB,eAAA,EAAiB;AACjC,MAAA,MAAM,KAAA,GAAQ,MAAM,QAAA,EAAS;AAC7B,MAAA,IAAI,CAAC,KAAA,CAAM,QAAA,CAAS,OAAA,EAAS;AAC3B,QAAA,KAAA,CAAM,UAAA,CAAW;AAAA,UACf,WAAW,eAAA,CAAgB;AAAA,YACzB,IAAA,EAAM,sBAAA;AAAA,YACN,OAAA,EAAS,YAAA;AAAA,YACT,SAAA,EAAW,YAAA;AAAA,YACX,OAAA,EAAS,+DAAA;AAAA,YACT,WAAA,EAAa;AAAA,WACd;AAAA,SACF,CAAA;AACD,QAAA;AAAA,MACF;AAEA,MAAA,MAAM,aAAA,GAAgB,cAAA;AAAA,QACpB,eAAA;AAAA,QACA,MAAM,QAAA,CAAS,YAAA;AAAA,QACf,MAAM,QAAA,CAAS;AAAA,OACjB;AACA,MAAA,MAAM,eAAe,aAAA,CAAc;AAAA,QACjC,GAAG,KAAA,CAAM,QAAA;AAAA,QACT,SAAA,EAAW;AAAA,OACZ,CAAA;AACD,MAAA,MAAM,YAAA,GAAe,yBAAyB,YAAY,CAAA;AAC1D,MAAA,MAAM,IAAA,GAA2B;AAAA,QAC/B,MAAA,EAAQ,MAAA;AAAA,QACR,MAAA,EAAQ,qBAAA;AAAA,QACR,aAAA,EAAe,MAAM,QAAA,CAAS,SAAA;AAAA,QAC9B,SAAA,EAAW,aAAA;AAAA,QACX,aAAA,EAAe;AAAA,OACjB;AACA,MAAA,KAAA,CAAM,UAAA;AAAA,QACJ;AAAA,UACE,QAAA,EAAU,YAAA;AAAA,UACV,QAAA,EAAU;AAAA,YACR,GAAG,YAAA,CAAa,QAAA;AAAA,YAChB,oBAAA,EAAsB,KAAA,CAAM,eAAA,EAAiB,CAAA,EAAG,GAAG;AAAA,WACrD;AAAA,UACA,YAAY,YAAA,CAAa,UAAA;AAAA,UACzB,eAAe,YAAA,CAAa,aAAA;AAAA,UAC5B,eAAA,EAAiB,gBAAA;AAAA,UACjB,cAAA,EAAgB,IAAA;AAAA,UAChB,SAAA,EAAW;AAAA,SACb;AAAA,QACA;AAAA,OACF;AAAA,IACF,CAAA;AAAA,IACA,oBAAoB,eAAA,EAAiB;AACnC,MAAA,MAAM,KAAA,GAAQ,MAAM,QAAA,EAAS;AAC7B,MAAA,IAAI,CAAC,KAAA,CAAM,UAAA,CAAW,OAAA,EAAS;AAC7B,QAAA,KAAA,CAAM,UAAA,CAAW;AAAA,UACf,WAAW,eAAA,CAAgB;AAAA,YACzB,IAAA,EAAM,sBAAA;AAAA,YACN,OAAA,EAAS,YAAA;AAAA,YACT,SAAA,EAAW,YAAA;AAAA,YACX,OAAA,EAAS,+DAAA;AAAA,YACT,WAAA,EAAa;AAAA,WACd;AAAA,SACF,CAAA;AACD,QAAA;AAAA,MACF;AAEA,MAAA,MAAM,cAAA,GAAiB,cAAA;AAAA,QACrB,eAAA;AAAA,QACA,MAAM,QAAA,CAAS,WAAA;AAAA,QACf,MAAM,QAAA,CAAS;AAAA,OACjB;AACA,MAAA,MAAM,eAAe,aAAA,CAAc;AAAA,QACjC,GAAG,KAAA,CAAM,QAAA;AAAA,QACT,UAAA,EAAY;AAAA,OACb,CAAA;AACD,MAAA,MAAM,YAAA,GAAe,yBAAyB,YAAY,CAAA;AAC1D,MAAA,MAAM,IAAA,GAA2B;AAAA,QAC/B,MAAA,EAAQ,MAAA;AAAA,QACR,MAAA,EAAQ,uBAAA;AAAA,QACR,aAAA,EAAe,MAAM,QAAA,CAAS,UAAA;AAAA,QAC9B,SAAA,EAAW,cAAA;AAAA,QACX,aAAA,EAAe;AAAA,OACjB;AACA,MAAA,KAAA,CAAM,UAAA;AAAA,QACJ;AAAA,UACE,QAAA,EAAU,YAAA;AAAA,UACV,UAAA,EAAY;AAAA,YACV,GAAG,YAAA,CAAa,UAAA;AAAA,YAChB,oBAAA,EAAsB,KAAA,CAAM,eAAA,EAAiB,CAAA,EAAG,GAAG;AAAA,WACrD;AAAA,UACA,UAAU,YAAA,CAAa,QAAA;AAAA,UACvB,eAAe,YAAA,CAAa,aAAA;AAAA,UAC5B,eAAA,EAAiB,kBAAA;AAAA,UACjB,cAAA,EAAgB,IAAA;AAAA,UAChB,SAAA,EAAW;AAAA,SACb;AAAA,QACA;AAAA,OACF;AAAA,IACF;AAAA,GACF;AAEA,EAAA,OAAO;AAAA,IACL,IAAI,KAAA,GAAQ;AACV,MAAA,OAAO,MAAM,QAAA,EAAS;AAAA,IACxB,CAAA;AAAA,IACA,OAAA;AAAA,IACA,UAAU,KAAA,CAAM,QAAA;AAAA,IAChB,WAAW,KAAA,CAAM;AAAA,GACnB;AACF","file":"chunk-TWTQ2Y7N.mjs","sourcesContent":["import { createUIFnError, type UIFnError } from '../errors';\nimport { clamp, type ChangeMeta, createStore } from './shared';\n\nexport interface ScrollAreaProps {\n type?: 'auto' | 'always' | 'scroll' | 'hover';\n scrollHideDelay?: number;\n}\n\nexport interface ScrollMetrics {\n scrollTop: number;\n scrollLeft: number;\n scrollHeight: number;\n scrollWidth: number;\n clientHeight: number;\n clientWidth: number;\n}\n\nexport interface ScrollAxisState {\n visible: boolean;\n thumbSizePercent: number;\n thumbPositionPercent: number;\n}\n\nexport interface ScrollAreaState {\n type: 'auto' | 'always' | 'scroll' | 'hover';\n scrollHideDelay: number;\n viewport: ScrollMetrics;\n vertical: ScrollAxisState;\n horizontal: ScrollAxisState;\n cornerVisible: boolean;\n lastInteraction: 'viewport' | 'vertical-thumb' | 'horizontal-thumb' | null;\n lastChangeMeta?: ChangeMeta<number>;\n lastError: UIFnError | null;\n}\n\nexport interface ScrollAreaActions {\n setViewportMetrics: (metrics: Partial<ScrollMetrics>) => void;\n onViewportScroll: (position: { top?: number; left?: number }) => void;\n scrollTo: (position: { top?: number; left?: number }) => void;\n dragVerticalThumb: (positionPercent: number) => void;\n dragHorizontalThumb: (positionPercent: number) => void;\n}\n\nexport interface ScrollAreaMachine {\n readonly state: ScrollAreaState;\n readonly actions: ScrollAreaActions;\n getState: () => ScrollAreaState;\n subscribe: (\n callback: (state: ScrollAreaState, meta?: ChangeMeta<number>) => void\n ) => () => void;\n}\n\nfunction createDefaultViewport(): ScrollMetrics {\n return {\n scrollTop: 0,\n scrollLeft: 0,\n scrollHeight: 0,\n scrollWidth: 0,\n clientHeight: 0,\n clientWidth: 0,\n };\n}\n\nfunction toAxisState(\n scrollSize: number,\n clientSize: number,\n scrollOffset: number\n): ScrollAxisState {\n const visible = scrollSize > clientSize && clientSize > 0;\n if (!visible) {\n return {\n visible: false,\n thumbSizePercent: 100,\n thumbPositionPercent: 0,\n };\n }\n\n const maxScroll = Math.max(1, scrollSize - clientSize);\n const thumbSizePercent = clamp((clientSize / scrollSize) * 100, 5, 100);\n const thumbPositionPercent = clamp((scrollOffset / maxScroll) * 100, 0, 100);\n\n return {\n visible: true,\n thumbSizePercent,\n thumbPositionPercent,\n };\n}\n\nfunction resolveStateFromViewport(\n viewport: ScrollMetrics\n): Pick<ScrollAreaState, 'vertical' | 'horizontal' | 'cornerVisible'> {\n const vertical = toAxisState(viewport.scrollHeight, viewport.clientHeight, viewport.scrollTop);\n const horizontal = toAxisState(viewport.scrollWidth, viewport.clientWidth, viewport.scrollLeft);\n\n return {\n vertical,\n horizontal,\n cornerVisible: vertical.visible && horizontal.visible,\n };\n}\n\nfunction toScrollOffset(positionPercent: number, scrollSize: number, clientSize: number): number {\n const maxScroll = Math.max(0, scrollSize - clientSize);\n if (maxScroll === 0) {\n return 0;\n }\n\n return (clamp(positionPercent, 0, 100) / 100) * maxScroll;\n}\n\nfunction clampViewport(viewport: ScrollMetrics): ScrollMetrics {\n return {\n ...viewport,\n scrollTop: clamp(\n viewport.scrollTop,\n 0,\n Math.max(0, viewport.scrollHeight - viewport.clientHeight)\n ),\n scrollLeft: clamp(\n viewport.scrollLeft,\n 0,\n Math.max(0, viewport.scrollWidth - viewport.clientWidth)\n ),\n };\n}\n\nexport function createScrollArea(props: ScrollAreaProps): ScrollAreaMachine {\n const viewport = createDefaultViewport();\n const computed = resolveStateFromViewport(viewport);\n const store = createStore<ScrollAreaState, number>({\n type: props.type ?? 'hover',\n scrollHideDelay: props.scrollHideDelay ?? 600,\n viewport,\n vertical: computed.vertical,\n horizontal: computed.horizontal,\n cornerVisible: computed.cornerVisible,\n lastInteraction: null,\n lastError: null,\n });\n\n const actions: ScrollAreaActions = {\n setViewportMetrics(metrics) {\n const state = store.getState();\n const nextViewport = clampViewport({\n ...state.viewport,\n ...metrics,\n });\n const nextComputed = resolveStateFromViewport(nextViewport);\n store.patchState({\n viewport: nextViewport,\n vertical: nextComputed.vertical,\n horizontal: nextComputed.horizontal,\n cornerVisible: nextComputed.cornerVisible,\n });\n },\n onViewportScroll(position) {\n const state = store.getState();\n const nextViewport = clampViewport({\n ...state.viewport,\n scrollTop: position.top !== undefined ? position.top : state.viewport.scrollTop,\n scrollLeft: position.left !== undefined ? position.left : state.viewport.scrollLeft,\n });\n const nextComputed = resolveStateFromViewport(nextViewport);\n const meta: ChangeMeta<number> = {\n source: 'user',\n reason: 'viewport-scroll',\n previousValue: state.viewport.scrollTop,\n nextValue: nextViewport.scrollTop,\n inputModality: 'pointer',\n };\n store.patchState(\n {\n viewport: nextViewport,\n vertical: nextComputed.vertical,\n horizontal: nextComputed.horizontal,\n cornerVisible: nextComputed.cornerVisible,\n lastInteraction: 'viewport',\n lastChangeMeta: meta,\n lastError: null,\n },\n meta\n );\n },\n scrollTo(position) {\n const state = store.getState();\n const nextViewport = clampViewport({\n ...state.viewport,\n scrollTop: position.top !== undefined ? position.top : state.viewport.scrollTop,\n scrollLeft: position.left !== undefined ? position.left : state.viewport.scrollLeft,\n });\n const nextComputed = resolveStateFromViewport(nextViewport);\n const meta: ChangeMeta<number> = {\n source: 'programmatic',\n reason: 'programmatic-scroll',\n previousValue: state.viewport.scrollTop,\n nextValue: nextViewport.scrollTop,\n };\n store.patchState(\n {\n viewport: nextViewport,\n vertical: nextComputed.vertical,\n horizontal: nextComputed.horizontal,\n cornerVisible: nextComputed.cornerVisible,\n lastInteraction: 'viewport',\n lastChangeMeta: meta,\n lastError: null,\n },\n meta\n );\n },\n dragVerticalThumb(positionPercent) {\n const state = store.getState();\n if (!state.vertical.visible) {\n store.patchState({\n lastError: createUIFnError({\n code: 'UIFN_ERR_SCROLL_SYNC',\n package: '@uifn/core',\n component: 'ScrollArea',\n message: 'ScrollArea viewport and thumb state MUST remain synchronized.',\n recoverable: true,\n }),\n });\n return;\n }\n\n const nextScrollTop = toScrollOffset(\n positionPercent,\n state.viewport.scrollHeight,\n state.viewport.clientHeight\n );\n const nextViewport = clampViewport({\n ...state.viewport,\n scrollTop: nextScrollTop,\n });\n const nextComputed = resolveStateFromViewport(nextViewport);\n const meta: ChangeMeta<number> = {\n source: 'user',\n reason: 'vertical-thumb-drag',\n previousValue: state.viewport.scrollTop,\n nextValue: nextScrollTop,\n inputModality: 'pointer',\n };\n store.patchState(\n {\n viewport: nextViewport,\n vertical: {\n ...nextComputed.vertical,\n thumbPositionPercent: clamp(positionPercent, 0, 100),\n },\n horizontal: nextComputed.horizontal,\n cornerVisible: nextComputed.cornerVisible,\n lastInteraction: 'vertical-thumb',\n lastChangeMeta: meta,\n lastError: null,\n },\n meta\n );\n },\n dragHorizontalThumb(positionPercent) {\n const state = store.getState();\n if (!state.horizontal.visible) {\n store.patchState({\n lastError: createUIFnError({\n code: 'UIFN_ERR_SCROLL_SYNC',\n package: '@uifn/core',\n component: 'ScrollArea',\n message: 'ScrollArea viewport and thumb state MUST remain synchronized.',\n recoverable: true,\n }),\n });\n return;\n }\n\n const nextScrollLeft = toScrollOffset(\n positionPercent,\n state.viewport.scrollWidth,\n state.viewport.clientWidth\n );\n const nextViewport = clampViewport({\n ...state.viewport,\n scrollLeft: nextScrollLeft,\n });\n const nextComputed = resolveStateFromViewport(nextViewport);\n const meta: ChangeMeta<number> = {\n source: 'user',\n reason: 'horizontal-thumb-drag',\n previousValue: state.viewport.scrollLeft,\n nextValue: nextScrollLeft,\n inputModality: 'pointer',\n };\n store.patchState(\n {\n viewport: nextViewport,\n horizontal: {\n ...nextComputed.horizontal,\n thumbPositionPercent: clamp(positionPercent, 0, 100),\n },\n vertical: nextComputed.vertical,\n cornerVisible: nextComputed.cornerVisible,\n lastInteraction: 'horizontal-thumb',\n lastChangeMeta: meta,\n lastError: null,\n },\n meta\n );\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"]}
|