@dxos/plugin-testing 0.8.4-main.69d29f4 → 0.8.4-main.7996785055

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 (144) hide show
  1. package/dist/lib/browser/add-toast-M6ZVP2PQ.mjs +22 -0
  2. package/dist/lib/browser/add-toast-M6ZVP2PQ.mjs.map +7 -0
  3. package/dist/lib/browser/{chunk-YHPXIILW.mjs → chunk-F2MMDTKN.mjs} +3 -3
  4. package/dist/lib/browser/chunk-F2MMDTKN.mjs.map +7 -0
  5. package/dist/lib/browser/chunk-M4TYMLOE.mjs +21 -0
  6. package/dist/lib/browser/chunk-M4TYMLOE.mjs.map +7 -0
  7. package/dist/lib/browser/close-M6YHTWUZ.mjs +10 -0
  8. package/dist/lib/browser/close-M6YHTWUZ.mjs.map +7 -0
  9. package/dist/lib/browser/index.mjs +75 -42
  10. package/dist/lib/browser/index.mjs.map +4 -4
  11. package/dist/lib/browser/meta.json +1 -1
  12. package/dist/lib/browser/open-ND4QPYWD.mjs +10 -0
  13. package/dist/lib/browser/open-ND4QPYWD.mjs.map +7 -0
  14. package/dist/lib/browser/operation-handler-DUWMXELV.mjs +16 -0
  15. package/dist/lib/browser/operation-handler-DUWMXELV.mjs.map +7 -0
  16. package/dist/lib/browser/scroll-into-view-UAINWR6E.mjs +10 -0
  17. package/dist/lib/browser/scroll-into-view-UAINWR6E.mjs.map +7 -0
  18. package/dist/lib/browser/set-layout-mode-E6SJ6ATN.mjs +10 -0
  19. package/dist/lib/browser/set-layout-mode-E6SJ6ATN.mjs.map +7 -0
  20. package/dist/lib/browser/{state-2M3RMJYA.mjs → state-MRRN7LZE.mjs} +6 -4
  21. package/dist/lib/browser/state-MRRN7LZE.mjs.map +7 -0
  22. package/dist/lib/browser/switch-workspace-RPYF6M6L.mjs +19 -0
  23. package/dist/lib/browser/switch-workspace-RPYF6M6L.mjs.map +7 -0
  24. package/dist/lib/browser/update-complementary-HNS4FIWF.mjs +25 -0
  25. package/dist/lib/browser/update-complementary-HNS4FIWF.mjs.map +7 -0
  26. package/dist/lib/browser/update-dialog-W7QOCQ2N.mjs +27 -0
  27. package/dist/lib/browser/update-dialog-W7QOCQ2N.mjs.map +7 -0
  28. package/dist/lib/browser/update-popover-UELZDJW6.mjs +45 -0
  29. package/dist/lib/browser/update-popover-UELZDJW6.mjs.map +7 -0
  30. package/dist/lib/browser/update-sidebar-RJZTREDE.mjs +25 -0
  31. package/dist/lib/browser/update-sidebar-RJZTREDE.mjs.map +7 -0
  32. package/dist/lib/node-esm/add-toast-VMEADC7Y.mjs +23 -0
  33. package/dist/lib/node-esm/add-toast-VMEADC7Y.mjs.map +7 -0
  34. package/dist/lib/node-esm/{chunk-OWK6XE6C.mjs → chunk-VDX7GMAD.mjs} +3 -3
  35. package/dist/lib/node-esm/chunk-VDX7GMAD.mjs.map +7 -0
  36. package/dist/lib/node-esm/chunk-ZLM7QUEK.mjs +22 -0
  37. package/dist/lib/node-esm/chunk-ZLM7QUEK.mjs.map +7 -0
  38. package/dist/lib/node-esm/close-B54TW3OK.mjs +12 -0
  39. package/dist/lib/node-esm/close-B54TW3OK.mjs.map +7 -0
  40. package/dist/lib/node-esm/index.mjs +75 -42
  41. package/dist/lib/node-esm/index.mjs.map +4 -4
  42. package/dist/lib/node-esm/meta.json +1 -1
  43. package/dist/lib/node-esm/open-OLJQ7VR3.mjs +12 -0
  44. package/dist/lib/node-esm/open-OLJQ7VR3.mjs.map +7 -0
  45. package/dist/lib/node-esm/operation-handler-TCIEZXBS.mjs +18 -0
  46. package/dist/lib/node-esm/operation-handler-TCIEZXBS.mjs.map +7 -0
  47. package/dist/lib/node-esm/scroll-into-view-C3XK4YMK.mjs +12 -0
  48. package/dist/lib/node-esm/scroll-into-view-C3XK4YMK.mjs.map +7 -0
  49. package/dist/lib/node-esm/set-layout-mode-AEQI6AVR.mjs +12 -0
  50. package/dist/lib/node-esm/set-layout-mode-AEQI6AVR.mjs.map +7 -0
  51. package/dist/lib/node-esm/{state-UF2MWBFU.mjs → state-PVDE6Q6G.mjs} +6 -4
  52. package/dist/lib/node-esm/state-PVDE6Q6G.mjs.map +7 -0
  53. package/dist/lib/node-esm/switch-workspace-ZDUCWF6E.mjs +20 -0
  54. package/dist/lib/node-esm/switch-workspace-ZDUCWF6E.mjs.map +7 -0
  55. package/dist/lib/node-esm/update-complementary-LAPUAZ5I.mjs +26 -0
  56. package/dist/lib/node-esm/update-complementary-LAPUAZ5I.mjs.map +7 -0
  57. package/dist/lib/node-esm/update-dialog-5M7FL4XG.mjs +28 -0
  58. package/dist/lib/node-esm/update-dialog-5M7FL4XG.mjs.map +7 -0
  59. package/dist/lib/node-esm/update-popover-2TDGFHL3.mjs +46 -0
  60. package/dist/lib/node-esm/update-popover-2TDGFHL3.mjs.map +7 -0
  61. package/dist/lib/node-esm/update-sidebar-CU6TUDK5.mjs +26 -0
  62. package/dist/lib/node-esm/update-sidebar-CU6TUDK5.mjs.map +7 -0
  63. package/dist/types/src/StorybookPlugin.d.ts.map +1 -1
  64. package/dist/types/src/capabilities/index.d.ts +1 -1
  65. package/dist/types/src/capabilities/index.d.ts.map +1 -1
  66. package/dist/types/src/capabilities/operation-handler/index.d.ts +4 -0
  67. package/dist/types/src/capabilities/operation-handler/index.d.ts.map +1 -0
  68. package/dist/types/src/capabilities/operation-handler/operation-handler.d.ts +6 -0
  69. package/dist/types/src/capabilities/operation-handler/operation-handler.d.ts.map +1 -0
  70. package/dist/types/src/capabilities/state/index.d.ts +1 -1
  71. package/dist/types/src/capabilities/state/state.d.ts +1 -1
  72. package/dist/types/src/capabilities/state/state.d.ts.map +1 -1
  73. package/dist/types/src/components/{Layout.d.ts → Layout/Layout.d.ts} +1 -1
  74. package/dist/types/src/components/Layout/Layout.d.ts.map +1 -0
  75. package/dist/types/src/components/Layout/index.d.ts +2 -0
  76. package/dist/types/src/components/Layout/index.d.ts.map +1 -0
  77. package/dist/types/src/core.d.ts +1 -6
  78. package/dist/types/src/core.d.ts.map +1 -1
  79. package/dist/types/src/operations/add-toast.d.ts +5 -0
  80. package/dist/types/src/operations/add-toast.d.ts.map +1 -0
  81. package/dist/types/src/operations/close.d.ts +5 -0
  82. package/dist/types/src/operations/close.d.ts.map +1 -0
  83. package/dist/types/src/operations/index.d.ts +3 -0
  84. package/dist/types/src/operations/index.d.ts.map +1 -0
  85. package/dist/types/src/operations/open.d.ts +5 -0
  86. package/dist/types/src/operations/open.d.ts.map +1 -0
  87. package/dist/types/src/operations/scroll-into-view.d.ts +5 -0
  88. package/dist/types/src/operations/scroll-into-view.d.ts.map +1 -0
  89. package/dist/types/src/operations/set-layout-mode.d.ts +5 -0
  90. package/dist/types/src/operations/set-layout-mode.d.ts.map +1 -0
  91. package/dist/types/src/operations/switch-workspace.d.ts +5 -0
  92. package/dist/types/src/operations/switch-workspace.d.ts.map +1 -0
  93. package/dist/types/src/operations/update-complementary.d.ts +5 -0
  94. package/dist/types/src/operations/update-complementary.d.ts.map +1 -0
  95. package/dist/types/src/operations/update-dialog.d.ts +5 -0
  96. package/dist/types/src/operations/update-dialog.d.ts.map +1 -0
  97. package/dist/types/src/operations/update-popover.d.ts +5 -0
  98. package/dist/types/src/operations/update-popover.d.ts.map +1 -0
  99. package/dist/types/src/operations/update-sidebar.d.ts +5 -0
  100. package/dist/types/src/operations/update-sidebar.d.ts.map +1 -0
  101. package/dist/types/src/operations/update-state.d.ts +5 -0
  102. package/dist/types/src/operations/update-state.d.ts.map +1 -0
  103. package/dist/types/src/types/capabilities.d.ts +2 -0
  104. package/dist/types/src/types/capabilities.d.ts.map +1 -1
  105. package/dist/types/tsconfig.tsbuildinfo +1 -1
  106. package/package.json +19 -18
  107. package/src/StorybookPlugin.ts +14 -13
  108. package/src/capabilities/index.ts +1 -1
  109. package/src/capabilities/operation-handler/index.ts +11 -0
  110. package/src/capabilities/operation-handler/operation-handler.ts +16 -0
  111. package/src/capabilities/state/state.tsx +5 -6
  112. package/src/components/Layout/Layout.tsx +230 -0
  113. package/src/components/Layout/index.ts +5 -0
  114. package/src/core.ts +2 -6
  115. package/src/meta.ts +1 -1
  116. package/src/operations/add-toast.ts +22 -0
  117. package/src/operations/close.ts +14 -0
  118. package/src/operations/index.ts +18 -0
  119. package/src/operations/open.ts +14 -0
  120. package/src/operations/scroll-into-view.ts +14 -0
  121. package/src/operations/set-layout-mode.ts +14 -0
  122. package/src/operations/switch-workspace.ts +20 -0
  123. package/src/operations/update-complementary.ts +27 -0
  124. package/src/operations/update-dialog.ts +27 -0
  125. package/src/operations/update-popover.ts +37 -0
  126. package/src/operations/update-sidebar.ts +26 -0
  127. package/src/operations/update-state.ts +17 -0
  128. package/src/types/capabilities.ts +4 -1
  129. package/dist/lib/browser/chunk-YHPXIILW.mjs.map +0 -7
  130. package/dist/lib/browser/operation-resolver-B2DOYB7C.mjs +0 -111
  131. package/dist/lib/browser/operation-resolver-B2DOYB7C.mjs.map +0 -7
  132. package/dist/lib/browser/state-2M3RMJYA.mjs.map +0 -7
  133. package/dist/lib/node-esm/chunk-OWK6XE6C.mjs.map +0 -7
  134. package/dist/lib/node-esm/operation-resolver-DJI7OPBP.mjs +0 -112
  135. package/dist/lib/node-esm/operation-resolver-DJI7OPBP.mjs.map +0 -7
  136. package/dist/lib/node-esm/state-UF2MWBFU.mjs.map +0 -7
  137. package/dist/types/src/capabilities/operation-resolver/index.d.ts +0 -3
  138. package/dist/types/src/capabilities/operation-resolver/index.d.ts.map +0 -1
  139. package/dist/types/src/capabilities/operation-resolver/operation-resolver.d.ts +0 -5
  140. package/dist/types/src/capabilities/operation-resolver/operation-resolver.d.ts.map +0 -1
  141. package/dist/types/src/components/Layout.d.ts.map +0 -1
  142. package/src/capabilities/operation-resolver/index.ts +0 -7
  143. package/src/capabilities/operation-resolver/operation-resolver.ts +0 -98
  144. package/src/components/Layout.tsx +0 -172
@@ -1,172 +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/react';
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
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 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 role='card--content' data={layout.popoverContent} limit={1} />
146
- </Card.Root>
147
- )}
148
- {layout.popoverKind === 'base' && <Surface role='popover' data={layout.popoverContent} limit={1} />}
149
- </Popover.Viewport>
150
- <Popover.Arrow />
151
- </Popover.Content>
152
- </Popover.Portal>
153
- </Popover.Root>
154
- </Mosaic.Root>
155
- </div>
156
- );
157
- };
158
-
159
- export const ContentError = ({ error }: { error?: Error }) => {
160
- const { t } = useTranslation(meta.id);
161
- const errorString = error?.toString() ?? '';
162
- return (
163
- <div role='none' className='overflow-auto p-8 attention-surface grid place-items-center'>
164
- <p
165
- role='alert'
166
- className={mx(descriptionMessage, 'break-words rounded-md p-8', errorString.length < 256 && 'text-lg')}
167
- >
168
- {error ? errorString : t('error fallback message')}
169
- </p>
170
- </div>
171
- );
172
- };