@dxos/plugin-testing 0.8.4-main.3eb6e50203 → 0.8.4-main.3fbcb4aa9b

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