@dxos/plugin-simple-layout 0.8.4-main.74a063c4e0 → 0.8.4-main.765dc60934

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 (207) hide show
  1. package/LICENSE +102 -5
  2. package/dist/lib/{browser/index.mjs → neutral/SimpleLayoutPlugin.mjs} +10 -38
  3. package/dist/lib/neutral/SimpleLayoutPlugin.mjs.map +7 -0
  4. package/dist/lib/neutral/app-graph-builder-EYQKLRRP.mjs +21 -0
  5. package/dist/lib/neutral/app-graph-builder-EYQKLRRP.mjs.map +7 -0
  6. package/dist/lib/neutral/capabilities/index.mjs +21 -0
  7. package/dist/lib/neutral/capabilities/index.mjs.map +7 -0
  8. package/dist/lib/neutral/chunk-7UDV3JDT.mjs +22 -0
  9. package/dist/lib/neutral/chunk-7UDV3JDT.mjs.map +7 -0
  10. package/dist/lib/neutral/chunk-AMTEDJHG.mjs +19 -0
  11. package/dist/lib/neutral/chunk-AMTEDJHG.mjs.map +7 -0
  12. package/dist/lib/neutral/chunk-FD2CAY4Q.mjs +26 -0
  13. package/dist/lib/neutral/chunk-FD2CAY4Q.mjs.map +7 -0
  14. package/dist/lib/neutral/chunk-J5LGTIGS.mjs +10 -0
  15. package/dist/lib/neutral/chunk-J5LGTIGS.mjs.map +7 -0
  16. package/dist/lib/neutral/chunk-XVUAQHKU.mjs +8 -0
  17. package/dist/lib/neutral/chunk-XVUAQHKU.mjs.map +7 -0
  18. package/dist/lib/neutral/close-WKMURGUB.mjs +35 -0
  19. package/dist/lib/neutral/close-WKMURGUB.mjs.map +7 -0
  20. package/dist/lib/neutral/components/index.mjs +924 -0
  21. package/dist/lib/neutral/components/index.mjs.map +7 -0
  22. package/dist/lib/neutral/hooks/index.mjs +332 -0
  23. package/dist/lib/neutral/hooks/index.mjs.map +7 -0
  24. package/dist/lib/neutral/index.mjs +14 -0
  25. package/dist/lib/neutral/index.mjs.map +7 -0
  26. package/dist/lib/neutral/meta.json +1 -0
  27. package/dist/lib/neutral/meta.mjs +8 -0
  28. package/dist/lib/neutral/meta.mjs.map +7 -0
  29. package/dist/lib/neutral/open-XI2T7D5O.mjs +49 -0
  30. package/dist/lib/neutral/open-XI2T7D5O.mjs.map +7 -0
  31. package/dist/lib/neutral/operation-handler-EAIE7KPR.mjs +13 -0
  32. package/dist/lib/neutral/operation-handler-EAIE7KPR.mjs.map +7 -0
  33. package/dist/lib/neutral/operations/index.mjs +8 -0
  34. package/dist/lib/neutral/operations/index.mjs.map +7 -0
  35. package/dist/lib/neutral/plugin.mjs +16 -0
  36. package/dist/lib/neutral/plugin.mjs.map +7 -0
  37. package/dist/lib/neutral/react-root-VE265VX4.mjs +18 -0
  38. package/dist/lib/neutral/react-root-VE265VX4.mjs.map +7 -0
  39. package/dist/lib/neutral/react-surface-REZMYKQV.mjs +46 -0
  40. package/dist/lib/neutral/react-surface-REZMYKQV.mjs.map +7 -0
  41. package/dist/lib/neutral/revert-workspace-ST6NZUNG.mjs +22 -0
  42. package/dist/lib/neutral/revert-workspace-ST6NZUNG.mjs.map +7 -0
  43. package/dist/lib/neutral/set-6ZRLWPJS.mjs +22 -0
  44. package/dist/lib/neutral/set-6ZRLWPJS.mjs.map +7 -0
  45. package/dist/lib/neutral/set-layout-mode-L22HRCKS.mjs +13 -0
  46. package/dist/lib/neutral/set-layout-mode-L22HRCKS.mjs.map +7 -0
  47. package/dist/lib/neutral/spotlight-dismiss-EIYW5E7M.mjs +58 -0
  48. package/dist/lib/neutral/spotlight-dismiss-EIYW5E7M.mjs.map +7 -0
  49. package/dist/lib/neutral/state-7NXKBLPY.mjs +47 -0
  50. package/dist/lib/neutral/state-7NXKBLPY.mjs.map +7 -0
  51. package/dist/lib/neutral/switch-workspace-PYWPTMFO.mjs +25 -0
  52. package/dist/lib/neutral/switch-workspace-PYWPTMFO.mjs.map +7 -0
  53. package/dist/lib/neutral/translations.mjs +36 -0
  54. package/dist/lib/neutral/translations.mjs.map +7 -0
  55. package/dist/lib/neutral/types/index.mjs +10 -0
  56. package/dist/lib/neutral/types/index.mjs.map +7 -0
  57. package/dist/lib/neutral/update-complementary-HKWF5OXT.mjs +33 -0
  58. package/dist/lib/neutral/update-complementary-HKWF5OXT.mjs.map +7 -0
  59. package/dist/lib/neutral/update-dialog-P4ASXCE7.mjs +30 -0
  60. package/dist/lib/neutral/update-dialog-P4ASXCE7.mjs.map +7 -0
  61. package/dist/lib/neutral/update-popover-REAKC2GN.mjs +34 -0
  62. package/dist/lib/neutral/update-popover-REAKC2GN.mjs.map +7 -0
  63. package/dist/lib/neutral/update-sidebar-O5SQPR6Q.mjs +12 -0
  64. package/dist/lib/neutral/update-sidebar-O5SQPR6Q.mjs.map +7 -0
  65. package/dist/lib/neutral/url-handler-GZXUUAHD.mjs +129 -0
  66. package/dist/lib/neutral/url-handler-GZXUUAHD.mjs.map +7 -0
  67. package/dist/types/src/SimpleLayoutPlugin.d.ts +1 -0
  68. package/dist/types/src/SimpleLayoutPlugin.d.ts.map +1 -1
  69. package/dist/types/src/capabilities/app-graph-builder.d.ts.map +1 -1
  70. package/dist/types/src/capabilities/index.d.ts +3 -3
  71. package/dist/types/src/capabilities/index.d.ts.map +1 -1
  72. package/dist/types/src/capabilities/operation-handler.d.ts +1 -1
  73. package/dist/types/src/capabilities/operation-handler.d.ts.map +1 -1
  74. package/dist/types/src/capabilities/react-root.d.ts.map +1 -1
  75. package/dist/types/src/capabilities/react-surface.d.ts.map +1 -1
  76. package/dist/types/src/capabilities/spotlight-dismiss.d.ts +1 -1
  77. package/dist/types/src/capabilities/spotlight-dismiss.d.ts.map +1 -1
  78. package/dist/types/src/capabilities/state.d.ts +3 -3
  79. package/dist/types/src/capabilities/state.d.ts.map +1 -1
  80. package/dist/types/src/capabilities/url-handler.d.ts.map +1 -1
  81. package/dist/types/src/components/ContentError.stories.d.ts +21 -21
  82. package/dist/types/src/components/ContentError.stories.d.ts.map +1 -1
  83. package/dist/types/src/components/DebugOverlay/DebugOverlay.d.ts.map +1 -1
  84. package/dist/types/src/components/Dialog/Dialog.d.ts.map +1 -1
  85. package/dist/types/src/components/Home/Home.d.ts.map +1 -1
  86. package/dist/types/src/components/Loading/Loading.stories.d.ts.map +1 -1
  87. package/dist/types/src/components/MobileLayout/MobileLayout.d.ts +2 -2
  88. package/dist/types/src/components/MobileLayout/MobileLayout.d.ts.map +1 -1
  89. package/dist/types/src/components/MobileLayout/MobileLayout.stories.d.ts.map +1 -1
  90. package/dist/types/src/components/NavBranch/NavBranch.d.ts.map +1 -1
  91. package/dist/types/src/components/Popover/Popover.d.ts.map +1 -1
  92. package/dist/types/src/components/SimpleLayout/AppBar.d.ts +1 -5
  93. package/dist/types/src/components/SimpleLayout/AppBar.d.ts.map +1 -1
  94. package/dist/types/src/components/SimpleLayout/AppBar.stories.d.ts +21 -21
  95. package/dist/types/src/components/SimpleLayout/AppBar.stories.d.ts.map +1 -1
  96. package/dist/types/src/components/SimpleLayout/Drawer.d.ts +4 -7
  97. package/dist/types/src/components/SimpleLayout/Drawer.d.ts.map +1 -1
  98. package/dist/types/src/components/SimpleLayout/Main.d.ts +4 -7
  99. package/dist/types/src/components/SimpleLayout/Main.d.ts.map +1 -1
  100. package/dist/types/src/components/SimpleLayout/NavBar.d.ts +1 -5
  101. package/dist/types/src/components/SimpleLayout/NavBar.d.ts.map +1 -1
  102. package/dist/types/src/components/SimpleLayout/NavBar.stories.d.ts +22 -26
  103. package/dist/types/src/components/SimpleLayout/NavBar.stories.d.ts.map +1 -1
  104. package/dist/types/src/components/SimpleLayout/SimpleLayout.stories.d.ts +21 -21
  105. package/dist/types/src/components/SimpleLayout/SimpleLayout.stories.d.ts.map +1 -1
  106. package/dist/types/src/components/hooks.d.ts.map +1 -1
  107. package/dist/types/src/hooks/actions.d.ts +3 -3
  108. package/dist/types/src/hooks/actions.d.ts.map +1 -1
  109. package/dist/types/src/hooks/useAppBarProps.d.ts +1 -1
  110. package/dist/types/src/hooks/useAppBarProps.d.ts.map +1 -1
  111. package/dist/types/src/hooks/useCompanions.d.ts.map +1 -1
  112. package/dist/types/src/hooks/useDrawerActions.d.ts.map +1 -1
  113. package/dist/types/src/hooks/useSimpleLayoutState.d.ts +3 -3
  114. package/dist/types/src/hooks/useSimpleLayoutState.d.ts.map +1 -1
  115. package/dist/types/src/index.d.ts +2 -1
  116. package/dist/types/src/index.d.ts.map +1 -1
  117. package/dist/types/src/meta.d.ts.map +1 -1
  118. package/dist/types/src/operations/close.d.ts +1 -1
  119. package/dist/types/src/operations/close.d.ts.map +1 -1
  120. package/dist/types/src/operations/index.d.ts +1 -1
  121. package/dist/types/src/operations/index.d.ts.map +1 -1
  122. package/dist/types/src/operations/open.d.ts +1 -1
  123. package/dist/types/src/operations/open.d.ts.map +1 -1
  124. package/dist/types/src/operations/revert-workspace.d.ts +1 -1
  125. package/dist/types/src/operations/revert-workspace.d.ts.map +1 -1
  126. package/dist/types/src/operations/set-layout-mode.d.ts +1 -1
  127. package/dist/types/src/operations/set-layout-mode.d.ts.map +1 -1
  128. package/dist/types/src/operations/set.d.ts +1 -1
  129. package/dist/types/src/operations/set.d.ts.map +1 -1
  130. package/dist/types/src/operations/state-access.d.ts +3 -3
  131. package/dist/types/src/operations/state-access.d.ts.map +1 -1
  132. package/dist/types/src/operations/switch-workspace.d.ts +1 -1
  133. package/dist/types/src/operations/switch-workspace.d.ts.map +1 -1
  134. package/dist/types/src/operations/update-complementary.d.ts +1 -1
  135. package/dist/types/src/operations/update-complementary.d.ts.map +1 -1
  136. package/dist/types/src/operations/update-dialog.d.ts +1 -1
  137. package/dist/types/src/operations/update-dialog.d.ts.map +1 -1
  138. package/dist/types/src/operations/update-popover.d.ts +1 -1
  139. package/dist/types/src/operations/update-popover.d.ts.map +1 -1
  140. package/dist/types/src/operations/update-sidebar.d.ts +1 -1
  141. package/dist/types/src/operations/update-sidebar.d.ts.map +1 -1
  142. package/dist/types/src/plugin.d.ts +4 -0
  143. package/dist/types/src/plugin.d.ts.map +1 -0
  144. package/dist/types/src/translations.d.ts +21 -22
  145. package/dist/types/src/translations.d.ts.map +1 -1
  146. package/dist/types/src/types/{capabilities.d.ts → SimpleLayoutCapabilities.d.ts} +2 -8
  147. package/dist/types/src/types/SimpleLayoutCapabilities.d.ts.map +1 -0
  148. package/dist/types/src/types/SimpleLayoutEvents.d.ts +4 -0
  149. package/dist/types/src/types/SimpleLayoutEvents.d.ts.map +1 -0
  150. package/dist/types/src/types/index.d.ts +2 -2
  151. package/dist/types/src/types/index.d.ts.map +1 -1
  152. package/dist/types/tsconfig.tsbuildinfo +1 -1
  153. package/package.json +85 -41
  154. package/src/SimpleLayoutPlugin.ts +4 -3
  155. package/src/capabilities/app-graph-builder.ts +1 -1
  156. package/src/capabilities/index.ts +1 -1
  157. package/src/capabilities/operation-handler.ts +1 -1
  158. package/src/capabilities/react-surface.tsx +1 -1
  159. package/src/capabilities/state.tsx +5 -6
  160. package/src/capabilities/url-handler.ts +16 -13
  161. package/src/components/ContentError.stories.tsx +1 -1
  162. package/src/components/Dialog/Dialog.tsx +13 -2
  163. package/src/components/Home/Home.tsx +1 -1
  164. package/src/components/Loading/Loading.tsx +1 -1
  165. package/src/components/MobileLayout/MobileLayout.stories.tsx +2 -2
  166. package/src/components/MobileLayout/MobileLayout.tsx +0 -2
  167. package/src/components/NavBranch/NavBranch.tsx +2 -6
  168. package/src/components/Popover/Popover.tsx +7 -3
  169. package/src/components/SimpleLayout/AppBar.stories.tsx +2 -1
  170. package/src/components/SimpleLayout/Drawer.tsx +8 -2
  171. package/src/components/SimpleLayout/Main.tsx +2 -2
  172. package/src/components/SimpleLayout/NavBar.stories.tsx +2 -1
  173. package/src/components/SimpleLayout/SimpleLayout.stories.tsx +6 -6
  174. package/src/components/SimpleLayout/SimpleLayout.tsx +2 -2
  175. package/src/hooks/actions.ts +5 -3
  176. package/src/hooks/useAppBarProps.ts +2 -22
  177. package/src/hooks/useDrawerActions.ts +2 -2
  178. package/src/hooks/useNavbarActions.ts +2 -2
  179. package/src/hooks/useSimpleLayoutState.ts +7 -5
  180. package/src/index.ts +2 -1
  181. package/src/meta.ts +2 -1
  182. package/src/operations/close.ts +1 -1
  183. package/src/operations/index.ts +1 -1
  184. package/src/operations/open.ts +2 -2
  185. package/src/operations/revert-workspace.ts +1 -1
  186. package/src/operations/set-layout-mode.ts +1 -1
  187. package/src/operations/set.ts +1 -1
  188. package/src/operations/state-access.ts +5 -3
  189. package/src/operations/switch-workspace.ts +1 -1
  190. package/src/operations/update-complementary.ts +1 -1
  191. package/src/operations/update-dialog.ts +1 -1
  192. package/src/operations/update-popover.ts +1 -1
  193. package/src/operations/update-sidebar.ts +1 -1
  194. package/src/plugin.ts +11 -0
  195. package/src/translations.ts +1 -1
  196. package/src/types/{capabilities.ts → SimpleLayoutCapabilities.ts} +3 -15
  197. package/src/types/SimpleLayoutEvents.ts +15 -0
  198. package/src/types/index.ts +2 -2
  199. package/dist/lib/browser/index.mjs.map +0 -7
  200. package/dist/lib/browser/meta.json +0 -1
  201. package/dist/lib/node-esm/index.mjs +0 -82
  202. package/dist/lib/node-esm/index.mjs.map +0 -7
  203. package/dist/lib/node-esm/meta.json +0 -1
  204. package/dist/types/src/types/capabilities.d.ts.map +0 -1
  205. package/dist/types/src/types/events.d.ts +0 -6
  206. package/dist/types/src/types/events.d.ts.map +0 -1
  207. package/src/types/events.ts +0 -15
@@ -3,7 +3,6 @@
3
3
  //
4
4
 
5
5
  import { Atom, useAtomValue } from '@effect-atom/atom-react';
6
- import * as Effect from 'effect/Effect';
7
6
  import * as Option from 'effect/Option';
8
7
  import { useCallback, useMemo } from 'react';
9
8
 
@@ -16,7 +15,7 @@ import { type ActionGraphProps } from '@dxos/react-ui-menu';
16
15
 
17
16
  import { type AppBarProps } from '#components';
18
17
  import { meta } from '#meta';
19
- import { SimpleLayoutState as SimpleLayoutStateCapability } from '#types';
18
+ import { SimpleLayoutCapabilities } from '#types';
20
19
 
21
20
  /**
22
21
  * Hook that computes all AppBar props from the app graph.
@@ -24,7 +23,7 @@ import { SimpleLayoutState as SimpleLayoutStateCapability } from '#types';
24
23
  */
25
24
  export const useAppBarProps = (): Omit<AppBarProps, 'classNames'> => {
26
25
  const { t } = useTranslation(meta.id);
27
- const stateAtom = useCapability(SimpleLayoutStateCapability);
26
+ const stateAtom = useCapability(SimpleLayoutCapabilities.State);
28
27
  const state = useAtomValue(stateAtom);
29
28
  const { graph } = useAppGraph();
30
29
  const { invokePromise } = useOperationInvoker();
@@ -55,25 +54,6 @@ export const useAppBarProps = (): Omit<AppBarProps, 'classNames'> => {
55
54
  relation: 'child',
56
55
  }));
57
56
 
58
- // Add alternate-tree action (e.g. Settings) from the workspace node.
59
- const workspaceConnections = state.workspace ? get(graph.connections(state.workspace, 'child')) : [];
60
- const alternateTreeNode = workspaceConnections.find(
61
- (node: Node.Node) => node.properties.disposition === 'alternate-tree',
62
- );
63
- if (alternateTreeNode && activeId !== alternateTreeNode.id) {
64
- const settingsAction = {
65
- id: `appbar-settings-${alternateTreeNode.id}`,
66
- type: Node.ActionType,
67
- data: () => Effect.promise(() => invokePromise(LayoutOperation.Open, { subject: [alternateTreeNode.id] })),
68
- properties: {
69
- label: alternateTreeNode.properties.label ?? alternateTreeNode.id,
70
- icon: alternateTreeNode.properties.icon ?? 'ph--placeholder--regular',
71
- },
72
- };
73
- nodes.push(settingsAction);
74
- edges.push({ source: 'root', target: settingsAction.id, relation: 'child' });
75
- }
76
-
77
57
  return { nodes, edges };
78
58
  }),
79
59
  [graph, stateAtom],
@@ -14,7 +14,7 @@ import { type ActionExecutor, type ActionGraphProps, createGapSeparator } from '
14
14
 
15
15
  import { useMobileLayout } from '#components';
16
16
  import { meta } from '#meta';
17
- import { SimpleLayoutState as SimpleLayoutStateCapability } from '#types';
17
+ import { SimpleLayoutCapabilities } from '#types';
18
18
 
19
19
  import { createCompanionActions } from './actions';
20
20
  import { useSimpleLayoutState } from './useSimpleLayoutState';
@@ -31,7 +31,7 @@ export type DrawerActions = {
31
31
  */
32
32
  export const useDrawerActions = (consumerName: string): DrawerActions => {
33
33
  const { t } = useTranslation(meta.id);
34
- const stateAtom = useCapability(SimpleLayoutStateCapability);
34
+ const stateAtom = useCapability(SimpleLayoutCapabilities.State);
35
35
  const { graph } = useAppGraph();
36
36
  const runAction = useActionRunner();
37
37
  const { updateState } = useSimpleLayoutState();
@@ -17,7 +17,7 @@ import {
17
17
  } from '@dxos/react-ui-menu';
18
18
 
19
19
  import { meta } from '#meta';
20
- import { SimpleLayoutState } from '#types';
20
+ import { SimpleLayoutCapabilities } from '#types';
21
21
 
22
22
  import { createCompanionActions } from './actions';
23
23
  import { useSimpleLayoutState } from './useSimpleLayoutState';
@@ -39,7 +39,7 @@ export const useNavbarActions = (): NavbarActions => {
39
39
  const { t } = useTranslation(meta.id);
40
40
  const { graph } = useAppGraph();
41
41
  const runAction = useActionRunner();
42
- const stateAtom = useCapability(SimpleLayoutState);
42
+ const stateAtom = useCapability(SimpleLayoutCapabilities.State);
43
43
  const { updateState } = useSimpleLayoutState();
44
44
 
45
45
  // Create a computed atom that derives everything from graph connections and state.
@@ -7,20 +7,22 @@ import { useCallback, useContext } from 'react';
7
7
 
8
8
  import { useCapability } from '@dxos/app-framework/ui';
9
9
 
10
- import { SimpleLayoutState } from '#types';
10
+ import { SimpleLayoutCapabilities } from '#types';
11
11
 
12
12
  export type UseSimpleLayoutState = {
13
- state: SimpleLayoutState;
14
- updateState: (fn: (current: SimpleLayoutState) => SimpleLayoutState) => void;
13
+ state: SimpleLayoutCapabilities.SimpleLayoutState;
14
+ updateState: (
15
+ fn: (current: SimpleLayoutCapabilities.SimpleLayoutState) => SimpleLayoutCapabilities.SimpleLayoutState,
16
+ ) => void;
15
17
  };
16
18
 
17
19
  export const useSimpleLayoutState = (): UseSimpleLayoutState => {
18
20
  const registry = useContext(RegistryContext);
19
- const stateAtom = useCapability(SimpleLayoutState);
21
+ const stateAtom = useCapability(SimpleLayoutCapabilities.State);
20
22
  const state = useAtomValue(stateAtom);
21
23
 
22
24
  const updateState = useCallback(
23
- (fn: (current: SimpleLayoutState) => SimpleLayoutState) => {
25
+ (fn: (current: SimpleLayoutCapabilities.SimpleLayoutState) => SimpleLayoutCapabilities.SimpleLayoutState) => {
24
26
  registry.set(stateAtom, fn(registry.get(stateAtom)));
25
27
  },
26
28
  [registry, stateAtom],
package/src/index.ts CHANGED
@@ -2,4 +2,5 @@
2
2
  // Copyright 2025 DXOS.org
3
3
  //
4
4
 
5
- export * from './SimpleLayoutPlugin';
5
+ export * from './meta';
6
+ export * from './types';
package/src/meta.ts CHANGED
@@ -6,11 +6,12 @@ import { type Plugin } from '@dxos/app-framework';
6
6
  import { trim } from '@dxos/util';
7
7
 
8
8
  export const meta: Plugin.Meta = {
9
- id: 'org.dxos.plugin.simple-layout',
9
+ id: 'org.dxos.plugin.simpleLayout',
10
10
  name: 'Simple Layout',
11
11
  description: trim`
12
12
  Minimal layout plugin for simplified UI contexts like popover windows.
13
13
  Provides basic content rendering without sidebars or complex navigation.
14
14
  `,
15
15
  icon: 'ph--layout--regular',
16
+ tags: ['system'],
16
17
  };
@@ -3,7 +3,7 @@
3
3
  import * as Effect from 'effect/Effect';
4
4
 
5
5
  import { LayoutOperation } from '@dxos/app-toolkit';
6
- import { Operation } from '@dxos/operation';
6
+ import { Operation } from '@dxos/compute';
7
7
 
8
8
  import { layoutStateAccess } from './state-access';
9
9
 
@@ -1,6 +1,6 @@
1
1
  // Copyright 2025 DXOS.org
2
2
 
3
- import { OperationHandlerSet } from '@dxos/operation';
3
+ import { OperationHandlerSet } from '@dxos/compute';
4
4
 
5
5
  export const SimpleLayoutOperationHandlerSet = OperationHandlerSet.lazy(
6
6
  () => import('./close'),
@@ -9,9 +9,9 @@ import {
9
9
  createEdgeExistenceChecker,
10
10
  validateNavigationTarget,
11
11
  } from '@dxos/app-toolkit';
12
+ import { Operation } from '@dxos/compute';
12
13
  import { Context } from '@dxos/context';
13
- import { Operation } from '@dxos/operation';
14
- import { ClientCapabilities } from '@dxos/plugin-client/types';
14
+ import { ClientCapabilities } from '@dxos/plugin-client';
15
15
 
16
16
  import { layoutStateAccess } from './state-access';
17
17
 
@@ -3,7 +3,7 @@
3
3
  import * as Effect from 'effect/Effect';
4
4
 
5
5
  import { LayoutOperation } from '@dxos/app-toolkit';
6
- import { Operation } from '@dxos/operation';
6
+ import { Operation } from '@dxos/compute';
7
7
 
8
8
  import { layoutStateAccess } from './state-access';
9
9
 
@@ -3,7 +3,7 @@
3
3
  import * as Effect from 'effect/Effect';
4
4
 
5
5
  import { LayoutOperation } from '@dxos/app-toolkit';
6
- import { Operation } from '@dxos/operation';
6
+ import { Operation } from '@dxos/compute';
7
7
 
8
8
  const handler: Operation.WithHandler<typeof LayoutOperation.SetLayoutMode> = LayoutOperation.SetLayoutMode.pipe(
9
9
  Operation.withHandler(Effect.fnUntraced(function* () {})),
@@ -3,7 +3,7 @@
3
3
  import * as Effect from 'effect/Effect';
4
4
 
5
5
  import { LayoutOperation } from '@dxos/app-toolkit';
6
- import { Operation } from '@dxos/operation';
6
+ import { Operation } from '@dxos/compute';
7
7
 
8
8
  import { layoutStateAccess } from './state-access';
9
9
 
@@ -4,15 +4,17 @@ import * as Effect from 'effect/Effect';
4
4
 
5
5
  import { Capabilities, Capability } from '@dxos/app-framework';
6
6
 
7
- import { type SimpleLayoutState, SimpleLayoutState as SimpleLayoutStateCapability } from '../types';
7
+ import { SimpleLayoutCapabilities } from '../types';
8
8
 
9
9
  export const layoutStateAccess = Effect.gen(function* () {
10
10
  const registry = yield* Capability.get(Capabilities.AtomRegistry);
11
- const stateAtom = yield* Capability.get(SimpleLayoutStateCapability);
11
+ const stateAtom = yield* Capability.get(SimpleLayoutCapabilities.State);
12
12
 
13
13
  return {
14
14
  getState: () => registry.get(stateAtom),
15
- updateState: (fn: (current: SimpleLayoutState) => SimpleLayoutState) => {
15
+ updateState: (
16
+ fn: (current: SimpleLayoutCapabilities.SimpleLayoutState) => SimpleLayoutCapabilities.SimpleLayoutState,
17
+ ) => {
16
18
  registry.set(stateAtom, fn(registry.get(stateAtom)));
17
19
  },
18
20
  };
@@ -3,7 +3,7 @@
3
3
  import * as Effect from 'effect/Effect';
4
4
 
5
5
  import { isPinnedWorkspace, LayoutOperation } from '@dxos/app-toolkit';
6
- import { Operation } from '@dxos/operation';
6
+ import { Operation } from '@dxos/compute';
7
7
 
8
8
  import { layoutStateAccess } from './state-access';
9
9
 
@@ -3,7 +3,7 @@
3
3
  import * as Effect from 'effect/Effect';
4
4
 
5
5
  import { LayoutOperation } from '@dxos/app-toolkit';
6
- import { Operation } from '@dxos/operation';
6
+ import { Operation } from '@dxos/compute';
7
7
  import { getLinkedVariant } from '@dxos/react-ui-attention';
8
8
 
9
9
  import { layoutStateAccess } from './state-access';
@@ -3,7 +3,7 @@
3
3
  import * as Effect from 'effect/Effect';
4
4
 
5
5
  import { LayoutOperation } from '@dxos/app-toolkit';
6
- import { Operation } from '@dxos/operation';
6
+ import { Operation } from '@dxos/compute';
7
7
 
8
8
  import { layoutStateAccess } from './state-access';
9
9
 
@@ -3,7 +3,7 @@
3
3
  import * as Effect from 'effect/Effect';
4
4
 
5
5
  import { LayoutOperation } from '@dxos/app-toolkit';
6
- import { Operation } from '@dxos/operation';
6
+ import { Operation } from '@dxos/compute';
7
7
 
8
8
  import { layoutStateAccess } from './state-access';
9
9
 
@@ -3,7 +3,7 @@
3
3
  import * as Effect from 'effect/Effect';
4
4
 
5
5
  import { LayoutOperation } from '@dxos/app-toolkit';
6
- import { Operation } from '@dxos/operation';
6
+ import { Operation } from '@dxos/compute';
7
7
 
8
8
  const handler: Operation.WithHandler<typeof LayoutOperation.UpdateSidebar> = LayoutOperation.UpdateSidebar.pipe(
9
9
  Operation.withHandler(() => Effect.void),
package/src/plugin.ts ADDED
@@ -0,0 +1,11 @@
1
+ //
2
+ // Copyright 2025 DXOS.org
3
+ //
4
+
5
+ import { Plugin } from '@dxos/app-framework';
6
+
7
+ import { meta } from './meta';
8
+
9
+ export const SimpleLayoutPlugin = Plugin.lazy(meta, () => import('#plugin'));
10
+
11
+ export { SimpleLayoutOperationHandlerSet } from './operations';
@@ -3,7 +3,7 @@
3
3
  //
4
4
 
5
5
  import { type Resource } from '@dxos/react-ui';
6
- import { translations as searchTranslations } from '@dxos/react-ui-search';
6
+ import { translations as searchTranslations } from '@dxos/react-ui-search/translations';
7
7
 
8
8
  import { meta } from '#meta';
9
9
 
@@ -2,6 +2,8 @@
2
2
  // Copyright 2025 DXOS.org
3
3
  //
4
4
 
5
+ // @import-as-namespace
6
+
5
7
  import { type Atom } from '@effect-atom/atom-react';
6
8
 
7
9
  import { Capability } from '@dxos/app-framework';
@@ -11,23 +13,17 @@ import { meta } from '#meta';
11
13
 
12
14
  export type DrawerState = 'closed' | 'open' | 'expanded';
13
15
 
14
- // TODO(wittjosiah): Handle toasts.
15
16
  export type SimpleLayoutState = {
16
- /** Data to be passed to the main content Surface. */
17
17
  content?: any;
18
-
19
18
  previousWorkspace: string;
20
19
  workspace: string;
21
20
  active?: string;
22
-
23
21
  dialogOpen: boolean;
24
22
  dialogType?: 'default' | 'alert';
25
23
  dialogBlockAlign?: 'start' | 'center' | 'end';
26
24
  dialogOverlayClasses?: string;
27
25
  dialogOverlayStyle?: Record<string, any>;
28
- /** Data to be passed to the dialog Surface. */
29
26
  dialogContent?: { component: string; props?: any } | null;
30
-
31
27
  popoverOpen?: boolean;
32
28
  popoverSide?: 'top' | 'right' | 'bottom' | 'left';
33
29
  popoverVariant?: 'virtual' | 'react';
@@ -36,18 +32,10 @@ export type SimpleLayoutState = {
36
32
  popoverKind?: 'base' | 'card';
37
33
  popoverTitle?: Label;
38
34
  popoverContent?: { component: string; props?: any } | { subject: any } | null;
39
-
40
- /** Bottom drawer state. */
41
35
  drawerState: DrawerState;
42
-
43
- /** Stack of previously active item IDs for back navigation. */
44
36
  history: string[];
45
-
46
- /** Whether running in popover window context (hides mobile-specific UI). */
47
37
  isPopover?: boolean;
48
-
49
- /** Variant of the companion to display in the drawer (e.g., "comments", "assistant-chat"). */
50
38
  companionVariant?: string;
51
39
  };
52
40
 
53
- export const SimpleLayoutState = Capability.make<Atom.Writable<SimpleLayoutState>>(`${meta.id}.state`);
41
+ export const State = Capability.make<Atom.Writable<SimpleLayoutState>>(`${meta.id}.state`);
@@ -0,0 +1,15 @@
1
+ //
2
+ // Copyright 2025 DXOS.org
3
+ //
4
+
5
+ // @import-as-namespace
6
+
7
+ import { type ActivationEvent } from '@dxos/app-framework';
8
+ import { AppActivationEvents } from '@dxos/app-toolkit';
9
+
10
+ import * as SimpleLayoutCapabilities from './SimpleLayoutCapabilities';
11
+
12
+ /** Fired when State capability is ready. */
13
+ export const StateReady: ActivationEvent.ActivationEvent = AppActivationEvents.createStateEvent(
14
+ SimpleLayoutCapabilities.State.identifier,
15
+ );
@@ -2,5 +2,5 @@
2
2
  // Copyright 2025 DXOS.org
3
3
  //
4
4
 
5
- export * from './capabilities';
6
- export * from './events';
5
+ export * as SimpleLayoutCapabilities from './SimpleLayoutCapabilities';
6
+ export * as SimpleLayoutEvents from './SimpleLayoutEvents';
@@ -1,7 +0,0 @@
1
- {
2
- "version": 3,
3
- "sources": ["../../../src/SimpleLayoutPlugin.ts", "../../../src/translations.ts"],
4
- "sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport { ActivationEvent, ActivationEvents, Capability, Plugin } from '@dxos/app-framework';\nimport { AppActivationEvents, AppPlugin } from '@dxos/app-toolkit';\n\nimport {\n AppGraphBuilder,\n OperationHandler,\n ReactRoot,\n ReactSurface,\n SpotlightDismiss,\n State,\n UrlHandler,\n} from '#capabilities';\nimport { meta } from '#meta';\nimport { SimpleLayoutEvents } from '#types';\n\nimport { translations } from './translations';\n\nexport type SimpleLayoutPluginOptions = {\n /** Determines if running in popover window context (hides mobile-specific UI). */\n isPopover?: boolean;\n};\n\nexport const SimpleLayoutPlugin = Plugin.define<SimpleLayoutPluginOptions>(meta).pipe(\n AppPlugin.addAppGraphModule({ activate: AppGraphBuilder }),\n AppPlugin.addOperationHandlerModule({ activate: OperationHandler }),\n AppPlugin.addTranslationsModule({ translations }),\n Plugin.addModule(({ isPopover = false }) => ({\n id: Capability.getModuleTag(State),\n activatesOn: ActivationEvents.Startup,\n activatesAfter: [SimpleLayoutEvents.StateReady, AppActivationEvents.LayoutReady],\n activate: () => State({ initialState: { isPopover } }),\n })),\n Plugin.addModule(({ isPopover = false }) => ({\n id: Capability.getModuleTag(SpotlightDismiss),\n activatesOn: ActivationEvents.Startup,\n activate: () => SpotlightDismiss({ isPopover }),\n })),\n Plugin.addModule({\n id: Capability.getModuleTag(ReactRoot),\n activatesOn: ActivationEvents.Startup,\n activate: ReactRoot,\n }),\n Plugin.addModule({\n id: Capability.getModuleTag(ReactSurface),\n activatesOn: ActivationEvents.Startup,\n activate: ReactSurface,\n }),\n Plugin.addModule({\n id: Capability.getModuleTag(UrlHandler),\n activatesOn: ActivationEvent.allOf(ActivationEvents.OperationInvokerReady, SimpleLayoutEvents.StateReady),\n activate: UrlHandler,\n }),\n Plugin.make,\n);\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport { type Resource } from '@dxos/react-ui';\nimport { translations as searchTranslations } from '@dxos/react-ui-search';\n\nimport { meta } from '#meta';\n\nexport const translations = [\n ...searchTranslations,\n {\n 'en-US': {\n [meta.id]: {\n 'plugin.name': 'Simple layout',\n 'settings.title': 'Simple layout settings',\n 'workspaces.heading': 'Workspaces',\n 'settings.heading': 'Settings',\n 'back.label': 'Back',\n 'browse.label': 'Browse',\n 'notifications.label': 'Notifications',\n 'profile.label': 'Profile',\n 'app-menu.label': 'App menu',\n 'main-menu.label': 'Main menu',\n 'companions-menu.label': 'Companions',\n 'error-fallback.message': 'An error occurred',\n 'drawer.label': 'Drawer',\n 'close-drawer.label': 'Close drawer',\n 'expand-drawer.label': 'Expand drawer',\n 'collapse-drawer.label': 'Collapse drawer',\n 'actions-menu.label': 'Actions',\n 'done.label': 'Done',\n },\n },\n },\n] as const satisfies Resource[];\n"],
5
- "mappings": ";AAIA,SAASA,iBAAiBC,kBAAkBC,YAAYC,cAAc;AACtE,SAASC,qBAAqBC,iBAAiB;AAE/C,SACEC,iBACAC,kBACAC,WACAC,cACAC,kBACAC,OACAC,kBACK;AACP,SAASC,QAAAA,aAAY;AACrB,SAASC,0BAA0B;;;ACZnC,SAASC,gBAAgBC,0BAA0B;AAEnD,SAASC,YAAY;AAEd,IAAMC,eAAe;KACvBC;EACH;IACE,SAAS;MACP,CAACC,KAAKC,EAAE,GAAG;QACT,eAAe;QACf,kBAAkB;QAClB,sBAAsB;QACtB,oBAAoB;QACpB,cAAc;QACd,gBAAgB;QAChB,uBAAuB;QACvB,iBAAiB;QACjB,kBAAkB;QAClB,mBAAmB;QACnB,yBAAyB;QACzB,0BAA0B;QAC1B,gBAAgB;QAChB,sBAAsB;QACtB,uBAAuB;QACvB,yBAAyB;QACzB,sBAAsB;QACtB,cAAc;MAChB;IACF;EACF;;;;ADRK,IAAMC,qBAAqBC,OAAOC,OAAkCC,KAAAA,EAAMC,KAC/EC,UAAUC,kBAAkB;EAAEC,UAAUC;AAAgB,CAAA,GACxDH,UAAUI,0BAA0B;EAAEF,UAAUG;AAAiB,CAAA,GACjEL,UAAUM,sBAAsB;EAAEC;AAAa,CAAA,GAC/CX,OAAOY,UAAU,CAAC,EAAEC,YAAY,MAAK,OAAQ;EAC3CC,IAAIC,WAAWC,aAAaC,KAAAA;EAC5BC,aAAaC,iBAAiBC;EAC9BC,gBAAgB;IAACC,mBAAmBC;IAAYC,oBAAoBC;;EACpEnB,UAAU,MAAMW,MAAM;IAAES,cAAc;MAAEb;IAAU;EAAE,CAAA;AACtD,EAAA,GACAb,OAAOY,UAAU,CAAC,EAAEC,YAAY,MAAK,OAAQ;EAC3CC,IAAIC,WAAWC,aAAaW,gBAAAA;EAC5BT,aAAaC,iBAAiBC;EAC9Bd,UAAU,MAAMqB,iBAAiB;IAAEd;EAAU,CAAA;AAC/C,EAAA,GACAb,OAAOY,UAAU;EACfE,IAAIC,WAAWC,aAAaY,SAAAA;EAC5BV,aAAaC,iBAAiBC;EAC9Bd,UAAUsB;AACZ,CAAA,GACA5B,OAAOY,UAAU;EACfE,IAAIC,WAAWC,aAAaa,YAAAA;EAC5BX,aAAaC,iBAAiBC;EAC9Bd,UAAUuB;AACZ,CAAA,GACA7B,OAAOY,UAAU;EACfE,IAAIC,WAAWC,aAAac,UAAAA;EAC5BZ,aAAaa,gBAAgBC,MAAMb,iBAAiBc,uBAAuBX,mBAAmBC,UAAU;EACxGjB,UAAUwB;AACZ,CAAA,GACA9B,OAAOkC,IAAI;",
6
- "names": ["ActivationEvent", "ActivationEvents", "Capability", "Plugin", "AppActivationEvents", "AppPlugin", "AppGraphBuilder", "OperationHandler", "ReactRoot", "ReactSurface", "SpotlightDismiss", "State", "UrlHandler", "meta", "SimpleLayoutEvents", "translations", "searchTranslations", "meta", "translations", "searchTranslations", "meta", "id", "SimpleLayoutPlugin", "Plugin", "define", "meta", "pipe", "AppPlugin", "addAppGraphModule", "activate", "AppGraphBuilder", "addOperationHandlerModule", "OperationHandler", "addTranslationsModule", "translations", "addModule", "isPopover", "id", "Capability", "getModuleTag", "State", "activatesOn", "ActivationEvents", "Startup", "activatesAfter", "SimpleLayoutEvents", "StateReady", "AppActivationEvents", "LayoutReady", "initialState", "SpotlightDismiss", "ReactRoot", "ReactSurface", "UrlHandler", "ActivationEvent", "allOf", "OperationInvokerReady", "make"]
7
- }
@@ -1 +0,0 @@
1
- {"inputs":{"src/translations.ts":{"bytes":3603,"imports":[{"path":"@dxos/react-ui-search","kind":"import-statement","external":true},{"path":"#meta","kind":"import-statement","external":true}],"format":"esm"},"src/SimpleLayoutPlugin.ts":{"bytes":7120,"imports":[{"path":"@dxos/app-framework","kind":"import-statement","external":true},{"path":"@dxos/app-toolkit","kind":"import-statement","external":true},{"path":"#capabilities","kind":"import-statement","external":true},{"path":"#meta","kind":"import-statement","external":true},{"path":"#types","kind":"import-statement","external":true},{"path":"src/translations.ts","kind":"import-statement","original":"./translations"}],"format":"esm"},"src/index.ts":{"bytes":490,"imports":[{"path":"src/SimpleLayoutPlugin.ts","kind":"import-statement","original":"./SimpleLayoutPlugin"}],"format":"esm"}},"outputs":{"dist/lib/browser/index.mjs.map":{"imports":[],"exports":[],"inputs":{},"bytes":5514},"dist/lib/browser/index.mjs":{"imports":[{"path":"@dxos/app-framework","kind":"import-statement","external":true},{"path":"@dxos/app-toolkit","kind":"import-statement","external":true},{"path":"#capabilities","kind":"import-statement","external":true},{"path":"#meta","kind":"import-statement","external":true},{"path":"#types","kind":"import-statement","external":true},{"path":"@dxos/react-ui-search","kind":"import-statement","external":true},{"path":"#meta","kind":"import-statement","external":true}],"exports":["SimpleLayoutPlugin"],"entryPoint":"src/index.ts","inputs":{"src/SimpleLayoutPlugin.ts":{"bytesInOutput":1583},"src/translations.ts":{"bytesInOutput":965},"src/index.ts":{"bytesInOutput":0}},"bytes":2699}}}
@@ -1,82 +0,0 @@
1
- import { createRequire } from 'node:module';const require = createRequire(import.meta.url);
2
-
3
- // src/SimpleLayoutPlugin.ts
4
- import { ActivationEvent, ActivationEvents, Capability, Plugin } from "@dxos/app-framework";
5
- import { AppActivationEvents, AppPlugin } from "@dxos/app-toolkit";
6
- import { AppGraphBuilder, OperationHandler, ReactRoot, ReactSurface, SpotlightDismiss, State, UrlHandler } from "#capabilities";
7
- import { meta as meta2 } from "#meta";
8
- import { SimpleLayoutEvents } from "#types";
9
-
10
- // src/translations.ts
11
- import { translations as searchTranslations } from "@dxos/react-ui-search";
12
- import { meta } from "#meta";
13
- var translations = [
14
- ...searchTranslations,
15
- {
16
- "en-US": {
17
- [meta.id]: {
18
- "plugin.name": "Simple layout",
19
- "settings.title": "Simple layout settings",
20
- "workspaces.heading": "Workspaces",
21
- "settings.heading": "Settings",
22
- "back.label": "Back",
23
- "browse.label": "Browse",
24
- "notifications.label": "Notifications",
25
- "profile.label": "Profile",
26
- "app-menu.label": "App menu",
27
- "main-menu.label": "Main menu",
28
- "companions-menu.label": "Companions",
29
- "error-fallback.message": "An error occurred",
30
- "drawer.label": "Drawer",
31
- "close-drawer.label": "Close drawer",
32
- "expand-drawer.label": "Expand drawer",
33
- "collapse-drawer.label": "Collapse drawer",
34
- "actions-menu.label": "Actions",
35
- "done.label": "Done"
36
- }
37
- }
38
- }
39
- ];
40
-
41
- // src/SimpleLayoutPlugin.ts
42
- var SimpleLayoutPlugin = Plugin.define(meta2).pipe(AppPlugin.addAppGraphModule({
43
- activate: AppGraphBuilder
44
- }), AppPlugin.addOperationHandlerModule({
45
- activate: OperationHandler
46
- }), AppPlugin.addTranslationsModule({
47
- translations
48
- }), Plugin.addModule(({ isPopover = false }) => ({
49
- id: Capability.getModuleTag(State),
50
- activatesOn: ActivationEvents.Startup,
51
- activatesAfter: [
52
- SimpleLayoutEvents.StateReady,
53
- AppActivationEvents.LayoutReady
54
- ],
55
- activate: () => State({
56
- initialState: {
57
- isPopover
58
- }
59
- })
60
- })), Plugin.addModule(({ isPopover = false }) => ({
61
- id: Capability.getModuleTag(SpotlightDismiss),
62
- activatesOn: ActivationEvents.Startup,
63
- activate: () => SpotlightDismiss({
64
- isPopover
65
- })
66
- })), Plugin.addModule({
67
- id: Capability.getModuleTag(ReactRoot),
68
- activatesOn: ActivationEvents.Startup,
69
- activate: ReactRoot
70
- }), Plugin.addModule({
71
- id: Capability.getModuleTag(ReactSurface),
72
- activatesOn: ActivationEvents.Startup,
73
- activate: ReactSurface
74
- }), Plugin.addModule({
75
- id: Capability.getModuleTag(UrlHandler),
76
- activatesOn: ActivationEvent.allOf(ActivationEvents.OperationInvokerReady, SimpleLayoutEvents.StateReady),
77
- activate: UrlHandler
78
- }), Plugin.make);
79
- export {
80
- SimpleLayoutPlugin
81
- };
82
- //# sourceMappingURL=index.mjs.map
@@ -1,7 +0,0 @@
1
- {
2
- "version": 3,
3
- "sources": ["../../../src/SimpleLayoutPlugin.ts", "../../../src/translations.ts"],
4
- "sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport { ActivationEvent, ActivationEvents, Capability, Plugin } from '@dxos/app-framework';\nimport { AppActivationEvents, AppPlugin } from '@dxos/app-toolkit';\n\nimport {\n AppGraphBuilder,\n OperationHandler,\n ReactRoot,\n ReactSurface,\n SpotlightDismiss,\n State,\n UrlHandler,\n} from '#capabilities';\nimport { meta } from '#meta';\nimport { SimpleLayoutEvents } from '#types';\n\nimport { translations } from './translations';\n\nexport type SimpleLayoutPluginOptions = {\n /** Determines if running in popover window context (hides mobile-specific UI). */\n isPopover?: boolean;\n};\n\nexport const SimpleLayoutPlugin = Plugin.define<SimpleLayoutPluginOptions>(meta).pipe(\n AppPlugin.addAppGraphModule({ activate: AppGraphBuilder }),\n AppPlugin.addOperationHandlerModule({ activate: OperationHandler }),\n AppPlugin.addTranslationsModule({ translations }),\n Plugin.addModule(({ isPopover = false }) => ({\n id: Capability.getModuleTag(State),\n activatesOn: ActivationEvents.Startup,\n activatesAfter: [SimpleLayoutEvents.StateReady, AppActivationEvents.LayoutReady],\n activate: () => State({ initialState: { isPopover } }),\n })),\n Plugin.addModule(({ isPopover = false }) => ({\n id: Capability.getModuleTag(SpotlightDismiss),\n activatesOn: ActivationEvents.Startup,\n activate: () => SpotlightDismiss({ isPopover }),\n })),\n Plugin.addModule({\n id: Capability.getModuleTag(ReactRoot),\n activatesOn: ActivationEvents.Startup,\n activate: ReactRoot,\n }),\n Plugin.addModule({\n id: Capability.getModuleTag(ReactSurface),\n activatesOn: ActivationEvents.Startup,\n activate: ReactSurface,\n }),\n Plugin.addModule({\n id: Capability.getModuleTag(UrlHandler),\n activatesOn: ActivationEvent.allOf(ActivationEvents.OperationInvokerReady, SimpleLayoutEvents.StateReady),\n activate: UrlHandler,\n }),\n Plugin.make,\n);\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport { type Resource } from '@dxos/react-ui';\nimport { translations as searchTranslations } from '@dxos/react-ui-search';\n\nimport { meta } from '#meta';\n\nexport const translations = [\n ...searchTranslations,\n {\n 'en-US': {\n [meta.id]: {\n 'plugin.name': 'Simple layout',\n 'settings.title': 'Simple layout settings',\n 'workspaces.heading': 'Workspaces',\n 'settings.heading': 'Settings',\n 'back.label': 'Back',\n 'browse.label': 'Browse',\n 'notifications.label': 'Notifications',\n 'profile.label': 'Profile',\n 'app-menu.label': 'App menu',\n 'main-menu.label': 'Main menu',\n 'companions-menu.label': 'Companions',\n 'error-fallback.message': 'An error occurred',\n 'drawer.label': 'Drawer',\n 'close-drawer.label': 'Close drawer',\n 'expand-drawer.label': 'Expand drawer',\n 'collapse-drawer.label': 'Collapse drawer',\n 'actions-menu.label': 'Actions',\n 'done.label': 'Done',\n },\n },\n },\n] as const satisfies Resource[];\n"],
5
- "mappings": ";;;AAIA,SAASA,iBAAiBC,kBAAkBC,YAAYC,cAAc;AACtE,SAASC,qBAAqBC,iBAAiB;AAE/C,SACEC,iBACAC,kBACAC,WACAC,cACAC,kBACAC,OACAC,kBACK;AACP,SAASC,QAAAA,aAAY;AACrB,SAASC,0BAA0B;;;ACZnC,SAASC,gBAAgBC,0BAA0B;AAEnD,SAASC,YAAY;AAEd,IAAMC,eAAe;KACvBC;EACH;IACE,SAAS;MACP,CAACC,KAAKC,EAAE,GAAG;QACT,eAAe;QACf,kBAAkB;QAClB,sBAAsB;QACtB,oBAAoB;QACpB,cAAc;QACd,gBAAgB;QAChB,uBAAuB;QACvB,iBAAiB;QACjB,kBAAkB;QAClB,mBAAmB;QACnB,yBAAyB;QACzB,0BAA0B;QAC1B,gBAAgB;QAChB,sBAAsB;QACtB,uBAAuB;QACvB,yBAAyB;QACzB,sBAAsB;QACtB,cAAc;MAChB;IACF;EACF;;;;ADRK,IAAMC,qBAAqBC,OAAOC,OAAkCC,KAAAA,EAAMC,KAC/EC,UAAUC,kBAAkB;EAAEC,UAAUC;AAAgB,CAAA,GACxDH,UAAUI,0BAA0B;EAAEF,UAAUG;AAAiB,CAAA,GACjEL,UAAUM,sBAAsB;EAAEC;AAAa,CAAA,GAC/CX,OAAOY,UAAU,CAAC,EAAEC,YAAY,MAAK,OAAQ;EAC3CC,IAAIC,WAAWC,aAAaC,KAAAA;EAC5BC,aAAaC,iBAAiBC;EAC9BC,gBAAgB;IAACC,mBAAmBC;IAAYC,oBAAoBC;;EACpEnB,UAAU,MAAMW,MAAM;IAAES,cAAc;MAAEb;IAAU;EAAE,CAAA;AACtD,EAAA,GACAb,OAAOY,UAAU,CAAC,EAAEC,YAAY,MAAK,OAAQ;EAC3CC,IAAIC,WAAWC,aAAaW,gBAAAA;EAC5BT,aAAaC,iBAAiBC;EAC9Bd,UAAU,MAAMqB,iBAAiB;IAAEd;EAAU,CAAA;AAC/C,EAAA,GACAb,OAAOY,UAAU;EACfE,IAAIC,WAAWC,aAAaY,SAAAA;EAC5BV,aAAaC,iBAAiBC;EAC9Bd,UAAUsB;AACZ,CAAA,GACA5B,OAAOY,UAAU;EACfE,IAAIC,WAAWC,aAAaa,YAAAA;EAC5BX,aAAaC,iBAAiBC;EAC9Bd,UAAUuB;AACZ,CAAA,GACA7B,OAAOY,UAAU;EACfE,IAAIC,WAAWC,aAAac,UAAAA;EAC5BZ,aAAaa,gBAAgBC,MAAMb,iBAAiBc,uBAAuBX,mBAAmBC,UAAU;EACxGjB,UAAUwB;AACZ,CAAA,GACA9B,OAAOkC,IAAI;",
6
- "names": ["ActivationEvent", "ActivationEvents", "Capability", "Plugin", "AppActivationEvents", "AppPlugin", "AppGraphBuilder", "OperationHandler", "ReactRoot", "ReactSurface", "SpotlightDismiss", "State", "UrlHandler", "meta", "SimpleLayoutEvents", "translations", "searchTranslations", "meta", "translations", "searchTranslations", "meta", "id", "SimpleLayoutPlugin", "Plugin", "define", "meta", "pipe", "AppPlugin", "addAppGraphModule", "activate", "AppGraphBuilder", "addOperationHandlerModule", "OperationHandler", "addTranslationsModule", "translations", "addModule", "isPopover", "id", "Capability", "getModuleTag", "State", "activatesOn", "ActivationEvents", "Startup", "activatesAfter", "SimpleLayoutEvents", "StateReady", "AppActivationEvents", "LayoutReady", "initialState", "SpotlightDismiss", "ReactRoot", "ReactSurface", "UrlHandler", "ActivationEvent", "allOf", "OperationInvokerReady", "make"]
7
- }
@@ -1 +0,0 @@
1
- {"inputs":{"src/translations.ts":{"bytes":3603,"imports":[{"path":"@dxos/react-ui-search","kind":"import-statement","external":true},{"path":"#meta","kind":"import-statement","external":true}],"format":"esm"},"src/SimpleLayoutPlugin.ts":{"bytes":7120,"imports":[{"path":"@dxos/app-framework","kind":"import-statement","external":true},{"path":"@dxos/app-toolkit","kind":"import-statement","external":true},{"path":"#capabilities","kind":"import-statement","external":true},{"path":"#meta","kind":"import-statement","external":true},{"path":"#types","kind":"import-statement","external":true},{"path":"src/translations.ts","kind":"import-statement","original":"./translations"}],"format":"esm"},"src/index.ts":{"bytes":490,"imports":[{"path":"src/SimpleLayoutPlugin.ts","kind":"import-statement","original":"./SimpleLayoutPlugin"}],"format":"esm"}},"outputs":{"dist/lib/node-esm/index.mjs.map":{"imports":[],"exports":[],"inputs":{},"bytes":5516},"dist/lib/node-esm/index.mjs":{"imports":[{"path":"@dxos/app-framework","kind":"import-statement","external":true},{"path":"@dxos/app-toolkit","kind":"import-statement","external":true},{"path":"#capabilities","kind":"import-statement","external":true},{"path":"#meta","kind":"import-statement","external":true},{"path":"#types","kind":"import-statement","external":true},{"path":"@dxos/react-ui-search","kind":"import-statement","external":true},{"path":"#meta","kind":"import-statement","external":true}],"exports":["SimpleLayoutPlugin"],"entryPoint":"src/index.ts","inputs":{"src/SimpleLayoutPlugin.ts":{"bytesInOutput":1583},"src/translations.ts":{"bytesInOutput":965},"src/index.ts":{"bytesInOutput":0}},"bytes":2792}}}
@@ -1 +0,0 @@
1
- {"version":3,"file":"capabilities.d.ts","sourceRoot":"","sources":["../../../../src/types/capabilities.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,KAAK,IAAI,EAAE,MAAM,yBAAyB,CAAC;AAEpD,OAAO,EAAE,UAAU,EAAE,MAAM,qBAAqB,CAAC;AACjD,OAAO,EAAE,KAAK,KAAK,EAAE,MAAM,gBAAgB,CAAC;AAI5C,MAAM,MAAM,WAAW,GAAG,QAAQ,GAAG,MAAM,GAAG,UAAU,CAAC;AAGzD,MAAM,MAAM,iBAAiB,GAAG;IAC9B,qDAAqD;IACrD,OAAO,CAAC,EAAE,GAAG,CAAC;IAEd,iBAAiB,EAAE,MAAM,CAAC;IAC1B,SAAS,EAAE,MAAM,CAAC;IAClB,MAAM,CAAC,EAAE,MAAM,CAAC;IAEhB,UAAU,EAAE,OAAO,CAAC;IACpB,UAAU,CAAC,EAAE,SAAS,GAAG,OAAO,CAAC;IACjC,gBAAgB,CAAC,EAAE,OAAO,GAAG,QAAQ,GAAG,KAAK,CAAC;IAC9C,oBAAoB,CAAC,EAAE,MAAM,CAAC;IAC9B,kBAAkB,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;IACzC,+CAA+C;IAC/C,aAAa,CAAC,EAAE;QAAE,SAAS,EAAE,MAAM,CAAC;QAAC,KAAK,CAAC,EAAE,GAAG,CAAA;KAAE,GAAG,IAAI,CAAC;IAE1D,WAAW,CAAC,EAAE,OAAO,CAAC;IACtB,WAAW,CAAC,EAAE,KAAK,GAAG,OAAO,GAAG,QAAQ,GAAG,MAAM,CAAC;IAClD,cAAc,CAAC,EAAE,SAAS,GAAG,OAAO,CAAC;IACrC,aAAa,CAAC,EAAE,iBAAiB,CAAC;IAClC,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,WAAW,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC;IAC9B,YAAY,CAAC,EAAE,KAAK,CAAC;IACrB,cAAc,CAAC,EAAE;QAAE,SAAS,EAAE,MAAM,CAAC;QAAC,KAAK,CAAC,EAAE,GAAG,CAAA;KAAE,GAAG;QAAE,OAAO,EAAE,GAAG,CAAA;KAAE,GAAG,IAAI,CAAC;IAE9E,2BAA2B;IAC3B,WAAW,EAAE,WAAW,CAAC;IAEzB,+DAA+D;IAC/D,OAAO,EAAE,MAAM,EAAE,CAAC;IAElB,4EAA4E;IAC5E,SAAS,CAAC,EAAE,OAAO,CAAC;IAEpB,8FAA8F;IAC9F,gBAAgB,CAAC,EAAE,MAAM,CAAC;CAC3B,CAAC;AAEF,eAAO,MAAM,iBAAiB,8EAAwE,CAAC"}
@@ -1,6 +0,0 @@
1
- import { type ActivationEvent } from '@dxos/app-framework';
2
- export declare namespace SimpleLayoutEvents {
3
- /** Fired when SimpleLayoutState capability is ready. */
4
- const StateReady: ActivationEvent.ActivationEvent;
5
- }
6
- //# sourceMappingURL=events.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"events.d.ts","sourceRoot":"","sources":["../../../../src/types/events.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,KAAK,eAAe,EAAE,MAAM,qBAAqB,CAAC;AAK3D,yBAAiB,kBAAkB,CAAC;IAClC,wDAAwD;IACjD,MAAM,UAAU,EAAE,eAAe,CAAC,eAExC,CAAC;CACH"}
@@ -1,15 +0,0 @@
1
- //
2
- // Copyright 2025 DXOS.org
3
- //
4
-
5
- import { type ActivationEvent } from '@dxos/app-framework';
6
- import { AppActivationEvents } from '@dxos/app-toolkit';
7
-
8
- import { SimpleLayoutState } from './capabilities';
9
-
10
- export namespace SimpleLayoutEvents {
11
- /** Fired when SimpleLayoutState capability is ready. */
12
- export const StateReady: ActivationEvent.ActivationEvent = AppActivationEvents.createStateEvent(
13
- SimpleLayoutState.identifier,
14
- );
15
- }