@dxos/plugin-simple-layout 0.8.4-main.9735255 → 0.8.4-main.abd8ff62ef

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 (259) hide show
  1. package/dist/lib/browser/SimpleLayoutPlugin-Q5BZE6KD.mjs +50 -0
  2. package/dist/lib/browser/SimpleLayoutPlugin-Q5BZE6KD.mjs.map +7 -0
  3. package/dist/lib/browser/index.mjs +18 -96
  4. package/dist/lib/browser/index.mjs.map +4 -4
  5. package/dist/lib/browser/meta.json +1 -1
  6. package/dist/lib/browser/translations.mjs +34 -0
  7. package/dist/lib/browser/translations.mjs.map +7 -0
  8. package/dist/lib/node-esm/SimpleLayoutPlugin-OD45TNPO.mjs +52 -0
  9. package/dist/lib/node-esm/SimpleLayoutPlugin-OD45TNPO.mjs.map +7 -0
  10. package/dist/lib/node-esm/index.mjs +18 -95
  11. package/dist/lib/node-esm/index.mjs.map +4 -4
  12. package/dist/lib/node-esm/meta.json +1 -1
  13. package/dist/lib/node-esm/translations.mjs +36 -0
  14. package/dist/lib/node-esm/translations.mjs.map +7 -0
  15. package/dist/types/src/SimpleLayoutPlugin.d.ts +2 -1
  16. package/dist/types/src/SimpleLayoutPlugin.d.ts.map +1 -1
  17. package/dist/types/src/capabilities/app-graph-builder.d.ts +6 -0
  18. package/dist/types/src/capabilities/app-graph-builder.d.ts.map +1 -0
  19. package/dist/types/src/capabilities/index.d.ts +21 -6
  20. package/dist/types/src/capabilities/index.d.ts.map +1 -1
  21. package/dist/types/src/capabilities/operation-handler.d.ts +6 -0
  22. package/dist/types/src/capabilities/operation-handler.d.ts.map +1 -0
  23. package/dist/types/src/capabilities/{react-root/react-root.d.ts → react-root.d.ts} +1 -1
  24. package/dist/types/src/capabilities/react-root.d.ts.map +1 -0
  25. package/dist/types/src/capabilities/react-surface.d.ts +5 -0
  26. package/dist/types/src/capabilities/react-surface.d.ts.map +1 -0
  27. package/dist/types/src/capabilities/{spotlight-dismiss/spotlight-dismiss.d.ts → spotlight-dismiss.d.ts} +1 -1
  28. package/dist/types/src/capabilities/spotlight-dismiss.d.ts.map +1 -0
  29. package/dist/types/src/capabilities/{state/state.d.ts → state.d.ts} +2 -2
  30. package/dist/types/src/capabilities/state.d.ts.map +1 -0
  31. package/dist/types/src/capabilities/url-handler.d.ts +12 -0
  32. package/dist/types/src/capabilities/url-handler.d.ts.map +1 -0
  33. package/dist/types/src/components/ContentError.stories.d.ts +27 -22
  34. package/dist/types/src/components/ContentError.stories.d.ts.map +1 -1
  35. package/dist/types/src/components/DebugOverlay/DebugOverlay.d.ts +19 -0
  36. package/dist/types/src/components/DebugOverlay/DebugOverlay.d.ts.map +1 -0
  37. package/dist/types/src/components/DebugOverlay/index.d.ts +2 -0
  38. package/dist/types/src/components/DebugOverlay/index.d.ts.map +1 -0
  39. package/dist/types/src/components/Dialog/Dialog.d.ts.map +1 -1
  40. package/dist/types/src/components/Home/Home.d.ts.map +1 -1
  41. package/dist/types/src/components/Loading/Loading.d.ts +3 -0
  42. package/dist/types/src/components/Loading/Loading.d.ts.map +1 -0
  43. package/dist/types/src/components/{ContentLoading.stories.d.ts → Loading/Loading.stories.d.ts} +1 -1
  44. package/dist/types/src/components/Loading/Loading.stories.d.ts.map +1 -0
  45. package/dist/types/src/components/Loading/index.d.ts +2 -0
  46. package/dist/types/src/components/Loading/index.d.ts.map +1 -0
  47. package/dist/types/src/components/MobileLayout/MobileLayout.d.ts +35 -0
  48. package/dist/types/src/components/MobileLayout/MobileLayout.d.ts.map +1 -0
  49. package/dist/types/src/components/MobileLayout/MobileLayout.stories.d.ts +7 -0
  50. package/dist/types/src/components/MobileLayout/MobileLayout.stories.d.ts.map +1 -0
  51. package/dist/types/src/components/MobileLayout/index.d.ts +2 -0
  52. package/dist/types/src/components/MobileLayout/index.d.ts.map +1 -0
  53. package/dist/types/src/components/NavBranch/NavBranch.d.ts +11 -0
  54. package/dist/types/src/components/NavBranch/NavBranch.d.ts.map +1 -0
  55. package/dist/types/src/components/NavBranch/index.d.ts +2 -0
  56. package/dist/types/src/components/NavBranch/index.d.ts.map +1 -0
  57. package/dist/types/src/components/Popover/Popover.d.ts.map +1 -1
  58. package/dist/types/src/components/SimpleLayout/AppBar.d.ts +24 -0
  59. package/dist/types/src/components/SimpleLayout/AppBar.d.ts.map +1 -0
  60. package/dist/types/src/components/SimpleLayout/AppBar.stories.d.ts +54 -0
  61. package/dist/types/src/components/SimpleLayout/AppBar.stories.d.ts.map +1 -0
  62. package/dist/types/src/components/SimpleLayout/Drawer.d.ts +4 -7
  63. package/dist/types/src/components/SimpleLayout/Drawer.d.ts.map +1 -1
  64. package/dist/types/src/components/SimpleLayout/Main.d.ts +4 -7
  65. package/dist/types/src/components/SimpleLayout/Main.d.ts.map +1 -1
  66. package/dist/types/src/components/SimpleLayout/NavBar.d.ts +13 -8
  67. package/dist/types/src/components/SimpleLayout/NavBar.d.ts.map +1 -1
  68. package/dist/types/src/components/SimpleLayout/NavBar.stories.d.ts +32 -26
  69. package/dist/types/src/components/SimpleLayout/NavBar.stories.d.ts.map +1 -1
  70. package/dist/types/src/components/SimpleLayout/SimpleLayout.d.ts.map +1 -1
  71. package/dist/types/src/components/SimpleLayout/SimpleLayout.stories.d.ts +26 -25
  72. package/dist/types/src/components/SimpleLayout/SimpleLayout.stories.d.ts.map +1 -1
  73. package/dist/types/src/components/SimpleLayout/index.d.ts +3 -0
  74. package/dist/types/src/components/SimpleLayout/index.d.ts.map +1 -1
  75. package/dist/types/src/components/hooks.d.ts +4 -2
  76. package/dist/types/src/components/hooks.d.ts.map +1 -1
  77. package/dist/types/src/components/index.d.ts +4 -2
  78. package/dist/types/src/components/index.d.ts.map +1 -1
  79. package/dist/types/src/hooks/actions.d.ts +19 -0
  80. package/dist/types/src/hooks/actions.d.ts.map +1 -0
  81. package/dist/types/src/hooks/index.d.ts +4 -0
  82. package/dist/types/src/hooks/index.d.ts.map +1 -1
  83. package/dist/types/src/hooks/useAppBarProps.d.ts +7 -0
  84. package/dist/types/src/hooks/useAppBarProps.d.ts.map +1 -0
  85. package/dist/types/src/hooks/useCompanions.d.ts +5 -1
  86. package/dist/types/src/hooks/useCompanions.d.ts.map +1 -1
  87. package/dist/types/src/hooks/useDrawerActions.d.ts +13 -0
  88. package/dist/types/src/hooks/useDrawerActions.d.ts.map +1 -0
  89. package/dist/types/src/hooks/useNavbarActions.d.ts +14 -0
  90. package/dist/types/src/hooks/useNavbarActions.d.ts.map +1 -0
  91. package/dist/types/src/hooks/useSimpleLayoutState.d.ts +3 -3
  92. package/dist/types/src/hooks/useSimpleLayoutState.d.ts.map +1 -1
  93. package/dist/types/src/index.d.ts +3 -1
  94. package/dist/types/src/index.d.ts.map +1 -1
  95. package/dist/types/src/operations/close.d.ts +5 -0
  96. package/dist/types/src/operations/close.d.ts.map +1 -0
  97. package/dist/types/src/operations/index.d.ts +3 -0
  98. package/dist/types/src/operations/index.d.ts.map +1 -0
  99. package/dist/types/src/operations/open.d.ts +5 -0
  100. package/dist/types/src/operations/open.d.ts.map +1 -0
  101. package/dist/types/src/operations/revert-workspace.d.ts +5 -0
  102. package/dist/types/src/operations/revert-workspace.d.ts.map +1 -0
  103. package/dist/types/src/operations/set-layout-mode.d.ts +5 -0
  104. package/dist/types/src/operations/set-layout-mode.d.ts.map +1 -0
  105. package/dist/types/src/operations/set.d.ts +5 -0
  106. package/dist/types/src/operations/set.d.ts.map +1 -0
  107. package/dist/types/src/operations/state-access.d.ts +8 -0
  108. package/dist/types/src/operations/state-access.d.ts.map +1 -0
  109. package/dist/types/src/operations/switch-workspace.d.ts +5 -0
  110. package/dist/types/src/operations/switch-workspace.d.ts.map +1 -0
  111. package/dist/types/src/operations/update-complementary.d.ts +5 -0
  112. package/dist/types/src/operations/update-complementary.d.ts.map +1 -0
  113. package/dist/types/src/operations/update-dialog.d.ts +5 -0
  114. package/dist/types/src/operations/update-dialog.d.ts.map +1 -0
  115. package/dist/types/src/operations/update-popover.d.ts +5 -0
  116. package/dist/types/src/operations/update-popover.d.ts.map +1 -0
  117. package/dist/types/src/operations/update-sidebar.d.ts +5 -0
  118. package/dist/types/src/operations/update-sidebar.d.ts.map +1 -0
  119. package/dist/types/src/translations.d.ts +26 -20
  120. package/dist/types/src/translations.d.ts.map +1 -1
  121. package/dist/types/src/types/capabilities.d.ts +17 -8
  122. package/dist/types/src/types/capabilities.d.ts.map +1 -1
  123. package/dist/types/src/types/events.d.ts.map +1 -1
  124. package/dist/types/tsconfig.tsbuildinfo +1 -1
  125. package/package.json +54 -30
  126. package/src/SimpleLayoutPlugin.ts +26 -14
  127. package/src/capabilities/app-graph-builder.ts +21 -0
  128. package/src/capabilities/index.ts +13 -6
  129. package/src/capabilities/operation-handler.ts +14 -0
  130. package/src/capabilities/{react-root/react-root.tsx → react-root.tsx} +4 -4
  131. package/src/capabilities/react-surface.tsx +50 -0
  132. package/src/capabilities/{spotlight-dismiss/spotlight-dismiss.ts → spotlight-dismiss.ts} +2 -2
  133. package/src/capabilities/{state/state.tsx → state.tsx} +6 -5
  134. package/src/capabilities/url-handler.ts +161 -0
  135. package/src/components/ContentError.stories.tsx +9 -8
  136. package/src/components/DebugOverlay/DebugOverlay.tsx +96 -0
  137. package/src/components/DebugOverlay/index.ts +5 -0
  138. package/src/components/Dialog/Dialog.tsx +17 -6
  139. package/src/components/Home/Home.tsx +51 -43
  140. package/src/components/{ContentLoading.stories.tsx → Loading/Loading.stories.tsx} +5 -5
  141. package/src/components/{ContentLoading.tsx → Loading/Loading.tsx} +2 -2
  142. package/src/components/Loading/index.ts +5 -0
  143. package/src/components/MobileLayout/MobileLayout.stories.tsx +133 -0
  144. package/src/components/MobileLayout/MobileLayout.tsx +374 -0
  145. package/src/components/MobileLayout/index.ts +5 -0
  146. package/src/components/NavBranch/NavBranch.tsx +124 -0
  147. package/src/components/{Workspace → NavBranch}/index.ts +1 -1
  148. package/src/components/Popover/Popover.tsx +13 -9
  149. package/src/components/SimpleLayout/AppBar.stories.tsx +144 -0
  150. package/src/components/SimpleLayout/AppBar.tsx +94 -0
  151. package/src/components/SimpleLayout/Drawer.tsx +44 -91
  152. package/src/components/SimpleLayout/Main.tsx +40 -34
  153. package/src/components/SimpleLayout/NavBar.stories.tsx +132 -24
  154. package/src/components/SimpleLayout/NavBar.tsx +18 -51
  155. package/src/components/SimpleLayout/SimpleLayout.stories.tsx +46 -60
  156. package/src/components/SimpleLayout/SimpleLayout.tsx +41 -23
  157. package/src/components/SimpleLayout/index.ts +3 -0
  158. package/src/components/hooks.ts +9 -9
  159. package/src/components/index.ts +4 -2
  160. package/src/hooks/actions.ts +84 -0
  161. package/src/hooks/index.ts +4 -0
  162. package/src/hooks/useAppBarProps.ts +95 -0
  163. package/src/hooks/useCompanions.ts +8 -5
  164. package/src/hooks/useDrawerActions.ts +100 -0
  165. package/src/hooks/useNavbarActions.ts +87 -0
  166. package/src/hooks/useSimpleLayoutState.ts +5 -5
  167. package/src/index.ts +7 -1
  168. package/src/meta.ts +1 -1
  169. package/src/operations/close.ts +34 -0
  170. package/src/operations/index.ts +16 -0
  171. package/src/operations/open.ts +63 -0
  172. package/src/operations/revert-workspace.ts +22 -0
  173. package/src/operations/set-layout-mode.ts +12 -0
  174. package/src/operations/set.ts +23 -0
  175. package/src/operations/state-access.ts +19 -0
  176. package/src/operations/switch-workspace.ts +26 -0
  177. package/src/operations/update-complementary.ts +35 -0
  178. package/src/operations/update-dialog.ts +28 -0
  179. package/src/operations/update-popover.ts +35 -0
  180. package/src/operations/update-sidebar.ts +12 -0
  181. package/src/translations.ts +21 -19
  182. package/src/types/capabilities.ts +14 -10
  183. package/src/types/events.ts +3 -2
  184. package/dist/lib/browser/chunk-LR3EE3VB.mjs +0 -789
  185. package/dist/lib/browser/chunk-LR3EE3VB.mjs.map +0 -7
  186. package/dist/lib/browser/chunk-P77G4YTR.mjs +0 -29
  187. package/dist/lib/browser/chunk-P77G4YTR.mjs.map +0 -7
  188. package/dist/lib/browser/operation-resolver-775UYAC2.mjs +0 -203
  189. package/dist/lib/browser/operation-resolver-775UYAC2.mjs.map +0 -7
  190. package/dist/lib/browser/react-root-KM55OMGJ.mjs +0 -21
  191. package/dist/lib/browser/react-root-KM55OMGJ.mjs.map +0 -7
  192. package/dist/lib/browser/react-surface-BABGAWGY.mjs +0 -39
  193. package/dist/lib/browser/react-surface-BABGAWGY.mjs.map +0 -7
  194. package/dist/lib/browser/spotlight-dismiss-VSNOPETH.mjs +0 -66
  195. package/dist/lib/browser/spotlight-dismiss-VSNOPETH.mjs.map +0 -7
  196. package/dist/lib/browser/state-OUFTC2KV.mjs +0 -47
  197. package/dist/lib/browser/state-OUFTC2KV.mjs.map +0 -7
  198. package/dist/lib/browser/url-handler-DOUFQIAC.mjs +0 -54
  199. package/dist/lib/browser/url-handler-DOUFQIAC.mjs.map +0 -7
  200. package/dist/lib/node-esm/chunk-F5TEKVJG.mjs +0 -31
  201. package/dist/lib/node-esm/chunk-F5TEKVJG.mjs.map +0 -7
  202. package/dist/lib/node-esm/chunk-HB2B3LLG.mjs +0 -790
  203. package/dist/lib/node-esm/chunk-HB2B3LLG.mjs.map +0 -7
  204. package/dist/lib/node-esm/operation-resolver-LDNYS3DI.mjs +0 -204
  205. package/dist/lib/node-esm/operation-resolver-LDNYS3DI.mjs.map +0 -7
  206. package/dist/lib/node-esm/react-root-36UYFEEB.mjs +0 -22
  207. package/dist/lib/node-esm/react-root-36UYFEEB.mjs.map +0 -7
  208. package/dist/lib/node-esm/react-surface-CGHFVWU3.mjs +0 -40
  209. package/dist/lib/node-esm/react-surface-CGHFVWU3.mjs.map +0 -7
  210. package/dist/lib/node-esm/spotlight-dismiss-L5PCWIJG.mjs +0 -68
  211. package/dist/lib/node-esm/spotlight-dismiss-L5PCWIJG.mjs.map +0 -7
  212. package/dist/lib/node-esm/state-Q2ZA26W5.mjs +0 -48
  213. package/dist/lib/node-esm/state-Q2ZA26W5.mjs.map +0 -7
  214. package/dist/lib/node-esm/url-handler-DVAZZEUO.mjs +0 -55
  215. package/dist/lib/node-esm/url-handler-DVAZZEUO.mjs.map +0 -7
  216. package/dist/types/src/capabilities/operation-resolver/index.d.ts +0 -3
  217. package/dist/types/src/capabilities/operation-resolver/index.d.ts.map +0 -1
  218. package/dist/types/src/capabilities/operation-resolver/operation-resolver.d.ts +0 -5
  219. package/dist/types/src/capabilities/operation-resolver/operation-resolver.d.ts.map +0 -1
  220. package/dist/types/src/capabilities/react-root/index.d.ts +0 -6
  221. package/dist/types/src/capabilities/react-root/index.d.ts.map +0 -1
  222. package/dist/types/src/capabilities/react-root/react-root.d.ts.map +0 -1
  223. package/dist/types/src/capabilities/react-surface/index.d.ts +0 -3
  224. package/dist/types/src/capabilities/react-surface/index.d.ts.map +0 -1
  225. package/dist/types/src/capabilities/react-surface/react-surface.d.ts +0 -5
  226. package/dist/types/src/capabilities/react-surface/react-surface.d.ts.map +0 -1
  227. package/dist/types/src/capabilities/spotlight-dismiss/index.d.ts +0 -3
  228. package/dist/types/src/capabilities/spotlight-dismiss/index.d.ts.map +0 -1
  229. package/dist/types/src/capabilities/spotlight-dismiss/spotlight-dismiss.d.ts.map +0 -1
  230. package/dist/types/src/capabilities/state/index.d.ts +0 -13
  231. package/dist/types/src/capabilities/state/index.d.ts.map +0 -1
  232. package/dist/types/src/capabilities/state/state.d.ts.map +0 -1
  233. package/dist/types/src/capabilities/url-handler/index.d.ts +0 -3
  234. package/dist/types/src/capabilities/url-handler/index.d.ts.map +0 -1
  235. package/dist/types/src/capabilities/url-handler/url-handler.d.ts +0 -10
  236. package/dist/types/src/capabilities/url-handler/url-handler.d.ts.map +0 -1
  237. package/dist/types/src/components/ContentError.d.ts +0 -5
  238. package/dist/types/src/components/ContentError.d.ts.map +0 -1
  239. package/dist/types/src/components/ContentLoading.d.ts +0 -3
  240. package/dist/types/src/components/ContentLoading.d.ts.map +0 -1
  241. package/dist/types/src/components/ContentLoading.stories.d.ts.map +0 -1
  242. package/dist/types/src/components/SimpleLayout/Banner.d.ts +0 -8
  243. package/dist/types/src/components/SimpleLayout/Banner.d.ts.map +0 -1
  244. package/dist/types/src/components/Workspace/Workspace.d.ts +0 -9
  245. package/dist/types/src/components/Workspace/Workspace.d.ts.map +0 -1
  246. package/dist/types/src/components/Workspace/index.d.ts +0 -2
  247. package/dist/types/src/components/Workspace/index.d.ts.map +0 -1
  248. package/src/capabilities/operation-resolver/index.ts +0 -10
  249. package/src/capabilities/operation-resolver/operation-resolver.ts +0 -215
  250. package/src/capabilities/react-root/index.ts +0 -7
  251. package/src/capabilities/react-surface/index.ts +0 -7
  252. package/src/capabilities/react-surface/react-surface.tsx +0 -40
  253. package/src/capabilities/spotlight-dismiss/index.ts +0 -7
  254. package/src/capabilities/state/index.ts +0 -9
  255. package/src/capabilities/url-handler/index.ts +0 -7
  256. package/src/capabilities/url-handler/url-handler.ts +0 -80
  257. package/src/components/ContentError.tsx +0 -23
  258. package/src/components/SimpleLayout/Banner.tsx +0 -113
  259. package/src/components/Workspace/Workspace.tsx +0 -115
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@dxos/plugin-simple-layout",
3
- "version": "0.8.4-main.9735255",
3
+ "version": "0.8.4-main.abd8ff62ef",
4
4
  "description": "Simple layout plugin for minimal UI contexts like popover windows.",
5
5
  "homepage": "https://dxos.org",
6
6
  "bugs": "https://github.com/dxos/dxos/issues",
@@ -12,12 +12,27 @@
12
12
  "author": "DXOS.org",
13
13
  "sideEffects": true,
14
14
  "type": "module",
15
+ "imports": {
16
+ "#capabilities": "./src/capabilities/index.ts",
17
+ "#components": "./src/components/index.ts",
18
+ "#hooks": "./src/hooks/index.ts",
19
+ "#meta": "./src/meta.ts",
20
+ "#operations": "./src/operations/index.ts",
21
+ "#translations": "./src/translations.ts",
22
+ "#types": "./src/types/index.ts"
23
+ },
15
24
  "exports": {
16
25
  ".": {
17
26
  "source": "./src/index.ts",
18
- "types": "./dist/types/src/index.d.ts",
19
27
  "browser": "./dist/lib/browser/index.mjs",
20
- "node": "./dist/lib/node-esm/index.mjs"
28
+ "node": "./dist/lib/node-esm/index.mjs",
29
+ "types": "./dist/types/src/index.d.ts"
30
+ },
31
+ "./translations": {
32
+ "source": "./src/translations.ts",
33
+ "types": "./dist/types/src/translations.d.ts",
34
+ "browser": "./dist/lib/browser/translations.mjs",
35
+ "node": "./dist/lib/node-esm/translations.mjs"
21
36
  }
22
37
  },
23
38
  "types": "dist/types/src/index.d.ts",
@@ -26,44 +41,53 @@
26
41
  "src"
27
42
  ],
28
43
  "dependencies": {
29
- "@effect-atom/atom": "^0.4.13",
30
- "@effect-atom/atom-react": "^0.4.6",
44
+ "@effect-atom/atom": "^0.5.1",
45
+ "@effect-atom/atom-react": "^0.5.0",
31
46
  "@radix-ui/react-context": "1.1.1",
32
- "@dxos/app-framework": "0.8.4-main.9735255",
33
- "@dxos/log": "0.8.4-main.9735255",
34
- "@dxos/operation": "0.8.4-main.9735255",
35
- "@dxos/plugin-graph": "0.8.4-main.9735255",
36
- "@dxos/react-ui-attention": "0.8.4-main.9735255",
37
- "@dxos/react-ui-menu": "0.8.4-main.9735255",
38
- "@dxos/react-ui-searchlist": "0.8.4-main.9735255",
39
- "@dxos/react-ui-mosaic": "0.8.4-main.9735255",
40
- "@dxos/schema": "0.8.4-main.9735255",
41
- "@dxos/react-ui-stack": "0.8.4-main.9735255",
42
- "@dxos/util": "0.8.4-main.9735255"
47
+ "@tauri-apps/plugin-deep-link": "^2.2.0",
48
+ "@tauri-apps/plugin-haptics": "^2.3.2",
49
+ "@dxos/app-toolkit": "0.8.4-main.abd8ff62ef",
50
+ "@dxos/async": "0.8.4-main.abd8ff62ef",
51
+ "@dxos/context": "0.8.4-main.abd8ff62ef",
52
+ "@dxos/compute": "0.8.4-main.abd8ff62ef",
53
+ "@dxos/echo": "0.8.4-main.abd8ff62ef",
54
+ "@dxos/effect": "0.8.4-main.abd8ff62ef",
55
+ "@dxos/plugin-client": "0.8.4-main.abd8ff62ef",
56
+ "@dxos/log": "0.8.4-main.abd8ff62ef",
57
+ "@dxos/react-ui-attention": "0.8.4-main.abd8ff62ef",
58
+ "@dxos/plugin-graph": "0.8.4-main.abd8ff62ef",
59
+ "@dxos/react-ui-list": "0.8.4-main.abd8ff62ef",
60
+ "@dxos/react-ui-menu": "0.8.4-main.abd8ff62ef",
61
+ "@dxos/react-ui-mosaic": "0.8.4-main.abd8ff62ef",
62
+ "@dxos/schema": "0.8.4-main.abd8ff62ef",
63
+ "@dxos/app-framework": "0.8.4-main.abd8ff62ef",
64
+ "@dxos/react-ui-search": "0.8.4-main.abd8ff62ef",
65
+ "@dxos/react-ui-stack": "0.8.4-main.abd8ff62ef",
66
+ "@dxos/util": "0.8.4-main.abd8ff62ef"
43
67
  },
44
68
  "devDependencies": {
45
69
  "@types/react": "~19.2.7",
46
70
  "@types/react-dom": "~19.2.3",
47
- "effect": "3.19.11",
71
+ "effect": "3.20.0",
48
72
  "react": "~19.2.3",
49
73
  "react-dom": "~19.2.3",
50
- "vite": "7.1.9",
51
- "@dxos/plugin-client": "0.8.4-main.9735255",
52
- "@dxos/plugin-preview": "0.8.4-main.9735255",
53
- "@dxos/plugin-search": "0.8.4-main.9735255",
54
- "@dxos/plugin-space": "0.8.4-main.9735255",
55
- "@dxos/react-ui": "0.8.4-main.9735255",
56
- "@dxos/plugin-testing": "0.8.4-main.9735255",
57
- "@dxos/schema": "0.8.4-main.9735255",
58
- "@dxos/storybook-utils": "0.8.4-main.9735255",
59
- "@dxos/ui-theme": "0.8.4-main.9735255"
74
+ "vite": "^8.0.10",
75
+ "@dxos/app-graph": "0.8.4-main.abd8ff62ef",
76
+ "@dxos/plugin-search": "0.8.4-main.abd8ff62ef",
77
+ "@dxos/plugin-space": "0.8.4-main.abd8ff62ef",
78
+ "@dxos/plugin-testing": "0.8.4-main.abd8ff62ef",
79
+ "@dxos/schema": "0.8.4-main.abd8ff62ef",
80
+ "@dxos/react-ui": "0.8.4-main.abd8ff62ef",
81
+ "@dxos/storybook-utils": "0.8.4-main.abd8ff62ef",
82
+ "@dxos/ui-theme": "0.8.4-main.abd8ff62ef",
83
+ "@dxos/plugin-preview": "0.8.4-main.abd8ff62ef"
60
84
  },
61
85
  "peerDependencies": {
62
- "effect": "3.19.11",
86
+ "effect": "3.20.0",
63
87
  "react": "~19.2.3",
64
88
  "react-dom": "~19.2.3",
65
- "@dxos/react-ui": "0.8.4-main.9735255",
66
- "@dxos/ui-theme": "0.8.4-main.9735255"
89
+ "@dxos/ui-theme": "0.8.4-main.abd8ff62ef",
90
+ "@dxos/react-ui": "0.8.4-main.abd8ff62ef"
67
91
  },
68
92
  "publishConfig": {
69
93
  "access": "public"
@@ -2,46 +2,58 @@
2
2
  // Copyright 2025 DXOS.org
3
3
  //
4
4
 
5
- import { ActivationEvent, Capability, Common, Plugin } from '@dxos/app-framework';
5
+ import { ActivationEvent, ActivationEvents, Capability, Plugin } from '@dxos/app-framework';
6
+ import { AppActivationEvents, AppPlugin } from '@dxos/app-toolkit';
6
7
 
7
- import { OperationResolver, ReactRoot, ReactSurface, SpotlightDismiss, State, UrlHandler } from './capabilities';
8
- import { meta } from './meta';
9
- import { translations } from './translations';
10
- import { SimpleLayoutEvents } from './types';
8
+ import {
9
+ AppGraphBuilder,
10
+ OperationHandler,
11
+ ReactRoot,
12
+ ReactSurface,
13
+ SpotlightDismiss,
14
+ State,
15
+ UrlHandler,
16
+ } from '#capabilities';
17
+ import { meta } from '#meta';
18
+ import { translations } from '#translations';
19
+ import { SimpleLayoutEvents } from '#types';
11
20
 
12
21
  export type SimpleLayoutPluginOptions = {
13
- /** Whether running in popover window context (hides mobile-specific UI). */
22
+ /** Determines if running in popover window context (hides mobile-specific UI). */
14
23
  isPopover?: boolean;
15
24
  };
16
25
 
17
26
  export const SimpleLayoutPlugin = Plugin.define<SimpleLayoutPluginOptions>(meta).pipe(
27
+ AppPlugin.addAppGraphModule({ activate: AppGraphBuilder }),
28
+ AppPlugin.addOperationHandlerModule({ activate: OperationHandler }),
29
+ AppPlugin.addTranslationsModule({ translations }),
18
30
  Plugin.addModule(({ isPopover = false }) => ({
19
31
  id: Capability.getModuleTag(State),
20
- activatesOn: Common.ActivationEvent.Startup,
21
- activatesAfter: [SimpleLayoutEvents.StateReady, Common.ActivationEvent.LayoutReady],
32
+ activatesOn: ActivationEvents.Startup,
33
+ firesAfterActivation: [SimpleLayoutEvents.StateReady, AppActivationEvents.LayoutReady],
22
34
  activate: () => State({ initialState: { isPopover } }),
23
35
  })),
24
36
  Plugin.addModule(({ isPopover = false }) => ({
25
37
  id: Capability.getModuleTag(SpotlightDismiss),
26
- activatesOn: Common.ActivationEvent.Startup,
38
+ activatesOn: ActivationEvents.Startup,
27
39
  activate: () => SpotlightDismiss({ isPopover }),
28
40
  })),
29
41
  Plugin.addModule({
30
42
  id: Capability.getModuleTag(ReactRoot),
31
- activatesOn: Common.ActivationEvent.Startup,
43
+ activatesOn: ActivationEvents.Startup,
32
44
  activate: ReactRoot,
33
45
  }),
34
46
  Plugin.addModule({
35
47
  id: Capability.getModuleTag(ReactSurface),
36
- activatesOn: Common.ActivationEvent.Startup,
48
+ activatesOn: ActivationEvents.Startup,
37
49
  activate: ReactSurface,
38
50
  }),
39
51
  Plugin.addModule({
40
52
  id: Capability.getModuleTag(UrlHandler),
41
- activatesOn: ActivationEvent.allOf(Common.ActivationEvent.OperationInvokerReady, SimpleLayoutEvents.StateReady),
53
+ activatesOn: ActivationEvent.allOf(ActivationEvents.OperationInvokerReady, SimpleLayoutEvents.StateReady),
42
54
  activate: UrlHandler,
43
55
  }),
44
- Common.Plugin.addOperationResolverModule({ activate: OperationResolver }),
45
- Common.Plugin.addTranslationsModule({ translations }),
46
56
  Plugin.make,
47
57
  );
58
+
59
+ export default SimpleLayoutPlugin;
@@ -0,0 +1,21 @@
1
+ //
2
+ // Copyright 2025 DXOS.org
3
+ //
4
+
5
+ import * as Effect from 'effect/Effect';
6
+
7
+ import { Capability } from '@dxos/app-framework';
8
+ import { AppCapabilities, AppNode } from '@dxos/app-toolkit';
9
+ import { GraphBuilder, NodeMatcher } from '@dxos/plugin-graph';
10
+
11
+ export default Capability.makeModule(
12
+ Effect.fnUntraced(function* () {
13
+ const extensions = yield* GraphBuilder.createExtension({
14
+ id: 'org.dxos.plugin.simpleLayout.not-found',
15
+ match: NodeMatcher.whenRoot,
16
+ connector: () => Effect.succeed([AppNode.makeNotFound()]),
17
+ });
18
+
19
+ return Capability.contributes(AppCapabilities.AppGraphBuilder, extensions);
20
+ }),
21
+ );
@@ -2,9 +2,16 @@
2
2
  // Copyright 2025 DXOS.org
3
3
  //
4
4
 
5
- export * from './operation-resolver';
6
- export * from './react-root';
7
- export * from './react-surface';
8
- export * from './spotlight-dismiss';
9
- export * from './state';
10
- export * from './url-handler';
5
+ import { Capability } from '@dxos/app-framework';
6
+ import { OperationHandlerSet } from '@dxos/compute';
7
+
8
+ export const AppGraphBuilder = Capability.lazy('AppGraphBuilder', () => import('./app-graph-builder'));
9
+ export const OperationHandler = Capability.lazy<OperationHandlerSet.OperationHandlerSet>(
10
+ 'OperationHandler',
11
+ () => import('./operation-handler'),
12
+ );
13
+ export const ReactRoot = Capability.lazy('ReactRoot', () => import('./react-root'));
14
+ export const ReactSurface = Capability.lazy('ReactSurface', () => import('./react-surface'));
15
+ export const SpotlightDismiss = Capability.lazy('SpotlightDismiss', () => import('./spotlight-dismiss'));
16
+ export const State = Capability.lazy('State', () => import('./state'));
17
+ export const UrlHandler = Capability.lazy('UrlHandler', () => import('./url-handler'));
@@ -0,0 +1,14 @@
1
+ // Copyright 2025 DXOS.org
2
+
3
+ import * as Effect from 'effect/Effect';
4
+
5
+ import { Capabilities, Capability } from '@dxos/app-framework';
6
+ import type { OperationHandlerSet } from '@dxos/compute';
7
+
8
+ import { SimpleLayoutOperationHandlerSet } from '#operations';
9
+
10
+ export default Capability.makeModule<OperationHandlerSet.OperationHandlerSet>(
11
+ Effect.fnUntraced(function* () {
12
+ return Capability.contributes(Capabilities.OperationHandler, SimpleLayoutOperationHandlerSet);
13
+ }),
14
+ );
@@ -5,14 +5,14 @@
5
5
  import * as Effect from 'effect/Effect';
6
6
  import React from 'react';
7
7
 
8
- import { Capability, Common } from '@dxos/app-framework';
8
+ import { Capabilities, Capability } from '@dxos/app-framework';
9
9
 
10
- import { SimpleLayout } from '../../components';
11
- import { meta } from '../../meta';
10
+ import { SimpleLayout } from '#components';
11
+ import { meta } from '#meta';
12
12
 
13
13
  export default Capability.makeModule(() =>
14
14
  Effect.succeed(
15
- Capability.contributes(Common.Capability.ReactRoot, {
15
+ Capability.contributes(Capabilities.ReactRoot, {
16
16
  id: meta.id,
17
17
  root: () => {
18
18
  return <SimpleLayout />;
@@ -0,0 +1,50 @@
1
+ //
2
+ // Copyright 2025 DXOS.org
3
+ //
4
+
5
+ import * as Effect from 'effect/Effect';
6
+ import React from 'react';
7
+
8
+ import { Capabilities, Capability } from '@dxos/app-framework';
9
+ import { Surface } from '@dxos/app-framework/ui';
10
+ import { NOT_FOUND_PATH } from '@dxos/app-toolkit';
11
+ import { NotFoundArticle } from '@dxos/app-toolkit/ui';
12
+ import { Node } from '@dxos/plugin-graph';
13
+
14
+ import { Home, NavBranch } from '#components';
15
+
16
+ type SurfaceData = {
17
+ attendableId: string;
18
+ properties: Record<string, any>;
19
+ };
20
+
21
+ const ALLOWED_DISPOSITIONS = ['workspace', 'user-account', 'pin-end'];
22
+
23
+ export default Capability.makeModule(() =>
24
+ Effect.succeed(
25
+ Capability.contributes(Capabilities.ReactSurface, [
26
+ Surface.create({
27
+ id: 'home',
28
+ role: 'article',
29
+ filter: (data): data is SurfaceData => data.attendableId === Node.RootId,
30
+ component: () => <Home />,
31
+ }),
32
+ Surface.create({
33
+ id: 'not-found',
34
+ role: 'article',
35
+ filter: (data): data is SurfaceData => data.attendableId === NOT_FOUND_PATH,
36
+ component: () => <NotFoundArticle />,
37
+ }),
38
+ Surface.create({
39
+ id: 'nav-branch',
40
+ role: 'article',
41
+ position: 'fallback',
42
+ filter: (data): data is SurfaceData => {
43
+ const props = data.properties as Record<string, any>;
44
+ return ALLOWED_DISPOSITIONS.includes(props?.disposition) || props?.role === 'branch';
45
+ },
46
+ component: ({ data }) => <NavBranch id={data.attendableId} />,
47
+ }),
48
+ ]),
49
+ ),
50
+ );
@@ -7,7 +7,7 @@
7
7
 
8
8
  import * as Effect from 'effect/Effect';
9
9
 
10
- import { Capability, Common } from '@dxos/app-framework';
10
+ import { Capabilities, Capability } from '@dxos/app-framework';
11
11
  import { log } from '@dxos/log';
12
12
  import { isTauri } from '@dxos/util';
13
13
 
@@ -76,7 +76,7 @@ export default Capability.makeModule(({ isPopover = false }: SpotlightDismissOpt
76
76
  };
77
77
  window.addEventListener('keydown', handleKeyDown);
78
78
 
79
- return Capability.contributes(Common.Capability.Null, null, () =>
79
+ return Capability.contributes(Capabilities.Null, null, () =>
80
80
  Effect.sync(() => {
81
81
  focusCleanup?.();
82
82
  window.removeEventListener('keydown', handleKeyDown);
@@ -5,11 +5,12 @@
5
5
  import { Atom } from '@effect-atom/atom-react';
6
6
  import * as Effect from 'effect/Effect';
7
7
 
8
- import { Capability, Common } from '@dxos/app-framework';
8
+ import { Capability } from '@dxos/app-framework';
9
+ import { AppCapabilities } from '@dxos/app-toolkit';
9
10
  import { Node } from '@dxos/plugin-graph';
10
11
 
11
- import { type SimpleLayoutState } from '../../types';
12
- import { SimpleLayoutState as SimpleLayoutStateCapability } from '../../types';
12
+ import { type SimpleLayoutState } from '#types';
13
+ import { SimpleLayoutState as SimpleLayoutStateCapability } from '#types';
13
14
 
14
15
  const defaultState: SimpleLayoutState = {
15
16
  dialogOpen: false,
@@ -29,7 +30,7 @@ export default Capability.makeModule(({ initialState }: SimpleLayoutStateOptions
29
30
  Effect.sync(() => {
30
31
  const stateAtom = Atom.make<SimpleLayoutState>({ ...defaultState, ...initialState });
31
32
 
32
- const layoutAtom = Atom.make((get): Common.Capability.Layout => {
33
+ const layoutAtom = Atom.make((get): AppCapabilities.Layout => {
33
34
  const state = get(stateAtom);
34
35
  return {
35
36
  mode: 'simple',
@@ -45,7 +46,7 @@ export default Capability.makeModule(({ initialState }: SimpleLayoutStateOptions
45
46
 
46
47
  return [
47
48
  Capability.contributes(SimpleLayoutStateCapability, stateAtom),
48
- Capability.contributes(Common.Capability.Layout, layoutAtom),
49
+ Capability.contributes(AppCapabilities.Layout, layoutAtom),
49
50
  ];
50
51
  }),
51
52
  );
@@ -0,0 +1,161 @@
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 { AppCapabilities, LayoutOperation, fromUrlPath, getWorkspaceFromPath, toUrlPath } from '@dxos/app-toolkit';
9
+ import { runAndForwardErrors } from '@dxos/effect';
10
+ import { log } from '@dxos/log';
11
+ import { isTauri } from '@dxos/util';
12
+
13
+ import { type SimpleLayoutState, SimpleLayoutState as SimpleLayoutStateCapability } from '#types';
14
+
15
+ /**
16
+ * URL handler for simple layout that syncs browser URL with layout state.
17
+ * URL paths map directly to qualified graph IDs with the leading `root` segment stripped.
18
+ * Root is represented as `/`.
19
+ *
20
+ * On Tauri, also listens for deep links via the deep-link plugin.
21
+ */
22
+ export default Capability.makeModule(
23
+ Effect.fnUntraced(function* () {
24
+ const { invokePromise } = yield* Capability.get(Capabilities.OperationInvoker);
25
+ const capabilities = yield* Capability.Service;
26
+
27
+ /** Dispatch all NavigationHandler contributions with a given URL. */
28
+ const dispatchNavigationHandlers = (url: URL) =>
29
+ Effect.gen(function* () {
30
+ const handlers = yield* Capability.getAll(AppCapabilities.NavigationHandler);
31
+ yield* Effect.all(
32
+ handlers.map((handler) => handler(url)),
33
+ { concurrency: 'unbounded' },
34
+ );
35
+ }).pipe(Effect.provideService(Capability.Service, capabilities), runAndForwardErrors);
36
+
37
+ /**
38
+ * Handle navigation from a URL.
39
+ * Dispatches to NavigationHandler contributions, then handles pathname routing.
40
+ */
41
+ const handlePathNavigation = (url?: URL) => {
42
+ const resolvedUrl = url ?? new URL(window.location.href);
43
+ void dispatchNavigationHandlers(resolvedUrl);
44
+
45
+ let pathname = resolvedUrl.pathname;
46
+ if (isFilePath(pathname)) {
47
+ log.info('[UrlHandler] Skipping file path (not a graph node)', { pathname });
48
+ pathname = '/';
49
+ }
50
+
51
+ const qualifiedId = fromUrlPath(pathname);
52
+ const workspace = getWorkspaceFromPath(qualifiedId);
53
+
54
+ void invokePromise(LayoutOperation.SwitchWorkspace, { subject: workspace });
55
+
56
+ const activeId = qualifiedId !== workspace ? qualifiedId : undefined;
57
+ if (activeId) {
58
+ void invokePromise(LayoutOperation.Open, { subject: [activeId] });
59
+ }
60
+ };
61
+
62
+ const onPopState = () => {
63
+ handlePathNavigation();
64
+ };
65
+
66
+ // Initial navigation.
67
+ yield* Effect.sync(() => handlePathNavigation());
68
+ window.addEventListener('popstate', onPopState);
69
+
70
+ // Tauri deep link support.
71
+ let unlistenDeepLink: (() => void) | undefined;
72
+ if (isTauri()) {
73
+ yield* Effect.tryPromise({
74
+ try: async () => {
75
+ const { getCurrent, onOpenUrl } = await import('@tauri-apps/plugin-deep-link');
76
+
77
+ const launchUrls = await getCurrent();
78
+ if (launchUrls && launchUrls.length > 0) {
79
+ log.info('[UrlHandler] App launched with deep links', { urls: launchUrls });
80
+ for (const urlString of launchUrls) {
81
+ handleDeepLink(urlString, handlePathNavigation);
82
+ }
83
+ }
84
+
85
+ unlistenDeepLink = await onOpenUrl((urls) => {
86
+ log.info('[UrlHandler] Deep links received', { urls });
87
+ for (const urlString of urls) {
88
+ handleDeepLink(urlString, handlePathNavigation);
89
+ }
90
+ });
91
+ },
92
+ catch: (error) => {
93
+ log.warn('[UrlHandler] Failed to initialize deep link listener', { error });
94
+ return error;
95
+ },
96
+ }).pipe(Effect.catchAll(() => Effect.void));
97
+ }
98
+
99
+ // Sync URL with layout state changes.
100
+ let lastWorkspace: string | undefined;
101
+ let lastActive: string | undefined;
102
+ const unsubscribe = yield* Capabilities.subscribeAtom(SimpleLayoutStateCapability, (state: SimpleLayoutState) => {
103
+ const { workspace, active } = state;
104
+
105
+ if (workspace !== lastWorkspace || active !== lastActive) {
106
+ lastWorkspace = workspace;
107
+ lastActive = active;
108
+
109
+ const path = active ? toUrlPath(active) : toUrlPath(workspace);
110
+ if (window.location.pathname !== path) {
111
+ history.pushState(null, '', `${path}${window.location.search}`);
112
+ }
113
+ }
114
+ });
115
+
116
+ return Capability.contributes(Capabilities.Null, null, () =>
117
+ Effect.sync(() => {
118
+ window.removeEventListener('popstate', onPopState);
119
+ unsubscribe();
120
+ unlistenDeepLink?.();
121
+ }),
122
+ );
123
+ }),
124
+ );
125
+
126
+ /** Check if a path is a redirect path handled elsewhere (e.g., OAuth). */
127
+ const isRedirectPath = (pathname: string): boolean => pathname.startsWith('/redirect/');
128
+
129
+ /** Paths with file extensions are not graph node paths. */
130
+ const isFilePath = (pathname: string): boolean => /\.[a-z]+$/i.test(pathname);
131
+
132
+ /** Handle a deep link URL string. Merges query params into window.location and navigates. */
133
+ const handleDeepLink = (urlString: string, navigate: (url?: URL) => void): void => {
134
+ log.info('[UrlHandler] Deep link received', { url: urlString });
135
+ try {
136
+ const deepLinkUrl = new URL(urlString);
137
+
138
+ // For custom schemes (e.g., composer://a/b/c), new URL() treats the first segment as the
139
+ // hostname. Reconstruct the full path from hostname + pathname.
140
+ const fullPath =
141
+ deepLinkUrl.protocol !== 'https:' && deepLinkUrl.protocol !== 'http:' && deepLinkUrl.hostname
142
+ ? '/' + deepLinkUrl.hostname + deepLinkUrl.pathname
143
+ : deepLinkUrl.pathname;
144
+
145
+ if (isRedirectPath(fullPath)) {
146
+ return;
147
+ }
148
+
149
+ // Merge deep link query params into the current window URL so handlers can read them.
150
+ const current = new URL(window.location.href);
151
+ if (deepLinkUrl.search) {
152
+ deepLinkUrl.searchParams.forEach((value, key) => current.searchParams.set(key, value));
153
+ }
154
+ current.pathname = fullPath;
155
+ history.replaceState(null, '', current.pathname + current.search);
156
+
157
+ navigate(current);
158
+ } catch (error) {
159
+ log.warn('[UrlHandler] Failed to parse deep link URL', { urlString, error });
160
+ }
161
+ };
@@ -4,28 +4,29 @@
4
4
 
5
5
  import { type Meta, type StoryObj } from '@storybook/react-vite';
6
6
 
7
+ import { ErrorFallback } from '@dxos/react-ui';
7
8
  import { withTheme } from '@dxos/react-ui/testing';
8
9
 
9
- import { translations } from '../translations';
10
-
11
- import { ContentError } from './ContentError';
10
+ import { translations } from '#translations';
12
11
 
13
12
  const meta = {
14
- title: 'plugins/plugin-simple-layout/ContentError',
15
- component: ContentError,
16
- decorators: [withTheme],
13
+ title: 'plugins/plugin-simple-layout/components/ErrorFallback',
14
+ component: ErrorFallback,
15
+ decorators: [withTheme()],
17
16
  parameters: {
18
17
  layout: 'centered',
19
18
  translations,
20
19
  },
21
- } satisfies Meta<typeof ContentError>;
20
+ } satisfies Meta<typeof ErrorFallback>;
22
21
 
23
22
  export default meta;
24
23
 
25
24
  type Story = StoryObj<typeof meta>;
26
25
 
27
26
  export const Default: Story = {
28
- args: {},
27
+ args: {
28
+ error: new Error('An unexpected error occurred'),
29
+ },
29
30
  };
30
31
 
31
32
  export const WithError: Story = {