@zentauri-ui/zentauri-components 1.4.5 → 1.4.7
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +196 -88
- package/cli/index.mjs +45 -26
- package/cli/registry.json +11 -2
- package/cli/rewrite-imports.mjs +8 -3
- package/dist/charts/area/Area.d.ts +6 -0
- package/dist/charts/area/Area.d.ts.map +1 -0
- package/dist/charts/area/index.d.ts +4 -0
- package/dist/charts/area/index.d.ts.map +1 -0
- package/dist/charts/area.js +119 -0
- package/dist/charts/area.js.map +1 -0
- package/dist/charts/area.mjs +106 -0
- package/dist/charts/area.mjs.map +1 -0
- package/dist/charts/bar/Bar.d.ts +6 -0
- package/dist/charts/bar/Bar.d.ts.map +1 -0
- package/dist/charts/bar/index.d.ts +4 -0
- package/dist/charts/bar/index.d.ts.map +1 -0
- package/dist/charts/bar.js +110 -0
- package/dist/charts/bar.js.map +1 -0
- package/dist/charts/bar.mjs +97 -0
- package/dist/charts/bar.mjs.map +1 -0
- package/dist/charts/bubble/Bubble.d.ts +6 -0
- package/dist/charts/bubble/Bubble.d.ts.map +1 -0
- package/dist/charts/bubble/index.d.ts +4 -0
- package/dist/charts/bubble/index.d.ts.map +1 -0
- package/dist/charts/bubble.js +122 -0
- package/dist/charts/bubble.js.map +1 -0
- package/dist/charts/bubble.mjs +109 -0
- package/dist/charts/bubble.mjs.map +1 -0
- package/dist/charts/line/Line.d.ts +6 -0
- package/dist/charts/line/Line.d.ts.map +1 -0
- package/dist/charts/line/index.d.ts +4 -0
- package/dist/charts/line/index.d.ts.map +1 -0
- package/dist/charts/line.js +113 -0
- package/dist/charts/line.js.map +1 -0
- package/dist/charts/line.mjs +100 -0
- package/dist/charts/line.mjs.map +1 -0
- package/dist/charts/shared/chart-frame.d.ts +32 -0
- package/dist/charts/shared/chart-frame.d.ts.map +1 -0
- package/dist/charts/shared/colors.d.ts +43 -0
- package/dist/charts/shared/colors.d.ts.map +1 -0
- package/dist/charts/shared/types.d.ts +43 -0
- package/dist/charts/shared/types.d.ts.map +1 -0
- package/dist/charts/shared/variants.d.ts +93 -0
- package/dist/charts/shared/variants.d.ts.map +1 -0
- package/dist/{chunk-IXDJ3IPG.mjs → chunk-2BAMNRAL.mjs} +40 -32
- package/dist/chunk-2BAMNRAL.mjs.map +1 -0
- package/dist/{chunk-JE3PD5ZA.js → chunk-2VUMVDR3.js} +8 -8
- package/dist/{chunk-JE3PD5ZA.js.map → chunk-2VUMVDR3.js.map} +1 -1
- package/dist/{chunk-DFEZH7TC.mjs → chunk-4D54YOL6.mjs} +2 -2
- package/dist/{chunk-DFEZH7TC.mjs.map → chunk-4D54YOL6.mjs.map} +1 -1
- package/dist/{chunk-BORK3BJO.mjs → chunk-5TV7EL3H.mjs} +19 -19
- package/dist/chunk-5TV7EL3H.mjs.map +1 -0
- package/dist/{chunk-BSWYZTYK.js → chunk-7DCFVPWN.js} +2 -2
- package/dist/chunk-7DCFVPWN.js.map +1 -0
- package/dist/{chunk-5QB2KNZQ.js → chunk-7TLKLMBM.js} +11 -9
- package/dist/chunk-7TLKLMBM.js.map +1 -0
- package/dist/{chunk-2P3UU2J3.mjs → chunk-A6KMZ5ZS.mjs} +12 -12
- package/dist/chunk-A6KMZ5ZS.mjs.map +1 -0
- package/dist/{chunk-U4YQCAXW.js → chunk-AD2LA3XN.js} +18 -18
- package/dist/chunk-AD2LA3XN.js.map +1 -0
- package/dist/{chunk-XLAFQ24R.js → chunk-AUGLZ3AN.js} +49 -41
- package/dist/chunk-AUGLZ3AN.js.map +1 -0
- package/dist/{chunk-OJ67PZ6N.js → chunk-BCZIYH53.js} +8 -8
- package/dist/{chunk-OJ67PZ6N.js.map → chunk-BCZIYH53.js.map} +1 -1
- package/dist/{chunk-UBFKTC2P.mjs → chunk-C5L465FW.mjs} +12 -12
- package/dist/chunk-C5L465FW.mjs.map +1 -0
- package/dist/chunk-CIN5JDN4.js +174 -0
- package/dist/chunk-CIN5JDN4.js.map +1 -0
- package/dist/{chunk-3OR47XMY.js → chunk-E4FZY7O2.js} +52 -33
- package/dist/chunk-E4FZY7O2.js.map +1 -0
- package/dist/{chunk-LVUPECBT.mjs → chunk-FQBMIZH2.mjs} +12 -12
- package/dist/chunk-FQBMIZH2.mjs.map +1 -0
- package/dist/{chunk-RDSPHBHK.mjs → chunk-G3LEYBRV.mjs} +50 -7
- package/dist/chunk-G3LEYBRV.mjs.map +1 -0
- package/dist/chunk-GBWGVNDA.js +160 -0
- package/dist/chunk-GBWGVNDA.js.map +1 -0
- package/dist/{chunk-XWM2S6VV.mjs → chunk-I6GR234Z.mjs} +22 -20
- package/dist/chunk-I6GR234Z.mjs.map +1 -0
- package/dist/{chunk-UXGHUBNJ.mjs → chunk-INMNX3HQ.mjs} +13 -13
- package/dist/{chunk-UXGHUBNJ.mjs.map → chunk-INMNX3HQ.mjs.map} +1 -1
- package/dist/chunk-IQZROQNJ.mjs +165 -0
- package/dist/chunk-IQZROQNJ.mjs.map +1 -0
- package/dist/{chunk-PGH27VTL.mjs → chunk-JBAUEGYD.mjs} +40 -32
- package/dist/chunk-JBAUEGYD.mjs.map +1 -0
- package/dist/{chunk-WZKGRU3U.js → chunk-JUDMPOCI.js} +103 -38
- package/dist/chunk-JUDMPOCI.js.map +1 -0
- package/dist/chunk-K6YI4FJO.mjs +158 -0
- package/dist/chunk-K6YI4FJO.mjs.map +1 -0
- package/dist/{chunk-WP7GYBRI.js → chunk-KC5LEZ6J.js} +2 -2
- package/dist/chunk-KC5LEZ6J.js.map +1 -0
- package/dist/{chunk-BVXTOEBI.mjs → chunk-LN77JJTY.mjs} +45 -26
- package/dist/chunk-LN77JJTY.mjs.map +1 -0
- package/dist/{chunk-E3DZNJAD.js → chunk-MCOQHXRW.js} +23 -21
- package/dist/chunk-MCOQHXRW.js.map +1 -0
- package/dist/{chunk-FLILFCQE.mjs → chunk-MTLLJFUI.mjs} +7 -8
- package/dist/chunk-MTLLJFUI.mjs.map +1 -0
- package/dist/{chunk-6I7X5BF2.js → chunk-N2OAI2HN.js} +18 -18
- package/dist/chunk-N2OAI2HN.js.map +1 -0
- package/dist/{chunk-BITDSQMR.js → chunk-OB4KJZK2.js} +19 -19
- package/dist/chunk-OB4KJZK2.js.map +1 -0
- package/dist/{chunk-PCK6LX3K.js → chunk-OLEMP2HL.js} +19 -19
- package/dist/{chunk-PCK6LX3K.js.map → chunk-OLEMP2HL.js.map} +1 -1
- package/dist/{chunk-2PQEXQVR.js → chunk-PWL5WD34.js} +76 -27
- package/dist/chunk-PWL5WD34.js.map +1 -0
- package/dist/{chunk-N4NO3SYL.js → chunk-Q5B44QW7.js} +48 -40
- package/dist/chunk-Q5B44QW7.js.map +1 -0
- package/dist/{chunk-FT2LMA66.mjs → chunk-QADZK5R7.mjs} +2 -2
- package/dist/chunk-QADZK5R7.mjs.map +1 -0
- package/dist/{chunk-WDCIZHXY.mjs → chunk-QZTEFGZF.mjs} +6 -4
- package/dist/chunk-QZTEFGZF.mjs.map +1 -0
- package/dist/{chunk-UOFTZKMM.js → chunk-S7WKFNPT.js} +18 -18
- package/dist/chunk-S7WKFNPT.js.map +1 -0
- package/dist/{chunk-XIXF7UVM.mjs → chunk-TINHLHCN.mjs} +12 -12
- package/dist/chunk-TINHLHCN.mjs.map +1 -0
- package/dist/{chunk-7HL3A4YF.mjs → chunk-TJUNN2PT.mjs} +73 -24
- package/dist/chunk-TJUNN2PT.mjs.map +1 -0
- package/dist/{chunk-4B7KGBQB.js → chunk-UWA23DUC.js} +12 -13
- package/dist/chunk-UWA23DUC.js.map +1 -0
- package/dist/{chunk-CY5BQKRZ.mjs → chunk-VXDEPZKH.mjs} +2 -2
- package/dist/chunk-VXDEPZKH.mjs.map +1 -0
- package/dist/{chunk-C2FCPQTO.js → chunk-Y745GQR2.js} +16 -16
- package/dist/chunk-Y745GQR2.js.map +1 -0
- package/dist/{chunk-TZ2JVWTZ.mjs → chunk-YNBJAFI2.mjs} +3 -3
- package/dist/{chunk-TZ2JVWTZ.mjs.map → chunk-YNBJAFI2.mjs.map} +1 -1
- package/dist/{chunk-P5HUBXUX.js → chunk-YTRGRHEB.js} +55 -12
- package/dist/chunk-YTRGRHEB.js.map +1 -0
- package/dist/{chunk-YNCD6TKE.mjs → chunk-ZBBFOMSJ.mjs} +103 -38
- package/dist/chunk-ZBBFOMSJ.mjs.map +1 -0
- package/dist/{chunk-UOZYPWDZ.js → chunk-ZS5756ZC.js} +2 -2
- package/dist/{chunk-UOZYPWDZ.js.map → chunk-ZS5756ZC.js.map} +1 -1
- package/dist/{chunk-W6PRMYUC.mjs → chunk-ZYZJ74XB.mjs} +3 -3
- package/dist/{chunk-W6PRMYUC.mjs.map → chunk-ZYZJ74XB.mjs.map} +1 -1
- package/dist/hooks/index.d.ts +2 -2
- package/dist/hooks/index.d.ts.map +1 -1
- package/dist/hooks/useClickOutside/useClickOutside.d.ts.map +1 -1
- package/dist/hooks/useClickOutside.js +2 -2
- package/dist/hooks/useClickOutside.mjs +1 -1
- package/dist/hooks/useClipboard/useClipboard.d.ts.map +1 -1
- package/dist/hooks/useClipboard.js.map +1 -1
- package/dist/hooks/useClipboard.mjs.map +1 -1
- package/dist/hooks/useFocusManagement/useFocusManagement.d.ts +5 -14
- package/dist/hooks/useFocusManagement/useFocusManagement.d.ts.map +1 -1
- package/dist/hooks/useFocusManagement.js +2 -2
- package/dist/hooks/useFocusManagement.mjs +1 -1
- package/dist/hooks/useLocalStorage/index.d.ts +1 -1
- package/dist/hooks/useLocalStorage/index.d.ts.map +1 -1
- package/dist/hooks/useLocalStorage.js +1 -3
- package/dist/hooks/useLocalStorage.js.map +1 -1
- package/dist/hooks/useLocalStorage.mjs +1 -3
- package/dist/hooks/useLocalStorage.mjs.map +1 -1
- package/dist/hooks/useMediaQuery/useMediaQuery.d.ts.map +1 -1
- package/dist/hooks/useMediaQuery.js +2 -2
- package/dist/hooks/useMediaQuery.mjs +1 -1
- package/dist/hooks/usePagination.js +4 -4
- package/dist/hooks/usePagination.mjs +2 -2
- package/dist/hooks/usePrefersColorScheme.js +2 -2
- package/dist/hooks/usePrefersColorScheme.mjs +1 -1
- package/dist/hooks/usePrefersReducedMotion.js +2 -2
- package/dist/hooks/usePrefersReducedMotion.mjs +1 -1
- package/dist/hooks/useResizeObserver/index.d.ts +1 -1
- package/dist/hooks/useResizeObserver/index.d.ts.map +1 -1
- package/dist/hooks/useSessionStorage/useSessionStorage.d.ts.map +1 -1
- package/dist/hooks/useSessionStorage.js.map +1 -1
- package/dist/hooks/useSessionStorage.mjs.map +1 -1
- package/dist/hooks/useThrottledCallback/useThrottledCallback.d.ts.map +1 -1
- package/dist/hooks/useThrottledCallback.js.map +1 -1
- package/dist/hooks/useThrottledCallback.mjs.map +1 -1
- package/dist/hooks/useWindowSize/useWindowSize.d.ts.map +1 -1
- package/dist/hooks/useWindowSize.js +4 -1
- package/dist/hooks/useWindowSize.js.map +1 -1
- package/dist/hooks/useWindowSize.mjs +4 -1
- package/dist/hooks/useWindowSize.mjs.map +1 -1
- package/dist/hooks/utils.js +5 -5
- package/dist/hooks/utils.mjs +1 -1
- package/dist/lib/utils.d.ts.map +1 -1
- package/dist/ui/accordion/accordion.d.ts.map +1 -1
- package/dist/ui/accordion/animated/accordion-content-animated.d.ts.map +1 -1
- package/dist/ui/accordion/animated/index.d.ts +1 -1
- package/dist/ui/accordion/animated/index.d.ts.map +1 -1
- package/dist/ui/accordion/animated/types.d.ts.map +1 -1
- package/dist/ui/accordion/animated.js +8 -11
- package/dist/ui/accordion/animated.js.map +1 -1
- package/dist/ui/accordion/animated.mjs +4 -7
- package/dist/ui/accordion/animated.mjs.map +1 -1
- package/dist/ui/accordion/variants.d.ts +2 -2
- package/dist/ui/accordion.js +10 -10
- package/dist/ui/accordion.js.map +1 -1
- package/dist/ui/accordion.mjs +3 -3
- package/dist/ui/accordion.mjs.map +1 -1
- package/dist/ui/alert/alert-base.d.ts.map +1 -1
- package/dist/ui/alert/alert.d.ts.map +1 -1
- package/dist/ui/alert/animated/index.d.ts.map +1 -1
- package/dist/ui/alert/animated.js +3 -3
- package/dist/ui/alert/animated.mjs +2 -2
- package/dist/ui/alert/types.d.ts.map +1 -1
- package/dist/ui/alert/variants.d.ts +1 -1
- package/dist/ui/alert.js +11 -11
- package/dist/ui/alert.js.map +1 -1
- package/dist/ui/alert.mjs +3 -3
- package/dist/ui/alert.mjs.map +1 -1
- package/dist/ui/avatar/animated/index.d.ts +1 -1
- package/dist/ui/avatar/animated/index.d.ts.map +1 -1
- package/dist/ui/avatar/animated.js +6 -6
- package/dist/ui/avatar/animated.mjs +3 -3
- package/dist/ui/avatar/avatar-base.d.ts.map +1 -1
- package/dist/ui/avatar/avatar.d.ts.map +1 -1
- package/dist/ui/avatar/variants.d.ts +1 -1
- package/dist/ui/avatar/variants.d.ts.map +1 -1
- package/dist/ui/avatar.js +10 -10
- package/dist/ui/avatar.js.map +1 -1
- package/dist/ui/avatar.mjs +3 -3
- package/dist/ui/avatar.mjs.map +1 -1
- package/dist/ui/badge/animated/index.d.ts +1 -1
- package/dist/ui/badge/animated/index.d.ts.map +1 -1
- package/dist/ui/badge/animated/types.d.ts.map +1 -1
- package/dist/ui/badge/animated.js +3 -3
- package/dist/ui/badge/animated.mjs +2 -2
- package/dist/ui/badge/badge-base.d.ts +1 -1
- package/dist/ui/badge/badge-base.d.ts.map +1 -1
- package/dist/ui/badge/types.d.ts +1 -0
- package/dist/ui/badge/types.d.ts.map +1 -1
- package/dist/ui/badge/variants.d.ts +18 -18
- package/dist/ui/badge/variants.d.ts.map +1 -1
- package/dist/ui/badge.js +5 -5
- package/dist/ui/badge.mjs +3 -3
- package/dist/ui/breadcrumb/breadcrumb.d.ts.map +1 -1
- package/dist/ui/breadcrumb/types.d.ts.map +1 -1
- package/dist/ui/breadcrumb/variants.d.ts +1 -1
- package/dist/ui/breadcrumb/variants.d.ts.map +1 -1
- package/dist/ui/breadcrumb.js +47 -43
- package/dist/ui/breadcrumb.js.map +1 -1
- package/dist/ui/breadcrumb.mjs +43 -39
- package/dist/ui/breadcrumb.mjs.map +1 -1
- package/dist/ui/buttons/animated/index.d.ts +1 -1
- package/dist/ui/buttons/animated/index.d.ts.map +1 -1
- package/dist/ui/buttons/animated/types.d.ts.map +1 -1
- package/dist/ui/buttons/animated.js +4 -4
- package/dist/ui/buttons/animated.mjs +2 -2
- package/dist/ui/buttons/types.d.ts.map +1 -1
- package/dist/ui/buttons/variants.d.ts +2 -2
- package/dist/ui/buttons.js +5 -5
- package/dist/ui/buttons.mjs +3 -3
- package/dist/ui/card/animated.js +8 -8
- package/dist/ui/card/animated.mjs +3 -3
- package/dist/ui/card/card-base.d.ts.map +1 -1
- package/dist/ui/card/card.d.ts.map +1 -1
- package/dist/ui/card/index.d.ts +2 -2
- package/dist/ui/card/index.d.ts.map +1 -1
- package/dist/ui/card/variants.d.ts +1 -1
- package/dist/ui/card.js +13 -13
- package/dist/ui/card.js.map +1 -1
- package/dist/ui/card.mjs +3 -3
- package/dist/ui/card.mjs.map +1 -1
- package/dist/ui/divider/animated/index.d.ts +1 -1
- package/dist/ui/divider/animated/index.d.ts.map +1 -1
- package/dist/ui/divider/animated/types.d.ts.map +1 -1
- package/dist/ui/divider/animated.js +3 -3
- package/dist/ui/divider/animated.mjs +2 -2
- package/dist/ui/divider/divider-base.d.ts.map +1 -1
- package/dist/ui/divider/variants.d.ts +2 -2
- package/dist/ui/divider.js +7 -7
- package/dist/ui/divider.mjs +3 -3
- package/dist/ui/drawer/animated/drawer-content-animated.d.ts.map +1 -1
- package/dist/ui/drawer/animated/index.d.ts +1 -1
- package/dist/ui/drawer/animated/index.d.ts.map +1 -1
- package/dist/ui/drawer/animated.js +19 -20
- package/dist/ui/drawer/animated.js.map +1 -1
- package/dist/ui/drawer/animated.mjs +9 -10
- package/dist/ui/drawer/animated.mjs.map +1 -1
- package/dist/ui/drawer/drawer-base.d.ts +1 -1
- package/dist/ui/drawer/drawer-base.d.ts.map +1 -1
- package/dist/ui/drawer/types.d.ts +1 -0
- package/dist/ui/drawer/types.d.ts.map +1 -1
- package/dist/ui/drawer/variants.d.ts +3 -3
- package/dist/ui/drawer.js +13 -13
- package/dist/ui/drawer.mjs +3 -3
- package/dist/ui/dropdown/dropdown.d.ts +1 -1
- package/dist/ui/dropdown/dropdown.d.ts.map +1 -1
- package/dist/ui/dropdown/types.d.ts +1 -0
- package/dist/ui/dropdown/types.d.ts.map +1 -1
- package/dist/ui/dropdown/variants.d.ts +4 -4
- package/dist/ui/dropdown.js +49 -31
- package/dist/ui/dropdown.js.map +1 -1
- package/dist/ui/dropdown.mjs +46 -28
- package/dist/ui/dropdown.mjs.map +1 -1
- package/dist/ui/empty-state/animated/empty-state-animated.d.ts.map +1 -1
- package/dist/ui/empty-state/animated/index.d.ts +2 -2
- package/dist/ui/empty-state/animated/index.d.ts.map +1 -1
- package/dist/ui/empty-state/animated.js +3 -3
- package/dist/ui/empty-state/animated.js.map +1 -1
- package/dist/ui/empty-state/animated.mjs +2 -2
- package/dist/ui/empty-state/animated.mjs.map +1 -1
- package/dist/ui/empty-state/empty-state-base.d.ts.map +1 -1
- package/dist/ui/empty-state/index.d.ts +1 -1
- package/dist/ui/empty-state/index.d.ts.map +1 -1
- package/dist/ui/empty-state/types.d.ts +1 -0
- package/dist/ui/empty-state/types.d.ts.map +1 -1
- package/dist/ui/empty-state.js +11 -11
- package/dist/ui/empty-state.mjs +3 -3
- package/dist/ui/file-upload/file-upload.d.ts.map +1 -1
- package/dist/ui/file-upload/variants.d.ts +1 -1
- package/dist/ui/file-upload/variants.d.ts.map +1 -1
- package/dist/ui/file-upload.js +4 -6
- package/dist/ui/file-upload.js.map +1 -1
- package/dist/ui/file-upload.mjs +2 -4
- package/dist/ui/file-upload.mjs.map +1 -1
- package/dist/ui/inputs/animated/index.d.ts +1 -1
- package/dist/ui/inputs/animated/index.d.ts.map +1 -1
- package/dist/ui/inputs/animated.js +3 -3
- package/dist/ui/inputs/animated.mjs +1 -1
- package/dist/ui/inputs/input-base.d.ts.map +1 -1
- package/dist/ui/inputs/types.d.ts +3 -1
- package/dist/ui/inputs/types.d.ts.map +1 -1
- package/dist/ui/inputs/variants.d.ts +2 -2
- package/dist/ui/inputs.js +49 -5
- package/dist/ui/inputs.js.map +1 -1
- package/dist/ui/inputs.mjs +47 -3
- package/dist/ui/inputs.mjs.map +1 -1
- package/dist/ui/modal/animated/index.d.ts +1 -1
- package/dist/ui/modal/animated/index.d.ts.map +1 -1
- package/dist/ui/modal/animated/modal-content-animated.d.ts.map +1 -1
- package/dist/ui/modal/animated.js +12 -13
- package/dist/ui/modal/animated.js.map +1 -1
- package/dist/ui/modal/animated.mjs +8 -9
- package/dist/ui/modal/animated.mjs.map +1 -1
- package/dist/ui/modal/index.d.ts +1 -1
- package/dist/ui/modal/index.d.ts.map +1 -1
- package/dist/ui/modal/modal-base.d.ts +4 -2
- package/dist/ui/modal/modal-base.d.ts.map +1 -1
- package/dist/ui/modal/types.d.ts.map +1 -1
- package/dist/ui/modal/variants.d.ts +2 -2
- package/dist/ui/modal.js +14 -14
- package/dist/ui/modal.js.map +1 -1
- package/dist/ui/modal.mjs +4 -4
- package/dist/ui/modal.mjs.map +1 -1
- package/dist/ui/pagination/pagination.d.ts +2 -2
- package/dist/ui/pagination/variants.d.ts +3 -3
- package/dist/ui/pagination.js +25 -25
- package/dist/ui/pagination.js.map +1 -1
- package/dist/ui/pagination.mjs +15 -15
- package/dist/ui/pagination.mjs.map +1 -1
- package/dist/ui/progress/animated/progress-animated.d.ts.map +1 -1
- package/dist/ui/progress/animated.js +52 -14
- package/dist/ui/progress/animated.js.map +1 -1
- package/dist/ui/progress/animated.mjs +45 -7
- package/dist/ui/progress/animated.mjs.map +1 -1
- package/dist/ui/progress/index.d.ts +2 -2
- package/dist/ui/progress/index.d.ts.map +1 -1
- package/dist/ui/progress/progress-base.d.ts.map +1 -1
- package/dist/ui/progress/progress.d.ts.map +1 -1
- package/dist/ui/progress/types.d.ts +3 -0
- package/dist/ui/progress/types.d.ts.map +1 -1
- package/dist/ui/progress/variants.d.ts +1 -1
- package/dist/ui/progress.js +10 -15
- package/dist/ui/progress.js.map +1 -1
- package/dist/ui/progress.mjs +4 -9
- package/dist/ui/progress.mjs.map +1 -1
- package/dist/ui/search/search-bar.d.ts +1 -1
- package/dist/ui/search/search-bar.d.ts.map +1 -1
- package/dist/ui/search/search-suggestion-list.d.ts.map +1 -1
- package/dist/ui/search/search-suggestion-utils.d.ts.map +1 -1
- package/dist/ui/search.js +25 -13
- package/dist/ui/search.js.map +1 -1
- package/dist/ui/search.mjs +21 -9
- package/dist/ui/search.mjs.map +1 -1
- package/dist/ui/select/select.d.ts +1 -1
- package/dist/ui/select/select.d.ts.map +1 -1
- package/dist/ui/select/types.d.ts +1 -0
- package/dist/ui/select/types.d.ts.map +1 -1
- package/dist/ui/select/variants.d.ts +4 -4
- package/dist/ui/select/variants.d.ts.map +1 -1
- package/dist/ui/select.js +145 -63
- package/dist/ui/select.js.map +1 -1
- package/dist/ui/select.mjs +141 -59
- package/dist/ui/select.mjs.map +1 -1
- package/dist/ui/skeleton/animated/skeleton-animated.d.ts.map +1 -1
- package/dist/ui/skeleton/animated/types.d.ts.map +1 -1
- package/dist/ui/skeleton/animated.js +34 -10
- package/dist/ui/skeleton/animated.js.map +1 -1
- package/dist/ui/skeleton/animated.mjs +29 -5
- package/dist/ui/skeleton/animated.mjs.map +1 -1
- package/dist/ui/skeleton/variants.d.ts +3 -3
- package/dist/ui/skeleton.js +10 -10
- package/dist/ui/skeleton.mjs +2 -2
- package/dist/ui/slider/slider.d.ts.map +1 -1
- package/dist/ui/slider/types.d.ts +8 -2
- package/dist/ui/slider/types.d.ts.map +1 -1
- package/dist/ui/slider/variants.d.ts +1 -1
- package/dist/ui/slider.js +53 -17
- package/dist/ui/slider.js.map +1 -1
- package/dist/ui/slider.mjs +45 -9
- package/dist/ui/slider.mjs.map +1 -1
- package/dist/ui/spinner/animated/spinner.d.ts.map +1 -1
- package/dist/ui/spinner/animated/variants.d.ts +1 -1
- package/dist/ui/spinner/animated.js +68 -56
- package/dist/ui/spinner/animated.js.map +1 -1
- package/dist/ui/spinner/animated.mjs +64 -52
- package/dist/ui/spinner/animated.mjs.map +1 -1
- package/dist/ui/stepper/stepper.d.ts +2 -7
- package/dist/ui/stepper/stepper.d.ts.map +1 -1
- package/dist/ui/stepper/types.d.ts +3 -3
- package/dist/ui/stepper/types.d.ts.map +1 -1
- package/dist/ui/stepper/variants.d.ts +1 -1
- package/dist/ui/stepper/variants.d.ts.map +1 -1
- package/dist/ui/stepper.js +12 -13
- package/dist/ui/stepper.js.map +1 -1
- package/dist/ui/stepper.mjs +9 -10
- package/dist/ui/stepper.mjs.map +1 -1
- package/dist/ui/table/animated/index.d.ts +2 -2
- package/dist/ui/table/animated/index.d.ts.map +1 -1
- package/dist/ui/table/animated.js +9 -9
- package/dist/ui/table/animated.mjs +3 -3
- package/dist/ui/table/table-base.d.ts +1 -1
- package/dist/ui/table/table-base.d.ts.map +1 -1
- package/dist/ui/table/types.d.ts +5 -1
- package/dist/ui/table/types.d.ts.map +1 -1
- package/dist/ui/table/variants.d.ts +3 -3
- package/dist/ui/table.js +15 -15
- package/dist/ui/table.mjs +2 -2
- package/dist/ui/tabs/animated/animations.d.ts.map +1 -1
- package/dist/ui/tabs/animated/index.d.ts +1 -1
- package/dist/ui/tabs/animated/index.d.ts.map +1 -1
- package/dist/ui/tabs/animated/types.d.ts.map +1 -1
- package/dist/ui/tabs/animated.js +4 -4
- package/dist/ui/tabs/animated.js.map +1 -1
- package/dist/ui/tabs/animated.mjs +2 -2
- package/dist/ui/tabs/animated.mjs.map +1 -1
- package/dist/ui/tabs/index.d.ts +1 -1
- package/dist/ui/tabs/index.d.ts.map +1 -1
- package/dist/ui/tabs/tabs-base.d.ts.map +1 -1
- package/dist/ui/tabs/tabs.d.ts +1 -1
- package/dist/ui/tabs/tabs.d.ts.map +1 -1
- package/dist/ui/tabs/types.d.ts +2 -1
- package/dist/ui/tabs/types.d.ts.map +1 -1
- package/dist/ui/tabs/variants.d.ts +1 -1
- package/dist/ui/tabs.js +10 -10
- package/dist/ui/tabs.mjs +2 -2
- package/dist/ui/toast/animated/toast-animated.d.ts.map +1 -1
- package/dist/ui/toast/animated.js +12 -10
- package/dist/ui/toast/animated.js.map +1 -1
- package/dist/ui/toast/animated.mjs +5 -3
- package/dist/ui/toast/animated.mjs.map +1 -1
- package/dist/ui/toast/types.d.ts.map +1 -1
- package/dist/ui/toast/variants.d.ts +1 -1
- package/dist/ui/toast.js +13 -13
- package/dist/ui/toast.mjs +2 -2
- package/dist/ui/toggle/animated/index.d.ts +2 -2
- package/dist/ui/toggle/animated/index.d.ts.map +1 -1
- package/dist/ui/toggle/animated/types.d.ts.map +1 -1
- package/dist/ui/toggle/animated.js +3 -3
- package/dist/ui/toggle/animated.mjs +1 -1
- package/dist/ui/toggle/index.d.ts +1 -1
- package/dist/ui/toggle/index.d.ts.map +1 -1
- package/dist/ui/toggle/toggle-base.d.ts.map +1 -1
- package/dist/ui/toggle/variants.d.ts +1 -1
- package/dist/ui/toggle.js +31 -6
- package/dist/ui/toggle.js.map +1 -1
- package/dist/ui/toggle.mjs +30 -5
- package/dist/ui/toggle.mjs.map +1 -1
- package/dist/ui/tooltip/animated/animations.d.ts.map +1 -1
- package/dist/ui/tooltip/animated/types.d.ts.map +1 -1
- package/dist/ui/tooltip/animated.js +5 -5
- package/dist/ui/tooltip/animated.js.map +1 -1
- package/dist/ui/tooltip/animated.mjs +2 -2
- package/dist/ui/tooltip/animated.mjs.map +1 -1
- package/dist/ui/tooltip/tooltip-base.d.ts.map +1 -1
- package/dist/ui/tooltip/types.d.ts +1 -0
- package/dist/ui/tooltip/types.d.ts.map +1 -1
- package/dist/ui/tooltip/variants.d.ts +1 -1
- package/dist/ui/tooltip/variants.d.ts.map +1 -1
- package/dist/ui/tooltip.js +8 -8
- package/dist/ui/tooltip.mjs +2 -2
- package/dist/ui/typography/blockquote-base.d.ts +6 -0
- package/dist/ui/typography/blockquote-base.d.ts.map +1 -0
- package/dist/ui/typography/blockquote.d.ts +6 -0
- package/dist/ui/typography/blockquote.d.ts.map +1 -0
- package/dist/ui/typography/code-block-base.d.ts +6 -0
- package/dist/ui/typography/code-block-base.d.ts.map +1 -0
- package/dist/ui/typography/code-block.d.ts +6 -0
- package/dist/ui/typography/code-block.d.ts.map +1 -0
- package/dist/ui/typography/heading-base.d.ts +6 -0
- package/dist/ui/typography/heading-base.d.ts.map +1 -0
- package/dist/ui/typography/heading.d.ts +6 -0
- package/dist/ui/typography/heading.d.ts.map +1 -0
- package/dist/ui/typography/index.d.ts +9 -0
- package/dist/ui/typography/index.d.ts.map +1 -0
- package/dist/ui/typography/inline-code-base.d.ts +6 -0
- package/dist/ui/typography/inline-code-base.d.ts.map +1 -0
- package/dist/ui/typography/inline-code.d.ts +6 -0
- package/dist/ui/typography/inline-code.d.ts.map +1 -0
- package/dist/ui/typography/list-base.d.ts +10 -0
- package/dist/ui/typography/list-base.d.ts.map +1 -0
- package/dist/ui/typography/list.d.ts +12 -0
- package/dist/ui/typography/list.d.ts.map +1 -0
- package/dist/ui/typography/text-base.d.ts +6 -0
- package/dist/ui/typography/text-base.d.ts.map +1 -0
- package/dist/ui/typography/text.d.ts +6 -0
- package/dist/ui/typography/text.d.ts.map +1 -0
- package/dist/ui/typography/types.d.ts +56 -0
- package/dist/ui/typography/types.d.ts.map +1 -0
- package/dist/ui/typography/variants.d.ts +16 -0
- package/dist/ui/typography/variants.d.ts.map +1 -0
- package/dist/ui/typography.js +312 -0
- package/dist/ui/typography.js.map +1 -0
- package/dist/ui/typography.mjs +299 -0
- package/dist/ui/typography.mjs.map +1 -0
- package/package.json +32 -12
- package/src/charts/area/Area.tsx +103 -0
- package/src/charts/area/index.ts +9 -0
- package/src/charts/bar/Bar.tsx +94 -0
- package/src/charts/bar/index.ts +9 -0
- package/src/charts/bubble/Bubble.tsx +113 -0
- package/src/charts/bubble/index.ts +9 -0
- package/src/charts/line/Line.tsx +97 -0
- package/src/charts/line/index.ts +9 -0
- package/src/charts/shared/chart-frame.tsx +107 -0
- package/src/charts/shared/colors.ts +31 -0
- package/src/charts/shared/types.ts +60 -0
- package/src/charts/shared/variants.ts +87 -0
- package/src/hooks/index.ts +8 -2
- package/src/hooks/useClickOutside/useClickOutside.ts +1 -4
- package/src/hooks/useClipboard/useClipboard.test.ts +3 -1
- package/src/hooks/useClipboard/useClipboard.ts +1 -2
- package/src/hooks/useDisclosure/useDisclosure.test.ts +1 -2
- package/src/hooks/useDocumentTitle/useDocumentTitle.test.ts +1 -3
- package/src/hooks/useFocusManagement/useFocusManagement.test.tsx +8 -0
- package/src/hooks/useFocusManagement/useFocusManagement.ts +162 -34
- package/src/hooks/useInView/useInView.test.ts +6 -1
- package/src/hooks/useLocalStorage/index.ts +1 -4
- package/src/hooks/useLocalStorage/useLocalStorage.test.ts +8 -20
- package/src/hooks/useLocalStorage/useLocalStorage.ts +4 -4
- package/src/hooks/useMediaQuery/useMediaQuery.ts +1 -4
- package/src/hooks/usePrefersReducedMotion/usePrefersReducedMotion.test.ts +3 -1
- package/src/hooks/useResizeObserver/index.ts +1 -4
- package/src/hooks/useSessionStorage/useSessionStorage.test.ts +2 -6
- package/src/hooks/useSessionStorage/useSessionStorage.ts +4 -2
- package/src/hooks/useThrottledCallback/useThrottledCallback.ts +4 -3
- package/src/hooks/useWindowSize/useWindowSize.ts +4 -1
- package/src/lib/utils.ts +3 -3
- package/src/ui/accordion/accordion.tsx +6 -1
- package/src/ui/accordion/animated/accordion-content-animated.tsx +1 -4
- package/src/ui/accordion/animated/index.ts +4 -1
- package/src/ui/accordion/animated/types.ts +6 -2
- package/src/ui/accordion/variants.ts +9 -9
- package/src/ui/alert/alert-base.tsx +6 -1
- package/src/ui/alert/alert.tsx +2 -2
- package/src/ui/alert/animated/index.ts +2 -2
- package/src/ui/alert/animated/types.ts +1 -1
- package/src/ui/alert/types.ts +1 -3
- package/src/ui/alert/variants.ts +9 -9
- package/src/ui/avatar/animated/index.ts +6 -2
- package/src/ui/avatar/avatar-base.tsx +2 -7
- package/src/ui/avatar/avatar.tsx +6 -1
- package/src/ui/avatar/variants.ts +23 -11
- package/src/ui/badge/animated/index.ts +6 -2
- package/src/ui/badge/animated/types.ts +1 -2
- package/src/ui/badge/badge-base.tsx +4 -1
- package/src/ui/badge/types.ts +1 -0
- package/src/ui/badge/variants.ts +16 -18
- package/src/ui/breadcrumb/breadcrumb.tsx +10 -2
- package/src/ui/breadcrumb/types.ts +20 -9
- package/src/ui/breadcrumb/variants.ts +34 -38
- package/src/ui/buttons/animated/index.ts +7 -1
- package/src/ui/buttons/animated/types.ts +0 -1
- package/src/ui/buttons/button.test.tsx +2 -2
- package/src/ui/buttons/types.ts +4 -5
- package/src/ui/buttons/variants.ts +17 -17
- package/src/ui/card/animated/types.ts +0 -1
- package/src/ui/card/card-base.tsx +1 -6
- package/src/ui/card/card.test.tsx +7 -3
- package/src/ui/card/card.tsx +1 -3
- package/src/ui/card/index.ts +7 -3
- package/src/ui/card/types.ts +1 -1
- package/src/ui/card/variants.ts +9 -9
- package/src/ui/divider/animated/index.ts +5 -1
- package/src/ui/divider/animated/types.ts +4 -2
- package/src/ui/divider/divider-base.tsx +0 -1
- package/src/ui/drawer/animated/drawer-content-animated.tsx +6 -11
- package/src/ui/drawer/animated/index.ts +6 -1
- package/src/ui/drawer/drawer-base.tsx +16 -8
- package/src/ui/drawer/types.ts +12 -3
- package/src/ui/drawer/variants.ts +18 -18
- package/src/ui/dropdown/dropdown.test.tsx +1 -3
- package/src/ui/dropdown/dropdown.tsx +30 -5
- package/src/ui/dropdown/types.ts +1 -0
- package/src/ui/dropdown/variants.ts +20 -20
- package/src/ui/empty-state/animated/empty-state-animated.tsx +2 -4
- package/src/ui/empty-state/animated/index.ts +8 -5
- package/src/ui/empty-state/empty-state-base.tsx +14 -2
- package/src/ui/empty-state/index.ts +7 -1
- package/src/ui/empty-state/types.ts +1 -0
- package/src/ui/file-upload/file-upload.tsx +3 -9
- package/src/ui/file-upload/variants.ts +18 -9
- package/src/ui/inputs/animated/index.ts +7 -1
- package/src/ui/inputs/input-base.tsx +60 -6
- package/src/ui/inputs/input.test.tsx +5 -1
- package/src/ui/inputs/types.ts +7 -2
- package/src/ui/modal/animated/index.ts +6 -1
- package/src/ui/modal/animated/modal-content-animated.tsx +4 -5
- package/src/ui/modal/index.ts +1 -1
- package/src/ui/modal/modal-base.tsx +19 -10
- package/src/ui/modal/modal.test.tsx +44 -4
- package/src/ui/modal/modal.tsx +1 -1
- package/src/ui/modal/types.ts +10 -2
- package/src/ui/modal/variants.ts +18 -18
- package/src/ui/pagination/pagination.tsx +2 -2
- package/src/ui/pagination/variants.ts +9 -9
- package/src/ui/progress/animated/progress-animated.tsx +43 -5
- package/src/ui/progress/animated/types.ts +1 -1
- package/src/ui/progress/index.ts +12 -2
- package/src/ui/progress/progress-base.tsx +61 -5
- package/src/ui/progress/progress.test.tsx +1 -3
- package/src/ui/progress/progress.tsx +2 -6
- package/src/ui/progress/types.ts +3 -0
- package/src/ui/search/filter-search-suggestions.test.ts +46 -12
- package/src/ui/search/filter-search-suggestions.ts +3 -3
- package/src/ui/search/search-bar.tsx +23 -23
- package/src/ui/search/search-suggestion-list.tsx +28 -11
- package/src/ui/search/search-suggestion-utils.ts +4 -1
- package/src/ui/select/select.tsx +96 -6
- package/src/ui/select/types.ts +1 -0
- package/src/ui/select/variants.ts +71 -68
- package/src/ui/skeleton/animated/skeleton-animated.tsx +25 -4
- package/src/ui/skeleton/animated/types.ts +0 -1
- package/src/ui/skeleton/skeleton-base.tsx +3 -3
- package/src/ui/skeleton/variants.ts +9 -9
- package/src/ui/slider/slider.test.tsx +23 -9
- package/src/ui/slider/slider.tsx +45 -4
- package/src/ui/slider/types.ts +9 -3
- package/src/ui/slider/variants.ts +1 -1
- package/src/ui/spinner/animated/spinner.tsx +6 -3
- package/src/ui/stepper/stepper.test.tsx +5 -6
- package/src/ui/stepper/stepper.tsx +12 -16
- package/src/ui/stepper/types.ts +11 -5
- package/src/ui/stepper/variants.ts +30 -15
- package/src/ui/table/animated/index.ts +6 -4
- package/src/ui/table/table-base.tsx +32 -11
- package/src/ui/table/types.ts +8 -1
- package/src/ui/tabs/animated/animations.ts +5 -1
- package/src/ui/tabs/animated/index.ts +7 -1
- package/src/ui/tabs/animated/types.ts +3 -3
- package/src/ui/tabs/index.ts +8 -1
- package/src/ui/tabs/tabs-base.tsx +71 -10
- package/src/ui/tabs/tabs.tsx +8 -1
- package/src/ui/tabs/types.ts +2 -1
- package/src/ui/tabs/variants.ts +10 -10
- package/src/ui/toast/animated/toast-animated.tsx +3 -1
- package/src/ui/toast/animated/types.ts +1 -1
- package/src/ui/toast/toast-base.tsx +1 -1
- package/src/ui/toast/types.ts +3 -1
- package/src/ui/toast/variants.ts +9 -9
- package/src/ui/toggle/animated/index.ts +7 -4
- package/src/ui/toggle/animated/types.ts +4 -2
- package/src/ui/toggle/index.ts +5 -1
- package/src/ui/toggle/toggle-base.tsx +36 -4
- package/src/ui/tooltip/animated/animations.ts +0 -1
- package/src/ui/tooltip/animated/types.ts +0 -1
- package/src/ui/tooltip/tooltip-base.tsx +118 -22
- package/src/ui/tooltip/types.ts +1 -0
- package/src/ui/tooltip/variants.ts +11 -13
- package/src/ui/typography/blockquote-base.tsx +32 -0
- package/src/ui/typography/blockquote.tsx +8 -0
- package/src/ui/typography/code-block-base.tsx +32 -0
- package/src/ui/typography/code-block.tsx +8 -0
- package/src/ui/typography/heading-base.tsx +56 -0
- package/src/ui/typography/heading.tsx +8 -0
- package/src/ui/typography/index.ts +28 -0
- package/src/ui/typography/inline-code-base.tsx +27 -0
- package/src/ui/typography/inline-code.tsx +8 -0
- package/src/ui/typography/list-base.tsx +80 -0
- package/src/ui/typography/list.tsx +15 -0
- package/src/ui/typography/text-base.tsx +43 -0
- package/src/ui/typography/text.tsx +8 -0
- package/src/ui/typography/types.ts +77 -0
- package/src/ui/typography/typography.test.tsx +82 -0
- package/src/ui/typography/variants.ts +80 -0
- package/dist/chunk-2P3UU2J3.mjs.map +0 -1
- package/dist/chunk-2PQEXQVR.js.map +0 -1
- package/dist/chunk-3OR47XMY.js.map +0 -1
- package/dist/chunk-4B7KGBQB.js.map +0 -1
- package/dist/chunk-5QB2KNZQ.js.map +0 -1
- package/dist/chunk-6I7X5BF2.js.map +0 -1
- package/dist/chunk-7HL3A4YF.mjs.map +0 -1
- package/dist/chunk-BITDSQMR.js.map +0 -1
- package/dist/chunk-BORK3BJO.mjs.map +0 -1
- package/dist/chunk-BSWYZTYK.js.map +0 -1
- package/dist/chunk-BVXTOEBI.mjs.map +0 -1
- package/dist/chunk-C2FCPQTO.js.map +0 -1
- package/dist/chunk-CY5BQKRZ.mjs.map +0 -1
- package/dist/chunk-E3DZNJAD.js.map +0 -1
- package/dist/chunk-FLILFCQE.mjs.map +0 -1
- package/dist/chunk-FT2LMA66.mjs.map +0 -1
- package/dist/chunk-IXDJ3IPG.mjs.map +0 -1
- package/dist/chunk-LVUPECBT.mjs.map +0 -1
- package/dist/chunk-N4NO3SYL.js.map +0 -1
- package/dist/chunk-P5HUBXUX.js.map +0 -1
- package/dist/chunk-PGH27VTL.mjs.map +0 -1
- package/dist/chunk-RDSPHBHK.mjs.map +0 -1
- package/dist/chunk-U4YQCAXW.js.map +0 -1
- package/dist/chunk-UBFKTC2P.mjs.map +0 -1
- package/dist/chunk-UOFTZKMM.js.map +0 -1
- package/dist/chunk-WDCIZHXY.mjs.map +0 -1
- package/dist/chunk-WL5I7RVS.mjs +0 -54
- package/dist/chunk-WL5I7RVS.mjs.map +0 -1
- package/dist/chunk-WP7GYBRI.js.map +0 -1
- package/dist/chunk-WZKGRU3U.js.map +0 -1
- package/dist/chunk-XIXF7UVM.mjs.map +0 -1
- package/dist/chunk-XLAFQ24R.js.map +0 -1
- package/dist/chunk-XWM2S6VV.mjs.map +0 -1
- package/dist/chunk-YNCD6TKE.mjs.map +0 -1
- package/dist/chunk-YPLVTUYL.js +0 -56
- package/dist/chunk-YPLVTUYL.js.map +0 -1
|
@@ -1,6 +1,15 @@
|
|
|
1
1
|
"use client";
|
|
2
2
|
|
|
3
|
-
import {
|
|
3
|
+
import {
|
|
4
|
+
createContext,
|
|
5
|
+
useCallback,
|
|
6
|
+
useContext,
|
|
7
|
+
useEffect,
|
|
8
|
+
useMemo,
|
|
9
|
+
useId,
|
|
10
|
+
useRef,
|
|
11
|
+
useState,
|
|
12
|
+
} from "react";
|
|
4
13
|
|
|
5
14
|
import { cn, clamp } from "../../lib/utils";
|
|
6
15
|
|
|
@@ -35,11 +44,37 @@ export function ProgressBase(props: ProgressProps) {
|
|
|
35
44
|
label,
|
|
36
45
|
children,
|
|
37
46
|
ref,
|
|
38
|
-
as:Wrapper = "div",
|
|
47
|
+
as: Wrapper = "div",
|
|
39
48
|
...rest
|
|
40
49
|
} = props;
|
|
41
50
|
const clamped = clamp(value, min, max);
|
|
42
51
|
const percent = max === min ? 0 : ((clamped - min) / (max - min)) * 100;
|
|
52
|
+
const labelSlotId = `${useId()}-progress-label`;
|
|
53
|
+
const labelSlotCountRef = useRef(0);
|
|
54
|
+
const [labelSlotMounted, setLabelSlotMounted] = useState(false);
|
|
55
|
+
const registerProgressLabel = useCallback(() => {
|
|
56
|
+
labelSlotCountRef.current += 1;
|
|
57
|
+
if (labelSlotCountRef.current === 1) {
|
|
58
|
+
setLabelSlotMounted(true);
|
|
59
|
+
}
|
|
60
|
+
return () => {
|
|
61
|
+
labelSlotCountRef.current -= 1;
|
|
62
|
+
if (labelSlotCountRef.current === 0) {
|
|
63
|
+
setLabelSlotMounted(false);
|
|
64
|
+
}
|
|
65
|
+
};
|
|
66
|
+
}, []);
|
|
67
|
+
const hasInlineLabelProp = Boolean(label?.trim().length);
|
|
68
|
+
|
|
69
|
+
const labelingProps = useMemo(() => {
|
|
70
|
+
if (hasInlineLabelProp) {
|
|
71
|
+
return { "aria-label": label?.trim() ?? "Progress" };
|
|
72
|
+
}
|
|
73
|
+
if (labelSlotMounted) {
|
|
74
|
+
return { "aria-labelledby": labelSlotId };
|
|
75
|
+
}
|
|
76
|
+
return { "aria-label": "Progress" };
|
|
77
|
+
}, [hasInlineLabelProp, label, labelSlotId, labelSlotMounted]);
|
|
43
78
|
|
|
44
79
|
const ctx = useMemo(
|
|
45
80
|
() => ({
|
|
@@ -51,8 +86,21 @@ export function ProgressBase(props: ProgressProps) {
|
|
|
51
86
|
striped: Boolean(striped),
|
|
52
87
|
animated: Boolean(animated),
|
|
53
88
|
appearance: appearance ?? "default",
|
|
89
|
+
labelSlotId,
|
|
90
|
+
registerProgressLabel,
|
|
54
91
|
}),
|
|
55
|
-
[
|
|
92
|
+
[
|
|
93
|
+
animated,
|
|
94
|
+
appearance,
|
|
95
|
+
clamped,
|
|
96
|
+
labelSlotId,
|
|
97
|
+
max,
|
|
98
|
+
min,
|
|
99
|
+
registerProgressLabel,
|
|
100
|
+
shape,
|
|
101
|
+
size,
|
|
102
|
+
striped,
|
|
103
|
+
],
|
|
56
104
|
);
|
|
57
105
|
|
|
58
106
|
return (
|
|
@@ -64,7 +112,7 @@ export function ProgressBase(props: ProgressProps) {
|
|
|
64
112
|
aria-valuemin={min}
|
|
65
113
|
aria-valuemax={max}
|
|
66
114
|
aria-valuenow={clamped}
|
|
67
|
-
|
|
115
|
+
{...labelingProps}
|
|
68
116
|
className={cn(
|
|
69
117
|
progressVariants({ appearance, size, shape, striped, animated }),
|
|
70
118
|
className,
|
|
@@ -87,7 +135,7 @@ export function ProgressBar({
|
|
|
87
135
|
className,
|
|
88
136
|
style,
|
|
89
137
|
ref,
|
|
90
|
-
as:Wrapper = "div",
|
|
138
|
+
as: Wrapper = "div",
|
|
91
139
|
...rest
|
|
92
140
|
}: ProgressSectionProps & {
|
|
93
141
|
style?: React.CSSProperties;
|
|
@@ -121,8 +169,16 @@ export function ProgressBar({
|
|
|
121
169
|
ProgressBar.displayName = "ProgressBar";
|
|
122
170
|
|
|
123
171
|
export function ProgressLabel({ className, children }: ProgressSectionProps) {
|
|
172
|
+
const { labelSlotId, registerProgressLabel } =
|
|
173
|
+
useProgressContext("ProgressLabel");
|
|
174
|
+
|
|
175
|
+
useEffect(() => {
|
|
176
|
+
return registerProgressLabel();
|
|
177
|
+
}, [registerProgressLabel]);
|
|
178
|
+
|
|
124
179
|
return (
|
|
125
180
|
<div
|
|
181
|
+
id={labelSlotId}
|
|
126
182
|
data-slot="progress-label"
|
|
127
183
|
className={cn("mb-2 font-medium text-slate-200", className)}
|
|
128
184
|
>
|
|
@@ -2,9 +2,7 @@ import { createRef } from "react";
|
|
|
2
2
|
import { render, screen } from "@testing-library/react";
|
|
3
3
|
import { describe, expect, it } from "vitest";
|
|
4
4
|
|
|
5
|
-
import {
|
|
6
|
-
Progress,
|
|
7
|
-
} from "./progress";
|
|
5
|
+
import { Progress } from "./progress";
|
|
8
6
|
import { ProgressBar, ProgressLabel, ProgressValue } from "./progress-base";
|
|
9
7
|
|
|
10
8
|
describe("Progress", () => {
|
|
@@ -2,11 +2,7 @@ import { ProgressBase } from "./progress-base";
|
|
|
2
2
|
import type { ProgressProps } from "./types";
|
|
3
3
|
|
|
4
4
|
export const Progress = (props: ProgressProps) => {
|
|
5
|
-
return
|
|
6
|
-
<ProgressBase
|
|
7
|
-
{...props}
|
|
8
|
-
/>
|
|
9
|
-
);
|
|
5
|
+
return <ProgressBase {...props} />;
|
|
10
6
|
};
|
|
11
7
|
|
|
12
|
-
Progress.displayName = "Progress";
|
|
8
|
+
Progress.displayName = "Progress";
|
package/src/ui/progress/types.ts
CHANGED
|
@@ -30,4 +30,7 @@ export type ProgressCtx = {
|
|
|
30
30
|
striped: boolean;
|
|
31
31
|
animated: boolean;
|
|
32
32
|
appearance: NonNullable<ProgressProps["appearance"]>;
|
|
33
|
+
labelSlotId: string;
|
|
34
|
+
/** Increments the label mount count; returned cleanup decrements. Multiple labels are supported. */
|
|
35
|
+
registerProgressLabel: () => () => void;
|
|
33
36
|
};
|
|
@@ -4,35 +4,63 @@ import { filterSearchSuggestions } from "./filter-search-suggestions";
|
|
|
4
4
|
import type { SearchFilterable } from "./types";
|
|
5
5
|
|
|
6
6
|
const sampleItems: SearchFilterable[] = [
|
|
7
|
-
{
|
|
7
|
+
{
|
|
8
|
+
id: "1",
|
|
9
|
+
label: "Installation",
|
|
10
|
+
href: "/preview/installation",
|
|
11
|
+
keywords: ["npm", "setup"],
|
|
12
|
+
},
|
|
8
13
|
{ id: "2", label: "Modal", href: "/preview/components/modal" },
|
|
9
|
-
{
|
|
14
|
+
{
|
|
15
|
+
id: "3",
|
|
16
|
+
label: "GitHub",
|
|
17
|
+
href: "https://example.com/repo",
|
|
18
|
+
keywords: ["github", "source"],
|
|
19
|
+
},
|
|
10
20
|
];
|
|
11
21
|
|
|
12
22
|
describe("filterSearchSuggestions", () => {
|
|
13
23
|
it("returns empty list for whitespace-only query", () => {
|
|
14
|
-
expect(
|
|
24
|
+
expect(
|
|
25
|
+
filterSearchSuggestions({ query: " ", items: sampleItems }),
|
|
26
|
+
).toEqual([]);
|
|
15
27
|
});
|
|
16
28
|
|
|
17
29
|
it("returns empty list for empty query", () => {
|
|
18
|
-
expect(filterSearchSuggestions({ query: "", items: sampleItems })).toEqual(
|
|
30
|
+
expect(filterSearchSuggestions({ query: "", items: sampleItems })).toEqual(
|
|
31
|
+
[],
|
|
32
|
+
);
|
|
19
33
|
});
|
|
20
34
|
|
|
21
35
|
it("matches label case-insensitively", () => {
|
|
22
|
-
expect(
|
|
23
|
-
{
|
|
24
|
-
]);
|
|
36
|
+
expect(
|
|
37
|
+
filterSearchSuggestions({ query: "modal", items: sampleItems }),
|
|
38
|
+
).toEqual([{ id: "2", label: "Modal", href: "/preview/components/modal" }]);
|
|
25
39
|
});
|
|
26
40
|
|
|
27
41
|
it("matches href substring", () => {
|
|
28
|
-
expect(
|
|
29
|
-
{
|
|
42
|
+
expect(
|
|
43
|
+
filterSearchSuggestions({ query: "installation", items: sampleItems }),
|
|
44
|
+
).toEqual([
|
|
45
|
+
{
|
|
46
|
+
id: "1",
|
|
47
|
+
label: "Installation",
|
|
48
|
+
href: "/preview/installation",
|
|
49
|
+
keywords: ["npm", "setup"],
|
|
50
|
+
},
|
|
30
51
|
]);
|
|
31
52
|
});
|
|
32
53
|
|
|
33
54
|
it("matches keywords", () => {
|
|
34
|
-
expect(
|
|
35
|
-
{
|
|
55
|
+
expect(
|
|
56
|
+
filterSearchSuggestions({ query: "github", items: sampleItems }),
|
|
57
|
+
).toEqual([
|
|
58
|
+
{
|
|
59
|
+
id: "3",
|
|
60
|
+
label: "GitHub",
|
|
61
|
+
href: "https://example.com/repo",
|
|
62
|
+
keywords: ["github", "source"],
|
|
63
|
+
},
|
|
36
64
|
]);
|
|
37
65
|
});
|
|
38
66
|
|
|
@@ -43,6 +71,12 @@ describe("filterSearchSuggestions", () => {
|
|
|
43
71
|
href: `/x/${index}`,
|
|
44
72
|
keywords: ["alpha"],
|
|
45
73
|
}));
|
|
46
|
-
expect(
|
|
74
|
+
expect(
|
|
75
|
+
filterSearchSuggestions({
|
|
76
|
+
query: "alpha",
|
|
77
|
+
items: many,
|
|
78
|
+
options: { maxResults: 5 },
|
|
79
|
+
}),
|
|
80
|
+
).toHaveLength(5);
|
|
47
81
|
});
|
|
48
82
|
});
|
|
@@ -28,9 +28,9 @@ export function filterSearchSuggestions<T extends SearchFilterable>({
|
|
|
28
28
|
for (const item of items) {
|
|
29
29
|
const isMatch =
|
|
30
30
|
item.label.toLowerCase().includes(normalized) ||
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
31
|
+
item.description?.toLowerCase().includes(normalized) ||
|
|
32
|
+
item.href?.toLowerCase().includes(normalized) ||
|
|
33
|
+
item.keywords?.some((k) => k.toLowerCase().includes(normalized));
|
|
34
34
|
|
|
35
35
|
if (isMatch) {
|
|
36
36
|
matches.push(item);
|
|
@@ -1,33 +1,32 @@
|
|
|
1
1
|
"use client";
|
|
2
2
|
|
|
3
|
-
import {
|
|
3
|
+
import { useId } from "react";
|
|
4
4
|
|
|
5
5
|
import { cn } from "../../lib/utils";
|
|
6
6
|
import { inputVariants } from "../inputs/variants";
|
|
7
7
|
|
|
8
8
|
import type { SearchBarProps } from "./types";
|
|
9
9
|
|
|
10
|
-
export const SearchBar = function SearchBar(
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
) {
|
|
10
|
+
export const SearchBar = function SearchBar({
|
|
11
|
+
value,
|
|
12
|
+
onValueChange,
|
|
13
|
+
leadingSlot,
|
|
14
|
+
className,
|
|
15
|
+
inputClassName,
|
|
16
|
+
appearance = "default",
|
|
17
|
+
inputSize = "md",
|
|
18
|
+
ring = true,
|
|
19
|
+
id,
|
|
20
|
+
onChange,
|
|
21
|
+
disabled,
|
|
22
|
+
type,
|
|
23
|
+
comboboxListboxId,
|
|
24
|
+
comboboxActiveOptionId,
|
|
25
|
+
comboboxExpanded,
|
|
26
|
+
"aria-label": ariaLabel,
|
|
27
|
+
ref,
|
|
28
|
+
...rest
|
|
29
|
+
}: SearchBarProps) {
|
|
31
30
|
const generatedId = useId();
|
|
32
31
|
const controlId = id ?? generatedId;
|
|
33
32
|
const combobox = Boolean(comboboxListboxId);
|
|
@@ -53,6 +52,7 @@ export const SearchBar = function SearchBar(
|
|
|
53
52
|
spellCheck={false}
|
|
54
53
|
disabled={disabled}
|
|
55
54
|
value={value}
|
|
55
|
+
aria-label={ariaLabel ?? (combobox ? undefined : "Search")}
|
|
56
56
|
data-slot="search-bar-input"
|
|
57
57
|
className={cn(
|
|
58
58
|
inputVariants({ appearance, size: inputSize, ring, as: "input" }),
|
|
@@ -78,6 +78,6 @@ export const SearchBar = function SearchBar(
|
|
|
78
78
|
/>
|
|
79
79
|
</div>
|
|
80
80
|
);
|
|
81
|
-
}
|
|
81
|
+
};
|
|
82
82
|
|
|
83
83
|
SearchBar.displayName = "SearchBar";
|
|
@@ -24,21 +24,39 @@ export function SearchSuggestionList({
|
|
|
24
24
|
return (
|
|
25
25
|
<div
|
|
26
26
|
data-slot="search-suggestion-list-empty"
|
|
27
|
-
className={cn(
|
|
27
|
+
className={cn(
|
|
28
|
+
"px-1 py-6 text-center text-sm text-slate-500",
|
|
29
|
+
className,
|
|
30
|
+
)}
|
|
28
31
|
>
|
|
29
32
|
{emptyLabel ?? "No matches."}
|
|
30
33
|
</div>
|
|
31
34
|
);
|
|
32
35
|
}
|
|
33
36
|
|
|
34
|
-
let lastGroup: string | undefined;
|
|
35
37
|
const useListbox = Boolean(listboxId);
|
|
36
38
|
|
|
39
|
+
const rows: Array<{
|
|
40
|
+
item: (typeof items)[number];
|
|
41
|
+
showGroup: boolean;
|
|
42
|
+
}> = [];
|
|
43
|
+
let lastGroupSeen: string | undefined;
|
|
44
|
+
for (const item of items) {
|
|
45
|
+
const showGroup = Boolean(item.group && item.group !== lastGroupSeen);
|
|
46
|
+
if (item.group) {
|
|
47
|
+
lastGroupSeen = item.group;
|
|
48
|
+
}
|
|
49
|
+
rows.push({ item, showGroup });
|
|
50
|
+
}
|
|
51
|
+
|
|
37
52
|
return (
|
|
38
53
|
<nav
|
|
39
54
|
data-slot="search-suggestion-list"
|
|
40
55
|
aria-label="Search results"
|
|
41
|
-
className={cn(
|
|
56
|
+
className={cn(
|
|
57
|
+
"flex max-h-[min(50vh,360px)] flex-col gap-1 overflow-y-auto pr-1",
|
|
58
|
+
className,
|
|
59
|
+
)}
|
|
42
60
|
>
|
|
43
61
|
<div
|
|
44
62
|
{...(useListbox
|
|
@@ -49,14 +67,12 @@ export function SearchSuggestionList({
|
|
|
49
67
|
: {})}
|
|
50
68
|
className={cn("flex flex-col gap-0.5", listClassName)}
|
|
51
69
|
>
|
|
52
|
-
{
|
|
53
|
-
const showGroup = item.group && item.group !== lastGroup;
|
|
54
|
-
if (item.group) {
|
|
55
|
-
lastGroup = item.group;
|
|
56
|
-
}
|
|
70
|
+
{rows.map(({ item, showGroup }) => {
|
|
57
71
|
const isActive = activeId === item.id;
|
|
58
72
|
const optionDomId =
|
|
59
|
-
useListbox && listboxId
|
|
73
|
+
useListbox && listboxId
|
|
74
|
+
? searchSuggestionOptionDomId(listboxId, item.id)
|
|
75
|
+
: undefined;
|
|
60
76
|
return (
|
|
61
77
|
<Fragment key={item.id}>
|
|
62
78
|
{showGroup ? (
|
|
@@ -80,7 +96,9 @@ export function SearchSuggestionList({
|
|
|
80
96
|
>
|
|
81
97
|
<span className="font-medium text-slate-100">{item.label}</span>
|
|
82
98
|
{item.description ? (
|
|
83
|
-
<span className="truncate text-xs text-slate-500">
|
|
99
|
+
<span className="truncate text-xs text-slate-500">
|
|
100
|
+
{item.description}
|
|
101
|
+
</span>
|
|
84
102
|
) : null}
|
|
85
103
|
</button>
|
|
86
104
|
</Fragment>
|
|
@@ -92,4 +110,3 @@ export function SearchSuggestionList({
|
|
|
92
110
|
}
|
|
93
111
|
|
|
94
112
|
SearchSuggestionList.displayName = "SearchSuggestionList";
|
|
95
|
-
|
|
@@ -2,7 +2,10 @@
|
|
|
2
2
|
* Builds a stable DOM id for a listbox option so `aria-activedescendant` on the combobox
|
|
3
3
|
* input can reference it. Safe for href-like `itemId` strings.
|
|
4
4
|
*/
|
|
5
|
-
export function searchSuggestionOptionDomId(
|
|
5
|
+
export function searchSuggestionOptionDomId(
|
|
6
|
+
listboxId: string,
|
|
7
|
+
itemId: string,
|
|
8
|
+
): string {
|
|
6
9
|
const safe = itemId.replace(/[^a-zA-Z0-9_-]/g, "_");
|
|
7
10
|
return `${listboxId}_opt_${safe}`;
|
|
8
11
|
}
|
package/src/ui/select/select.tsx
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
"use client";
|
|
2
|
-
import { useState, useEffect, useCallback, useRef } from "react";
|
|
2
|
+
import { useState, useEffect, useCallback, useRef, useId } from "react";
|
|
3
3
|
import {
|
|
4
4
|
SelectProps,
|
|
5
5
|
SelectOption,
|
|
@@ -32,6 +32,7 @@ export const Select = ({
|
|
|
32
32
|
onChange,
|
|
33
33
|
multiple = true,
|
|
34
34
|
}: SelectProps) => {
|
|
35
|
+
const listboxId = `${useId()}-listbox`;
|
|
35
36
|
const [internal, setInternal] = useState<string[]>(defaultValue);
|
|
36
37
|
const [open, setOpen] = useState(false);
|
|
37
38
|
const [options, setOptions] = useState<SelectOption[]>([]);
|
|
@@ -97,6 +98,7 @@ export const Select = ({
|
|
|
97
98
|
registerOption,
|
|
98
99
|
options,
|
|
99
100
|
multiple,
|
|
101
|
+
listboxId,
|
|
100
102
|
}}
|
|
101
103
|
>
|
|
102
104
|
<div ref={rootRef} className="relative w-full">
|
|
@@ -110,16 +112,25 @@ export const SelectTrigger = ({
|
|
|
110
112
|
className,
|
|
111
113
|
variant,
|
|
112
114
|
size,
|
|
115
|
+
onClick,
|
|
113
116
|
...props
|
|
114
117
|
}: SelectTriggerProps) => {
|
|
115
|
-
const { open, setOpen } = useSelect();
|
|
118
|
+
const { open, setOpen, listboxId } = useSelect();
|
|
116
119
|
|
|
117
120
|
return (
|
|
118
121
|
<button
|
|
119
122
|
type="button"
|
|
120
|
-
|
|
123
|
+
aria-expanded={open}
|
|
124
|
+
aria-haspopup="listbox"
|
|
125
|
+
aria-controls={listboxId}
|
|
121
126
|
className={cn(selectTriggerVariants({ variant, size }), className)}
|
|
122
127
|
{...props}
|
|
128
|
+
onClick={(event) => {
|
|
129
|
+
onClick?.(event);
|
|
130
|
+
if (!event.defaultPrevented) {
|
|
131
|
+
setOpen(!open);
|
|
132
|
+
}
|
|
133
|
+
}}
|
|
123
134
|
/>
|
|
124
135
|
);
|
|
125
136
|
};
|
|
@@ -161,12 +172,84 @@ export const SelectContent = ({
|
|
|
161
172
|
spacing = "default",
|
|
162
173
|
...props
|
|
163
174
|
}: SelectContentProps) => {
|
|
164
|
-
const { open } = useSelect();
|
|
175
|
+
const { open, listboxId, multiple } = useSelect();
|
|
176
|
+
const panelRef = useRef<HTMLDivElement>(null);
|
|
177
|
+
|
|
178
|
+
useEffect(() => {
|
|
179
|
+
if (!open) {
|
|
180
|
+
return;
|
|
181
|
+
}
|
|
182
|
+
const panel = panelRef.current;
|
|
183
|
+
if (!panel) {
|
|
184
|
+
return;
|
|
185
|
+
}
|
|
186
|
+
const opts = Array.from(
|
|
187
|
+
panel.querySelectorAll<HTMLElement>('[role="option"]'),
|
|
188
|
+
).filter((el) => el.getAttribute("aria-disabled") !== "true");
|
|
189
|
+
requestAnimationFrame(() => opts[0]?.focus());
|
|
190
|
+
}, [open]);
|
|
191
|
+
|
|
192
|
+
useEffect(() => {
|
|
193
|
+
if (!open) {
|
|
194
|
+
return;
|
|
195
|
+
}
|
|
196
|
+
const panel = panelRef.current;
|
|
197
|
+
if (!panel) {
|
|
198
|
+
return;
|
|
199
|
+
}
|
|
200
|
+
|
|
201
|
+
const enabledOptions = () =>
|
|
202
|
+
Array.from(panel.querySelectorAll<HTMLElement>('[role="option"]')).filter(
|
|
203
|
+
(el) => el.getAttribute("aria-disabled") !== "true",
|
|
204
|
+
);
|
|
205
|
+
|
|
206
|
+
const handleKeyDown = (event: KeyboardEvent) => {
|
|
207
|
+
const options = enabledOptions();
|
|
208
|
+
if (options.length === 0) {
|
|
209
|
+
return;
|
|
210
|
+
}
|
|
211
|
+
|
|
212
|
+
const idx = options.findIndex((el) => el === document.activeElement);
|
|
213
|
+
|
|
214
|
+
if (event.key === "ArrowDown") {
|
|
215
|
+
event.preventDefault();
|
|
216
|
+
const next = idx < 0 ? 0 : Math.min(idx + 1, options.length - 1);
|
|
217
|
+
options[next]?.focus();
|
|
218
|
+
return;
|
|
219
|
+
}
|
|
220
|
+
|
|
221
|
+
if (event.key === "ArrowUp") {
|
|
222
|
+
event.preventDefault();
|
|
223
|
+
const prev = idx <= 0 ? options.length - 1 : Math.max(idx - 1, 0);
|
|
224
|
+
options[prev]?.focus();
|
|
225
|
+
return;
|
|
226
|
+
}
|
|
227
|
+
|
|
228
|
+
if (event.key === "Home") {
|
|
229
|
+
event.preventDefault();
|
|
230
|
+
options[0]?.focus();
|
|
231
|
+
return;
|
|
232
|
+
}
|
|
233
|
+
|
|
234
|
+
if (event.key === "End") {
|
|
235
|
+
event.preventDefault();
|
|
236
|
+
options[options.length - 1]?.focus();
|
|
237
|
+
}
|
|
238
|
+
};
|
|
239
|
+
|
|
240
|
+
panel.addEventListener("keydown", handleKeyDown);
|
|
241
|
+
return () => panel.removeEventListener("keydown", handleKeyDown);
|
|
242
|
+
}, [open]);
|
|
165
243
|
|
|
166
244
|
if (!open) return null;
|
|
167
245
|
|
|
168
246
|
return (
|
|
169
247
|
<div
|
|
248
|
+
ref={panelRef}
|
|
249
|
+
id={listboxId}
|
|
250
|
+
role="listbox"
|
|
251
|
+
aria-multiselectable={multiple}
|
|
252
|
+
tabIndex={-1}
|
|
170
253
|
className={cn(
|
|
171
254
|
selectContentVariants({ appearance, size, spacing }),
|
|
172
255
|
className,
|
|
@@ -198,10 +281,17 @@ export const SelectItem = ({
|
|
|
198
281
|
<div
|
|
199
282
|
role="option"
|
|
200
283
|
aria-selected={isActive}
|
|
201
|
-
|
|
284
|
+
aria-disabled={disabled ? true : undefined}
|
|
285
|
+
tabIndex={-1}
|
|
202
286
|
onClick={() => !disabled && toggleValue(value)}
|
|
203
287
|
onKeyDown={(e) => {
|
|
204
|
-
if (
|
|
288
|
+
if (disabled) {
|
|
289
|
+
return;
|
|
290
|
+
}
|
|
291
|
+
if (e.key === "Enter" || e.key === " ") {
|
|
292
|
+
e.preventDefault();
|
|
293
|
+
toggleValue(value);
|
|
294
|
+
}
|
|
205
295
|
}}
|
|
206
296
|
data-selected={isActive ? "true" : "false"}
|
|
207
297
|
className={cn(
|