@dxos/react-ui 0.8.4-main.937b3ca → 0.8.4-main.9be5663bfe
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-CEKVHJ27.mjs → chunk-OCVRIJCH.mjs} +184 -110
- package/dist/lib/browser/chunk-OCVRIJCH.mjs.map +7 -0
- package/dist/lib/browser/index.mjs +3033 -1990
- package/dist/lib/browser/index.mjs.map +4 -4
- package/dist/lib/browser/meta.json +1 -1
- package/dist/lib/browser/testing/index.mjs +73 -37
- package/dist/lib/browser/testing/index.mjs.map +4 -4
- package/dist/lib/node-esm/{chunk-2NHEX4AD.mjs → chunk-QUD5P3RU.mjs} +184 -110
- package/dist/lib/node-esm/chunk-QUD5P3RU.mjs.map +7 -0
- package/dist/lib/node-esm/index.mjs +3033 -1990
- 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 +73 -37
- package/dist/lib/node-esm/testing/index.mjs.map +4 -4
- package/dist/types/src/components/Avatars/Avatar.d.ts +1 -1
- 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/Avatars/AvatarGroup.stories.d.ts.map +1 -1
- package/dist/types/src/components/Breadcrumb/Breadcrumb.d.ts.map +1 -1
- package/dist/types/src/components/Breadcrumb/Breadcrumb.stories.d.ts.map +1 -1
- package/dist/types/src/components/Button/Button.d.ts +2 -2
- package/dist/types/src/components/Button/Button.d.ts.map +1 -1
- package/dist/types/src/components/Button/Button.stories.d.ts.map +1 -1
- package/dist/types/src/components/Button/IconButton.d.ts.map +1 -1
- package/dist/types/src/components/Button/IconButton.stories.d.ts +3 -0
- package/dist/types/src/components/Button/IconButton.stories.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/Toggle.stories.d.ts.map +1 -1
- package/dist/types/src/components/Button/ToggleGroup.d.ts +6 -6
- package/dist/types/src/components/Button/ToggleGroup.d.ts.map +1 -1
- package/dist/types/src/components/Button/ToggleGroup.stories.d.ts.map +1 -1
- package/dist/types/src/components/Card/Card.d.ts +118 -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/CopyButton.d.ts.map +1 -1
- 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/Dialog/AlertDialog.d.ts +37 -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 +44 -22
- package/dist/types/src/components/Dialog/Dialog.d.ts.map +1 -1
- package/dist/types/src/components/Dialog/Dialog.stories.d.ts +6 -8
- package/dist/types/src/components/Dialog/Dialog.stories.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 +19 -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 +36 -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 +3 -0
- 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 +4 -7
- package/dist/types/src/components/Input/Input.d.ts.map +1 -1
- package/dist/types/src/components/Input/Input.stories.d.ts +7 -7
- package/dist/types/src/components/Input/Input.stories.d.ts.map +1 -1
- package/dist/types/src/components/Link/Link.stories.d.ts.map +1 -1
- package/dist/types/src/components/List/List.d.ts +5 -3
- package/dist/types/src/components/List/List.d.ts.map +1 -1
- package/dist/types/src/components/List/List.stories.d.ts +3 -1
- package/dist/types/src/components/List/List.stories.d.ts.map +1 -1
- package/dist/types/src/components/List/Tree.d.ts.map +1 -1
- package/dist/types/src/components/List/Tree.stories.d.ts.map +1 -1
- package/dist/types/src/components/List/Treegrid.d.ts +5 -9
- package/dist/types/src/components/List/Treegrid.d.ts.map +1 -1
- package/dist/types/src/components/List/Treegrid.stories.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/Menu/ContextMenu.d.ts.map +1 -1
- package/dist/types/src/components/Menu/ContextMenu.stories.d.ts.map +1 -1
- package/dist/types/src/components/Menu/DropdownMenu.d.ts +51 -50
- package/dist/types/src/components/Menu/DropdownMenu.d.ts.map +1 -1
- package/dist/types/src/components/Menu/DropdownMenu.stories.d.ts +14 -1
- package/dist/types/src/components/Menu/DropdownMenu.stories.d.ts.map +1 -1
- package/dist/types/src/components/Message/Message.d.ts.map +1 -1
- package/dist/types/src/components/Message/Message.stories.d.ts +4 -5
- package/dist/types/src/components/Message/Message.stories.d.ts.map +1 -1
- package/dist/types/src/components/Popover/Popover.d.ts +32 -23
- package/dist/types/src/components/Popover/Popover.d.ts.map +1 -1
- package/dist/types/src/components/Popover/Popover.stories.d.ts.map +1 -1
- package/dist/types/src/components/ScrollArea/ScrollArea.d.ts +26 -28
- package/dist/types/src/components/ScrollArea/ScrollArea.d.ts.map +1 -1
- package/dist/types/src/components/ScrollArea/ScrollArea.stories.d.ts +54 -9
- package/dist/types/src/components/ScrollArea/ScrollArea.stories.d.ts.map +1 -1
- package/dist/types/src/components/ScrollContainer/ScrollContainer.d.ts +34 -13
- package/dist/types/src/components/ScrollContainer/ScrollContainer.d.ts.map +1 -1
- package/dist/types/src/components/ScrollContainer/ScrollContainer.stories.d.ts +9 -5
- package/dist/types/src/components/ScrollContainer/ScrollContainer.stories.d.ts.map +1 -1
- 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 +3 -3
- 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 +34 -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.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 +2 -1
- package/dist/types/src/components/ThemeProvider/ThemeProvider.d.ts.map +1 -1
- package/dist/types/src/components/ThemeProvider/ThemeProvider.stories.d.ts +12 -0
- package/dist/types/src/components/ThemeProvider/ThemeProvider.stories.d.ts.map +1 -0
- package/dist/types/src/components/Toast/Toast.d.ts +15 -15
- package/dist/types/src/components/Toast/Toast.d.ts.map +1 -1
- package/dist/types/src/components/Toast/Toast.stories.d.ts.map +1 -1
- package/dist/types/src/components/Toolbar/Toolbar.d.ts +30 -12
- package/dist/types/src/components/Toolbar/Toolbar.d.ts.map +1 -1
- package/dist/types/src/components/Toolbar/Toolbar.stories.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 +9 -4
- package/dist/types/src/components/index.d.ts.map +1 -1
- package/dist/types/src/exemplars/generics.stories.d.ts +19 -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 +1 -1
- package/dist/types/src/hooks/useDensityContext.d.ts.map +1 -1
- package/dist/types/src/index.d.ts +1 -0
- 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 +35 -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 +7 -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 +11 -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 +10 -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 +35 -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 +1 -1
- package/dist/types/src/testing/decorators/withLayout.d.ts.map +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/usePx.d.ts.map +1 -1
- package/dist/types/tsconfig.tsbuildinfo +1 -1
- package/package.json +27 -22
- package/src/components/Avatars/Avatar.stories.tsx +7 -9
- package/src/components/Avatars/Avatar.tsx +6 -14
- package/src/components/Avatars/AvatarGroup.stories.tsx +2 -3
- package/src/components/Breadcrumb/Breadcrumb.stories.tsx +3 -4
- package/src/components/Breadcrumb/Breadcrumb.tsx +11 -37
- package/src/components/Button/Button.stories.tsx +3 -4
- package/src/components/Button/Button.tsx +11 -25
- package/src/components/Button/IconButton.stories.tsx +8 -6
- package/src/components/Button/IconButton.tsx +2 -4
- package/src/components/Button/Toggle.stories.tsx +2 -3
- package/src/components/Button/Toggle.tsx +4 -4
- package/src/components/Button/ToggleGroup.stories.tsx +2 -3
- package/src/components/Button/ToggleGroup.tsx +12 -16
- package/src/components/Card/Card.stories.tsx +151 -0
- package/src/components/Card/Card.tsx +492 -0
- package/src/components/Card/index.ts +5 -0
- package/src/components/Clipboard/CopyButton.tsx +4 -5
- package/src/components/Dialog/AlertDialog.stories.tsx +16 -17
- package/src/components/Dialog/AlertDialog.tsx +123 -82
- package/src/components/Dialog/Dialog.stories.tsx +100 -20
- package/src/components/Dialog/Dialog.tsx +113 -87
- package/src/components/ErrorFallback/ErrorFallback.stories.tsx +45 -0
- package/src/components/ErrorFallback/ErrorFallback.tsx +70 -0
- package/src/components/ErrorFallback/ErrorStack.tsx +114 -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 -15
- package/src/components/Icon/Icon.tsx +6 -2
- 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 +20 -40
- package/src/components/Input/Input.tsx +24 -69
- package/src/components/Link/Link.stories.tsx +2 -3
- package/src/components/Link/Link.tsx +2 -2
- package/src/components/List/List.stories.tsx +15 -23
- package/src/components/List/List.tsx +16 -20
- package/src/components/List/ListDropIndicator.tsx +7 -7
- package/src/components/List/Tree.stories.tsx +5 -6
- package/src/components/List/Tree.tsx +0 -1
- package/src/components/List/TreeDropIndicator.tsx +6 -6
- package/src/components/List/Treegrid.stories.tsx +29 -30
- package/src/components/List/Treegrid.tsx +23 -28
- package/src/components/Main/Main.stories.tsx +41 -24
- package/src/components/Main/Main.tsx +139 -83
- package/src/components/Menu/ContextMenu.stories.tsx +2 -3
- package/src/components/Menu/ContextMenu.tsx +9 -33
- package/src/components/Menu/DropdownMenu.stories.tsx +2 -3
- package/src/components/Menu/DropdownMenu.tsx +58 -52
- package/src/components/Message/Message.stories.tsx +26 -12
- package/src/components/Message/Message.tsx +14 -30
- package/src/components/Popover/Popover.stories.tsx +7 -8
- package/src/components/Popover/Popover.tsx +62 -59
- package/src/components/ScrollArea/ScrollArea.stories.tsx +214 -75
- package/src/components/ScrollArea/ScrollArea.tsx +85 -113
- package/src/components/ScrollArea/index.ts +1 -1
- package/src/components/ScrollContainer/ScrollContainer.stories.tsx +47 -26
- package/src/components/ScrollContainer/ScrollContainer.tsx +206 -92
- package/src/components/Select/Select.stories.tsx +7 -8
- package/src/components/Select/Select.tsx +11 -27
- package/src/components/Separator/Separator.tsx +5 -8
- package/src/components/Skeleton/Skeleton.stories.tsx +51 -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 +127 -0
- package/src/components/Splitter/index.ts +5 -0
- package/src/components/Status/Status.stories.tsx +21 -18
- package/src/components/Status/Status.tsx +10 -7
- package/src/components/Tag/Tag.stories.tsx +4 -10
- package/src/components/Tag/Tag.tsx +2 -7
- package/src/components/ThemeProvider/ThemeProvider.stories.tsx +31 -0
- package/src/components/ThemeProvider/ThemeProvider.tsx +9 -7
- package/src/components/Toast/Toast.stories.tsx +2 -3
- package/src/components/Toast/Toast.tsx +22 -41
- package/src/components/Toolbar/Toolbar.stories.tsx +2 -3
- package/src/components/Toolbar/Toolbar.tsx +173 -26
- package/src/components/Tooltip/Tooltip.stories.tsx +20 -19
- package/src/components/Tooltip/Tooltip.tsx +18 -18
- package/src/components/index.ts +10 -5
- 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 +2 -2
- package/src/index.ts +1 -0
- package/src/playground/Controls.stories.tsx +3 -10
- package/src/playground/Custom.stories.tsx +15 -18
- 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 +29 -0
- package/src/primitives/Container/Container.tsx +19 -0
- package/src/primitives/Container/index.ts +5 -0
- package/src/primitives/Flex/Flex.stories.tsx +57 -0
- package/src/primitives/Flex/Flex.tsx +27 -0
- package/src/primitives/Flex/index.ts +5 -0
- package/src/primitives/Grid/Grid.stories.tsx +56 -0
- package/src/primitives/Grid/Grid.tsx +30 -0
- package/src/primitives/Grid/index.ts +5 -0
- package/src/primitives/Panel/Panel.stories.tsx +68 -0
- package/src/primitives/Panel/Panel.tsx +120 -0
- package/src/primitives/Panel/index.ts +5 -0
- package/src/primitives/index.ts +9 -0
- package/src/testing/Loading.tsx +47 -0
- package/src/testing/decorators/withLayout.tsx +21 -7
- package/src/testing/decorators/withLayoutVariants.tsx +18 -21
- package/src/testing/decorators/withTheme.tsx +24 -19
- package/src/testing/index.ts +2 -0
- package/src/translations.ts +19 -0
- package/src/util/usePx.ts +1 -0
- package/dist/lib/browser/chunk-CEKVHJ27.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-2NHEX4AD.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/src/components/AnchoredOverflow/AnchoredOverflow.tsx +0 -59
- package/src/components/AnchoredOverflow/index.ts +0 -5
|
@@ -3,23 +3,7 @@
|
|
|
3
3
|
//
|
|
4
4
|
|
|
5
5
|
import { createContext } from '@radix-ui/react-context';
|
|
6
|
-
import
|
|
7
|
-
DialogClose as DialogClosePrimitive,
|
|
8
|
-
type DialogCloseProps as DialogClosePrimitiveProps,
|
|
9
|
-
DialogContent as DialogContentPrimitive,
|
|
10
|
-
DialogDescription as DialogDescriptionPrimitive,
|
|
11
|
-
type DialogDescriptionProps as DialogDescriptionPrimitiveProps,
|
|
12
|
-
DialogOverlay as DialogOverlayPrimitive,
|
|
13
|
-
type DialogOverlayProps as DialogOverlayPrimitiveProps,
|
|
14
|
-
DialogPortal as DialogPortalPrimitive,
|
|
15
|
-
type DialogPortalProps as DialogPortalPrimitiveProps,
|
|
16
|
-
Root as DialogRootPrimitive,
|
|
17
|
-
type DialogProps as DialogRootPrimitiveProps,
|
|
18
|
-
DialogTitle as DialogTitlePrimitive,
|
|
19
|
-
type DialogTitleProps as DialogTitlePrimitiveProps,
|
|
20
|
-
DialogTrigger as DialogTriggerPrimitive,
|
|
21
|
-
type DialogTriggerProps as DialogTriggerPrimitiveProps,
|
|
22
|
-
} from '@radix-ui/react-dialog';
|
|
6
|
+
import * as DialogPrimitive from '@radix-ui/react-dialog';
|
|
23
7
|
import React, {
|
|
24
8
|
type ComponentPropsWithRef,
|
|
25
9
|
type ForwardRefExoticComponent,
|
|
@@ -30,21 +14,29 @@ import React, {
|
|
|
30
14
|
import { useTranslation } from 'react-i18next';
|
|
31
15
|
|
|
32
16
|
import { type DialogSize, osTranslations } from '@dxos/ui-theme';
|
|
17
|
+
import { slottable } from '@dxos/ui-theme';
|
|
18
|
+
import { type SlottableProps } from '@dxos/ui-types';
|
|
33
19
|
|
|
34
20
|
import { useThemeContext } from '../../hooks';
|
|
21
|
+
import { Column } from '../../primitives';
|
|
35
22
|
import { type ThemedClassName } from '../../util';
|
|
36
|
-
import { IconButton
|
|
23
|
+
import { IconButton } from '../Button';
|
|
37
24
|
import { ElevationProvider } from '../ElevationProvider';
|
|
38
25
|
|
|
39
26
|
//
|
|
40
27
|
// Root
|
|
41
28
|
//
|
|
42
29
|
|
|
43
|
-
type DialogRootProps =
|
|
30
|
+
type DialogRootProps = DialogPrimitive.DialogProps;
|
|
44
31
|
|
|
45
32
|
const DialogRoot: FunctionComponent<DialogRootProps> = (props) => (
|
|
46
33
|
<ElevationProvider elevation='dialog'>
|
|
47
|
-
<
|
|
34
|
+
<DialogPrimitive.Root
|
|
35
|
+
// NOTE: Radix warning unless set to undefined.
|
|
36
|
+
// https://www.radix-ui.com/primitives/docs/components/dialog#description
|
|
37
|
+
aria-describedby={undefined}
|
|
38
|
+
{...props}
|
|
39
|
+
/>
|
|
48
40
|
</ElevationProvider>
|
|
49
41
|
);
|
|
50
42
|
|
|
@@ -52,17 +44,17 @@ const DialogRoot: FunctionComponent<DialogRootProps> = (props) => (
|
|
|
52
44
|
// Trigger
|
|
53
45
|
//
|
|
54
46
|
|
|
55
|
-
type DialogTriggerProps =
|
|
47
|
+
type DialogTriggerProps = DialogPrimitive.DialogTriggerProps;
|
|
56
48
|
|
|
57
|
-
const DialogTrigger: FunctionComponent<DialogTriggerProps> =
|
|
49
|
+
const DialogTrigger: FunctionComponent<DialogTriggerProps> = DialogPrimitive.Trigger;
|
|
58
50
|
|
|
59
51
|
//
|
|
60
52
|
// Portal
|
|
61
53
|
//
|
|
62
54
|
|
|
63
|
-
type DialogPortalProps =
|
|
55
|
+
type DialogPortalProps = DialogPrimitive.DialogPortalProps;
|
|
64
56
|
|
|
65
|
-
const DialogPortal: FunctionComponent<DialogPortalProps> =
|
|
57
|
+
const DialogPortal: FunctionComponent<DialogPortalProps> = DialogPrimitive.Portal;
|
|
66
58
|
|
|
67
59
|
//
|
|
68
60
|
// Overlay
|
|
@@ -77,21 +69,23 @@ const [OverlayLayoutProvider, useOverlayLayoutContext] = createContext<OverlayLa
|
|
|
77
69
|
{},
|
|
78
70
|
);
|
|
79
71
|
|
|
80
|
-
type DialogOverlayProps = ThemedClassName<
|
|
72
|
+
type DialogOverlayProps = ThemedClassName<
|
|
73
|
+
DialogPrimitive.DialogOverlayProps & { blockAlign?: 'center' | 'start' | 'end' }
|
|
74
|
+
>;
|
|
81
75
|
|
|
82
76
|
const DialogOverlay: ForwardRefExoticComponent<DialogOverlayProps> = forwardRef<HTMLDivElement, DialogOverlayProps>(
|
|
83
77
|
({ classNames, children, blockAlign, ...props }, forwardedRef) => {
|
|
84
78
|
const { tx } = useThemeContext();
|
|
85
79
|
|
|
86
80
|
return (
|
|
87
|
-
<
|
|
81
|
+
<DialogPrimitive.Overlay
|
|
88
82
|
{...props}
|
|
89
|
-
className={tx('dialog.overlay', 'dialog__overlay', {}, classNames)}
|
|
90
|
-
ref={forwardedRef}
|
|
91
83
|
data-block-align={blockAlign}
|
|
84
|
+
className={tx('dialog.overlay', {}, classNames)}
|
|
85
|
+
ref={forwardedRef}
|
|
92
86
|
>
|
|
93
87
|
<OverlayLayoutProvider inOverlayLayout>{children}</OverlayLayoutProvider>
|
|
94
|
-
</
|
|
88
|
+
</DialogPrimitive.Overlay>
|
|
95
89
|
);
|
|
96
90
|
},
|
|
97
91
|
);
|
|
@@ -104,32 +98,36 @@ DialogOverlay.displayName = DIALOG_OVERLAY_NAME;
|
|
|
104
98
|
|
|
105
99
|
const DIALOG_CONTENT_NAME = 'DialogContent';
|
|
106
100
|
|
|
107
|
-
type DialogContentProps = ThemedClassName<ComponentPropsWithRef<typeof
|
|
101
|
+
type DialogContentProps = ThemedClassName<ComponentPropsWithRef<typeof DialogPrimitive.Content>> & {
|
|
108
102
|
size?: DialogSize;
|
|
109
103
|
inOverlayLayout?: boolean;
|
|
110
104
|
};
|
|
111
105
|
|
|
112
106
|
const DialogContent: ForwardRefExoticComponent<DialogContentProps> = forwardRef<HTMLDivElement, DialogContentProps>(
|
|
113
|
-
({ classNames, children, size, inOverlayLayout: propsInOverlayLayout, ...props }, forwardedRef) => {
|
|
107
|
+
({ classNames, children, size = 'md', inOverlayLayout: propsInOverlayLayout, ...props }, forwardedRef) => {
|
|
114
108
|
const { tx } = useThemeContext();
|
|
115
109
|
const { inOverlayLayout } = useOverlayLayoutContext(DIALOG_CONTENT_NAME);
|
|
116
110
|
|
|
117
111
|
return (
|
|
118
|
-
<
|
|
112
|
+
<DialogPrimitive.Content
|
|
113
|
+
{...props}
|
|
119
114
|
// NOTE: Radix warning unless set to undefined.
|
|
120
115
|
// https://www.radix-ui.com/primitives/docs/components/dialog#description
|
|
121
116
|
aria-describedby={undefined}
|
|
122
|
-
{...props}
|
|
123
117
|
className={tx(
|
|
124
118
|
'dialog.content',
|
|
125
|
-
|
|
126
|
-
|
|
119
|
+
{
|
|
120
|
+
size,
|
|
121
|
+
inOverlayLayout: propsInOverlayLayout || inOverlayLayout,
|
|
122
|
+
},
|
|
127
123
|
classNames,
|
|
128
124
|
)}
|
|
129
125
|
ref={forwardedRef}
|
|
130
126
|
>
|
|
131
|
-
|
|
132
|
-
|
|
127
|
+
<Column.Root classNames='dx-expander' gutter='sm'>
|
|
128
|
+
{children}
|
|
129
|
+
</Column.Root>
|
|
130
|
+
</DialogPrimitive.Content>
|
|
133
131
|
);
|
|
134
132
|
},
|
|
135
133
|
);
|
|
@@ -140,35 +138,36 @@ DialogContent.displayName = DIALOG_CONTENT_NAME;
|
|
|
140
138
|
// Header
|
|
141
139
|
//
|
|
142
140
|
|
|
143
|
-
type DialogHeaderProps =
|
|
141
|
+
type DialogHeaderProps = PropsWithChildren;
|
|
144
142
|
|
|
145
|
-
const DialogHeader: ForwardRefExoticComponent<
|
|
146
|
-
({
|
|
143
|
+
const DialogHeader: ForwardRefExoticComponent<DialogHeaderProps> = forwardRef<HTMLHeadingElement, DialogHeaderProps>(
|
|
144
|
+
({ children }, forwardedRef) => {
|
|
147
145
|
const { tx } = useThemeContext();
|
|
148
146
|
return (
|
|
149
|
-
<
|
|
150
|
-
{
|
|
151
|
-
|
|
152
|
-
className={tx('dialog.header', 'dialog__header', { srOnly }, classNames)}
|
|
153
|
-
ref={forwardedRef}
|
|
154
|
-
/>
|
|
147
|
+
<Column.Row className={tx('dialog.header')} center ref={forwardedRef}>
|
|
148
|
+
{children}
|
|
149
|
+
</Column.Row>
|
|
155
150
|
);
|
|
156
151
|
},
|
|
157
152
|
);
|
|
158
153
|
|
|
159
154
|
//
|
|
160
|
-
//
|
|
155
|
+
// CloseIconButton
|
|
161
156
|
//
|
|
162
157
|
|
|
163
|
-
type
|
|
158
|
+
type DialogCloseIconButtonProps = { label?: string };
|
|
164
159
|
|
|
165
|
-
const
|
|
166
|
-
({
|
|
167
|
-
const {
|
|
160
|
+
const DialogCloseIconButton = forwardRef<HTMLButtonElement, DialogCloseIconButtonProps>(
|
|
161
|
+
({ label, ...props }, forwardedRef) => {
|
|
162
|
+
const { t } = useTranslation(osTranslations);
|
|
168
163
|
return (
|
|
169
|
-
<
|
|
164
|
+
<IconButton
|
|
170
165
|
{...props}
|
|
171
|
-
|
|
166
|
+
label={label ?? t('close-dialog.label')}
|
|
167
|
+
icon='ph--x--regular'
|
|
168
|
+
iconOnly
|
|
169
|
+
size={4}
|
|
170
|
+
variant='ghost'
|
|
172
171
|
ref={forwardedRef}
|
|
173
172
|
/>
|
|
174
173
|
);
|
|
@@ -176,57 +175,80 @@ const DialogTitle: ForwardRefExoticComponent<DialogTitleProps> = forwardRef<HTML
|
|
|
176
175
|
);
|
|
177
176
|
|
|
178
177
|
//
|
|
179
|
-
//
|
|
178
|
+
// Body
|
|
180
179
|
//
|
|
181
180
|
|
|
182
|
-
type
|
|
181
|
+
type DialogBodyProps = SlottableProps;
|
|
183
182
|
|
|
184
|
-
const
|
|
185
|
-
HTMLParagraphElement,
|
|
186
|
-
DialogDescriptionProps
|
|
187
|
-
>(({ classNames, srOnly, ...props }, forwardedRef) => {
|
|
183
|
+
const DialogBody = slottable<HTMLDivElement>(({ children, asChild, ...props }, forwardedRef) => {
|
|
188
184
|
const { tx } = useThemeContext();
|
|
189
185
|
return (
|
|
190
|
-
<
|
|
191
|
-
{
|
|
192
|
-
|
|
193
|
-
ref={forwardedRef}
|
|
194
|
-
/>
|
|
186
|
+
<Column.Content {...props} asChild={asChild} className={tx('dialog.body', {})} ref={forwardedRef}>
|
|
187
|
+
{children}
|
|
188
|
+
</Column.Content>
|
|
195
189
|
);
|
|
196
190
|
});
|
|
197
191
|
|
|
198
192
|
//
|
|
199
|
-
//
|
|
193
|
+
// Title
|
|
200
194
|
//
|
|
201
195
|
|
|
202
|
-
type
|
|
196
|
+
type DialogTitleProps = ThemedClassName<DialogPrimitive.DialogTitleProps> & { srOnly?: boolean };
|
|
203
197
|
|
|
204
|
-
const
|
|
198
|
+
const DialogTitle = forwardRef<HTMLHeadingElement, DialogTitleProps>(
|
|
199
|
+
({ classNames, srOnly, ...props }, forwardedRef) => {
|
|
200
|
+
const { tx } = useThemeContext();
|
|
201
|
+
return (
|
|
202
|
+
<DialogPrimitive.Title {...props} className={tx('dialog.title', { srOnly }, classNames)} ref={forwardedRef} />
|
|
203
|
+
);
|
|
204
|
+
},
|
|
205
|
+
);
|
|
205
206
|
|
|
206
207
|
//
|
|
207
|
-
//
|
|
208
|
+
// Description
|
|
208
209
|
//
|
|
209
210
|
|
|
210
|
-
type
|
|
211
|
+
type DialogDescriptionProps = ThemedClassName<DialogPrimitive.DialogDescriptionProps> & { srOnly?: boolean };
|
|
211
212
|
|
|
212
|
-
const
|
|
213
|
-
|
|
214
|
-
|
|
215
|
-
|
|
216
|
-
|
|
217
|
-
|
|
218
|
-
|
|
219
|
-
|
|
220
|
-
|
|
221
|
-
|
|
222
|
-
|
|
223
|
-
|
|
224
|
-
|
|
225
|
-
|
|
226
|
-
|
|
227
|
-
|
|
228
|
-
|
|
229
|
-
|
|
213
|
+
const DialogDescription = forwardRef<HTMLParagraphElement, DialogDescriptionProps>(
|
|
214
|
+
({ classNames, srOnly, ...props }, forwardedRef) => {
|
|
215
|
+
const { tx } = useThemeContext();
|
|
216
|
+
return (
|
|
217
|
+
<DialogPrimitive.Description
|
|
218
|
+
{...props}
|
|
219
|
+
className={tx('dialog.description', { srOnly }, classNames)}
|
|
220
|
+
ref={forwardedRef}
|
|
221
|
+
/>
|
|
222
|
+
);
|
|
223
|
+
},
|
|
224
|
+
);
|
|
225
|
+
|
|
226
|
+
//
|
|
227
|
+
// ActionBar
|
|
228
|
+
//
|
|
229
|
+
|
|
230
|
+
type DialogActionBarProps = ThemedClassName<PropsWithChildren>;
|
|
231
|
+
|
|
232
|
+
const DialogActionBar = forwardRef<HTMLDivElement, DialogActionBarProps>(
|
|
233
|
+
({ children, classNames, ...props }, forwardedRef) => {
|
|
234
|
+
const { tx } = useThemeContext();
|
|
235
|
+
return (
|
|
236
|
+
<Column.Row center>
|
|
237
|
+
<div {...props} className={tx('dialog.actionbar', {}, classNames)} ref={forwardedRef}>
|
|
238
|
+
{children}
|
|
239
|
+
</div>
|
|
240
|
+
</Column.Row>
|
|
241
|
+
);
|
|
242
|
+
},
|
|
243
|
+
);
|
|
244
|
+
|
|
245
|
+
//
|
|
246
|
+
// Close
|
|
247
|
+
//
|
|
248
|
+
|
|
249
|
+
type DialogCloseProps = DialogPrimitive.DialogCloseProps;
|
|
250
|
+
|
|
251
|
+
const DialogClose: FunctionComponent<DialogCloseProps> = DialogPrimitive.Close;
|
|
230
252
|
|
|
231
253
|
//
|
|
232
254
|
// Dialog
|
|
@@ -239,8 +261,10 @@ export const Dialog = {
|
|
|
239
261
|
Overlay: DialogOverlay,
|
|
240
262
|
Content: DialogContent,
|
|
241
263
|
Header: DialogHeader,
|
|
264
|
+
Body: DialogBody,
|
|
242
265
|
Title: DialogTitle,
|
|
243
266
|
Description: DialogDescription,
|
|
267
|
+
ActionBar: DialogActionBar,
|
|
244
268
|
Close: DialogClose,
|
|
245
269
|
CloseIconButton: DialogCloseIconButton,
|
|
246
270
|
};
|
|
@@ -252,8 +276,10 @@ export type {
|
|
|
252
276
|
DialogOverlayProps,
|
|
253
277
|
DialogContentProps,
|
|
254
278
|
DialogHeaderProps,
|
|
279
|
+
DialogBodyProps,
|
|
255
280
|
DialogTitleProps,
|
|
256
281
|
DialogDescriptionProps,
|
|
282
|
+
DialogActionBarProps,
|
|
257
283
|
DialogCloseProps,
|
|
258
284
|
DialogCloseIconButtonProps,
|
|
259
285
|
};
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
//
|
|
2
|
+
// Copyright 2026 DXOS.org
|
|
3
|
+
//
|
|
4
|
+
|
|
5
|
+
import { type Meta, type StoryObj } from '@storybook/react-vite';
|
|
6
|
+
import React from 'react';
|
|
7
|
+
|
|
8
|
+
import { ErrorBoundary } from '@dxos/react-error-boundary';
|
|
9
|
+
|
|
10
|
+
import { withLayout, withTheme } from '../../testing';
|
|
11
|
+
import { ErrorFallback } from './ErrorFallback';
|
|
12
|
+
import { ThrowError } from './ThrowError';
|
|
13
|
+
|
|
14
|
+
const DefaultStory = () => {
|
|
15
|
+
return (
|
|
16
|
+
<ErrorBoundary name='story' FallbackComponent={ErrorFallback}>
|
|
17
|
+
<ThrowError />
|
|
18
|
+
</ErrorBoundary>
|
|
19
|
+
);
|
|
20
|
+
};
|
|
21
|
+
|
|
22
|
+
const meta: Meta = {
|
|
23
|
+
title: 'ui/react-ui-core/components/ErrorFallback',
|
|
24
|
+
component: ErrorFallback,
|
|
25
|
+
decorators: [withTheme(), withLayout({ layout: 'column' })],
|
|
26
|
+
parameters: {
|
|
27
|
+
layout: 'fullscreen',
|
|
28
|
+
},
|
|
29
|
+
};
|
|
30
|
+
|
|
31
|
+
export default meta;
|
|
32
|
+
|
|
33
|
+
type Story = StoryObj<typeof meta>;
|
|
34
|
+
|
|
35
|
+
export const Default: Story = {
|
|
36
|
+
render: DefaultStory,
|
|
37
|
+
play: async () => {
|
|
38
|
+
// This story intentionally renders an ErrorBoundary fallback; clear the smoke-test error flag.
|
|
39
|
+
(window as any).__ERROR_BOUNDARY_ERRORS__ = [];
|
|
40
|
+
},
|
|
41
|
+
};
|
|
42
|
+
|
|
43
|
+
export const StringError: Story = {
|
|
44
|
+
render: () => <ErrorFallback error='This is a string error message' data={{ context: 'story' }} />,
|
|
45
|
+
};
|
|
@@ -0,0 +1,70 @@
|
|
|
1
|
+
//
|
|
2
|
+
// Copyright 2026 DXOS.org
|
|
3
|
+
//
|
|
4
|
+
|
|
5
|
+
import React, { type PropsWithChildren } from 'react';
|
|
6
|
+
import { type FallbackProps } from 'react-error-boundary';
|
|
7
|
+
|
|
8
|
+
import { safeStringify } from '@dxos/util';
|
|
9
|
+
|
|
10
|
+
import { ErrorStack } from './ErrorStack';
|
|
11
|
+
|
|
12
|
+
export type ErrorFallbackProps = PropsWithChildren<Pick<FallbackProps, 'error'> & { title?: string; data?: any }>;
|
|
13
|
+
|
|
14
|
+
/**
|
|
15
|
+
* Themed fallback component for `ErrorBoundary`.
|
|
16
|
+
*/
|
|
17
|
+
export const ErrorFallback = ({ children, error, title, data }: ErrorFallbackProps) => {
|
|
18
|
+
const isDev = process.env.NODE_ENV === 'development';
|
|
19
|
+
const message = error instanceof Error ? error.message : String(error);
|
|
20
|
+
|
|
21
|
+
return (
|
|
22
|
+
<div role='alert' data-testid='error-boundary-fallback' className='flex flex-col p-4 gap-4 overflow-auto'>
|
|
23
|
+
<h1 className='text-lg text-info-text'>{title ?? 'Runtime Error'}</h1>
|
|
24
|
+
<p>{message}</p>
|
|
25
|
+
|
|
26
|
+
{isDev && error instanceof Error && (
|
|
27
|
+
<Section
|
|
28
|
+
title='Stack'
|
|
29
|
+
onClick={() => {
|
|
30
|
+
const text = error instanceof Error ? (error.stack ?? error.message) : String(error);
|
|
31
|
+
void navigator.clipboard.writeText(text);
|
|
32
|
+
}}
|
|
33
|
+
>
|
|
34
|
+
<ErrorStack error={error} />
|
|
35
|
+
</Section>
|
|
36
|
+
)}
|
|
37
|
+
|
|
38
|
+
{data && (
|
|
39
|
+
<Section
|
|
40
|
+
title='Data'
|
|
41
|
+
onClick={() => {
|
|
42
|
+
void navigator.clipboard.writeText(JSON.stringify(data, undefined, 2));
|
|
43
|
+
}}
|
|
44
|
+
>
|
|
45
|
+
<pre className='overflow-x-auto text-xs'>{safeStringify(data, undefined, 2)}</pre>
|
|
46
|
+
</Section>
|
|
47
|
+
)}
|
|
48
|
+
|
|
49
|
+
{children}
|
|
50
|
+
</div>
|
|
51
|
+
);
|
|
52
|
+
};
|
|
53
|
+
|
|
54
|
+
const Section = ({ children, title, onClick }: PropsWithChildren<{ title?: string; onClick?: () => void }>) => {
|
|
55
|
+
return (
|
|
56
|
+
<div className='flex flex-col gap-1'>
|
|
57
|
+
{onClick && (
|
|
58
|
+
<button
|
|
59
|
+
type='button'
|
|
60
|
+
onClick={onClick}
|
|
61
|
+
className='flex items-center gap-1 text-xs text-subdued hover:text-primary-500 transition-colors'
|
|
62
|
+
title={`Copy ${title}`}
|
|
63
|
+
>
|
|
64
|
+
<h2 className='text-xs uppercase text-subdued'>{title}</h2>
|
|
65
|
+
</button>
|
|
66
|
+
)}
|
|
67
|
+
{children}
|
|
68
|
+
</div>
|
|
69
|
+
);
|
|
70
|
+
};
|
|
@@ -0,0 +1,114 @@
|
|
|
1
|
+
//
|
|
2
|
+
// Copyright 2026 DXOS.org
|
|
3
|
+
//
|
|
4
|
+
|
|
5
|
+
import ErrorStackParser from 'error-stack-parser';
|
|
6
|
+
import React from 'react';
|
|
7
|
+
|
|
8
|
+
import { mx } from '@dxos/ui-theme';
|
|
9
|
+
|
|
10
|
+
type LocalFrame = { href: string; fileName: string };
|
|
11
|
+
|
|
12
|
+
export type ParsedStackFrame = ReturnType<typeof ErrorStackParser.parse>[number];
|
|
13
|
+
|
|
14
|
+
export type ErrorStackProps = {
|
|
15
|
+
/** When set, these frames are shown instead of parsing `error`. */
|
|
16
|
+
frames?: ParsedStackFrame[];
|
|
17
|
+
/** Used when `frames` is omitted. */
|
|
18
|
+
error?: Error;
|
|
19
|
+
};
|
|
20
|
+
|
|
21
|
+
/**
|
|
22
|
+
* Parses `captureOwnerStack()` output (React dev) into frames for {@link ErrorStack}.
|
|
23
|
+
* Prefixes a synthetic Error line when needed so `error-stack-parser` can read V8-style stacks.
|
|
24
|
+
*/
|
|
25
|
+
export const parseCaptureOwnerStack = (stack: string | null): ParsedStackFrame[] | null => {
|
|
26
|
+
if (stack == null || stack.length === 0) {
|
|
27
|
+
return null;
|
|
28
|
+
}
|
|
29
|
+
const err = new Error();
|
|
30
|
+
err.stack = stack;
|
|
31
|
+
try {
|
|
32
|
+
return ErrorStackParser.parse(err);
|
|
33
|
+
} catch {
|
|
34
|
+
err.stack = `Error\n${stack}`;
|
|
35
|
+
try {
|
|
36
|
+
return ErrorStackParser.parse(err);
|
|
37
|
+
} catch {
|
|
38
|
+
return null;
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
};
|
|
42
|
+
|
|
43
|
+
/**
|
|
44
|
+
* Renders a parsed error stack trace with tree connector symbols and clickable vscode:// links for local frames.
|
|
45
|
+
*/
|
|
46
|
+
export const ErrorStack = ({ error, frames: framesProp }: ErrorStackProps) => {
|
|
47
|
+
const frames = framesProp ?? (error ? ErrorStackParser.parse(error) : []);
|
|
48
|
+
if (frames.length === 0) {
|
|
49
|
+
return null;
|
|
50
|
+
}
|
|
51
|
+
|
|
52
|
+
return (
|
|
53
|
+
<div className='font-mono text-sm'>
|
|
54
|
+
{frames.map((frame, i) => {
|
|
55
|
+
const isLast = i === frames.length - 1;
|
|
56
|
+
const local = frame.fileName
|
|
57
|
+
? parseLocalFrame(frame.fileName, frame.lineNumber, frame.columnNumber)
|
|
58
|
+
: undefined;
|
|
59
|
+
const name = frame.functionName ?? '<anonymous>';
|
|
60
|
+
return (
|
|
61
|
+
<div
|
|
62
|
+
key={i}
|
|
63
|
+
className={mx(
|
|
64
|
+
'grid grid-cols-[16px_1fr_auto_auto] items-stretch gap-x-2',
|
|
65
|
+
local && 'cursor-pointer hover:bg-hover-surface',
|
|
66
|
+
)}
|
|
67
|
+
>
|
|
68
|
+
{/* Tree connector: vertical line full-height + horizontal branch at midpoint */}
|
|
69
|
+
<div className='relative'>
|
|
70
|
+
<div
|
|
71
|
+
className={mx(
|
|
72
|
+
'absolute left-1/2 -translate-x-1/2 w-px bg-neutral-500',
|
|
73
|
+
isLast ? 'top-0 h-1/2' : 'inset-y-0',
|
|
74
|
+
)}
|
|
75
|
+
/>
|
|
76
|
+
<div className='absolute top-1/2 -translate-y-1/2 left-1/2 right-0 h-px bg-neutral-500' />
|
|
77
|
+
</div>
|
|
78
|
+
{local ? (
|
|
79
|
+
<a href={local.href} className='truncate self-center'>
|
|
80
|
+
{name}
|
|
81
|
+
</a>
|
|
82
|
+
) : (
|
|
83
|
+
<span className='text-subdued truncate self-center'>{name}</span>
|
|
84
|
+
)}
|
|
85
|
+
<span className='text-xs text-subdued truncate self-center'>{local?.fileName ?? ''}</span>
|
|
86
|
+
<span className='text-xs text-subdued text-right self-center'>
|
|
87
|
+
{local ? `${frame.lineNumber}:${frame.columnNumber}` : ''}
|
|
88
|
+
</span>
|
|
89
|
+
</div>
|
|
90
|
+
);
|
|
91
|
+
})}
|
|
92
|
+
</div>
|
|
93
|
+
);
|
|
94
|
+
};
|
|
95
|
+
|
|
96
|
+
/**
|
|
97
|
+
* Parses a Vite `/@fs/` URL into a `vscode://` deep link and short filename.
|
|
98
|
+
* Returns undefined if the URL cannot be resolved to a local file.
|
|
99
|
+
*/
|
|
100
|
+
const parseLocalFrame = (fileUrl: string, line?: number, col?: number): LocalFrame | undefined => {
|
|
101
|
+
try {
|
|
102
|
+
const { pathname } = new URL(fileUrl);
|
|
103
|
+
if (!pathname.startsWith('/@fs/')) {
|
|
104
|
+
return undefined;
|
|
105
|
+
}
|
|
106
|
+
const localPath = pathname.slice(4); // /@fs/Users/... → /Users/...
|
|
107
|
+
return {
|
|
108
|
+
href: `vscode://file/${localPath}:${line ?? 1}:${col ?? 1}`,
|
|
109
|
+
fileName: pathname.split('/').pop() ?? localPath,
|
|
110
|
+
};
|
|
111
|
+
} catch {
|
|
112
|
+
return undefined;
|
|
113
|
+
}
|
|
114
|
+
};
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
//
|
|
2
|
+
// Copyright 2026 DXOS.org
|
|
3
|
+
//
|
|
4
|
+
|
|
5
|
+
import { useEffect, useState } from 'react';
|
|
6
|
+
|
|
7
|
+
export type ThrowErrorProps = {
|
|
8
|
+
error?: () => Error;
|
|
9
|
+
delay?: number;
|
|
10
|
+
};
|
|
11
|
+
|
|
12
|
+
/**
|
|
13
|
+
* Use this to debug the error boundary.
|
|
14
|
+
*/
|
|
15
|
+
export const ThrowError = ({ delay = 1_000, ...props }: ThrowErrorProps) => {
|
|
16
|
+
const [error, setError] = useState<Error>();
|
|
17
|
+
useEffect(() => {
|
|
18
|
+
if (delay < 0) {
|
|
19
|
+
return;
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
const t = setTimeout(() => {
|
|
23
|
+
setError(generator({ delay, ...props }));
|
|
24
|
+
}, delay);
|
|
25
|
+
return () => clearTimeout(t);
|
|
26
|
+
}, [delay, generator]);
|
|
27
|
+
|
|
28
|
+
if (error) {
|
|
29
|
+
throw error;
|
|
30
|
+
}
|
|
31
|
+
|
|
32
|
+
return null;
|
|
33
|
+
};
|
|
34
|
+
|
|
35
|
+
const generator = ({ error, delay }: ThrowErrorProps) => {
|
|
36
|
+
return error?.() ?? new Error(`Error generated after ${delay}ms`);
|
|
37
|
+
};
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
# Focus
|
|
2
|
+
|
|
3
|
+
## Problem
|
|
4
|
+
|
|
5
|
+
Grid cells use `overflow-hidden` which clips outward CSS `ring` (box-shadow) and `outline` styles.
|
|
6
|
+
Using `border` for focus indicators creates doubled lines at grid cell boundaries.
|
|
7
|
+
Inset `box-shadow` alone is obscured by child elements with backgrounds (e.g., toolbar headers).
|
|
8
|
+
|
|
9
|
+
## Solution
|
|
10
|
+
|
|
11
|
+
Uses a `::after` pseudo-element overlay with `ring-inset` to paint the focus ring above all child content.
|
|
12
|
+
The pseudo-element is absolutely positioned, `pointer-events-none`, and inherits `border-radius`.
|
|
13
|
+
|
|
14
|
+
- **Default**: ring is transparent (invisible until focused).
|
|
15
|
+
- **`border` prop**: shows a CSS `border-separator` when unfocused (e.g., for grid cell edges).
|
|
16
|
+
- **Focus/active/error states**: ring color changes to the appropriate indicator color.
|
|
17
|
+
|
|
18
|
+
Both `Focus.Group` and `Focus.Item` support the `border` prop.
|
|
19
|
+
|
|
20
|
+
## Why `::after` overlay
|
|
21
|
+
|
|
22
|
+
| Approach | Clipped? | Obscured by children? | Notes |
|
|
23
|
+
| ------------------------ | -------- | --------------------- | --------------------------------------------------------------------- |
|
|
24
|
+
| `ring` (outward) | Yes | N/A | Extends outside bounds, clipped by parent `overflow-hidden`. |
|
|
25
|
+
| `ring-inset` | No | Yes | Inset box-shadow is part of background layer; children paint over it. |
|
|
26
|
+
| `::after` + `ring-inset` | No | No | Pseudo-element paints above children. Requires `position: relative`. |
|
|
27
|
+
|
|
28
|
+
## Relationship to `dx-focus-ring-inset-over-all`
|
|
29
|
+
|
|
30
|
+
The CSS class `dx-focus-ring-inset-over-all` (in `focus-ring.css`) uses the same `::after` technique
|
|
31
|
+
but only reacts to `:focus-visible`. `Focus.Group/Item` additionally support programmatic states
|
|
32
|
+
via `data-focus-state` (`active`, `error`).
|
|
33
|
+
|
|
34
|
+
## Clean-up
|
|
35
|
+
|
|
36
|
+
- [ ] Unify: extend `dx-focus-ring-inset-over-all` to support `data-focus-state` attributes,
|
|
37
|
+
then have `Focus.Group/Item` use the CSS class instead of inline Tailwind utilities.
|
|
38
|
+
Consumers: Plank, StackItem, Tabs, AttentionProvider, main sidebar.
|
|
39
|
+
|
|
40
|
+
## Audit
|
|
41
|
+
|
|
42
|
+
- [ ] Create a list of all container components (outside of `react-ui`) that directly use `overflow-hidden`;
|
|
43
|
+
Consider containers to be components that have `children` and expand (e.g., `grid`, `grow`, `h-full`, `w-full`).
|