@dxos/react-ui-stack 0.8.4-main.f5c0578 → 0.8.4-main.fcfe5033a5

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.
Files changed (103) hide show
  1. package/dist/lib/browser/index.mjs +723 -62
  2. package/dist/lib/browser/index.mjs.map +4 -4
  3. package/dist/lib/browser/meta.json +1 -1
  4. package/dist/lib/node-esm/index.mjs +724 -62
  5. package/dist/lib/node-esm/index.mjs.map +4 -4
  6. package/dist/lib/node-esm/meta.json +1 -1
  7. package/dist/types/src/components/Stack/Stack.d.ts +13 -10
  8. package/dist/types/src/components/Stack/Stack.d.ts.map +1 -1
  9. package/dist/types/src/components/Stack/Stack.stories.d.ts +12 -3
  10. package/dist/types/src/components/Stack/Stack.stories.d.ts.map +1 -1
  11. package/dist/types/src/components/StackContext.d.ts +2 -1
  12. package/dist/types/src/components/StackContext.d.ts.map +1 -1
  13. package/dist/types/src/components/StackItem/MenuSignifier.d.ts.map +1 -1
  14. package/dist/types/src/components/StackItem/StackItem.d.ts +12 -15
  15. package/dist/types/src/components/StackItem/StackItem.d.ts.map +1 -1
  16. package/dist/types/src/components/StackItem/StackItem.stories.d.ts +13 -5
  17. package/dist/types/src/components/StackItem/StackItem.stories.d.ts.map +1 -1
  18. package/dist/types/src/components/StackItem/StackItemContent.d.ts +4 -37
  19. package/dist/types/src/components/StackItem/StackItemContent.d.ts.map +1 -1
  20. package/dist/types/src/components/StackItem/StackItemDragHandle.d.ts.map +1 -1
  21. package/dist/types/src/components/StackItem/StackItemHeading.d.ts +1 -1
  22. package/dist/types/src/components/StackItem/StackItemHeading.d.ts.map +1 -1
  23. package/dist/types/src/components/StackItem/StackItemResizeHandle.d.ts +1 -1
  24. package/dist/types/src/components/StackItem/StackItemResizeHandle.d.ts.map +1 -1
  25. package/dist/types/src/components/StackItem/StackItemSigil.d.ts +2 -2
  26. package/dist/types/src/components/StackItem/StackItemSigil.d.ts.map +1 -1
  27. package/dist/types/src/components/index.d.ts +1 -1
  28. package/dist/types/src/components/index.d.ts.map +1 -1
  29. package/dist/types/src/components/{defs.d.ts → types.d.ts} +1 -1
  30. package/dist/types/src/components/types.d.ts.map +1 -0
  31. package/dist/types/src/hooks/useStackDropForElements.d.ts +8 -6
  32. package/dist/types/src/hooks/useStackDropForElements.d.ts.map +1 -1
  33. package/dist/types/src/index.d.ts +0 -1
  34. package/dist/types/src/index.d.ts.map +1 -1
  35. package/dist/types/src/translations.d.ts +10 -10
  36. package/dist/types/src/translations.d.ts.map +1 -1
  37. package/dist/types/tsconfig.tsbuildinfo +1 -1
  38. package/package.json +41 -38
  39. package/src/components/Stack/Stack.stories.tsx +13 -17
  40. package/src/components/Stack/Stack.tsx +238 -52
  41. package/src/components/StackContext.tsx +2 -1
  42. package/src/components/StackItem/MenuSignifier.tsx +2 -9
  43. package/src/components/StackItem/StackItem.stories.tsx +21 -17
  44. package/src/components/StackItem/StackItem.tsx +51 -34
  45. package/src/components/StackItem/StackItemContent.tsx +24 -44
  46. package/src/components/StackItem/StackItemDragHandle.tsx +4 -3
  47. package/src/components/StackItem/StackItemHeading.tsx +14 -17
  48. package/src/components/StackItem/StackItemResizeHandle.tsx +1 -2
  49. package/src/components/StackItem/StackItemSigil.tsx +9 -7
  50. package/src/components/index.ts +2 -1
  51. package/src/hooks/useStackDropForElements.ts +60 -46
  52. package/src/index.ts +0 -3
  53. package/src/playwright/playwright.config.ts +1 -1
  54. package/src/translations.ts +9 -9
  55. package/dist/lib/browser/chunk-WOG2GQRG.mjs +0 -1200
  56. package/dist/lib/browser/chunk-WOG2GQRG.mjs.map +0 -7
  57. package/dist/lib/browser/testing/index.mjs +0 -31
  58. package/dist/lib/browser/testing/index.mjs.map +0 -7
  59. package/dist/lib/node-esm/chunk-PO2QGNXW.mjs +0 -1202
  60. package/dist/lib/node-esm/chunk-PO2QGNXW.mjs.map +0 -7
  61. package/dist/lib/node-esm/testing/index.mjs +0 -32
  62. package/dist/lib/node-esm/testing/index.mjs.map +0 -7
  63. package/dist/types/src/components/defs.d.ts.map +0 -1
  64. package/dist/types/src/components/deprecated/LayoutControls.d.ts +0 -19
  65. package/dist/types/src/components/deprecated/LayoutControls.d.ts.map +0 -1
  66. package/dist/types/src/exemplars/Card/Card.d.ts +0 -58
  67. package/dist/types/src/exemplars/Card/Card.d.ts.map +0 -1
  68. package/dist/types/src/exemplars/Card/Card.stories.d.ts +0 -13
  69. package/dist/types/src/exemplars/Card/Card.stories.d.ts.map +0 -1
  70. package/dist/types/src/exemplars/Card/CardDragPreview.d.ts +0 -6
  71. package/dist/types/src/exemplars/Card/CardDragPreview.d.ts.map +0 -1
  72. package/dist/types/src/exemplars/Card/fragments.d.ts +0 -13
  73. package/dist/types/src/exemplars/Card/fragments.d.ts.map +0 -1
  74. package/dist/types/src/exemplars/Card/index.d.ts +0 -4
  75. package/dist/types/src/exemplars/Card/index.d.ts.map +0 -1
  76. package/dist/types/src/exemplars/CardStack/CardStack.d.ts +0 -40
  77. package/dist/types/src/exemplars/CardStack/CardStack.d.ts.map +0 -1
  78. package/dist/types/src/exemplars/CardStack/CardStack.stories.d.ts +0 -9
  79. package/dist/types/src/exemplars/CardStack/CardStack.stories.d.ts.map +0 -1
  80. package/dist/types/src/exemplars/CardStack/CardStackDragPreview.d.ts +0 -9
  81. package/dist/types/src/exemplars/CardStack/CardStackDragPreview.d.ts.map +0 -1
  82. package/dist/types/src/exemplars/CardStack/index.d.ts +0 -3
  83. package/dist/types/src/exemplars/CardStack/index.d.ts.map +0 -1
  84. package/dist/types/src/exemplars/index.d.ts +0 -3
  85. package/dist/types/src/exemplars/index.d.ts.map +0 -1
  86. package/dist/types/src/testing/CardContainer.d.ts +0 -6
  87. package/dist/types/src/testing/CardContainer.d.ts.map +0 -1
  88. package/dist/types/src/testing/index.d.ts +0 -2
  89. package/dist/types/src/testing/index.d.ts.map +0 -1
  90. package/src/components/deprecated/LayoutControls.tsx +0 -109
  91. package/src/exemplars/Card/Card.stories.tsx +0 -78
  92. package/src/exemplars/Card/Card.tsx +0 -187
  93. package/src/exemplars/Card/CardDragPreview.tsx +0 -22
  94. package/src/exemplars/Card/fragments.ts +0 -24
  95. package/src/exemplars/Card/index.ts +0 -7
  96. package/src/exemplars/CardStack/CardStack.stories.tsx +0 -173
  97. package/src/exemplars/CardStack/CardStack.tsx +0 -136
  98. package/src/exemplars/CardStack/CardStackDragPreview.tsx +0 -61
  99. package/src/exemplars/CardStack/index.ts +0 -6
  100. package/src/exemplars/index.ts +0 -6
  101. package/src/testing/CardContainer.tsx +0 -37
  102. package/src/testing/index.ts +0 -5
  103. /package/src/components/{defs.ts → types.ts} +0 -0
@@ -1,136 +0,0 @@
1
- //
2
- // Copyright 2025 DXOS.org
3
- //
4
-
5
- import { Slot } from '@radix-ui/react-slot';
6
- import React, { type ComponentPropsWithoutRef, forwardRef } from 'react';
7
-
8
- import type { ThemedClassName } from '@dxos/react-ui';
9
- import { mx } from '@dxos/react-ui-theme';
10
-
11
- import { Stack, type StackProps, railGridHorizontalContainFitContent } from '../../components';
12
- import { Card } from '../Card';
13
-
14
- type SharedCardStackProps = ThemedClassName<ComponentPropsWithoutRef<'div'>> & { asChild?: boolean };
15
-
16
- const CardStackStack = forwardRef<
17
- HTMLDivElement,
18
- Omit<StackProps, 'orientation' | 'size' | 'rail' | 'separatorOnScroll'>
19
- >(({ children, classNames, itemsCount = 0, ...props }, forwardedRef) => {
20
- return (
21
- <Stack
22
- orientation='vertical'
23
- size='contain'
24
- rail={false}
25
- classNames={
26
- /* NOTE(thure): Do not let this element have zero intrinsic size, otherwise the drop indicator will not display. See #9035. */
27
- ['plb-1', itemsCount > 0 && 'plb-2', classNames]
28
- }
29
- itemsCount={itemsCount}
30
- separatorOnScroll={9}
31
- data-density='fine'
32
- {...props}
33
- ref={forwardedRef}
34
- >
35
- {children}
36
- </Stack>
37
- );
38
- });
39
-
40
- const CardStackDragHandle = Card.DragHandle;
41
-
42
- const cardStackHeading = 'mli-2 order-first bg-transparent rounded-bs-md flex items-center';
43
-
44
- const CardStackHeading = forwardRef<HTMLDivElement, SharedCardStackProps>(
45
- ({ children, classNames, asChild, role = 'heading', ...props }, forwardedRef) => {
46
- const Root = asChild ? Slot : 'div';
47
- const rootProps = asChild
48
- ? { classNames: [cardStackHeading, classNames] }
49
- : { className: mx(cardStackHeading, classNames), role };
50
- return (
51
- <Root {...props} {...rootProps} ref={forwardedRef}>
52
- {children}
53
- </Root>
54
- );
55
- },
56
- );
57
-
58
- const cardStackFooter =
59
- 'plb-2 mli-2 border-bs border-transparent [[data-scroll-separator-end="true"]_&]:border-subduedSeparator';
60
-
61
- const CardStackFooter = forwardRef<HTMLDivElement, SharedCardStackProps>(
62
- ({ children, classNames, asChild, role = 'none', ...props }, forwardedRef) => {
63
- const Root = asChild ? Slot : 'div';
64
- const rootProps = asChild
65
- ? { classNames: [cardStackFooter, classNames] }
66
- : { className: mx(cardStackFooter, classNames), role };
67
- return (
68
- <Root {...props} {...rootProps} ref={forwardedRef}>
69
- {children}
70
- </Root>
71
- );
72
- },
73
- );
74
-
75
- const cardStackContent = [
76
- 'shrink min-bs-0 bg-baseSurface border border-separator rounded-md grid dx-focus-ring-group-x-indicator kanban-drop',
77
- railGridHorizontalContainFitContent,
78
- ];
79
-
80
- const CardStackContent = forwardRef<HTMLDivElement, SharedCardStackProps>(
81
- ({ children, classNames, asChild, role = 'none', ...props }, forwardedRef) => {
82
- const Root = asChild ? Slot : 'div';
83
- const rootProps = asChild
84
- ? { classNames: [...cardStackContent, classNames] }
85
- : { className: mx(...cardStackContent, classNames), role };
86
- return (
87
- <Root {...props} {...rootProps} data-scroll-separator='false' ref={forwardedRef}>
88
- {children}
89
- </Root>
90
- );
91
- },
92
- );
93
-
94
- const cardStackRoot = 'flex flex-col pli-2 plb-2';
95
-
96
- const CardStackRoot = forwardRef<HTMLDivElement, SharedCardStackProps>(
97
- ({ children, classNames, asChild, role = 'none', ...props }, forwardedRef) => {
98
- const Root = asChild ? Slot : 'div';
99
- const rootProps = asChild
100
- ? { classNames: [cardStackRoot, classNames] }
101
- : { className: mx(cardStackRoot, classNames), role };
102
- return (
103
- <Root {...props} {...rootProps} ref={forwardedRef}>
104
- {children}
105
- </Root>
106
- );
107
- },
108
- );
109
-
110
- const cardStackItem = 'contain-layout pli-2 plb-1 first-of-type:pbs-0 last-of-type:pbe-0';
111
-
112
- const CardStackItem = forwardRef<HTMLDivElement, SharedCardStackProps>(
113
- ({ children, classNames, asChild, role = 'none', ...props }, forwardedRef) => {
114
- const Root = asChild ? Slot : 'div';
115
- const rootProps = asChild
116
- ? { classNames: [cardStackItem, classNames] }
117
- : { className: mx(cardStackItem, classNames), role };
118
- return (
119
- <Root {...props} {...rootProps} ref={forwardedRef}>
120
- {children}
121
- </Root>
122
- );
123
- },
124
- );
125
-
126
- export const CardStack = {
127
- Root: CardStackRoot,
128
- Content: CardStackContent,
129
- Stack: CardStackStack,
130
- Heading: CardStackHeading,
131
- Footer: CardStackFooter,
132
- DragHandle: CardStackDragHandle,
133
- Item: CardStackItem,
134
- };
135
-
136
- export { cardStackRoot, cardStackFooter, cardStackHeading, cardStackContent, cardStackItem };
@@ -1,61 +0,0 @@
1
- //
2
- // Copyright 2025 DXOS.org
3
- //
4
-
5
- import React, { type PropsWithChildren } from 'react';
6
-
7
- import { IconButton, useTranslation } from '@dxos/react-ui';
8
- import { mx } from '@dxos/react-ui-theme';
9
-
10
- import { type StackProps } from '../../components';
11
- import { translationKey } from '../../translations';
12
-
13
- const CardStackDragPreviewRoot = ({ children }: PropsWithChildren<{}>) => {
14
- return (
15
- <div className='p-2'>
16
- <div className='rounded-md max-bs-[calc(100dvh-1rem)] overflow-hidden bg-baseSurface border border-separator ring-focusLine ring-neutralFocusIndicator flex flex-col'>
17
- {children}
18
- </div>
19
- </div>
20
- );
21
- };
22
-
23
- const CardStackDragPreviewHeading = ({ children }: PropsWithChildren<{}>) => {
24
- const { t } = useTranslation(translationKey);
25
- return (
26
- <div className='flex items-center p-2'>
27
- <IconButton
28
- iconOnly
29
- icon='ph--dots-six-vertical--regular'
30
- variant='ghost'
31
- label={t('column drag handle label')}
32
- classNames='pli-2'
33
- />
34
- {children}
35
- </div>
36
- );
37
- };
38
-
39
- const CardStackDragPreviewContent = ({
40
- children,
41
- itemsCount = 0,
42
- }: PropsWithChildren<Pick<StackProps, 'itemsCount'>>) => {
43
- return (
44
- <div
45
- className={mx('overflow-y-auto flex-1 pli-2 flex flex-col gap-2', 'plb-1', itemsCount > 0 ? 'plb-2' : 'plb-1')}
46
- >
47
- {children}
48
- </div>
49
- );
50
- };
51
-
52
- const CardStackDragPreviewFooter = ({ children }: PropsWithChildren<{}>) => {
53
- return <div className='p-2 border-t border-separator'>{children}</div>;
54
- };
55
-
56
- export const CardStackDragPreview = {
57
- Root: CardStackDragPreviewRoot,
58
- Heading: CardStackDragPreviewHeading,
59
- Content: CardStackDragPreviewContent,
60
- Footer: CardStackDragPreviewFooter,
61
- };
@@ -1,6 +0,0 @@
1
- //
2
- // Copyright 2025 DXOS.org
3
- //
4
-
5
- export * from './CardStack';
6
- export * from './CardStackDragPreview';
@@ -1,6 +0,0 @@
1
- //
2
- // Copyright 2023 DXOS.org
3
- //
4
-
5
- export * from './Card';
6
- export * from './CardStack';
@@ -1,37 +0,0 @@
1
- //
2
- // Copyright 2025 DXOS.org
3
- //
4
-
5
- import React, { type PropsWithChildren } from 'react';
6
-
7
- import { ExtrinsicCardContainer, IntrinsicCardContainer, PopoverCardContainer } from '@dxos/storybook-utils';
8
-
9
- import { Card } from '../exemplars';
10
-
11
- export const CardContainer = ({
12
- children,
13
- icon = 'ph--placeholder--regular',
14
- role,
15
- }: PropsWithChildren<{ icon?: string; role?: string }>) => {
16
- switch (role) {
17
- case 'card--popover':
18
- return <PopoverCardContainer icon={icon}>{children}</PopoverCardContainer>;
19
-
20
- case 'card--extrinsic':
21
- return (
22
- <ExtrinsicCardContainer>
23
- <Card.StaticRoot>{children}</Card.StaticRoot>
24
- </ExtrinsicCardContainer>
25
- );
26
-
27
- case 'card--intrinsic':
28
- return (
29
- <IntrinsicCardContainer>
30
- <Card.StaticRoot>{children}</Card.StaticRoot>
31
- </IntrinsicCardContainer>
32
- );
33
-
34
- default:
35
- return <Card.StaticRoot>{children}</Card.StaticRoot>;
36
- }
37
- };
@@ -1,5 +0,0 @@
1
- //
2
- // Copyright 2023 DXOS.org
3
- //
4
-
5
- export * from './CardContainer';
File without changes