@dxos/react-ui 0.8.4-main.d05673bc65 → 0.8.4-main.e00bdcdb52
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-2FKSMWNY.mjs → chunk-BDBC6H6V.mjs} +79 -5
- package/dist/lib/browser/chunk-BDBC6H6V.mjs.map +7 -0
- package/dist/lib/browser/index.mjs +921 -736
- package/dist/lib/browser/index.mjs.map +4 -4
- package/dist/lib/browser/meta.json +1 -1
- package/dist/lib/browser/testing/index.mjs +30 -18
- package/dist/lib/browser/testing/index.mjs.map +3 -3
- package/dist/lib/browser/translations.mjs +18 -0
- package/dist/lib/browser/translations.mjs.map +7 -0
- package/dist/lib/node-esm/{chunk-ZNBLTSHI.mjs → chunk-3JSJK2ZY.mjs} +79 -5
- package/dist/lib/node-esm/chunk-3JSJK2ZY.mjs.map +7 -0
- package/dist/lib/node-esm/index.mjs +921 -736
- 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 +30 -18
- package/dist/lib/node-esm/testing/index.mjs.map +3 -3
- package/dist/lib/node-esm/translations.mjs +20 -0
- package/dist/lib/node-esm/translations.mjs.map +7 -0
- 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 +1 -1
- package/dist/types/src/components/Button/Button.stories.d.ts.map +1 -1
- package/dist/types/src/components/Button/IconButton.d.ts +1 -0
- 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 +2 -2
- package/dist/types/src/components/Button/ToggleGroup.stories.d.ts.map +1 -1
- package/dist/types/src/components/Card/Card.d.ts +70 -50
- package/dist/types/src/components/Card/Card.d.ts.map +1 -1
- package/dist/types/src/components/Card/Card.stories.d.ts +2 -2
- package/dist/types/src/components/Card/Card.stories.d.ts.map +1 -1
- package/dist/types/src/components/Clipboard/ClipboardProvider.d.ts.map +1 -1
- 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/DensityProvider/DensityProvider.d.ts.map +1 -1
- package/dist/types/src/components/Dialog/AlertDialog.d.ts +42 -31
- 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 +47 -30
- package/dist/types/src/components/Dialog/Dialog.d.ts.map +1 -1
- package/dist/types/src/components/Dialog/Dialog.stories.d.ts +3 -2
- package/dist/types/src/components/Dialog/Dialog.stories.d.ts.map +1 -1
- package/dist/types/src/components/ElevationProvider/ElevationProvider.d.ts.map +1 -1
- package/dist/types/src/components/ErrorFallback/ErrorFallback.d.ts.map +1 -1
- package/dist/types/src/components/ErrorFallback/ErrorFallback.stories.d.ts.map +1 -1
- package/dist/types/src/components/ErrorFallback/ErrorStack.d.ts +14 -3
- package/dist/types/src/components/ErrorFallback/ErrorStack.d.ts.map +1 -1
- package/dist/types/src/components/ErrorFallback/ThrowError.d.ts.map +1 -1
- 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 +2 -1
- package/dist/types/src/components/Image/Image.d.ts.map +1 -1
- package/dist/types/src/components/Image/Image.stories.d.ts +3 -2
- package/dist/types/src/components/Image/Image.stories.d.ts.map +1 -1
- package/dist/types/src/components/Input/Input.d.ts +14 -17
- package/dist/types/src/components/Input/Input.d.ts.map +1 -1
- package/dist/types/src/components/Input/Input.stories.d.ts +3 -3
- 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/ListDropIndicator.d.ts.map +1 -1
- package/dist/types/src/components/List/Tree.d.ts +2 -2
- 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/TreeDropIndicator.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 +7 -3
- package/dist/types/src/components/Main/Main.d.ts.map +1 -1
- package/dist/types/src/components/Main/Main.stories.d.ts.map +1 -1
- package/dist/types/src/components/Main/useSwipeToDismiss.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 +58 -49
- 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 +2 -2
- package/dist/types/src/components/Message/Message.stories.d.ts.map +1 -1
- package/dist/types/src/components/Popover/Popover.d.ts +38 -22
- 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 +12 -9
- package/dist/types/src/components/ScrollArea/ScrollArea.d.ts.map +1 -1
- package/dist/types/src/components/ScrollArea/ScrollArea.stories.d.ts +18 -5
- package/dist/types/src/components/ScrollArea/ScrollArea.stories.d.ts.map +1 -1
- package/dist/types/src/components/ScrollContainer/ScrollContainer.d.ts +42 -13
- package/dist/types/src/components/ScrollContainer/ScrollContainer.d.ts.map +1 -1
- package/dist/types/src/components/ScrollContainer/ScrollContainer.stories.d.ts +5 -6
- 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.stories.d.ts.map +1 -1
- package/dist/types/src/components/Splitter/Splitter.d.ts +19 -17
- package/dist/types/src/components/Splitter/Splitter.d.ts.map +1 -1
- package/dist/types/src/components/Splitter/Splitter.stories.d.ts.map +1 -1
- 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.map +1 -1
- package/dist/types/src/components/Tag/Tag.stories.d.ts.map +1 -1
- package/dist/types/src/components/ThemeProvider/ThemeProvider.d.ts +1 -1
- package/dist/types/src/components/ThemeProvider/ThemeProvider.d.ts.map +1 -1
- package/dist/types/src/components/ThemeProvider/ThemeProvider.stories.d.ts +1 -1
- package/dist/types/src/components/ThemeProvider/ThemeProvider.stories.d.ts.map +1 -1
- package/dist/types/src/components/ThemeProvider/TranslationsProvider.d.ts +54 -55
- package/dist/types/src/components/ThemeProvider/TranslationsProvider.d.ts.map +1 -1
- package/dist/types/src/components/ThemeProvider/index.d.ts +1 -1
- package/dist/types/src/components/ThemeProvider/index.d.ts.map +1 -1
- package/dist/types/src/components/Toast/Toast.d.ts +16 -16
- 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 +11 -19
- 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 +10 -10
- 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 +1 -0
- package/dist/types/src/components/index.d.ts.map +1 -1
- package/dist/types/src/exemplars/generics.stories.d.ts +6 -5
- package/dist/types/src/exemplars/generics.stories.d.ts.map +1 -1
- package/dist/types/src/exemplars/slot.stories.d.ts +1 -0
- package/dist/types/src/exemplars/slot.stories.d.ts.map +1 -1
- package/dist/types/src/exemplars/tabster.stories.d.ts.map +1 -1
- package/dist/types/src/exemplars/virtualizer.stories.d.ts.map +1 -1
- 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/hooks/useElevationContext.d.ts.map +1 -1
- package/dist/types/src/hooks/useIconHref.d.ts.map +1 -1
- package/dist/types/src/hooks/useSafeArea.d.ts.map +1 -1
- package/dist/types/src/hooks/useSafeCollisionPadding.d.ts.map +1 -1
- package/dist/types/src/hooks/useVisualViewport.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 +1 -1
- package/dist/types/src/playground/Custom.stories.d.ts.map +1 -1
- package/dist/types/src/playground/Typography.stories.d.ts.map +1 -1
- package/dist/types/src/primitives/Column/Column.d.ts +21 -14
- package/dist/types/src/primitives/Column/Column.d.ts.map +1 -1
- package/dist/types/src/primitives/Column/Column.stories.d.ts +19 -0
- package/dist/types/src/primitives/Column/Column.stories.d.ts.map +1 -1
- package/dist/types/src/primitives/Container/Container.d.ts +4 -5
- package/dist/types/src/primitives/Container/Container.d.ts.map +1 -1
- package/dist/types/src/primitives/Container/Container.stories.d.ts.map +1 -1
- package/dist/types/src/primitives/Flex/Flex.d.ts +5 -7
- package/dist/types/src/primitives/Flex/Flex.d.ts.map +1 -1
- package/dist/types/src/primitives/Flex/Flex.stories.d.ts.map +1 -1
- package/dist/types/src/primitives/Grid/Grid.d.ts +3 -8
- package/dist/types/src/primitives/Grid/Grid.d.ts.map +1 -1
- package/dist/types/src/primitives/Grid/Grid.stories.d.ts.map +1 -1
- package/dist/types/src/primitives/Panel/Panel.d.ts +24 -15
- package/dist/types/src/primitives/Panel/Panel.d.ts.map +1 -1
- package/dist/types/src/primitives/Panel/Panel.stories.d.ts.map +1 -1
- package/dist/types/src/testing/Loading.d.ts.map +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 +1 -1
- package/dist/types/src/testing/decorators/withTheme.d.ts.map +1 -1
- package/dist/types/src/translations.d.ts +3 -3
- package/dist/types/src/translations.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 +28 -25
- package/src/components/Avatars/Avatar.stories.tsx +2 -3
- package/src/components/Avatars/Avatar.tsx +1 -2
- package/src/components/Avatars/AvatarGroup.stories.tsx +0 -1
- package/src/components/Breadcrumb/Breadcrumb.stories.tsx +1 -2
- package/src/components/Button/Button.stories.tsx +0 -1
- package/src/components/Button/Button.tsx +5 -13
- package/src/components/Button/IconButton.stories.tsx +6 -4
- package/src/components/Button/IconButton.tsx +3 -4
- package/src/components/Button/Toggle.stories.tsx +0 -1
- package/src/components/Button/Toggle.tsx +4 -4
- package/src/components/Button/ToggleGroup.stories.tsx +0 -1
- package/src/components/Button/ToggleGroup.tsx +12 -16
- package/src/components/Card/Card.stories.tsx +12 -12
- package/src/components/Card/Card.tsx +266 -108
- package/src/components/Clipboard/CopyButton.tsx +3 -4
- package/src/components/Dialog/AlertDialog.stories.tsx +5 -6
- package/src/components/Dialog/AlertDialog.tsx +67 -126
- package/src/components/Dialog/Dialog.stories.tsx +64 -9
- package/src/components/Dialog/Dialog.tsx +84 -88
- package/src/components/ErrorFallback/ErrorFallback.stories.tsx +3 -8
- package/src/components/ErrorFallback/ErrorStack.tsx +36 -2
- 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 +43 -13
- package/src/components/Icon/Icon.tsx +5 -1
- package/src/components/Image/Image.stories.tsx +3 -3
- package/src/components/Image/Image.tsx +31 -8
- package/src/components/Input/Input.stories.tsx +3 -4
- package/src/components/Input/Input.tsx +7 -7
- package/src/components/Link/Link.stories.tsx +0 -1
- package/src/components/List/List.stories.tsx +0 -1
- package/src/components/List/List.tsx +6 -5
- package/src/components/List/Tree.stories.tsx +1 -2
- package/src/components/List/Tree.tsx +0 -1
- package/src/components/List/Treegrid.stories.tsx +26 -27
- package/src/components/List/Treegrid.tsx +14 -14
- package/src/components/Main/Main.stories.tsx +0 -1
- package/src/components/Main/Main.tsx +1 -2
- package/src/components/Menu/ContextMenu.stories.tsx +0 -1
- package/src/components/Menu/DropdownMenu.stories.tsx +0 -1
- package/src/components/Menu/DropdownMenu.tsx +48 -42
- package/src/components/Message/Message.stories.tsx +6 -7
- package/src/components/Message/Message.tsx +1 -5
- package/src/components/Popover/Popover.stories.tsx +4 -5
- package/src/components/Popover/Popover.tsx +42 -42
- package/src/components/ScrollArea/ScrollArea.stories.tsx +93 -30
- package/src/components/ScrollArea/ScrollArea.tsx +39 -23
- package/src/components/ScrollContainer/ScrollContainer.stories.tsx +20 -18
- package/src/components/ScrollContainer/ScrollContainer.tsx +200 -91
- package/src/components/Select/Select.stories.tsx +5 -6
- package/src/components/Separator/Separator.tsx +4 -7
- package/src/components/Skeleton/Skeleton.stories.tsx +0 -1
- package/src/components/Splitter/Splitter.stories.tsx +29 -29
- package/src/components/Splitter/Splitter.tsx +35 -34
- package/src/components/Status/Status.stories.tsx +0 -1
- package/src/components/Status/Status.tsx +8 -5
- package/src/components/Tag/Tag.stories.tsx +0 -1
- package/src/components/ThemeProvider/ThemeProvider.stories.tsx +0 -1
- package/src/components/ThemeProvider/ThemeProvider.tsx +5 -4
- package/src/components/ThemeProvider/index.ts +1 -1
- package/src/components/Toast/Toast.stories.tsx +0 -1
- package/src/components/Toast/Toast.tsx +16 -31
- package/src/components/Toolbar/Toolbar.stories.tsx +0 -1
- package/src/components/Toolbar/Toolbar.tsx +21 -35
- package/src/components/Tooltip/Tooltip.stories.tsx +6 -7
- package/src/components/Tooltip/Tooltip.tsx +15 -16
- package/src/components/index.ts +1 -0
- package/src/exemplars/generics.stories.tsx +7 -15
- package/src/exemplars/slot.stories.tsx +67 -57
- package/src/exemplars/tabster.stories.tsx +1 -1
- package/src/exemplars/virtualizer.stories.tsx +4 -4
- package/src/hooks/index.ts +1 -0
- package/src/hooks/useDensityContext.ts +2 -2
- package/src/playground/Custom.stories.tsx +6 -9
- package/src/primitives/Column/AUDIT.md +148 -0
- package/src/primitives/Column/Column.stories.tsx +122 -19
- package/src/primitives/Column/Column.tsx +73 -42
- package/src/primitives/Container/Container.stories.tsx +0 -1
- package/src/primitives/Container/Container.tsx +5 -8
- package/src/primitives/Flex/Flex.stories.tsx +0 -1
- package/src/primitives/Flex/Flex.tsx +10 -12
- package/src/primitives/Grid/Grid.stories.tsx +0 -1
- package/src/primitives/Grid/Grid.tsx +4 -9
- package/src/primitives/Panel/Panel.stories.tsx +9 -8
- package/src/primitives/Panel/Panel.tsx +64 -63
- package/src/testing/Loading.tsx +25 -4
- package/src/testing/decorators/withLayout.tsx +6 -6
- package/src/testing/decorators/withTheme.tsx +10 -7
- package/src/translations.ts +3 -3
- package/src/util/usePx.ts +1 -0
- package/dist/lib/browser/chunk-2FKSMWNY.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-ZNBLTSHI.mjs.map +0 -7
|
@@ -4,8 +4,8 @@
|
|
|
4
4
|
|
|
5
5
|
import { createContext } from '@radix-ui/react-context';
|
|
6
6
|
import React, {
|
|
7
|
-
type HTMLAttributes,
|
|
8
7
|
type PropsWithChildren,
|
|
8
|
+
type RefObject,
|
|
9
9
|
forwardRef,
|
|
10
10
|
useCallback,
|
|
11
11
|
useEffect,
|
|
@@ -17,12 +17,14 @@ import React, {
|
|
|
17
17
|
|
|
18
18
|
import { addEventListener, combine } from '@dxos/async';
|
|
19
19
|
import { invariant } from '@dxos/invariant';
|
|
20
|
-
import {
|
|
20
|
+
import { useMergeRefs } from '@dxos/react-hooks';
|
|
21
|
+
import { composable, composableProps, slottable } from '@dxos/ui-theme';
|
|
21
22
|
import { mx } from '@dxos/ui-theme';
|
|
23
|
+
import { type SlottableProps } from '@dxos/ui-types';
|
|
22
24
|
|
|
23
25
|
import { type ThemedClassName } from '../../util';
|
|
24
26
|
import { IconButton } from '../Button';
|
|
25
|
-
import { ScrollArea } from '../ScrollArea';
|
|
27
|
+
import { ScrollArea, type ScrollAreaRootProps } from '../ScrollArea';
|
|
26
28
|
|
|
27
29
|
const isBottom = (el: HTMLElement | null) => {
|
|
28
30
|
return !!(el && el.scrollHeight - el.scrollTop === el.clientHeight);
|
|
@@ -35,9 +37,15 @@ export interface ScrollController {
|
|
|
35
37
|
}
|
|
36
38
|
|
|
37
39
|
type ScrollContainerContextValue = {
|
|
38
|
-
scrollToBottom: (behavior?: ScrollBehavior) => void;
|
|
39
40
|
controller?: ScrollController;
|
|
40
41
|
pinned?: boolean;
|
|
42
|
+
overflow?: boolean;
|
|
43
|
+
/** Called by Viewport to register/unregister the scroll element. */
|
|
44
|
+
setViewport: (el: HTMLDivElement | null) => void;
|
|
45
|
+
/** Called by Viewport on wheel events to update pinned state. */
|
|
46
|
+
setPinned: (value: boolean) => void;
|
|
47
|
+
/** Called by Viewport on scroll events to update overflow state. */
|
|
48
|
+
setOverflow: (value: boolean) => void;
|
|
41
49
|
};
|
|
42
50
|
|
|
43
51
|
const [ScrollContainerProvider, useScrollContainerContext] =
|
|
@@ -47,102 +55,85 @@ const [ScrollContainerProvider, useScrollContainerContext] =
|
|
|
47
55
|
// Root
|
|
48
56
|
//
|
|
49
57
|
|
|
50
|
-
type RootProps =
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
behavior?: ScrollBehavior;
|
|
55
|
-
}>
|
|
56
|
-
>;
|
|
58
|
+
type RootProps = PropsWithChildren<{
|
|
59
|
+
pin?: boolean;
|
|
60
|
+
behavior?: ScrollBehavior;
|
|
61
|
+
}>;
|
|
57
62
|
|
|
58
63
|
/**
|
|
59
|
-
*
|
|
64
|
+
* Headless scroll container that provides context for scroll state.
|
|
65
|
+
* Render ScrollContainer.Content and ScrollContainer.Viewport as children.
|
|
60
66
|
*/
|
|
61
67
|
const Root = forwardRef<ScrollController, RootProps>(
|
|
62
|
-
({ children,
|
|
63
|
-
const scrollerRef = useRef<HTMLDivElement>(null);
|
|
68
|
+
({ children, pin, behavior: behaviorProp = 'smooth' }, forwardedRef) => {
|
|
69
|
+
const scrollerRef = useRef<HTMLDivElement | null>(null);
|
|
64
70
|
const autoScrollRef = useRef(false);
|
|
65
|
-
const [overflow, setOverflow] = useState(false);
|
|
66
71
|
const [pinned, setPinned] = useState(pin);
|
|
72
|
+
const [overflow, setOverflow] = useState(false);
|
|
67
73
|
|
|
68
74
|
const timeoutRef = useRef<NodeJS.Timeout>(undefined);
|
|
69
|
-
const scrollToBottom = useCallback(
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
75
|
+
const scrollToBottom = useCallback(
|
|
76
|
+
(behavior: ScrollBehavior = behaviorProp) => {
|
|
77
|
+
if (scrollerRef.current) {
|
|
78
|
+
if (behavior !== 'instant') {
|
|
79
|
+
// Temporarily hide scrollbar to prevent flickering during smooth scroll.
|
|
80
|
+
// For instant scrolling we skip this — there's no animation to hide,
|
|
81
|
+
// and adding the class changes element size which re-fires the ResizeObserver.
|
|
82
|
+
autoScrollRef.current = true;
|
|
83
|
+
scrollerRef.current.classList.add('scrollbar-none');
|
|
84
|
+
clearTimeout(timeoutRef.current);
|
|
85
|
+
timeoutRef.current = setTimeout(() => {
|
|
86
|
+
scrollerRef.current?.classList.remove('scrollbar-none');
|
|
87
|
+
autoScrollRef.current = false;
|
|
88
|
+
}, 500);
|
|
89
|
+
}
|
|
90
|
+
|
|
91
|
+
scrollerRef.current.scrollTo({
|
|
92
|
+
top: scrollerRef.current.scrollHeight,
|
|
93
|
+
behavior,
|
|
94
|
+
});
|
|
95
|
+
|
|
96
|
+
setPinned(true);
|
|
85
97
|
}
|
|
98
|
+
},
|
|
99
|
+
[behaviorProp],
|
|
100
|
+
);
|
|
86
101
|
|
|
87
|
-
|
|
88
|
-
}
|
|
89
|
-
}, []);
|
|
90
|
-
|
|
91
|
-
const controller = useMemo(
|
|
102
|
+
const controller = useMemo<ScrollController>(
|
|
92
103
|
() => ({
|
|
93
|
-
viewport
|
|
104
|
+
get viewport() {
|
|
105
|
+
return scrollerRef.current;
|
|
106
|
+
},
|
|
94
107
|
scrollToTop: () => {
|
|
95
108
|
invariant(scrollerRef.current);
|
|
96
109
|
scrollerRef.current.scrollTo({ top: 0, behavior: 'smooth' });
|
|
97
110
|
setPinned(false);
|
|
98
111
|
},
|
|
99
|
-
scrollToBottom: () => {
|
|
100
|
-
scrollToBottom(
|
|
112
|
+
scrollToBottom: (behavior = 'smooth' as ScrollBehavior) => {
|
|
113
|
+
scrollToBottom(behavior);
|
|
101
114
|
},
|
|
102
115
|
}),
|
|
103
|
-
[scrollToBottom
|
|
116
|
+
[scrollToBottom],
|
|
104
117
|
);
|
|
105
118
|
|
|
106
119
|
// Scroll controller imperative ref.
|
|
107
120
|
useImperativeHandle(forwardedRef, () => controller, [controller]);
|
|
108
121
|
|
|
109
|
-
//
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
return;
|
|
113
|
-
}
|
|
114
|
-
|
|
115
|
-
return combine(
|
|
116
|
-
// Check if user scrolls.
|
|
117
|
-
addEventListener(scrollerRef.current, 'wheel', () => {
|
|
118
|
-
setPinned(isBottom(scrollerRef.current));
|
|
119
|
-
}),
|
|
120
|
-
// Check if scrolls.
|
|
121
|
-
addEventListener(scrollerRef.current, 'scroll', () => {
|
|
122
|
-
setOverflow((scrollerRef.current?.scrollTop ?? 0) > 0);
|
|
123
|
-
}),
|
|
124
|
-
);
|
|
122
|
+
// Called by Viewport when the scroll element mounts/unmounts.
|
|
123
|
+
const setViewport = useCallback((el: HTMLDivElement | null) => {
|
|
124
|
+
scrollerRef.current = el;
|
|
125
125
|
}, []);
|
|
126
126
|
|
|
127
127
|
return (
|
|
128
|
-
<ScrollContainerProvider
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
'opacity-0 duration-200 transition-opacity data-[visible="true"]:opacity-100',
|
|
138
|
-
'bg-gradient-to-b from-(--surface-bg) to-transparent pointer-events-none',
|
|
139
|
-
)}
|
|
140
|
-
/>
|
|
141
|
-
)}
|
|
142
|
-
<ScrollArea.Root classNames={mx('min-h-0', classNames)} thin>
|
|
143
|
-
<ScrollArea.Viewport ref={scrollerRef}>{children}</ScrollArea.Viewport>
|
|
144
|
-
</ScrollArea.Root>
|
|
145
|
-
</div>
|
|
128
|
+
<ScrollContainerProvider
|
|
129
|
+
pinned={pinned}
|
|
130
|
+
overflow={overflow}
|
|
131
|
+
controller={controller}
|
|
132
|
+
setViewport={setViewport}
|
|
133
|
+
setPinned={setPinned}
|
|
134
|
+
setOverflow={setOverflow}
|
|
135
|
+
>
|
|
136
|
+
{children}
|
|
146
137
|
</ScrollContainerProvider>
|
|
147
138
|
);
|
|
148
139
|
},
|
|
@@ -150,41 +141,155 @@ const Root = forwardRef<ScrollController, RootProps>(
|
|
|
150
141
|
|
|
151
142
|
Root.displayName = 'ScrollContainer.Root';
|
|
152
143
|
|
|
144
|
+
//
|
|
145
|
+
// Content
|
|
146
|
+
//
|
|
147
|
+
|
|
148
|
+
type ContentProps = Pick<ScrollAreaRootProps, 'thin' | 'padding' | 'centered'>;
|
|
149
|
+
|
|
150
|
+
/**
|
|
151
|
+
* Composable wrapper around ScrollArea.Root.
|
|
152
|
+
* Provides the DOM structure for the scroll container.
|
|
153
|
+
*/
|
|
154
|
+
const Content = composable<HTMLDivElement, ContentProps>(
|
|
155
|
+
({ children, thin, padding, centered, ...props }, forwardedRef) => {
|
|
156
|
+
return (
|
|
157
|
+
<ScrollArea.Root
|
|
158
|
+
{...composableProps(props, { classNames: 'relative' })}
|
|
159
|
+
thin={thin}
|
|
160
|
+
padding={padding}
|
|
161
|
+
centered={centered}
|
|
162
|
+
ref={forwardedRef}
|
|
163
|
+
>
|
|
164
|
+
{children}
|
|
165
|
+
</ScrollArea.Root>
|
|
166
|
+
);
|
|
167
|
+
},
|
|
168
|
+
);
|
|
169
|
+
|
|
170
|
+
Content.displayName = 'ScrollContainer.Content';
|
|
171
|
+
|
|
153
172
|
//
|
|
154
173
|
// Viewport
|
|
155
174
|
//
|
|
156
175
|
|
|
157
176
|
const VIEWPORT_NAME = 'ScrollContainer.Viewport';
|
|
158
177
|
|
|
159
|
-
type ViewportProps =
|
|
178
|
+
type ViewportProps = SlottableProps;
|
|
160
179
|
|
|
161
|
-
const Viewport =
|
|
162
|
-
const
|
|
163
|
-
const
|
|
180
|
+
const Viewport = slottable<HTMLDivElement, ViewportProps>(({ children, asChild, ...props }, forwardedRef) => {
|
|
181
|
+
const scrollerRef = useRef<HTMLDivElement>(null);
|
|
182
|
+
const mergedRef = useMergeRefs([forwardedRef, scrollerRef]);
|
|
183
|
+
const { setViewport, setPinned, setOverflow } = useScrollContainerContext(VIEWPORT_NAME);
|
|
164
184
|
|
|
185
|
+
// Register the scroll element with Root and set up wheel/scroll listeners.
|
|
165
186
|
useEffect(() => {
|
|
166
|
-
|
|
187
|
+
const el = scrollerRef.current;
|
|
188
|
+
if (!el) {
|
|
167
189
|
return;
|
|
168
190
|
}
|
|
169
191
|
|
|
170
|
-
|
|
171
|
-
scrollToBottom();
|
|
192
|
+
setViewport(el);
|
|
172
193
|
|
|
173
|
-
|
|
174
|
-
|
|
175
|
-
|
|
176
|
-
|
|
177
|
-
|
|
194
|
+
return combine(
|
|
195
|
+
addEventListener(el, 'wheel', () => setPinned(isBottom(el))),
|
|
196
|
+
addEventListener(el, 'scroll', () => setOverflow((el.scrollTop ?? 0) > 0)),
|
|
197
|
+
() => setViewport(null),
|
|
198
|
+
);
|
|
199
|
+
}, [setViewport, setPinned, setOverflow]);
|
|
178
200
|
|
|
179
201
|
return (
|
|
180
|
-
|
|
181
|
-
{
|
|
182
|
-
|
|
202
|
+
<>
|
|
203
|
+
<ScrollArea.Viewport asChild={asChild} {...composableProps(props)} ref={mergedRef}>
|
|
204
|
+
{children}
|
|
205
|
+
</ScrollArea.Viewport>
|
|
206
|
+
<PinEffect scrollerRef={scrollerRef} />
|
|
207
|
+
</>
|
|
183
208
|
);
|
|
184
209
|
});
|
|
185
210
|
|
|
186
211
|
Viewport.displayName = VIEWPORT_NAME;
|
|
187
212
|
|
|
213
|
+
/**
|
|
214
|
+
* Isolated component that consumes pinned/controller from context.
|
|
215
|
+
* Kept separate so that Viewport does not re-render when pinned changes.
|
|
216
|
+
*/
|
|
217
|
+
const PIN_EFFECT_NAME = 'ScrollContainer.PinEffect';
|
|
218
|
+
|
|
219
|
+
const PinEffect = ({ scrollerRef }: { scrollerRef: RefObject<HTMLDivElement | null> }) => {
|
|
220
|
+
const { pinned, controller } = useScrollContainerContext(PIN_EFFECT_NAME);
|
|
221
|
+
|
|
222
|
+
// Pin scroll to bottom when content changes.
|
|
223
|
+
useEffect(() => {
|
|
224
|
+
const viewport = scrollerRef.current;
|
|
225
|
+
if (!pinned || !viewport) {
|
|
226
|
+
return;
|
|
227
|
+
}
|
|
228
|
+
|
|
229
|
+
// Scroll instantly so we don't visually jump while content is being added.
|
|
230
|
+
controller?.scrollToBottom('instant');
|
|
231
|
+
|
|
232
|
+
// Setup resize observer on content children to detect size changes (e.g. streaming).
|
|
233
|
+
// We observe children rather than the viewport itself, because the viewport's size
|
|
234
|
+
// stays fixed — only its content grows.
|
|
235
|
+
// Use instant scroll in the callback — smooth scrolling adds/removes the
|
|
236
|
+
// scrollbar-none class, which changes the element size and re-fires the
|
|
237
|
+
// observer, creating an infinite loop.
|
|
238
|
+
const resizeObserver = new ResizeObserver(() => controller?.scrollToBottom('smooth'));
|
|
239
|
+
Array.from(viewport.children).forEach((child) => {
|
|
240
|
+
resizeObserver.observe(child);
|
|
241
|
+
});
|
|
242
|
+
|
|
243
|
+
// Watch for added/removed children.
|
|
244
|
+
const mutationObserver = new MutationObserver((mutations) => {
|
|
245
|
+
mutations.forEach((mutation) => {
|
|
246
|
+
mutation.addedNodes.forEach((node) => {
|
|
247
|
+
if (node instanceof Element) {
|
|
248
|
+
resizeObserver.observe(node);
|
|
249
|
+
}
|
|
250
|
+
});
|
|
251
|
+
});
|
|
252
|
+
|
|
253
|
+
controller?.scrollToBottom('smooth');
|
|
254
|
+
});
|
|
255
|
+
mutationObserver.observe(viewport, { childList: true });
|
|
256
|
+
|
|
257
|
+
return () => {
|
|
258
|
+
resizeObserver.disconnect();
|
|
259
|
+
mutationObserver.disconnect();
|
|
260
|
+
};
|
|
261
|
+
}, [pinned, controller, scrollerRef]);
|
|
262
|
+
|
|
263
|
+
return null;
|
|
264
|
+
};
|
|
265
|
+
|
|
266
|
+
//
|
|
267
|
+
// Fade
|
|
268
|
+
//
|
|
269
|
+
|
|
270
|
+
const FADE_NAME = 'ScrollContainer.Fade';
|
|
271
|
+
|
|
272
|
+
type FadeProps = {};
|
|
273
|
+
|
|
274
|
+
const Fade = () => {
|
|
275
|
+
const { overflow } = useScrollContainerContext(FADE_NAME);
|
|
276
|
+
|
|
277
|
+
return (
|
|
278
|
+
<div
|
|
279
|
+
role='none'
|
|
280
|
+
data-visible={overflow}
|
|
281
|
+
className={mx(
|
|
282
|
+
// NOTE: Gradients may not be visible with dark reader extensions.
|
|
283
|
+
'z-10 absolute top-0 inset-x-0 h-24 w-full',
|
|
284
|
+
'opacity-0 duration-200 transition-opacity data-[visible="true"]:opacity-100',
|
|
285
|
+
'bg-gradient-to-b from-(--surface-bg) to-transparent pointer-events-none',
|
|
286
|
+
)}
|
|
287
|
+
/>
|
|
288
|
+
);
|
|
289
|
+
};
|
|
290
|
+
|
|
291
|
+
Fade.displayName = FADE_NAME;
|
|
292
|
+
|
|
188
293
|
//
|
|
189
294
|
// ScrollDownButton
|
|
190
295
|
//
|
|
@@ -194,7 +299,7 @@ const SCROLL_DOWN_BUTTON_NAME = 'ScrollContainer.ScrollDownButton';
|
|
|
194
299
|
type ScrollDownButtonProps = ThemedClassName;
|
|
195
300
|
|
|
196
301
|
const ScrollDownButton = ({ classNames }: ScrollDownButtonProps) => {
|
|
197
|
-
const { pinned,
|
|
302
|
+
const { pinned, controller } = useScrollContainerContext(SCROLL_DOWN_BUTTON_NAME);
|
|
198
303
|
|
|
199
304
|
return (
|
|
200
305
|
<div
|
|
@@ -211,7 +316,7 @@ const ScrollDownButton = ({ classNames }: ScrollDownButtonProps) => {
|
|
|
211
316
|
iconOnly
|
|
212
317
|
size={4}
|
|
213
318
|
label='Scroll down'
|
|
214
|
-
onClick={() => scrollToBottom()}
|
|
319
|
+
onClick={() => controller?.scrollToBottom()}
|
|
215
320
|
/>
|
|
216
321
|
</div>
|
|
217
322
|
);
|
|
@@ -227,12 +332,16 @@ export { useScrollContainerContext };
|
|
|
227
332
|
|
|
228
333
|
export const ScrollContainer = {
|
|
229
334
|
Root,
|
|
335
|
+
Content,
|
|
230
336
|
Viewport,
|
|
337
|
+
Fade,
|
|
231
338
|
ScrollDownButton,
|
|
232
339
|
};
|
|
233
340
|
|
|
234
341
|
export type {
|
|
235
342
|
RootProps as ScrollContainerRootProps,
|
|
343
|
+
ContentProps as ScrollContainerContentProps,
|
|
236
344
|
ViewportProps as ScrollContainerViewportProps,
|
|
345
|
+
FadeProps as ScrollContainerFadeProps,
|
|
237
346
|
ScrollDownButtonProps as ScrollContainerScrollDownButtonProps,
|
|
238
347
|
};
|
|
@@ -5,20 +5,19 @@
|
|
|
5
5
|
import { type Meta, type StoryObj } from '@storybook/react-vite';
|
|
6
6
|
import React, { useState } from 'react';
|
|
7
7
|
|
|
8
|
-
import {
|
|
8
|
+
import { random } from '@dxos/random';
|
|
9
9
|
|
|
10
10
|
import { withTheme } from '../../testing';
|
|
11
11
|
import { withLayoutVariants } from '../../testing';
|
|
12
|
-
|
|
13
12
|
import { Select } from './Select';
|
|
14
13
|
|
|
15
|
-
|
|
14
|
+
random.seed(1234);
|
|
16
15
|
|
|
17
16
|
type ItemProps = { id: string; text: string };
|
|
18
17
|
|
|
19
|
-
type
|
|
18
|
+
type DefaultStoryProps = { items: ItemProps[] };
|
|
20
19
|
|
|
21
|
-
const DefaultStory = ({ items = [] }:
|
|
20
|
+
const DefaultStory = ({ items = [] }: DefaultStoryProps) => {
|
|
22
21
|
const [value, setValue] = useState<string>();
|
|
23
22
|
return (
|
|
24
23
|
<Select.Root value={value} onValueChange={setValue}>
|
|
@@ -53,6 +52,6 @@ type Story = StoryObj<typeof meta>;
|
|
|
53
52
|
|
|
54
53
|
export const Default: Story = {
|
|
55
54
|
args: {
|
|
56
|
-
items: Array.from({ length: 16 }).map((_, i) => ({ id: `item-${i}`, text:
|
|
55
|
+
items: Array.from({ length: 16 }).map((_, i) => ({ id: `item-${i}`, text: random.lorem.word() })),
|
|
57
56
|
},
|
|
58
57
|
};
|
|
@@ -1,24 +1,21 @@
|
|
|
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}
|
|
18
|
+
orientation={orientation}
|
|
22
19
|
className={tx('separator.root', { orientation, subdued }, classNames)}
|
|
23
20
|
ref={forwardedRef}
|
|
24
21
|
/>
|
|
@@ -9,50 +9,50 @@ import { Panel } from '../../primitives';
|
|
|
9
9
|
import { withLayout, withTheme } from '../../testing';
|
|
10
10
|
import { ScrollArea } from '../ScrollArea';
|
|
11
11
|
import { Toolbar } from '../Toolbar';
|
|
12
|
-
|
|
13
12
|
import { Splitter, type SplitterRootProps } from './Splitter';
|
|
14
13
|
|
|
15
14
|
const PanelContent = forwardRef<HTMLDivElement, ComponentPropsWithoutRef<'div'> & { label: string }>(
|
|
16
|
-
({ label, ...props },
|
|
17
|
-
<
|
|
18
|
-
<Panel.
|
|
19
|
-
<
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
<
|
|
23
|
-
<ScrollArea.
|
|
24
|
-
|
|
25
|
-
{
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
</Panel.Root>
|
|
34
|
-
</div>
|
|
15
|
+
({ label, ...props }, forwardedRef) => (
|
|
16
|
+
<Panel.Root {...props} ref={forwardedRef}>
|
|
17
|
+
<Panel.Toolbar asChild>
|
|
18
|
+
<Toolbar.Root>{label}</Toolbar.Root>
|
|
19
|
+
</Panel.Toolbar>
|
|
20
|
+
<Panel.Content asChild>
|
|
21
|
+
<ScrollArea.Root orientation='vertical'>
|
|
22
|
+
<ScrollArea.Viewport>
|
|
23
|
+
{Array.from({ length: 100 }).map((_, i) => (
|
|
24
|
+
<div key={i} className='p-1'>
|
|
25
|
+
{label}-{i}
|
|
26
|
+
</div>
|
|
27
|
+
))}
|
|
28
|
+
</ScrollArea.Viewport>
|
|
29
|
+
</ScrollArea.Root>
|
|
30
|
+
</Panel.Content>
|
|
31
|
+
</Panel.Root>
|
|
35
32
|
),
|
|
36
33
|
);
|
|
37
34
|
|
|
38
35
|
const DefaultStory = (props: SplitterRootProps) => {
|
|
39
|
-
const [mode, setMode] = useState(props.mode ?? '
|
|
36
|
+
const [mode, setMode] = useState(props.mode ?? 'split');
|
|
37
|
+
const [ratio, setRatio] = useState(props.ratio ?? 0.5);
|
|
40
38
|
|
|
41
39
|
return (
|
|
42
40
|
<Panel.Root>
|
|
43
41
|
<Panel.Toolbar asChild>
|
|
44
42
|
<Toolbar.Root>
|
|
45
|
-
<Toolbar.Button onClick={() => setMode('
|
|
46
|
-
<Toolbar.Button onClick={() => setMode('
|
|
47
|
-
<Toolbar.Button onClick={() => setMode('
|
|
43
|
+
<Toolbar.Button onClick={() => setMode('top')}>A</Toolbar.Button>
|
|
44
|
+
<Toolbar.Button onClick={() => setMode('split')}>A+B</Toolbar.Button>
|
|
45
|
+
<Toolbar.Button onClick={() => setMode('bottom')}>B</Toolbar.Button>
|
|
46
|
+
<Toolbar.Separator />
|
|
47
|
+
<Toolbar.Button onClick={() => setRatio((r) => 1 - r)}>Toggle</Toolbar.Button>
|
|
48
48
|
</Toolbar.Root>
|
|
49
49
|
</Panel.Toolbar>
|
|
50
50
|
<Panel.Content asChild>
|
|
51
|
-
<Splitter.Root mode={mode} ratio={
|
|
52
|
-
<Splitter.Panel asChild position='
|
|
51
|
+
<Splitter.Root mode={mode} ratio={ratio}>
|
|
52
|
+
<Splitter.Panel asChild position='top'>
|
|
53
53
|
<PanelContent label='A' />
|
|
54
54
|
</Splitter.Panel>
|
|
55
|
-
<Splitter.Panel asChild position='
|
|
55
|
+
<Splitter.Panel asChild position='bottom'>
|
|
56
56
|
<PanelContent label='B' />
|
|
57
57
|
</Splitter.Panel>
|
|
58
58
|
</Splitter.Root>
|
|
@@ -77,7 +77,7 @@ type Story = StoryObj<SplitterRootProps>;
|
|
|
77
77
|
|
|
78
78
|
export const Default: Story = {
|
|
79
79
|
args: {
|
|
80
|
-
mode: '
|
|
81
|
-
ratio: 0.
|
|
80
|
+
mode: 'split',
|
|
81
|
+
ratio: 0.4,
|
|
82
82
|
},
|
|
83
83
|
};
|