@dxos/react-ui 0.8.4-main.72ec0f3 → 0.8.4-main.7996785055
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/dist/lib/browser/chunk-LUPEFGHJ.mjs +776 -0
- package/dist/lib/browser/chunk-LUPEFGHJ.mjs.map +7 -0
- package/dist/lib/browser/index.mjs +4097 -68
- package/dist/lib/browser/index.mjs.map +4 -4
- package/dist/lib/browser/meta.json +1 -1
- package/dist/lib/browser/testing/index.mjs +74 -63
- package/dist/lib/browser/testing/index.mjs.map +4 -4
- package/dist/lib/node-esm/chunk-EQOBFLZC.mjs +778 -0
- package/dist/lib/node-esm/chunk-EQOBFLZC.mjs.map +7 -0
- package/dist/lib/node-esm/index.mjs +4097 -68
- package/dist/lib/node-esm/index.mjs.map +4 -4
- package/dist/lib/node-esm/meta.json +1 -1
- package/dist/lib/node-esm/testing/index.mjs +74 -63
- package/dist/lib/node-esm/testing/index.mjs.map +4 -4
- package/dist/types/src/components/Avatars/Avatar.d.ts.map +1 -1
- package/dist/types/src/components/Avatars/Avatar.stories.d.ts.map +1 -1
- package/dist/types/src/components/Breadcrumb/Breadcrumb.d.ts.map +1 -1
- package/dist/types/src/components/Button/Button.d.ts +3 -3
- package/dist/types/src/components/Button/Button.d.ts.map +1 -1
- package/dist/types/src/components/Button/IconButton.d.ts +2 -1
- package/dist/types/src/components/Button/IconButton.d.ts.map +1 -1
- package/dist/types/src/components/Button/Toggle.d.ts +2 -2
- package/dist/types/src/components/Button/Toggle.d.ts.map +1 -1
- package/dist/types/src/components/Button/ToggleGroup.d.ts +10 -10
- package/dist/types/src/components/Button/ToggleGroup.d.ts.map +1 -1
- package/dist/types/src/components/Button/ToggleGroup.stories.d.ts +4 -4
- package/dist/types/src/components/Card/Card.d.ts +145 -0
- package/dist/types/src/components/Card/Card.d.ts.map +1 -0
- package/dist/types/src/components/Card/Card.stories.d.ts +21 -0
- package/dist/types/src/components/Card/Card.stories.d.ts.map +1 -0
- package/dist/types/src/components/Card/index.d.ts +2 -0
- package/dist/types/src/components/Card/index.d.ts.map +1 -0
- package/dist/types/src/components/Clipboard/index.d.ts +10 -1
- package/dist/types/src/components/Clipboard/index.d.ts.map +1 -1
- package/dist/types/src/components/DensityProvider/DensityProvider.d.ts +1 -1
- package/dist/types/src/components/DensityProvider/DensityProvider.d.ts.map +1 -1
- package/dist/types/src/components/Dialog/AlertDialog.d.ts +41 -19
- package/dist/types/src/components/Dialog/AlertDialog.d.ts.map +1 -1
- package/dist/types/src/components/Dialog/AlertDialog.stories.d.ts.map +1 -1
- package/dist/types/src/components/Dialog/Dialog.d.ts +56 -21
- package/dist/types/src/components/Dialog/Dialog.d.ts.map +1 -1
- package/dist/types/src/components/Dialog/Dialog.stories.d.ts +10 -10
- package/dist/types/src/components/Dialog/Dialog.stories.d.ts.map +1 -1
- package/dist/types/src/components/ElevationProvider/ElevationProvider.d.ts +1 -1
- package/dist/types/src/components/ElevationProvider/ElevationProvider.d.ts.map +1 -1
- package/dist/types/src/components/ErrorFallback/ErrorFallback.d.ts +11 -0
- package/dist/types/src/components/ErrorFallback/ErrorFallback.d.ts.map +1 -0
- package/dist/types/src/components/ErrorFallback/ErrorFallback.stories.d.ts +7 -0
- package/dist/types/src/components/ErrorFallback/ErrorFallback.stories.d.ts.map +1 -0
- package/dist/types/src/components/ErrorFallback/ErrorStack.d.ts +8 -0
- package/dist/types/src/components/ErrorFallback/ErrorStack.d.ts.map +1 -0
- package/dist/types/src/components/ErrorFallback/ThrowError.d.ts +9 -0
- package/dist/types/src/components/ErrorFallback/ThrowError.d.ts.map +1 -0
- package/dist/types/src/components/ErrorFallback/index.d.ts +5 -0
- package/dist/types/src/components/ErrorFallback/index.d.ts.map +1 -0
- package/dist/types/src/components/Focus/Focus.d.ts +44 -0
- package/dist/types/src/components/Focus/Focus.d.ts.map +1 -0
- package/dist/types/src/components/Focus/Focus.stories.d.ts +9 -0
- package/dist/types/src/components/Focus/Focus.stories.d.ts.map +1 -0
- package/dist/types/src/components/Focus/index.d.ts +2 -0
- package/dist/types/src/components/Focus/index.d.ts.map +1 -0
- package/dist/types/src/components/Icon/Icon.d.ts +4 -1
- package/dist/types/src/components/Icon/Icon.d.ts.map +1 -1
- package/dist/types/src/components/Icon/Icon.stories.d.ts +11 -3
- package/dist/types/src/components/Icon/Icon.stories.d.ts.map +1 -1
- package/dist/types/src/components/Image/Image.d.ts +14 -0
- package/dist/types/src/components/Image/Image.d.ts.map +1 -0
- package/dist/types/src/components/Image/Image.stories.d.ts +33 -0
- package/dist/types/src/components/Image/Image.stories.d.ts.map +1 -0
- package/dist/types/src/components/Image/index.d.ts +2 -0
- package/dist/types/src/components/Image/index.d.ts.map +1 -0
- package/dist/types/src/components/Input/Input.d.ts +7 -7
- package/dist/types/src/components/Input/Input.d.ts.map +1 -1
- package/dist/types/src/components/Input/Input.stories.d.ts +8 -8
- package/dist/types/src/components/Input/Input.stories.d.ts.map +1 -1
- package/dist/types/src/components/List/List.d.ts +10 -4
- package/dist/types/src/components/List/List.d.ts.map +1 -1
- package/dist/types/src/components/List/List.stories.d.ts +8 -2
- package/dist/types/src/components/List/List.stories.d.ts.map +1 -1
- package/dist/types/src/components/List/Treegrid.d.ts.map +1 -1
- package/dist/types/src/components/Main/Main.d.ts +9 -10
- package/dist/types/src/components/Main/Main.d.ts.map +1 -1
- package/dist/types/src/components/Main/Main.stories.d.ts +0 -3
- package/dist/types/src/components/Main/Main.stories.d.ts.map +1 -1
- package/dist/types/src/components/{Menus → Menu}/ContextMenu.d.ts +6 -6
- package/dist/types/src/components/Menu/ContextMenu.d.ts.map +1 -0
- package/dist/types/src/components/Menu/ContextMenu.stories.d.ts.map +1 -0
- package/dist/types/src/components/Menu/DropdownMenu.d.ts +113 -0
- package/dist/types/src/components/Menu/DropdownMenu.d.ts.map +1 -0
- package/dist/types/src/components/Menu/DropdownMenu.stories.d.ts +28 -0
- package/dist/types/src/components/Menu/DropdownMenu.stories.d.ts.map +1 -0
- package/dist/types/src/components/Menu/index.d.ts.map +1 -0
- package/dist/types/src/components/Message/Message.d.ts +1 -1
- package/dist/types/src/components/Message/Message.d.ts.map +1 -1
- package/dist/types/src/components/Message/Message.stories.d.ts +5 -6
- package/dist/types/src/components/Message/Message.stories.d.ts.map +1 -1
- package/dist/types/src/components/Popover/Popover.d.ts +33 -24
- package/dist/types/src/components/Popover/Popover.d.ts.map +1 -1
- package/dist/types/src/components/ScrollArea/ScrollArea.d.ts +32 -24
- package/dist/types/src/components/ScrollArea/ScrollArea.d.ts.map +1 -1
- package/dist/types/src/components/ScrollArea/ScrollArea.stories.d.ts +65 -8
- package/dist/types/src/components/ScrollArea/ScrollArea.stories.d.ts.map +1 -1
- package/dist/types/src/components/ScrollContainer/ScrollContainer.d.ts +27 -9
- package/dist/types/src/components/ScrollContainer/ScrollContainer.d.ts.map +1 -1
- package/dist/types/src/components/ScrollContainer/ScrollContainer.stories.d.ts +8 -3
- package/dist/types/src/components/ScrollContainer/ScrollContainer.stories.d.ts.map +1 -1
- package/dist/types/src/components/Select/Select.d.ts +9 -9
- package/dist/types/src/components/Select/Select.d.ts.map +1 -1
- package/dist/types/src/components/Select/Select.stories.d.ts +2 -2
- package/dist/types/src/components/Select/Select.stories.d.ts.map +1 -1
- package/dist/types/src/components/Separator/Separator.d.ts +4 -4
- package/dist/types/src/components/Separator/Separator.d.ts.map +1 -1
- package/dist/types/src/components/Skeleton/Skeleton.d.ts +12 -0
- package/dist/types/src/components/Skeleton/Skeleton.d.ts.map +1 -0
- package/dist/types/src/components/Skeleton/Skeleton.stories.d.ts +17 -0
- package/dist/types/src/components/Skeleton/Skeleton.stories.d.ts.map +1 -0
- package/dist/types/src/components/Skeleton/index.d.ts +2 -0
- package/dist/types/src/components/Skeleton/index.d.ts.map +1 -0
- package/dist/types/src/components/Splitter/Splitter.d.ts +37 -0
- package/dist/types/src/components/Splitter/Splitter.d.ts.map +1 -0
- package/dist/types/src/components/Splitter/Splitter.stories.d.ts +7 -0
- package/dist/types/src/components/Splitter/Splitter.stories.d.ts.map +1 -0
- package/dist/types/src/components/Splitter/index.d.ts +2 -0
- package/dist/types/src/components/Splitter/index.d.ts.map +1 -0
- package/dist/types/src/components/Status/Status.d.ts +3 -4
- package/dist/types/src/components/Status/Status.d.ts.map +1 -1
- package/dist/types/src/components/Status/Status.stories.d.ts +4 -2
- package/dist/types/src/components/Status/Status.stories.d.ts.map +1 -1
- package/dist/types/src/components/Tag/Tag.d.ts +1 -1
- package/dist/types/src/components/Tag/Tag.d.ts.map +1 -1
- package/dist/types/src/components/Tag/Tag.stories.d.ts +0 -5
- package/dist/types/src/components/Tag/Tag.stories.d.ts.map +1 -1
- package/dist/types/src/components/ThemeProvider/ThemeProvider.d.ts +3 -3
- package/dist/types/src/components/ThemeProvider/ThemeProvider.d.ts.map +1 -1
- package/dist/types/src/components/{Menus/DropdownMenu.stories.d.ts → ThemeProvider/ThemeProvider.stories.d.ts} +2 -5
- package/dist/types/src/components/ThemeProvider/ThemeProvider.stories.d.ts.map +1 -0
- package/dist/types/src/components/ThemeProvider/TranslationsProvider.d.ts +1 -8
- package/dist/types/src/components/ThemeProvider/TranslationsProvider.d.ts.map +1 -1
- package/dist/types/src/components/ThemeProvider/index.d.ts +2 -1
- package/dist/types/src/components/ThemeProvider/index.d.ts.map +1 -1
- package/dist/types/src/components/Toast/Toast.d.ts +19 -19
- package/dist/types/src/components/Toast/Toast.d.ts.map +1 -1
- package/dist/types/src/components/Toolbar/Toolbar.d.ts +43 -17
- package/dist/types/src/components/Toolbar/Toolbar.d.ts.map +1 -1
- package/dist/types/src/components/Tooltip/Tooltip.d.ts +9 -9
- package/dist/types/src/components/Tooltip/Tooltip.d.ts.map +1 -1
- package/dist/types/src/components/Tooltip/Tooltip.stories.d.ts +2 -2
- package/dist/types/src/components/Tooltip/Tooltip.stories.d.ts.map +1 -1
- package/dist/types/src/components/index.d.ts +10 -5
- package/dist/types/src/components/index.d.ts.map +1 -1
- package/dist/types/src/exemplars/generics.stories.d.ts +23 -0
- package/dist/types/src/exemplars/generics.stories.d.ts.map +1 -0
- package/dist/types/src/exemplars/slot.stories.d.ts +15 -0
- package/dist/types/src/exemplars/slot.stories.d.ts.map +1 -0
- package/dist/types/src/exemplars/tabster.stories.d.ts +8 -0
- package/dist/types/src/exemplars/tabster.stories.d.ts.map +1 -0
- package/dist/types/src/exemplars/virtualizer.stories.d.ts +11 -0
- package/dist/types/src/exemplars/virtualizer.stories.d.ts.map +1 -0
- package/dist/types/src/hooks/index.d.ts +1 -0
- package/dist/types/src/hooks/index.d.ts.map +1 -1
- package/dist/types/src/hooks/useDensityContext.d.ts +2 -2
- package/dist/types/src/hooks/useDensityContext.d.ts.map +1 -1
- package/dist/types/src/hooks/useElevationContext.d.ts +1 -1
- package/dist/types/src/hooks/useElevationContext.d.ts.map +1 -1
- package/dist/types/src/index.d.ts +2 -1
- package/dist/types/src/index.d.ts.map +1 -1
- package/dist/types/src/playground/Controls.stories.d.ts.map +1 -1
- package/dist/types/src/playground/Custom.stories.d.ts.map +1 -1
- package/dist/types/src/primitives/Column/Column.d.ts +51 -0
- package/dist/types/src/primitives/Column/Column.d.ts.map +1 -0
- package/dist/types/src/primitives/Column/Column.stories.d.ts +25 -0
- package/dist/types/src/primitives/Column/Column.stories.d.ts.map +1 -0
- package/dist/types/src/primitives/Column/index.d.ts +2 -0
- package/dist/types/src/primitives/Column/index.d.ts.map +1 -0
- package/dist/types/src/primitives/Container/Container.d.ts +11 -0
- package/dist/types/src/primitives/Container/Container.d.ts.map +1 -0
- package/dist/types/src/primitives/Container/Container.stories.d.ts +6 -0
- package/dist/types/src/primitives/Container/Container.stories.d.ts.map +1 -0
- package/dist/types/src/primitives/Container/index.d.ts +2 -0
- package/dist/types/src/primitives/Container/index.d.ts.map +1 -0
- package/dist/types/src/primitives/Flex/Flex.d.ts +15 -0
- package/dist/types/src/primitives/Flex/Flex.d.ts.map +1 -0
- package/dist/types/src/primitives/Flex/Flex.stories.d.ts +8 -0
- package/dist/types/src/primitives/Flex/Flex.stories.d.ts.map +1 -0
- package/dist/types/src/primitives/Flex/index.d.ts +2 -0
- package/dist/types/src/primitives/Flex/index.d.ts.map +1 -0
- package/dist/types/src/primitives/Grid/Grid.d.ts +14 -0
- package/dist/types/src/primitives/Grid/Grid.d.ts.map +1 -0
- package/dist/types/src/primitives/Grid/Grid.stories.d.ts +8 -0
- package/dist/types/src/primitives/Grid/Grid.stories.d.ts.map +1 -0
- package/dist/types/src/primitives/Grid/index.d.ts +2 -0
- package/dist/types/src/primitives/Grid/index.d.ts.map +1 -0
- package/dist/types/src/primitives/Panel/Panel.d.ts +46 -0
- package/dist/types/src/primitives/Panel/Panel.d.ts.map +1 -0
- package/dist/types/src/primitives/Panel/Panel.stories.d.ts +6 -0
- package/dist/types/src/primitives/Panel/Panel.stories.d.ts.map +1 -0
- package/dist/types/src/primitives/Panel/index.d.ts +2 -0
- package/dist/types/src/primitives/Panel/index.d.ts.map +1 -0
- package/dist/types/src/primitives/index.d.ts +6 -0
- package/dist/types/src/primitives/index.d.ts.map +1 -0
- package/dist/types/src/testing/Loading.d.ts +9 -0
- package/dist/types/src/testing/Loading.d.ts.map +1 -0
- package/dist/types/src/testing/decorators/withLayout.d.ts +3 -3
- package/dist/types/src/testing/decorators/withLayout.d.ts.map +1 -1
- package/dist/types/src/testing/decorators/withLayoutVariants.d.ts +1 -1
- package/dist/types/src/testing/decorators/withLayoutVariants.d.ts.map +1 -1
- package/dist/types/src/testing/decorators/withTheme.d.ts +3 -2
- package/dist/types/src/testing/decorators/withTheme.d.ts.map +1 -1
- package/dist/types/src/testing/index.d.ts +1 -0
- package/dist/types/src/testing/index.d.ts.map +1 -1
- package/dist/types/src/translations.d.ts +11 -0
- package/dist/types/src/translations.d.ts.map +1 -0
- package/dist/types/src/util/index.d.ts +1 -2
- package/dist/types/src/util/index.d.ts.map +1 -1
- package/dist/types/src/util/usePx.d.ts.map +1 -1
- package/dist/types/tsconfig.tsbuildinfo +1 -1
- package/package.json +40 -31
- package/src/components/Avatars/Avatar.stories.tsx +7 -8
- package/src/components/Avatars/Avatar.tsx +6 -13
- package/src/components/Avatars/AvatarGroup.stories.tsx +2 -2
- package/src/components/Breadcrumb/Breadcrumb.stories.tsx +3 -3
- package/src/components/Breadcrumb/Breadcrumb.tsx +11 -37
- package/src/components/Button/Button.stories.tsx +3 -3
- package/src/components/Button/Button.tsx +12 -26
- package/src/components/Button/IconButton.stories.tsx +4 -4
- package/src/components/Button/IconButton.tsx +9 -5
- package/src/components/Button/Toggle.stories.tsx +2 -2
- package/src/components/Button/Toggle.tsx +4 -4
- package/src/components/Button/ToggleGroup.stories.tsx +2 -2
- package/src/components/Button/ToggleGroup.tsx +12 -16
- package/src/components/Card/Card.stories.tsx +151 -0
- package/src/components/Card/Card.tsx +394 -0
- package/src/components/Card/index.ts +5 -0
- package/src/components/Clipboard/CopyButton.tsx +6 -6
- package/src/components/DensityProvider/DensityProvider.tsx +1 -1
- package/src/components/Dialog/AlertDialog.stories.tsx +16 -16
- package/src/components/Dialog/AlertDialog.tsx +121 -82
- package/src/components/Dialog/Dialog.stories.tsx +139 -28
- package/src/components/Dialog/Dialog.tsx +192 -71
- package/src/components/ElevationProvider/ElevationProvider.tsx +1 -1
- package/src/components/ErrorFallback/ErrorFallback.stories.tsx +50 -0
- package/src/components/ErrorFallback/ErrorFallback.tsx +70 -0
- package/src/components/ErrorFallback/ErrorStack.tsx +80 -0
- package/src/components/ErrorFallback/ThrowError.tsx +37 -0
- package/src/components/ErrorFallback/index.ts +9 -0
- package/src/components/Focus/AUDIT.md +43 -0
- package/src/components/Focus/Focus.stories.tsx +230 -0
- package/src/components/Focus/Focus.tsx +201 -0
- package/src/components/Focus/index.ts +5 -0
- package/src/components/Icon/Icon.stories.tsx +45 -14
- package/src/components/Icon/Icon.tsx +7 -3
- package/src/components/Image/Image.stories.tsx +86 -0
- package/src/components/Image/Image.tsx +223 -0
- package/src/components/Image/index.ts +5 -0
- package/src/components/Input/Input.stories.tsx +21 -40
- package/src/components/Input/Input.tsx +36 -72
- package/src/components/Link/Link.stories.tsx +2 -2
- package/src/components/Link/Link.tsx +2 -2
- package/src/components/List/List.stories.tsx +30 -33
- package/src/components/List/List.tsx +16 -19
- package/src/components/List/ListDropIndicator.tsx +7 -7
- package/src/components/List/Tree.stories.tsx +5 -5
- package/src/components/List/TreeDropIndicator.tsx +6 -6
- package/src/components/List/Treegrid.stories.tsx +3 -3
- package/src/components/List/Treegrid.tsx +10 -15
- package/src/components/Main/Main.stories.tsx +41 -23
- package/src/components/Main/Main.tsx +139 -82
- package/src/components/{Menus → Menu}/ContextMenu.stories.tsx +2 -2
- package/src/components/{Menus → Menu}/ContextMenu.tsx +9 -33
- package/src/components/{Menus → Menu}/DropdownMenu.stories.tsx +2 -2
- package/src/components/{Menus → Menu}/DropdownMenu.tsx +119 -109
- package/src/components/Message/Message.stories.tsx +28 -13
- package/src/components/Message/Message.tsx +43 -34
- package/src/components/Popover/Popover.stories.tsx +4 -4
- package/src/components/Popover/Popover.tsx +97 -92
- package/src/components/ScrollArea/ScrollArea.stories.tsx +222 -32
- package/src/components/ScrollArea/ScrollArea.tsx +97 -79
- package/src/components/ScrollArea/index.ts +1 -1
- package/src/components/ScrollContainer/ScrollContainer.stories.tsx +43 -22
- package/src/components/ScrollContainer/ScrollContainer.tsx +193 -104
- package/src/components/Select/Select.stories.tsx +4 -4
- package/src/components/Select/Select.tsx +11 -27
- package/src/components/Separator/Separator.tsx +5 -8
- package/src/components/Skeleton/Skeleton.stories.tsx +52 -0
- package/src/components/Skeleton/Skeleton.tsx +26 -0
- package/src/components/Skeleton/index.ts +5 -0
- package/src/components/Splitter/Splitter.stories.tsx +83 -0
- package/src/components/Splitter/Splitter.tsx +140 -0
- package/src/components/Splitter/index.ts +5 -0
- package/src/components/Status/Status.stories.tsx +21 -17
- package/src/components/Status/Status.tsx +10 -7
- package/src/components/Tag/Tag.stories.tsx +6 -11
- package/src/components/Tag/Tag.tsx +3 -8
- package/src/components/ThemeProvider/ThemeProvider.stories.tsx +32 -0
- package/src/components/ThemeProvider/ThemeProvider.tsx +10 -9
- package/src/components/ThemeProvider/TranslationsProvider.tsx +1 -16
- package/src/components/ThemeProvider/index.ts +3 -3
- package/src/components/Toast/Toast.stories.tsx +2 -2
- package/src/components/Toast/Toast.tsx +22 -41
- package/src/components/Toolbar/Toolbar.stories.tsx +2 -2
- package/src/components/Toolbar/Toolbar.tsx +183 -22
- package/src/components/Tooltip/Tooltip.stories.tsx +16 -14
- package/src/components/Tooltip/Tooltip.tsx +40 -38
- package/src/components/index.ts +11 -6
- package/src/exemplars/generics.stories.tsx +41 -0
- package/src/exemplars/slot.stories.tsx +117 -0
- package/src/exemplars/tabster.stories.tsx +127 -0
- package/src/exemplars/virtualizer.stories.tsx +137 -0
- package/src/hooks/index.ts +1 -0
- package/src/hooks/useDensityContext.ts +3 -3
- package/src/hooks/useElevationContext.ts +1 -1
- package/src/index.ts +2 -1
- package/src/playground/Controls.stories.tsx +3 -10
- package/src/playground/Custom.stories.tsx +11 -21
- package/src/playground/Typography.stories.tsx +3 -3
- package/src/primitives/Column/AUDIT.md +354 -0
- package/src/primitives/Column/Column.stories.tsx +183 -0
- package/src/primitives/Column/Column.tsx +169 -0
- package/src/primitives/Column/index.ts +5 -0
- package/src/primitives/Container/Container.stories.tsx +30 -0
- package/src/primitives/Container/Container.tsx +19 -0
- package/src/primitives/Container/index.ts +5 -0
- package/src/primitives/Flex/Flex.stories.tsx +58 -0
- package/src/primitives/Flex/Flex.tsx +24 -0
- package/src/primitives/Flex/index.ts +5 -0
- package/src/primitives/Grid/Grid.stories.tsx +57 -0
- package/src/primitives/Grid/Grid.tsx +30 -0
- package/src/primitives/Grid/index.ts +5 -0
- package/src/primitives/Panel/Panel.stories.tsx +67 -0
- package/src/primitives/Panel/Panel.tsx +114 -0
- package/src/primitives/Panel/index.ts +5 -0
- package/src/primitives/index.ts +9 -0
- package/src/testing/Loading.tsx +26 -0
- package/src/testing/decorators/withLayout.tsx +39 -18
- package/src/testing/decorators/withLayoutVariants.tsx +20 -23
- package/src/testing/decorators/withTheme.tsx +26 -20
- package/src/testing/index.ts +2 -0
- package/src/translations.ts +19 -0
- package/src/util/index.ts +2 -2
- package/src/util/usePx.ts +1 -0
- package/dist/lib/browser/chunk-53MI2QCM.mjs +0 -4707
- package/dist/lib/browser/chunk-53MI2QCM.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-ID67AFFF.mjs +0 -4709
- package/dist/lib/node-esm/chunk-ID67AFFF.mjs.map +0 -7
- package/dist/types/src/components/AnchoredOverflow/AnchoredOverflow.d.ts +0 -15
- package/dist/types/src/components/AnchoredOverflow/AnchoredOverflow.d.ts.map +0 -1
- package/dist/types/src/components/AnchoredOverflow/index.d.ts +0 -2
- package/dist/types/src/components/AnchoredOverflow/index.d.ts.map +0 -1
- package/dist/types/src/components/Menus/ContextMenu.d.ts.map +0 -1
- package/dist/types/src/components/Menus/ContextMenu.stories.d.ts.map +0 -1
- package/dist/types/src/components/Menus/DropdownMenu.d.ts +0 -113
- package/dist/types/src/components/Menus/DropdownMenu.d.ts.map +0 -1
- package/dist/types/src/components/Menus/DropdownMenu.stories.d.ts.map +0 -1
- package/dist/types/src/components/Menus/index.d.ts.map +0 -1
- package/dist/types/src/util/ThemedClassName.d.ts +0 -5
- package/dist/types/src/util/ThemedClassName.d.ts.map +0 -1
- package/dist/types/src/util/domino.d.ts +0 -18
- package/dist/types/src/util/domino.d.ts.map +0 -1
- package/src/components/AnchoredOverflow/AnchoredOverflow.tsx +0 -59
- package/src/components/AnchoredOverflow/index.ts +0 -5
- package/src/util/ThemedClassName.ts +0 -7
- package/src/util/domino.ts +0 -53
- /package/dist/types/src/components/{Menus → Menu}/ContextMenu.stories.d.ts +0 -0
- /package/dist/types/src/components/{Menus → Menu}/index.d.ts +0 -0
- /package/src/components/{Menus → Menu}/index.ts +0 -0
|
@@ -2,27 +2,28 @@
|
|
|
2
2
|
// Copyright 2025 DXOS.org
|
|
3
3
|
//
|
|
4
4
|
|
|
5
|
-
import { useState } from '@preact-signals/safe-react/react';
|
|
6
5
|
import { createContext } from '@radix-ui/react-context';
|
|
7
6
|
import React, {
|
|
8
|
-
type HTMLAttributes,
|
|
9
7
|
type PropsWithChildren,
|
|
8
|
+
type RefObject,
|
|
10
9
|
forwardRef,
|
|
11
10
|
useCallback,
|
|
12
11
|
useEffect,
|
|
13
12
|
useImperativeHandle,
|
|
14
13
|
useMemo,
|
|
15
14
|
useRef,
|
|
15
|
+
useState,
|
|
16
16
|
} from 'react';
|
|
17
17
|
|
|
18
|
-
// TODO(burdon): Move these deps to @dxos/dom-util.
|
|
19
18
|
import { addEventListener, combine } from '@dxos/async';
|
|
20
19
|
import { invariant } from '@dxos/invariant';
|
|
21
|
-
import {
|
|
22
|
-
import { mx } from '@dxos/
|
|
20
|
+
import { useMergeRefs } from '@dxos/react-hooks';
|
|
21
|
+
import { composableProps, mx } from '@dxos/ui-theme';
|
|
22
|
+
import { SlottableProps } from '@dxos/ui-types';
|
|
23
23
|
|
|
24
24
|
import { type ThemedClassName } from '../../util';
|
|
25
25
|
import { IconButton } from '../Button';
|
|
26
|
+
import { ScrollArea } from '../ScrollArea';
|
|
26
27
|
|
|
27
28
|
const isBottom = (el: HTMLElement | null) => {
|
|
28
29
|
return !!(el && el.scrollHeight - el.scrollTop === el.clientHeight);
|
|
@@ -35,9 +36,15 @@ export interface ScrollController {
|
|
|
35
36
|
}
|
|
36
37
|
|
|
37
38
|
type ScrollContainerContextValue = {
|
|
38
|
-
scrollToBottom: (behavior?: ScrollBehavior) => void;
|
|
39
39
|
controller?: ScrollController;
|
|
40
40
|
pinned?: boolean;
|
|
41
|
+
overflow?: boolean;
|
|
42
|
+
/** Called by Viewport to register/unregister the scroll element. */
|
|
43
|
+
setViewport: (el: HTMLDivElement | null) => void;
|
|
44
|
+
/** Called by Viewport on wheel events to update pinned state. */
|
|
45
|
+
setPinned: (value: boolean) => void;
|
|
46
|
+
/** Called by Viewport on scroll events to update overflow state. */
|
|
47
|
+
setOverflow: (value: boolean) => void;
|
|
41
48
|
};
|
|
42
49
|
|
|
43
50
|
const [ScrollContainerProvider, useScrollContainerContext] =
|
|
@@ -50,144 +57,224 @@ const [ScrollContainerProvider, useScrollContainerContext] =
|
|
|
50
57
|
type RootProps = ThemedClassName<
|
|
51
58
|
PropsWithChildren<{
|
|
52
59
|
pin?: boolean;
|
|
53
|
-
|
|
60
|
+
behavior?: ScrollBehavior;
|
|
54
61
|
}>
|
|
55
62
|
>;
|
|
56
63
|
|
|
57
64
|
/**
|
|
58
|
-
*
|
|
65
|
+
* Headless scroll container that provides context for scroll state.
|
|
66
|
+
* Render ScrollContainer.Viewport as a child to provide the scrollable area.
|
|
59
67
|
*/
|
|
60
|
-
const Root = forwardRef<ScrollController, RootProps>(
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
scrollToTop: () => {
|
|
92
|
-
invariant(scrollerRef.current);
|
|
93
|
-
scrollerRef.current.scrollTo({ top: 0, behavior: 'smooth' });
|
|
94
|
-
setPinned(false);
|
|
95
|
-
},
|
|
96
|
-
scrollToBottom: () => {
|
|
97
|
-
scrollToBottom('smooth');
|
|
68
|
+
const Root = forwardRef<ScrollController, RootProps>(
|
|
69
|
+
({ children, pin, behavior: behaviorProp = 'smooth' }, forwardedRef) => {
|
|
70
|
+
const scrollerRef = useRef<HTMLDivElement | null>(null);
|
|
71
|
+
const autoScrollRef = useRef(false);
|
|
72
|
+
const [pinned, setPinned] = useState(pin);
|
|
73
|
+
const [overflow, setOverflow] = useState(false);
|
|
74
|
+
|
|
75
|
+
const timeoutRef = useRef<NodeJS.Timeout>(undefined);
|
|
76
|
+
const scrollToBottom = useCallback(
|
|
77
|
+
(behavior: ScrollBehavior = behaviorProp) => {
|
|
78
|
+
if (scrollerRef.current) {
|
|
79
|
+
if (behavior !== 'instant') {
|
|
80
|
+
// Temporarily hide scrollbar to prevent flickering during smooth scroll.
|
|
81
|
+
// For instant scrolling we skip this — there's no animation to hide,
|
|
82
|
+
// and adding the class changes element size which re-fires the ResizeObserver.
|
|
83
|
+
autoScrollRef.current = true;
|
|
84
|
+
scrollerRef.current.classList.add('scrollbar-none');
|
|
85
|
+
clearTimeout(timeoutRef.current);
|
|
86
|
+
timeoutRef.current = setTimeout(() => {
|
|
87
|
+
scrollerRef.current?.classList.remove('scrollbar-none');
|
|
88
|
+
autoScrollRef.current = false;
|
|
89
|
+
}, 500);
|
|
90
|
+
}
|
|
91
|
+
|
|
92
|
+
scrollerRef.current.scrollTo({
|
|
93
|
+
top: scrollerRef.current.scrollHeight,
|
|
94
|
+
behavior,
|
|
95
|
+
});
|
|
96
|
+
|
|
97
|
+
setPinned(true);
|
|
98
|
+
}
|
|
98
99
|
},
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
100
|
+
[behaviorProp],
|
|
101
|
+
);
|
|
102
|
+
|
|
103
|
+
const controller = useMemo<ScrollController>(
|
|
104
|
+
() => ({
|
|
105
|
+
get viewport() {
|
|
106
|
+
return scrollerRef.current;
|
|
107
|
+
},
|
|
108
|
+
scrollToTop: () => {
|
|
109
|
+
invariant(scrollerRef.current);
|
|
110
|
+
scrollerRef.current.scrollTo({ top: 0, behavior: 'smooth' });
|
|
111
|
+
setPinned(false);
|
|
112
|
+
},
|
|
113
|
+
scrollToBottom: (behavior = 'smooth' as ScrollBehavior) => {
|
|
114
|
+
scrollToBottom(behavior);
|
|
115
|
+
},
|
|
116
|
+
}),
|
|
117
|
+
[scrollToBottom],
|
|
118
|
+
);
|
|
119
|
+
|
|
120
|
+
// Scroll controller imperative ref.
|
|
121
|
+
useImperativeHandle(forwardedRef, () => controller, [controller]);
|
|
122
|
+
|
|
123
|
+
// Called by Viewport when the scroll element mounts/unmounts.
|
|
124
|
+
const setViewport = useCallback((el: HTMLDivElement | null) => {
|
|
125
|
+
scrollerRef.current = el;
|
|
126
|
+
}, []);
|
|
127
|
+
|
|
128
|
+
return (
|
|
129
|
+
<ScrollContainerProvider
|
|
130
|
+
pinned={pinned}
|
|
131
|
+
overflow={overflow}
|
|
132
|
+
controller={controller}
|
|
133
|
+
setViewport={setViewport}
|
|
134
|
+
setPinned={setPinned}
|
|
135
|
+
setOverflow={setOverflow}
|
|
136
|
+
>
|
|
137
|
+
<ScrollArea.Root thin centered padding className='relative'>
|
|
138
|
+
{children}
|
|
139
|
+
</ScrollArea.Root>
|
|
140
|
+
</ScrollContainerProvider>
|
|
141
|
+
);
|
|
142
|
+
},
|
|
143
|
+
);
|
|
144
|
+
|
|
145
|
+
Root.displayName = 'ScrollContainer.Root';
|
|
146
|
+
|
|
147
|
+
//
|
|
148
|
+
// Viewport
|
|
149
|
+
//
|
|
102
150
|
|
|
103
|
-
|
|
104
|
-
useImperativeHandle(forwardedRef, () => controller, [controller]);
|
|
151
|
+
const VIEWPORT_NAME = 'ScrollContainer.Viewport';
|
|
105
152
|
|
|
106
|
-
|
|
153
|
+
type ViewportProps = SlottableProps;
|
|
154
|
+
|
|
155
|
+
const Viewport = forwardRef<HTMLDivElement, ViewportProps>(({ children, ...props }, forwardedRef) => {
|
|
156
|
+
const scrollerRef = useRef<HTMLDivElement>(null);
|
|
157
|
+
const mergedRef = useMergeRefs([forwardedRef, scrollerRef]);
|
|
158
|
+
const { setViewport, setPinned, setOverflow } = useScrollContainerContext(VIEWPORT_NAME);
|
|
159
|
+
|
|
160
|
+
// Register the scroll element with Root and set up wheel/scroll listeners.
|
|
107
161
|
useEffect(() => {
|
|
108
|
-
|
|
162
|
+
const el = scrollerRef.current;
|
|
163
|
+
if (!el) {
|
|
109
164
|
return;
|
|
110
165
|
}
|
|
111
166
|
|
|
167
|
+
setViewport(el);
|
|
168
|
+
|
|
112
169
|
return combine(
|
|
113
|
-
|
|
114
|
-
addEventListener(
|
|
115
|
-
|
|
116
|
-
}),
|
|
117
|
-
// Check if scrolls.
|
|
118
|
-
addEventListener(scrollerRef.current, 'scroll', () => {
|
|
119
|
-
setOverflow((scrollerRef.current?.scrollTop ?? 0) > 0);
|
|
120
|
-
}),
|
|
170
|
+
addEventListener(el, 'wheel', () => setPinned(isBottom(el))),
|
|
171
|
+
addEventListener(el, 'scroll', () => setOverflow((el.scrollTop ?? 0) > 0)),
|
|
172
|
+
() => setViewport(null),
|
|
121
173
|
);
|
|
122
|
-
}, []);
|
|
174
|
+
}, [setViewport, setPinned, setOverflow]);
|
|
123
175
|
|
|
124
176
|
return (
|
|
125
|
-
|
|
126
|
-
<
|
|
127
|
-
{
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
className={mx(
|
|
132
|
-
// NOTE: Gradients may not be visible with dark reader extensions.
|
|
133
|
-
'z-10 absolute block-start-0 inset-inline-0 bs-24 is-full',
|
|
134
|
-
'opacity-0 duration-200 transition-opacity data-[visible="true"]:opacity-100',
|
|
135
|
-
'bg-gradient-to-b from-[--surface-bg] to-transparent pointer-events-none',
|
|
136
|
-
)}
|
|
137
|
-
/>
|
|
138
|
-
)}
|
|
139
|
-
<div className={mx('flex flex-col min-bs-0 overflow-y-auto scrollbar-thin', classNames)} ref={scrollerRef}>
|
|
140
|
-
{children}
|
|
141
|
-
</div>
|
|
142
|
-
</div>
|
|
143
|
-
</ScrollContainerProvider>
|
|
177
|
+
<>
|
|
178
|
+
<ScrollArea.Viewport {...composableProps(props)} ref={mergedRef}>
|
|
179
|
+
{children}
|
|
180
|
+
</ScrollArea.Viewport>
|
|
181
|
+
<PinEffect scrollerRef={scrollerRef} />
|
|
182
|
+
</>
|
|
144
183
|
);
|
|
145
184
|
});
|
|
146
185
|
|
|
147
|
-
|
|
186
|
+
Viewport.displayName = VIEWPORT_NAME;
|
|
148
187
|
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
|
|
188
|
+
/**
|
|
189
|
+
* Isolated component that consumes pinned/controller from context.
|
|
190
|
+
* Kept separate so that Viewport does not re-render when pinned changes.
|
|
191
|
+
*/
|
|
192
|
+
const PIN_EFFECT_NAME = 'ScrollContainer.PinEffect';
|
|
154
193
|
|
|
155
|
-
const
|
|
156
|
-
const
|
|
157
|
-
const { pinned, scrollToBottom } = useScrollContainerContext(Viewport.displayName!);
|
|
194
|
+
const PinEffect = ({ scrollerRef }: { scrollerRef: RefObject<HTMLDivElement | null> }) => {
|
|
195
|
+
const { pinned, controller } = useScrollContainerContext(PIN_EFFECT_NAME);
|
|
158
196
|
|
|
197
|
+
// Pin scroll to bottom when content changes.
|
|
159
198
|
useEffect(() => {
|
|
160
|
-
|
|
199
|
+
const viewport = scrollerRef.current;
|
|
200
|
+
if (!pinned || !viewport) {
|
|
161
201
|
return;
|
|
162
202
|
}
|
|
163
203
|
|
|
164
|
-
//
|
|
165
|
-
|
|
166
|
-
|
|
204
|
+
// Scroll instantly so we don't visually jump while content is being added.
|
|
205
|
+
controller?.scrollToBottom('instant');
|
|
206
|
+
|
|
207
|
+
// Setup resize observer on content children to detect size changes (e.g. streaming).
|
|
208
|
+
// We observe children rather than the viewport itself, because the viewport's size
|
|
209
|
+
// stays fixed — only its content grows.
|
|
210
|
+
// Use instant scroll in the callback — smooth scrolling adds/removes the
|
|
211
|
+
// scrollbar-none class, which changes the element size and re-fires the
|
|
212
|
+
// observer, creating an infinite loop.
|
|
213
|
+
const resizeObserver = new ResizeObserver(() => controller?.scrollToBottom('smooth'));
|
|
214
|
+
Array.from(viewport.children).forEach((child) => {
|
|
215
|
+
resizeObserver.observe(child);
|
|
216
|
+
});
|
|
217
|
+
|
|
218
|
+
// Watch for added/removed children.
|
|
219
|
+
const mutationObserver = new MutationObserver((mutations) => {
|
|
220
|
+
mutations.forEach((mutation) => {
|
|
221
|
+
mutation.addedNodes.forEach((node) => {
|
|
222
|
+
if (node instanceof Element) {
|
|
223
|
+
resizeObserver.observe(node);
|
|
224
|
+
}
|
|
225
|
+
});
|
|
226
|
+
});
|
|
227
|
+
|
|
228
|
+
controller?.scrollToBottom('smooth');
|
|
229
|
+
});
|
|
230
|
+
mutationObserver.observe(viewport, { childList: true });
|
|
167
231
|
|
|
168
|
-
resizeObserver.observe(contentRef.current);
|
|
169
232
|
return () => {
|
|
170
233
|
resizeObserver.disconnect();
|
|
234
|
+
mutationObserver.disconnect();
|
|
171
235
|
};
|
|
172
|
-
}, [pinned,
|
|
236
|
+
}, [pinned, controller, scrollerRef]);
|
|
237
|
+
|
|
238
|
+
return null;
|
|
239
|
+
};
|
|
240
|
+
|
|
241
|
+
//
|
|
242
|
+
// Fade
|
|
243
|
+
//
|
|
244
|
+
|
|
245
|
+
const FADE_NAME = 'ScrollContainer.Fade';
|
|
246
|
+
|
|
247
|
+
type FadeProps = {};
|
|
248
|
+
|
|
249
|
+
const Fade = () => {
|
|
250
|
+
const { overflow } = useScrollContainerContext(FADE_NAME);
|
|
173
251
|
|
|
174
252
|
return (
|
|
175
|
-
<div
|
|
176
|
-
|
|
177
|
-
|
|
253
|
+
<div
|
|
254
|
+
role='none'
|
|
255
|
+
data-visible={overflow}
|
|
256
|
+
className={mx(
|
|
257
|
+
// NOTE: Gradients may not be visible with dark reader extensions.
|
|
258
|
+
'z-10 absolute top-0 inset-x-0 h-24 w-full',
|
|
259
|
+
'opacity-0 duration-200 transition-opacity data-[visible="true"]:opacity-100',
|
|
260
|
+
'bg-gradient-to-b from-(--surface-bg) to-transparent pointer-events-none',
|
|
261
|
+
)}
|
|
262
|
+
/>
|
|
178
263
|
);
|
|
179
|
-
}
|
|
264
|
+
};
|
|
180
265
|
|
|
181
|
-
|
|
266
|
+
Fade.displayName = FADE_NAME;
|
|
182
267
|
|
|
183
268
|
//
|
|
184
269
|
// ScrollDownButton
|
|
185
270
|
//
|
|
186
271
|
|
|
272
|
+
const SCROLL_DOWN_BUTTON_NAME = 'ScrollContainer.ScrollDownButton';
|
|
273
|
+
|
|
187
274
|
type ScrollDownButtonProps = ThemedClassName;
|
|
188
275
|
|
|
189
276
|
const ScrollDownButton = ({ classNames }: ScrollDownButtonProps) => {
|
|
190
|
-
const { pinned,
|
|
277
|
+
const { pinned, controller } = useScrollContainerContext(SCROLL_DOWN_BUTTON_NAME);
|
|
191
278
|
|
|
192
279
|
return (
|
|
193
280
|
<div
|
|
@@ -204,13 +291,13 @@ const ScrollDownButton = ({ classNames }: ScrollDownButtonProps) => {
|
|
|
204
291
|
iconOnly
|
|
205
292
|
size={4}
|
|
206
293
|
label='Scroll down'
|
|
207
|
-
onClick={() => scrollToBottom()}
|
|
294
|
+
onClick={() => controller?.scrollToBottom()}
|
|
208
295
|
/>
|
|
209
296
|
</div>
|
|
210
297
|
);
|
|
211
298
|
};
|
|
212
299
|
|
|
213
|
-
ScrollDownButton.displayName =
|
|
300
|
+
ScrollDownButton.displayName = SCROLL_DOWN_BUTTON_NAME;
|
|
214
301
|
|
|
215
302
|
//
|
|
216
303
|
// ScrollContainer
|
|
@@ -221,11 +308,13 @@ export { useScrollContainerContext };
|
|
|
221
308
|
export const ScrollContainer = {
|
|
222
309
|
Root,
|
|
223
310
|
Viewport,
|
|
311
|
+
Fade,
|
|
224
312
|
ScrollDownButton,
|
|
225
313
|
};
|
|
226
314
|
|
|
227
315
|
export type {
|
|
228
316
|
RootProps as ScrollContainerRootProps,
|
|
229
317
|
ViewportProps as ScrollContainerViewportProps,
|
|
318
|
+
FadeProps as ScrollContainerFadeProps,
|
|
230
319
|
ScrollDownButtonProps as ScrollContainerScrollDownButtonProps,
|
|
231
320
|
};
|
|
@@ -16,9 +16,9 @@ faker.seed(1234);
|
|
|
16
16
|
|
|
17
17
|
type ItemProps = { id: string; text: string };
|
|
18
18
|
|
|
19
|
-
type
|
|
19
|
+
type DefaultStoryProps = { items: ItemProps[] };
|
|
20
20
|
|
|
21
|
-
const DefaultStory = ({ items = [] }:
|
|
21
|
+
const DefaultStory = ({ items = [] }: DefaultStoryProps) => {
|
|
22
22
|
const [value, setValue] = useState<string>();
|
|
23
23
|
return (
|
|
24
24
|
<Select.Root value={value} onValueChange={setValue}>
|
|
@@ -42,9 +42,9 @@ const DefaultStory = ({ items = [] }: StoryProps) => {
|
|
|
42
42
|
};
|
|
43
43
|
|
|
44
44
|
const meta = {
|
|
45
|
-
title: 'ui/react-ui-core/Select',
|
|
45
|
+
title: 'ui/react-ui-core/components/Select',
|
|
46
46
|
render: DefaultStory,
|
|
47
|
-
decorators: [withTheme, withLayoutVariants()],
|
|
47
|
+
decorators: [withTheme(), withLayoutVariants()],
|
|
48
48
|
} satisfies Meta<typeof DefaultStory>;
|
|
49
49
|
|
|
50
50
|
export default meta;
|
|
@@ -39,7 +39,7 @@ const SelectTriggerButton = forwardRef<HTMLButtonElement, SelectTriggerButtonPro
|
|
|
39
39
|
<SelectPrimitive.Trigger asChild ref={forwardedRef}>
|
|
40
40
|
<Button {...props}>
|
|
41
41
|
<SelectPrimitive.Value placeholder={placeholder}>{children}</SelectPrimitive.Value>
|
|
42
|
-
<span className='
|
|
42
|
+
<span className='w-1 flex-1' />
|
|
43
43
|
<SelectPrimitive.Icon asChild>
|
|
44
44
|
<Icon size={3} icon='ph--caret-down--bold' />
|
|
45
45
|
</SelectPrimitive.Icon>
|
|
@@ -61,7 +61,7 @@ const SelectContent = forwardRef<HTMLDivElement, SelectContentProps>(
|
|
|
61
61
|
{...props}
|
|
62
62
|
data-arrow-keys='up down'
|
|
63
63
|
collisionPadding={safeCollisionPadding}
|
|
64
|
-
className={tx('select.content',
|
|
64
|
+
className={tx('select.content', { elevation }, classNames)}
|
|
65
65
|
position='popper'
|
|
66
66
|
ref={forwardedRef}
|
|
67
67
|
>
|
|
@@ -79,7 +79,7 @@ const SelectScrollUpButton = forwardRef<HTMLDivElement, SelectScrollUpButtonProp
|
|
|
79
79
|
return (
|
|
80
80
|
<SelectPrimitive.SelectScrollUpButton
|
|
81
81
|
{...props}
|
|
82
|
-
className={tx('select.scrollButton',
|
|
82
|
+
className={tx('select.scrollButton', {}, classNames)}
|
|
83
83
|
ref={forwardedRef}
|
|
84
84
|
>
|
|
85
85
|
{children ?? <Icon size={3} icon='ph--caret-up--bold' />}
|
|
@@ -96,7 +96,7 @@ const SelectScrollDownButton = forwardRef<HTMLDivElement, SelectScrollDownButton
|
|
|
96
96
|
return (
|
|
97
97
|
<SelectPrimitive.SelectScrollDownButton
|
|
98
98
|
{...props}
|
|
99
|
-
className={tx('select.scrollButton',
|
|
99
|
+
className={tx('select.scrollButton', {}, classNames)}
|
|
100
100
|
ref={forwardedRef}
|
|
101
101
|
>
|
|
102
102
|
{children ?? <Icon size={3} icon='ph--caret-down--bold' />}
|
|
@@ -111,11 +111,7 @@ const SelectViewport = forwardRef<HTMLDivElement, SelectViewportProps>(
|
|
|
111
111
|
({ classNames, children, ...props }, forwardedRef) => {
|
|
112
112
|
const { tx } = useThemeContext();
|
|
113
113
|
return (
|
|
114
|
-
<SelectPrimitive.SelectViewport
|
|
115
|
-
{...props}
|
|
116
|
-
className={tx('select.viewport', 'select__viewport', {}, classNames)}
|
|
117
|
-
ref={forwardedRef}
|
|
118
|
-
>
|
|
114
|
+
<SelectPrimitive.SelectViewport {...props} className={tx('select.viewport', {}, classNames)} ref={forwardedRef}>
|
|
119
115
|
{children}
|
|
120
116
|
</SelectPrimitive.SelectViewport>
|
|
121
117
|
);
|
|
@@ -126,7 +122,7 @@ type SelectItemProps = ThemedClassName<SelectPrimitive.SelectItemProps>;
|
|
|
126
122
|
|
|
127
123
|
const SelectItem = forwardRef<HTMLDivElement, SelectItemProps>(({ classNames, ...props }, forwardedRef) => {
|
|
128
124
|
const { tx } = useThemeContext();
|
|
129
|
-
return <SelectPrimitive.Item {...props} className={tx('select.item',
|
|
125
|
+
return <SelectPrimitive.Item {...props} className={tx('select.item', {}, classNames)} ref={forwardedRef} />;
|
|
130
126
|
});
|
|
131
127
|
|
|
132
128
|
type SelectItemTextProps = SelectPrimitive.SelectItemTextProps;
|
|
@@ -141,7 +137,7 @@ const SelectItemIndicator = forwardRef<HTMLDivElement, SelectItemIndicatorProps>
|
|
|
141
137
|
return (
|
|
142
138
|
<SelectPrimitive.ItemIndicator
|
|
143
139
|
{...props}
|
|
144
|
-
className={tx('select.itemIndicator',
|
|
140
|
+
className={tx('select.itemIndicator', {}, classNames)}
|
|
145
141
|
ref={forwardedRef}
|
|
146
142
|
>
|
|
147
143
|
{children}
|
|
@@ -156,9 +152,9 @@ type SelectOptionProps = SelectItemProps;
|
|
|
156
152
|
const SelectOption = forwardRef<HTMLDivElement, SelectItemProps>(({ children, classNames, ...props }, forwardedRef) => {
|
|
157
153
|
const { tx } = useThemeContext();
|
|
158
154
|
return (
|
|
159
|
-
<SelectPrimitive.Item {...props} className={tx('select.item',
|
|
155
|
+
<SelectPrimitive.Item {...props} className={tx('select.item', {}, classNames)} ref={forwardedRef}>
|
|
160
156
|
<SelectPrimitive.ItemText>{children}</SelectPrimitive.ItemText>
|
|
161
|
-
<span className='grow
|
|
157
|
+
<span className='grow w-1' />
|
|
162
158
|
{/* <SelectPrimitive.ItemIndicator className={tx('select.itemIndicator', 'option__indicator', {})}> */}
|
|
163
159
|
<Icon icon='ph--check--regular' />
|
|
164
160
|
{/* </SelectPrimitive.ItemIndicator> */}
|
|
@@ -178,26 +174,14 @@ type SelectSeparatorProps = ThemedClassName<SelectPrimitive.SelectSeparatorProps
|
|
|
178
174
|
|
|
179
175
|
const SelectSeparator = forwardRef<HTMLDivElement, SelectSeparatorProps>(({ classNames, ...props }, forwardedRef) => {
|
|
180
176
|
const { tx } = useThemeContext();
|
|
181
|
-
return (
|
|
182
|
-
<SelectPrimitive.Separator
|
|
183
|
-
{...props}
|
|
184
|
-
className={tx('select.separator', 'select__separator', {}, classNames)}
|
|
185
|
-
ref={forwardedRef}
|
|
186
|
-
/>
|
|
187
|
-
);
|
|
177
|
+
return <SelectPrimitive.Separator {...props} className={tx('select.separator', {}, classNames)} ref={forwardedRef} />;
|
|
188
178
|
});
|
|
189
179
|
|
|
190
180
|
type SelectArrowProps = ThemedClassName<SelectPrimitive.SelectArrowProps>;
|
|
191
181
|
|
|
192
182
|
const SelectArrow = forwardRef<SVGSVGElement, SelectArrowProps>(({ classNames, ...props }, forwardedRef) => {
|
|
193
183
|
const { tx } = useThemeContext();
|
|
194
|
-
return (
|
|
195
|
-
<SelectPrimitive.Arrow
|
|
196
|
-
{...props}
|
|
197
|
-
className={tx('select.arrow', 'select__arrow', {}, classNames)}
|
|
198
|
-
ref={forwardedRef}
|
|
199
|
-
/>
|
|
200
|
-
);
|
|
184
|
+
return <SelectPrimitive.Arrow {...props} className={tx('select.arrow', {}, classNames)} ref={forwardedRef} />;
|
|
201
185
|
});
|
|
202
186
|
|
|
203
187
|
export const Select = {
|
|
@@ -1,25 +1,22 @@
|
|
|
1
1
|
//
|
|
2
2
|
// Copyright 2023 DXOS.org
|
|
3
3
|
//
|
|
4
|
-
import
|
|
5
|
-
Separator as SeparatorPrimitive,
|
|
6
|
-
type SeparatorProps as SeparatorPrimitiveProps,
|
|
7
|
-
} from '@radix-ui/react-separator';
|
|
4
|
+
import * as SeparatorPrimitive from '@radix-ui/react-separator';
|
|
8
5
|
import React, { forwardRef } from 'react';
|
|
9
6
|
|
|
10
7
|
import { useThemeContext } from '../../hooks';
|
|
11
8
|
import { type ThemedClassName } from '../../util';
|
|
12
9
|
|
|
13
|
-
type SeparatorProps = ThemedClassName<
|
|
10
|
+
type SeparatorProps = ThemedClassName<SeparatorPrimitive.SeparatorProps> & { subdued?: boolean };
|
|
14
11
|
|
|
15
12
|
const Separator = forwardRef<HTMLDivElement, SeparatorProps>(
|
|
16
13
|
({ classNames, orientation = 'horizontal', subdued, ...props }, forwardedRef) => {
|
|
17
14
|
const { tx } = useThemeContext();
|
|
18
15
|
return (
|
|
19
|
-
<SeparatorPrimitive
|
|
20
|
-
orientation={orientation}
|
|
16
|
+
<SeparatorPrimitive.Root
|
|
21
17
|
{...props}
|
|
22
|
-
|
|
18
|
+
orientation={orientation}
|
|
19
|
+
className={tx('separator.root', { orientation, subdued }, classNames)}
|
|
23
20
|
ref={forwardedRef}
|
|
24
21
|
/>
|
|
25
22
|
);
|
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
//
|
|
2
|
+
// Copyright 2024 DXOS.org
|
|
3
|
+
//
|
|
4
|
+
|
|
5
|
+
import React from 'react';
|
|
6
|
+
|
|
7
|
+
import { withTheme } from '../../testing';
|
|
8
|
+
|
|
9
|
+
import { Skeleton } from './Skeleton';
|
|
10
|
+
|
|
11
|
+
export default {
|
|
12
|
+
title: 'ui/react-ui-core/components/Skeleton',
|
|
13
|
+
component: Skeleton,
|
|
14
|
+
decorators: [withTheme()],
|
|
15
|
+
parameters: {
|
|
16
|
+
layout: 'centered',
|
|
17
|
+
},
|
|
18
|
+
};
|
|
19
|
+
|
|
20
|
+
export const Default = {
|
|
21
|
+
render: () => (
|
|
22
|
+
<div className='flex flex-col gap-4 p-4 border border-separator rounded-xs'>
|
|
23
|
+
<div className='flex w-fit items-center gap-4'>
|
|
24
|
+
<Skeleton classNames='size-10 shrink-0 rounded-full' />
|
|
25
|
+
<div className='grid gap-2'>
|
|
26
|
+
<Skeleton classNames='h-4 w-[150px]' />
|
|
27
|
+
<Skeleton classNames='h-4 w-[100px]' />
|
|
28
|
+
</div>
|
|
29
|
+
</div>
|
|
30
|
+
</div>
|
|
31
|
+
),
|
|
32
|
+
};
|
|
33
|
+
|
|
34
|
+
export const Card = {
|
|
35
|
+
render: () => (
|
|
36
|
+
<div className='flex flex-col gap-3 w-96 p-4 border border-separator rounded-xs'>
|
|
37
|
+
<div className='flex items-center gap-3'>
|
|
38
|
+
<Skeleton variant='circle' classNames='h-12 w-12 rounded-full' />
|
|
39
|
+
<div className='flex flex-col gap-2 flex-1'>
|
|
40
|
+
<Skeleton classNames='h-4 w-24' />
|
|
41
|
+
<Skeleton classNames='h-3 w-32' />
|
|
42
|
+
</div>
|
|
43
|
+
</div>
|
|
44
|
+
<Skeleton classNames='h-32 w-full rounded-sm' />
|
|
45
|
+
<div className='flex flex-col gap-2'>
|
|
46
|
+
<Skeleton classNames='h-3 w-full' />
|
|
47
|
+
<Skeleton classNames='h-3 w-5/6' />
|
|
48
|
+
<Skeleton classNames='h-3 w-4/6' />
|
|
49
|
+
</div>
|
|
50
|
+
</div>
|
|
51
|
+
),
|
|
52
|
+
};
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
//
|
|
2
|
+
// Copyright 2024 DXOS.org
|
|
3
|
+
//
|
|
4
|
+
|
|
5
|
+
import React, { type ComponentPropsWithRef, forwardRef } from 'react';
|
|
6
|
+
|
|
7
|
+
import { useThemeContext } from '../../hooks';
|
|
8
|
+
import { type ThemedClassName } from '../../util';
|
|
9
|
+
|
|
10
|
+
type SkeletonProps = ThemedClassName<ComponentPropsWithRef<'div'>> & {
|
|
11
|
+
variant?: 'default' | 'circle' | 'text';
|
|
12
|
+
};
|
|
13
|
+
|
|
14
|
+
/**
|
|
15
|
+
* A skeleton loading component that displays a placeholder while content is loading.
|
|
16
|
+
*/
|
|
17
|
+
const Skeleton = forwardRef<HTMLDivElement, SkeletonProps>(
|
|
18
|
+
({ classNames, variant = 'default', ...props }, forwardedRef) => {
|
|
19
|
+
const { tx } = useThemeContext();
|
|
20
|
+
return <div {...props} className={tx('skeleton.root', { variant }, classNames)} ref={forwardedRef} />;
|
|
21
|
+
},
|
|
22
|
+
);
|
|
23
|
+
|
|
24
|
+
export { Skeleton };
|
|
25
|
+
|
|
26
|
+
export type { SkeletonProps };
|