@dxos/plugin-testing 0.8.4-main.c85a9c8dae → 0.8.4-main.fcc0d83b33

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 (100) hide show
  1. package/dist/lib/browser/harness.mjs +35 -0
  2. package/dist/lib/browser/harness.mjs.map +7 -0
  3. package/dist/lib/browser/index.mjs +21 -166
  4. package/dist/lib/browser/index.mjs.map +4 -4
  5. package/dist/lib/browser/meta.json +1 -1
  6. package/dist/lib/node-esm/harness.mjs +37 -0
  7. package/dist/lib/node-esm/harness.mjs.map +7 -0
  8. package/dist/lib/node-esm/index.mjs +21 -165
  9. package/dist/lib/node-esm/index.mjs.map +4 -4
  10. package/dist/lib/node-esm/meta.json +1 -1
  11. package/dist/types/src/StorybookPlugin.d.ts +1 -1
  12. package/dist/types/src/StorybookPlugin.d.ts.map +1 -1
  13. package/dist/types/src/capabilities/index.d.ts +15 -2
  14. package/dist/types/src/capabilities/index.d.ts.map +1 -1
  15. package/dist/types/src/capabilities/operation-handler.d.ts +6 -0
  16. package/dist/types/src/capabilities/operation-handler.d.ts.map +1 -0
  17. package/dist/types/src/capabilities/{state/state.d.ts → state.d.ts} +1 -1
  18. package/dist/types/src/capabilities/state.d.ts.map +1 -0
  19. package/dist/types/src/components/Layout/Layout.d.ts.map +1 -0
  20. package/dist/types/src/components/Layout/index.d.ts +2 -0
  21. package/dist/types/src/components/Layout/index.d.ts.map +1 -0
  22. package/dist/types/src/core.d.ts +1 -7
  23. package/dist/types/src/core.d.ts.map +1 -1
  24. package/dist/types/src/harness.d.ts +20 -0
  25. package/dist/types/src/harness.d.ts.map +1 -0
  26. package/dist/types/src/operations/add-toast.d.ts +5 -0
  27. package/dist/types/src/operations/add-toast.d.ts.map +1 -0
  28. package/dist/types/src/operations/close.d.ts +5 -0
  29. package/dist/types/src/operations/close.d.ts.map +1 -0
  30. package/dist/types/src/operations/index.d.ts +3 -0
  31. package/dist/types/src/operations/index.d.ts.map +1 -0
  32. package/dist/types/src/operations/open.d.ts +5 -0
  33. package/dist/types/src/operations/open.d.ts.map +1 -0
  34. package/dist/types/src/operations/scroll-into-view.d.ts +5 -0
  35. package/dist/types/src/operations/scroll-into-view.d.ts.map +1 -0
  36. package/dist/types/src/operations/set-layout-mode.d.ts +5 -0
  37. package/dist/types/src/operations/set-layout-mode.d.ts.map +1 -0
  38. package/dist/types/src/operations/switch-workspace.d.ts +5 -0
  39. package/dist/types/src/operations/switch-workspace.d.ts.map +1 -0
  40. package/dist/types/src/operations/update-complementary.d.ts +5 -0
  41. package/dist/types/src/operations/update-complementary.d.ts.map +1 -0
  42. package/dist/types/src/operations/update-dialog.d.ts +5 -0
  43. package/dist/types/src/operations/update-dialog.d.ts.map +1 -0
  44. package/dist/types/src/operations/update-popover.d.ts +5 -0
  45. package/dist/types/src/operations/update-popover.d.ts.map +1 -0
  46. package/dist/types/src/operations/update-sidebar.d.ts +5 -0
  47. package/dist/types/src/operations/update-sidebar.d.ts.map +1 -0
  48. package/dist/types/src/operations/update-state.d.ts +5 -0
  49. package/dist/types/src/operations/update-state.d.ts.map +1 -0
  50. package/dist/types/src/types/capabilities.d.ts +2 -0
  51. package/dist/types/src/types/capabilities.d.ts.map +1 -1
  52. package/dist/types/tsconfig.tsbuildinfo +1 -1
  53. package/package.json +30 -18
  54. package/src/StorybookPlugin.ts +7 -7
  55. package/src/capabilities/index.ts +8 -2
  56. package/src/capabilities/operation-handler.ts +16 -0
  57. package/src/capabilities/{state/state.tsx → state.tsx} +2 -1
  58. package/src/components/Layout/Layout.tsx +236 -0
  59. package/src/components/Layout/index.ts +5 -0
  60. package/src/core.ts +0 -5
  61. package/src/harness.ts +52 -0
  62. package/src/meta.ts +1 -1
  63. package/src/operations/add-toast.ts +22 -0
  64. package/src/operations/close.ts +14 -0
  65. package/src/operations/index.ts +18 -0
  66. package/src/operations/open.ts +18 -0
  67. package/src/operations/scroll-into-view.ts +14 -0
  68. package/src/operations/set-layout-mode.ts +14 -0
  69. package/src/operations/switch-workspace.ts +20 -0
  70. package/src/operations/update-complementary.ts +27 -0
  71. package/src/operations/update-dialog.ts +27 -0
  72. package/src/operations/update-popover.ts +37 -0
  73. package/src/operations/update-sidebar.ts +26 -0
  74. package/src/operations/update-state.ts +17 -0
  75. package/src/types/capabilities.ts +5 -2
  76. package/dist/lib/browser/chunk-YHPXIILW.mjs +0 -21
  77. package/dist/lib/browser/chunk-YHPXIILW.mjs.map +0 -7
  78. package/dist/lib/browser/operation-resolver-FLU4ZARD.mjs +0 -112
  79. package/dist/lib/browser/operation-resolver-FLU4ZARD.mjs.map +0 -7
  80. package/dist/lib/browser/state-MIKI67FF.mjs +0 -43
  81. package/dist/lib/browser/state-MIKI67FF.mjs.map +0 -7
  82. package/dist/lib/node-esm/chunk-OWK6XE6C.mjs +0 -23
  83. package/dist/lib/node-esm/chunk-OWK6XE6C.mjs.map +0 -7
  84. package/dist/lib/node-esm/operation-resolver-NWF6KBHP.mjs +0 -113
  85. package/dist/lib/node-esm/operation-resolver-NWF6KBHP.mjs.map +0 -7
  86. package/dist/lib/node-esm/state-JQVVUKO2.mjs +0 -44
  87. package/dist/lib/node-esm/state-JQVVUKO2.mjs.map +0 -7
  88. package/dist/types/src/capabilities/operation-resolver/index.d.ts +0 -3
  89. package/dist/types/src/capabilities/operation-resolver/index.d.ts.map +0 -1
  90. package/dist/types/src/capabilities/operation-resolver/operation-resolver.d.ts +0 -5
  91. package/dist/types/src/capabilities/operation-resolver/operation-resolver.d.ts.map +0 -1
  92. package/dist/types/src/capabilities/state/index.d.ts +0 -14
  93. package/dist/types/src/capabilities/state/index.d.ts.map +0 -1
  94. package/dist/types/src/capabilities/state/state.d.ts.map +0 -1
  95. package/dist/types/src/components/Layout.d.ts.map +0 -1
  96. package/src/capabilities/operation-resolver/index.ts +0 -7
  97. package/src/capabilities/operation-resolver/operation-resolver.ts +0 -99
  98. package/src/capabilities/state/index.ts +0 -7
  99. package/src/components/Layout.tsx +0 -176
  100. /package/dist/types/src/components/{Layout.d.ts → Layout/Layout.d.ts} +0 -0
@@ -1,99 +0,0 @@
1
- //
2
- // Copyright 2025 DXOS.org
3
- //
4
-
5
- import * as Effect from 'effect/Effect';
6
-
7
- import { Capabilities, Capability } from '@dxos/app-framework';
8
- import { LayoutOperation } from '@dxos/app-toolkit';
9
- import { OperationResolver } from '@dxos/operation';
10
-
11
- import { LayoutState, type LayoutStateProps } from '../../types';
12
-
13
- export default Capability.makeModule(
14
- Effect.fnUntraced(function* () {
15
- const registry = yield* Capability.get(Capabilities.AtomRegistry);
16
- const stateAtom = yield* Capability.get(LayoutState);
17
-
18
- const updateState = (fn: (state: LayoutStateProps) => Partial<LayoutStateProps>) => {
19
- const current = registry.get(stateAtom);
20
- registry.set(stateAtom, { ...current, ...fn(current) });
21
- };
22
-
23
- return Capability.contributes(Capabilities.OperationResolver, [
24
- OperationResolver.make({
25
- operation: LayoutOperation.UpdateSidebar,
26
- handler: Effect.fnUntraced(function* ({ state }) {
27
- updateState((layout) => {
28
- const next = state ?? layout.sidebarState;
29
- if (next !== layout.sidebarState) {
30
- return { sidebarState: next };
31
- }
32
- return {};
33
- });
34
- }),
35
- }),
36
- OperationResolver.make({
37
- operation: LayoutOperation.UpdateComplementary,
38
- handler: Effect.fnUntraced(function* ({ state }) {
39
- updateState((layout) => {
40
- const next = state ?? layout.complementarySidebarState;
41
- if (next !== layout.complementarySidebarState) {
42
- return { complementarySidebarState: next };
43
- }
44
- return {};
45
- });
46
- }),
47
- }),
48
- OperationResolver.make({
49
- operation: LayoutOperation.UpdateDialog,
50
- handler: Effect.fnUntraced(function* ({
51
- subject,
52
- state,
53
- type,
54
- blockAlign,
55
- overlayClasses,
56
- overlayStyle,
57
- props,
58
- }) {
59
- updateState(() => ({
60
- dialogOpen: state ?? Boolean(subject),
61
- dialogType: type ?? 'default',
62
- dialogBlockAlign: blockAlign ?? 'center',
63
- dialogOverlayClasses: overlayClasses,
64
- dialogOverlayStyle: overlayStyle,
65
- dialogContent: subject ? { component: subject, props } : null,
66
- }));
67
- }),
68
- }),
69
- OperationResolver.make({
70
- operation: LayoutOperation.UpdatePopover,
71
- handler: Effect.fnUntraced(function* (input) {
72
- const { subject, state, side, kind, props } = input;
73
- updateState(() => {
74
- const base: Partial<LayoutStateProps> = {
75
- popoverKind: kind ?? 'base',
76
- popoverTitle: kind === 'card' ? input.title : undefined,
77
- popoverContent:
78
- typeof subject === 'string' ? { component: subject, props } : subject ? { subject } : undefined,
79
- popoverOpen: state ?? Boolean(subject),
80
- popoverSide: side,
81
- };
82
- if ('variant' in input && input.variant === 'virtual') {
83
- return { ...base, popoverVariant: 'virtual', popoverAnchor: input.anchor };
84
- } else if ('anchorId' in input) {
85
- return { ...base, popoverVariant: 'react', popoverAnchorId: input.anchorId };
86
- }
87
- return base;
88
- });
89
- }),
90
- }),
91
- OperationResolver.make({
92
- operation: LayoutOperation.SwitchWorkspace,
93
- handler: Effect.fnUntraced(function* ({ subject }) {
94
- updateState(() => ({ workspace: subject }));
95
- }),
96
- }),
97
- ]);
98
- }),
99
- );
@@ -1,7 +0,0 @@
1
- //
2
- // Copyright 2025 DXOS.org
3
- //
4
-
5
- import { Capability } from '@dxos/app-framework';
6
-
7
- export const State = Capability.lazy('State', () => import('./state'));
@@ -1,176 +0,0 @@
1
- //
2
- // Copyright 2023 DXOS.org
3
- //
4
-
5
- import { RegistryContext, useAtomValue } from '@effect-atom/atom-react';
6
- import React, { type PropsWithChildren, useCallback, useContext, useEffect, useRef, useState } from 'react';
7
-
8
- import { Surface, useCapability } from '@dxos/app-framework/ui';
9
- import {
10
- AlertDialog,
11
- Dialog,
12
- Main,
13
- Popover,
14
- type PopoverContentInteractOutsideEvent,
15
- toLocalizedString,
16
- useTranslation,
17
- } from '@dxos/react-ui';
18
- import { Card } from '@dxos/react-ui';
19
- import { Mosaic } from '@dxos/react-ui-mosaic';
20
- import { descriptionMessage, mx } from '@dxos/ui-theme';
21
-
22
- import { meta } from '../meta';
23
- import { LayoutState, type LayoutStateProps } from '../types';
24
-
25
- const debounce_delay = 100;
26
-
27
- // TODO(wittjosiah): Support dialogs, tooltips, maybe toast.
28
- export const Layout = ({ children }: PropsWithChildren<{}>) => {
29
- const { t } = useTranslation(meta.id);
30
- const trigger = useRef<HTMLButtonElement | null>(null);
31
- const registry = useContext(RegistryContext);
32
- const stateAtom = useCapability(LayoutState);
33
- const layout = useAtomValue(stateAtom);
34
- const [iter, setIter] = useState(0);
35
- const [open, setOpen] = useState(false);
36
- const debounceRef = useRef<NodeJS.Timeout | null>(null);
37
-
38
- const updateState = useCallback(
39
- (updates: Partial<LayoutStateProps>) => {
40
- const current = registry.get(stateAtom);
41
- registry.set(stateAtom, { ...current, ...updates });
42
- },
43
- [registry, stateAtom],
44
- );
45
-
46
- useEffect(() => {
47
- setOpen(false);
48
- if (debounceRef.current) {
49
- clearTimeout(debounceRef.current);
50
- debounceRef.current = null;
51
- }
52
- trigger.current = layout.popoverAnchor ?? null;
53
- setIter((iter) => iter + 1);
54
- if (layout.popoverOpen) {
55
- debounceRef.current = setTimeout(() => setOpen(true), debounce_delay);
56
- }
57
- }, [layout.popoverAnchor, layout.popoverContent, layout.popoverOpen]);
58
-
59
- const handleClose = useCallback(() => {
60
- setOpen(false);
61
- updateState({
62
- popoverOpen: false,
63
- popoverAnchor: undefined,
64
- popoverAnchorId: undefined,
65
- popoverSide: undefined,
66
- });
67
- }, [updateState]);
68
-
69
- const handleInteractOutside = useCallback(
70
- (event: KeyboardEvent | PopoverContentInteractOutsideEvent) => {
71
- if (
72
- // TODO(thure): CodeMirror should not focus itself when it updates.
73
- event.type === 'dismissableLayer.focusOutside' &&
74
- (event.currentTarget as HTMLElement | undefined)?.classList.contains('cm-content')
75
- ) {
76
- event.preventDefault();
77
- } else {
78
- handleClose();
79
- }
80
- },
81
- [handleClose],
82
- );
83
-
84
- const DialogRoot = layout.dialogType === 'alert' ? AlertDialog.Root : Dialog.Root;
85
- const DialogOverlay = layout.dialogType === 'alert' ? AlertDialog.Overlay : Dialog.Overlay;
86
-
87
- return (
88
- <div role='none' className='fixed inset-0 flex overflow-hidden'>
89
- <Mosaic.Root>
90
- <Popover.Root open={open}>
91
- <Main.Root
92
- navigationSidebarState={layout.sidebarState}
93
- complementarySidebarState={layout.complementarySidebarState}
94
- onNavigationSidebarStateChange={(next) => updateState({ sidebarState: next })}
95
- onComplementarySidebarStateChange={(next) => updateState({ complementarySidebarState: next })}
96
- >
97
- {children}
98
- </Main.Root>
99
-
100
- <DialogRoot
101
- modal={layout.dialogBlockAlign !== 'end'}
102
- open={layout.dialogOpen}
103
- onOpenChange={(nextOpen) => updateState({ dialogOpen: nextOpen })}
104
- >
105
- {layout.dialogBlockAlign === 'end' ? (
106
- <Surface.Surface
107
- role='dialog'
108
- data={layout.dialogContent}
109
- limit={1}
110
- fallback={ErrorFallback}
111
- placeholder={<div />}
112
- />
113
- ) : (
114
- <DialogOverlay
115
- blockAlign={layout.dialogBlockAlign}
116
- classNames={layout.dialogOverlayClasses}
117
- style={layout.dialogOverlayStyle}
118
- >
119
- <Surface.Surface role='dialog' data={layout.dialogContent} limit={1} fallback={ErrorFallback} />
120
- </DialogOverlay>
121
- )}
122
- </DialogRoot>
123
-
124
- <Popover.VirtualTrigger key={iter} virtualRef={trigger} />
125
- <Popover.Portal>
126
- <Popover.Content
127
- side={layout.popoverSide}
128
- onInteractOutside={handleInteractOutside}
129
- onEscapeKeyDown={handleInteractOutside}
130
- sticky='always'
131
- hideWhenDetached
132
- >
133
- <Popover.Viewport>
134
- {layout.popoverKind === 'card' && (
135
- <Card.Root>
136
- <Card.Toolbar>
137
- {/* TODO(wittjosiah): Cleaner way to handle no drag handle in toolbar? */}
138
- <span />
139
- {layout.popoverTitle ? (
140
- <Card.Title>{toLocalizedString(layout.popoverTitle, t)}</Card.Title>
141
- ) : (
142
- <span />
143
- )}
144
- <Card.CloseIconButton onClick={handleClose} />
145
- </Card.Toolbar>
146
- <Surface.Surface role='card--content' data={layout.popoverContent} limit={1} />
147
- </Card.Root>
148
- )}
149
- {layout.popoverKind === 'base' && (
150
- <Surface.Surface role='popover' data={layout.popoverContent} limit={1} />
151
- )}
152
- </Popover.Viewport>
153
- <Popover.Arrow />
154
- </Popover.Content>
155
- </Popover.Portal>
156
- </Popover.Root>
157
- </Mosaic.Root>
158
- </div>
159
- );
160
- };
161
-
162
- export const ErrorFallback = ({ error }: { error?: Error }) => {
163
- const { t } = useTranslation(meta.id);
164
- const errorString = error?.toString() ?? '';
165
- return (
166
- <div
167
- role='alert'
168
- data-testid='error-boundary-fallback'
169
- className={mx('overflow-auto p-8 dx-attention-surface grid place-items-center')}
170
- >
171
- <p className={mx(descriptionMessage, 'break-words rounded-md p-8', errorString.length < 256 && 'text-lg')}>
172
- {error ? errorString : t('error fallback message')}
173
- </p>
174
- </div>
175
- );
176
- };