@dxos/app-framework 0.8.4-main.bc674ce → 0.8.4-main.bcb3aa67d6

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 (421) hide show
  1. package/.storybook/main.mts +1 -3
  2. package/dist/lib/browser/{capability-7PCNSWBT.mjs → capability-4NSF2SOO.mjs} +16 -11
  3. package/dist/lib/browser/capability-4NSF2SOO.mjs.map +7 -0
  4. package/dist/lib/browser/capability-EB3UKSKA.mjs +35 -0
  5. package/dist/lib/browser/capability-EB3UKSKA.mjs.map +7 -0
  6. package/dist/lib/browser/{chunk-FMZN33N4.mjs → chunk-27FZETIA.mjs} +324 -181
  7. package/dist/lib/browser/chunk-27FZETIA.mjs.map +7 -0
  8. package/dist/lib/browser/chunk-CV7I2AAB.mjs +80 -0
  9. package/dist/lib/browser/chunk-CV7I2AAB.mjs.map +7 -0
  10. package/dist/lib/browser/{chunk-6Y7PZV72.mjs → chunk-FL2XTEJH.mjs} +3 -4
  11. package/dist/lib/browser/chunk-FL2XTEJH.mjs.map +7 -0
  12. package/dist/lib/browser/chunk-H7OMDDGW.mjs +42 -0
  13. package/dist/lib/browser/chunk-H7OMDDGW.mjs.map +7 -0
  14. package/dist/lib/browser/chunk-HDQXX5DC.mjs +157 -0
  15. package/dist/lib/browser/chunk-HDQXX5DC.mjs.map +7 -0
  16. package/dist/lib/browser/chunk-I34GF4NG.mjs +34 -0
  17. package/dist/lib/browser/chunk-I34GF4NG.mjs.map +7 -0
  18. package/dist/lib/browser/chunk-KNBRTZVK.mjs +892 -0
  19. package/dist/lib/browser/chunk-KNBRTZVK.mjs.map +7 -0
  20. package/dist/lib/browser/{chunk-7IQHKD4U.mjs → chunk-NO7R7QHA.mjs} +4 -7
  21. package/dist/lib/browser/chunk-NO7R7QHA.mjs.map +7 -0
  22. package/dist/lib/browser/{chunk-TCLLRCS3.mjs → chunk-P2E7VMRF.mjs} +10 -7
  23. package/dist/lib/browser/chunk-P2E7VMRF.mjs.map +7 -0
  24. package/dist/lib/browser/{chunk-PKQT6C53.mjs → chunk-QSXYHXCE.mjs} +3 -2
  25. package/dist/lib/browser/chunk-QSXYHXCE.mjs.map +7 -0
  26. package/dist/lib/browser/chunk-RFSO3JRG.mjs +1 -0
  27. package/dist/lib/browser/chunk-TGX63LTL.mjs +8 -0
  28. package/dist/lib/browser/{chunk-FHQTHCX7.mjs.map → chunk-TGX63LTL.mjs.map} +1 -1
  29. package/dist/lib/browser/cli/index.mjs +90 -0
  30. package/dist/lib/browser/cli/index.mjs.map +7 -0
  31. package/dist/lib/browser/common/activation-events.mjs +24 -0
  32. package/dist/lib/browser/common/capabilities.mjs +46 -0
  33. package/dist/lib/browser/core/activation-event.mjs +1 -1
  34. package/dist/lib/browser/core/capability.mjs +1 -1
  35. package/dist/lib/browser/core/plugin-manager.mjs +4 -4
  36. package/dist/lib/browser/core/plugin.mjs +6 -4
  37. package/dist/lib/browser/core/url-loader.mjs +12 -0
  38. package/dist/lib/browser/index.mjs +40 -131
  39. package/dist/lib/browser/index.mjs.map +4 -4
  40. package/dist/lib/browser/invoker-capability-P7KPBTP3.mjs +43 -0
  41. package/dist/lib/browser/invoker-capability-P7KPBTP3.mjs.map +7 -0
  42. package/dist/lib/browser/meta.json +1 -1
  43. package/dist/lib/browser/testing/index.mjs +56 -34
  44. package/dist/lib/browser/testing/index.mjs.map +3 -3
  45. package/dist/lib/browser/{react → ui}/index.mjs +19 -21
  46. package/dist/lib/browser/ui/index.mjs.map +7 -0
  47. package/dist/lib/node-esm/{capability-CFLQ2QQU.mjs → capability-CB3MNEI3.mjs} +16 -11
  48. package/dist/lib/node-esm/capability-CB3MNEI3.mjs.map +7 -0
  49. package/dist/lib/node-esm/capability-CMROGK7R.mjs +36 -0
  50. package/dist/lib/node-esm/capability-CMROGK7R.mjs.map +7 -0
  51. package/dist/lib/node-esm/{chunk-STMXUEPO.mjs → chunk-37NG7SIN.mjs} +3 -4
  52. package/dist/lib/node-esm/chunk-37NG7SIN.mjs.map +7 -0
  53. package/dist/lib/node-esm/chunk-7JPKC7OM.mjs +893 -0
  54. package/dist/lib/node-esm/chunk-7JPKC7OM.mjs.map +7 -0
  55. package/dist/lib/node-esm/chunk-7PPVTBYR.mjs +81 -0
  56. package/dist/lib/node-esm/chunk-7PPVTBYR.mjs.map +7 -0
  57. package/dist/lib/node-esm/chunk-BQ56U4QX.mjs +43 -0
  58. package/dist/lib/node-esm/chunk-BQ56U4QX.mjs.map +7 -0
  59. package/dist/lib/node-esm/{chunk-GT6OKM5I.mjs → chunk-CG6UBBZZ.mjs} +10 -7
  60. package/dist/lib/node-esm/chunk-CG6UBBZZ.mjs.map +7 -0
  61. package/dist/lib/node-esm/chunk-EL3R25OQ.mjs +2 -0
  62. package/dist/lib/node-esm/chunk-EL3R25OQ.mjs.map +7 -0
  63. package/dist/lib/node-esm/{chunk-663A54LQ.mjs → chunk-EXYTXQ47.mjs} +4 -7
  64. package/dist/lib/node-esm/chunk-EXYTXQ47.mjs.map +7 -0
  65. package/dist/lib/node-esm/{chunk-UEWJDI2L.mjs → chunk-FKE4Z3D6.mjs} +2 -2
  66. package/dist/lib/node-esm/{chunk-UEWJDI2L.mjs.map → chunk-FKE4Z3D6.mjs.map} +1 -1
  67. package/dist/lib/node-esm/chunk-OXXXRCQX.mjs +158 -0
  68. package/dist/lib/node-esm/chunk-OXXXRCQX.mjs.map +7 -0
  69. package/dist/lib/node-esm/chunk-WZCSOX5Q.mjs +35 -0
  70. package/dist/lib/node-esm/chunk-WZCSOX5Q.mjs.map +7 -0
  71. package/dist/lib/node-esm/{chunk-XYQTBFPA.mjs → chunk-YH44RHP6.mjs} +324 -181
  72. package/dist/lib/node-esm/chunk-YH44RHP6.mjs.map +7 -0
  73. package/dist/lib/node-esm/{chunk-7OWSHPYK.mjs → chunk-ZZ7CKK6W.mjs} +3 -2
  74. package/dist/lib/node-esm/chunk-ZZ7CKK6W.mjs.map +7 -0
  75. package/dist/lib/node-esm/cli/index.mjs +91 -0
  76. package/dist/lib/node-esm/cli/index.mjs.map +7 -0
  77. package/dist/lib/node-esm/common/activation-events.mjs +25 -0
  78. package/dist/lib/node-esm/common/activation-events.mjs.map +7 -0
  79. package/dist/lib/node-esm/common/capabilities.mjs +47 -0
  80. package/dist/lib/node-esm/common/capabilities.mjs.map +7 -0
  81. package/dist/lib/node-esm/core/activation-event.mjs +1 -1
  82. package/dist/lib/node-esm/core/capability.mjs +1 -1
  83. package/dist/lib/node-esm/core/plugin-manager.mjs +4 -4
  84. package/dist/lib/node-esm/core/plugin.mjs +6 -4
  85. package/dist/lib/node-esm/core/url-loader.mjs +13 -0
  86. package/dist/lib/node-esm/core/url-loader.mjs.map +7 -0
  87. package/dist/lib/node-esm/index.mjs +40 -131
  88. package/dist/lib/node-esm/index.mjs.map +4 -4
  89. package/dist/lib/node-esm/invoker-capability-3C5H46ZY.mjs +44 -0
  90. package/dist/lib/node-esm/invoker-capability-3C5H46ZY.mjs.map +7 -0
  91. package/dist/lib/node-esm/meta.json +1 -1
  92. package/dist/lib/node-esm/testing/index.mjs +56 -34
  93. package/dist/lib/node-esm/testing/index.mjs.map +3 -3
  94. package/dist/lib/node-esm/{react → ui}/index.mjs +19 -21
  95. package/dist/lib/node-esm/ui/index.mjs.map +7 -0
  96. package/dist/plugin/node-esm/index.mjs +384 -0
  97. package/dist/plugin/node-esm/index.mjs.map +7 -0
  98. package/dist/plugin/node-esm/meta.json +1 -0
  99. package/dist/types/src/{cli.d.ts → cli/cli.d.ts} +2 -2
  100. package/dist/types/src/cli/cli.d.ts.map +1 -0
  101. package/dist/types/src/cli/index.d.ts +2 -0
  102. package/dist/types/src/cli/index.d.ts.map +1 -0
  103. package/dist/types/src/common/activation-events.d.ts +27 -0
  104. package/dist/types/src/common/activation-events.d.ts.map +1 -0
  105. package/dist/types/src/common/capabilities.d.ts +110 -0
  106. package/dist/types/src/common/capabilities.d.ts.map +1 -0
  107. package/dist/types/src/common/index.d.ts +4 -9
  108. package/dist/types/src/common/index.d.ts.map +1 -1
  109. package/dist/types/src/common/operations.d.ts +8 -369
  110. package/dist/types/src/common/operations.d.ts.map +1 -1
  111. package/dist/types/src/common/translations.d.ts +0 -9
  112. package/dist/types/src/common/translations.d.ts.map +1 -1
  113. package/dist/types/src/core/activation-event.d.ts +1 -1
  114. package/dist/types/src/core/activation-event.d.ts.map +1 -1
  115. package/dist/types/src/core/capability.d.ts +7 -7
  116. package/dist/types/src/core/capability.d.ts.map +1 -1
  117. package/dist/types/src/core/index.d.ts +1 -0
  118. package/dist/types/src/core/index.d.ts.map +1 -1
  119. package/dist/types/src/core/plugin-manager.d.ts +9 -2
  120. package/dist/types/src/core/plugin-manager.d.ts.map +1 -1
  121. package/dist/types/src/core/plugin.d.ts +6 -1
  122. package/dist/types/src/core/plugin.d.ts.map +1 -1
  123. package/dist/types/src/core/url-loader.d.ts +25 -0
  124. package/dist/types/src/core/url-loader.d.ts.map +1 -0
  125. package/dist/types/src/core/url-loader.test.d.ts +2 -0
  126. package/dist/types/src/core/url-loader.test.d.ts.map +1 -0
  127. package/dist/types/src/index.d.ts +1 -3
  128. package/dist/types/src/index.d.ts.map +1 -1
  129. package/dist/types/src/plugin-operation/history/capability.d.ts +1 -1
  130. package/dist/types/src/plugin-operation/history/errors.d.ts +30 -3
  131. package/dist/types/src/plugin-operation/history/errors.d.ts.map +1 -1
  132. package/dist/types/src/plugin-operation/history/undo-mapping.d.ts +11 -3
  133. package/dist/types/src/plugin-operation/history/undo-mapping.d.ts.map +1 -1
  134. package/dist/types/src/plugin-operation/invoker-capability.d.ts +1 -1
  135. package/dist/types/src/plugin-operation/invoker-capability.d.ts.map +1 -1
  136. package/dist/types/src/plugin-operation/testing.d.ts +26 -77
  137. package/dist/types/src/plugin-operation/testing.d.ts.map +1 -1
  138. package/dist/types/src/plugin-runtime/capability.d.ts +2 -2
  139. package/dist/types/src/plugin-runtime/capability.d.ts.map +1 -1
  140. package/dist/types/src/testing/withPluginManager.d.ts +1 -1
  141. package/dist/types/src/testing/withPluginManager.d.ts.map +1 -1
  142. package/dist/types/src/{react → ui/components/App}/App.d.ts +3 -2
  143. package/dist/types/src/ui/components/App/App.d.ts.map +1 -0
  144. package/dist/types/src/{react/Surface.stories.d.ts → ui/components/App/App.stories.d.ts} +7 -2
  145. package/dist/types/src/ui/components/App/App.stories.d.ts.map +1 -0
  146. package/dist/types/src/ui/components/App/index.d.ts +2 -0
  147. package/dist/types/src/ui/components/App/index.d.ts.map +1 -0
  148. package/dist/types/src/ui/components/PluginManager/PluginManagerContext.stories.d.ts.map +1 -0
  149. package/dist/types/src/{react → ui/components/PluginManager}/PluginManagerProvider.d.ts +1 -1
  150. package/dist/types/src/ui/components/PluginManager/PluginManagerProvider.d.ts.map +1 -0
  151. package/dist/types/src/ui/components/PluginManager/index.d.ts +2 -0
  152. package/dist/types/src/ui/components/PluginManager/index.d.ts.map +1 -0
  153. package/dist/types/src/ui/components/Surface/SurfaceComponent.d.ts +12 -0
  154. package/dist/types/src/ui/components/Surface/SurfaceComponent.d.ts.map +1 -0
  155. package/dist/types/src/{react/App.stories.d.ts → ui/components/Surface/SurfaceComponent.stories.d.ts} +1 -1
  156. package/dist/types/src/ui/components/Surface/SurfaceComponent.stories.d.ts.map +1 -0
  157. package/dist/types/src/ui/components/Surface/SurfaceInfo.d.ts.map +1 -0
  158. package/dist/types/src/ui/components/Surface/SurfaceProfilerContext.d.ts +48 -0
  159. package/dist/types/src/ui/components/Surface/SurfaceProfilerContext.d.ts.map +1 -0
  160. package/dist/types/src/ui/components/Surface/context.d.ts +5 -0
  161. package/dist/types/src/ui/components/Surface/context.d.ts.map +1 -0
  162. package/dist/types/src/ui/components/Surface/index.d.ts +26 -0
  163. package/dist/types/src/ui/components/Surface/index.d.ts.map +1 -0
  164. package/dist/types/src/{common/surface.d.ts → ui/components/Surface/types.d.ts} +20 -18
  165. package/dist/types/src/ui/components/Surface/types.d.ts.map +1 -0
  166. package/dist/types/src/ui/components/index.d.ts +4 -0
  167. package/dist/types/src/ui/components/index.d.ts.map +1 -0
  168. package/dist/types/src/ui/hooks/index.d.ts +6 -0
  169. package/dist/types/src/ui/hooks/index.d.ts.map +1 -0
  170. package/dist/types/src/{react → ui/hooks}/useApp.d.ts +26 -9
  171. package/dist/types/src/ui/hooks/useApp.d.ts.map +1 -0
  172. package/dist/types/src/ui/hooks/useApp.test.d.ts +2 -0
  173. package/dist/types/src/ui/hooks/useApp.test.d.ts.map +1 -0
  174. package/dist/types/src/{react → ui/hooks}/useCapabilities.d.ts +6 -1
  175. package/dist/types/src/ui/hooks/useCapabilities.d.ts.map +1 -0
  176. package/dist/types/src/ui/hooks/useLoading.d.ts.map +1 -0
  177. package/dist/types/src/{react/common.d.ts → ui/hooks/useSettingsState.d.ts} +1 -5
  178. package/dist/types/src/ui/hooks/useSettingsState.d.ts.map +1 -0
  179. package/dist/types/src/ui/hooks/useSurface.d.ts +3 -0
  180. package/dist/types/src/ui/hooks/useSurface.d.ts.map +1 -0
  181. package/dist/types/src/ui/index.d.ts +3 -0
  182. package/dist/types/src/ui/index.d.ts.map +1 -0
  183. package/dist/types/src/vite-plugin/composer-plugin.d.ts +18 -0
  184. package/dist/types/src/vite-plugin/composer-plugin.d.ts.map +1 -0
  185. package/dist/types/src/vite-plugin/import-map-plugin.d.ts +16 -0
  186. package/dist/types/src/vite-plugin/import-map-plugin.d.ts.map +1 -0
  187. package/dist/types/src/vite-plugin/index.d.ts +3 -0
  188. package/dist/types/src/vite-plugin/index.d.ts.map +1 -0
  189. package/dist/types/src/vite-plugin/packages.d.ts +7 -0
  190. package/dist/types/src/vite-plugin/packages.d.ts.map +1 -0
  191. package/dist/types/tsconfig.tsbuildinfo +1 -1
  192. package/moon.yml +20 -6
  193. package/package.json +91 -64
  194. package/src/{cli.ts → cli/cli.ts} +10 -10
  195. package/src/{playground/debug → cli}/index.ts +1 -1
  196. package/src/common/activation-events.ts +44 -0
  197. package/src/common/capabilities.ts +172 -0
  198. package/src/common/index.ts +4 -9
  199. package/src/common/operations.ts +6 -382
  200. package/src/common/translations.ts +0 -12
  201. package/src/context.ts +1 -1
  202. package/src/core/activation-event.ts +5 -2
  203. package/src/core/capability-manager.ts +1 -1
  204. package/src/core/capability.ts +11 -10
  205. package/src/core/index.ts +1 -0
  206. package/src/core/plugin-manager.test.ts +313 -44
  207. package/src/core/plugin-manager.ts +344 -157
  208. package/src/core/plugin.ts +10 -2
  209. package/src/core/url-loader.test.ts +79 -0
  210. package/src/core/url-loader.ts +148 -0
  211. package/src/index.ts +1 -3
  212. package/src/plugin-operation/OperationPlugin.ts +5 -5
  213. package/src/plugin-operation/history/capability.ts +5 -5
  214. package/src/plugin-operation/history/errors.ts +2 -6
  215. package/src/plugin-operation/history/history-tracker.test.ts +36 -42
  216. package/src/plugin-operation/history/undo-mapping.ts +6 -3
  217. package/src/plugin-operation/history/undo-registry.test.ts +3 -3
  218. package/src/plugin-operation/invoker-capability.ts +21 -7
  219. package/src/plugin-operation/meta.ts +1 -1
  220. package/src/plugin-operation/testing.ts +25 -45
  221. package/src/plugin-runtime/RuntimePlugin.ts +4 -4
  222. package/src/plugin-runtime/capability.ts +5 -5
  223. package/src/plugin-runtime/meta.ts +1 -1
  224. package/src/testing/service.ts +6 -6
  225. package/src/testing/withPluginManager.stories.tsx +6 -6
  226. package/src/testing/withPluginManager.tsx +46 -19
  227. package/src/ui/components/App/App.stories.tsx +92 -0
  228. package/src/{react → ui/components/App}/App.tsx +9 -11
  229. package/src/{playground/layout → ui/components/App}/index.ts +1 -1
  230. package/src/{react → ui/components/PluginManager}/PluginManagerContext.stories.tsx +13 -14
  231. package/src/{react → ui/components/PluginManager}/PluginManagerProvider.ts +1 -1
  232. package/src/ui/components/PluginManager/index.ts +5 -0
  233. package/src/{react/Surface.stories.tsx → ui/components/Surface/SurfaceComponent.stories.tsx} +28 -24
  234. package/src/{react/Surface.tsx → ui/components/Surface/SurfaceComponent.tsx} +48 -58
  235. package/src/{react → ui/components/Surface}/SurfaceInfo.tsx +2 -2
  236. package/src/ui/components/Surface/SurfaceProfilerContext.tsx +207 -0
  237. package/src/ui/components/Surface/context.ts +12 -0
  238. package/src/ui/components/Surface/index.ts +35 -0
  239. package/src/{common/surface.ts → ui/components/Surface/types.ts} +22 -25
  240. package/src/ui/components/index.ts +7 -0
  241. package/src/ui/hooks/index.ts +9 -0
  242. package/src/ui/hooks/useApp.test.tsx +159 -0
  243. package/src/{react → ui/hooks}/useApp.tsx +110 -30
  244. package/src/{react → ui/hooks}/useCapabilities.ts +9 -5
  245. package/src/{react/common.ts → ui/hooks/useSettingsState.ts} +0 -11
  246. package/src/ui/hooks/useSurface.ts +13 -0
  247. package/src/ui/index.ts +6 -0
  248. package/src/vite-plugin/composer-plugin.ts +128 -0
  249. package/src/vite-plugin/import-map-plugin.ts +315 -0
  250. package/src/vite-plugin/index.ts +6 -0
  251. package/src/vite-plugin/packages.ts +29 -0
  252. package/tsconfig.json +4 -28
  253. package/tsconfig.node.json +2 -4
  254. package/typedoc.json +2 -4
  255. package/vitest.config.ts +1 -1
  256. package/dist/lib/browser/app-graph-builder-M2VPYQC6.mjs +0 -149
  257. package/dist/lib/browser/app-graph-builder-M2VPYQC6.mjs.map +0 -7
  258. package/dist/lib/browser/capability-7PCNSWBT.mjs.map +0 -7
  259. package/dist/lib/browser/capability-KP3PFEXD.mjs +0 -31
  260. package/dist/lib/browser/capability-KP3PFEXD.mjs.map +0 -7
  261. package/dist/lib/browser/chunk-6Y7PZV72.mjs.map +0 -7
  262. package/dist/lib/browser/chunk-7IQHKD4U.mjs.map +0 -7
  263. package/dist/lib/browser/chunk-BLQJSGL3.mjs +0 -732
  264. package/dist/lib/browser/chunk-BLQJSGL3.mjs.map +0 -7
  265. package/dist/lib/browser/chunk-FHQTHCX7.mjs +0 -8
  266. package/dist/lib/browser/chunk-FMZN33N4.mjs.map +0 -7
  267. package/dist/lib/browser/chunk-H4WPA7U7.mjs +0 -77
  268. package/dist/lib/browser/chunk-H4WPA7U7.mjs.map +0 -7
  269. package/dist/lib/browser/chunk-PKQT6C53.mjs.map +0 -7
  270. package/dist/lib/browser/chunk-TCLLRCS3.mjs.map +0 -7
  271. package/dist/lib/browser/chunk-XYNO72GQ.mjs +0 -746
  272. package/dist/lib/browser/chunk-XYNO72GQ.mjs.map +0 -7
  273. package/dist/lib/browser/common/index.mjs +0 -38
  274. package/dist/lib/browser/invoker-capability-SZRSTHEH.mjs +0 -32
  275. package/dist/lib/browser/invoker-capability-SZRSTHEH.mjs.map +0 -7
  276. package/dist/lib/browser/operation-resolver-6MP2MYOY.mjs +0 -64
  277. package/dist/lib/browser/operation-resolver-6MP2MYOY.mjs.map +0 -7
  278. package/dist/lib/node-esm/app-graph-builder-LROHGJEM.mjs +0 -150
  279. package/dist/lib/node-esm/app-graph-builder-LROHGJEM.mjs.map +0 -7
  280. package/dist/lib/node-esm/capability-CFLQ2QQU.mjs.map +0 -7
  281. package/dist/lib/node-esm/capability-RCUNM2M7.mjs +0 -32
  282. package/dist/lib/node-esm/capability-RCUNM2M7.mjs.map +0 -7
  283. package/dist/lib/node-esm/chunk-663A54LQ.mjs.map +0 -7
  284. package/dist/lib/node-esm/chunk-6WXBT3EC.mjs +0 -747
  285. package/dist/lib/node-esm/chunk-6WXBT3EC.mjs.map +0 -7
  286. package/dist/lib/node-esm/chunk-7OWSHPYK.mjs.map +0 -7
  287. package/dist/lib/node-esm/chunk-GQEBIGKD.mjs +0 -733
  288. package/dist/lib/node-esm/chunk-GQEBIGKD.mjs.map +0 -7
  289. package/dist/lib/node-esm/chunk-GT6OKM5I.mjs.map +0 -7
  290. package/dist/lib/node-esm/chunk-STMXUEPO.mjs.map +0 -7
  291. package/dist/lib/node-esm/chunk-XR6NMKEP.mjs +0 -78
  292. package/dist/lib/node-esm/chunk-XR6NMKEP.mjs.map +0 -7
  293. package/dist/lib/node-esm/chunk-XYQTBFPA.mjs.map +0 -7
  294. package/dist/lib/node-esm/common/index.mjs +0 -39
  295. package/dist/lib/node-esm/invoker-capability-PNMA5JOS.mjs +0 -33
  296. package/dist/lib/node-esm/invoker-capability-PNMA5JOS.mjs.map +0 -7
  297. package/dist/lib/node-esm/operation-resolver-7YWDMTNU.mjs +0 -65
  298. package/dist/lib/node-esm/operation-resolver-7YWDMTNU.mjs.map +0 -7
  299. package/dist/types/src/cli.d.ts.map +0 -1
  300. package/dist/types/src/common/activation-event.d.ts +0 -66
  301. package/dist/types/src/common/activation-event.d.ts.map +0 -1
  302. package/dist/types/src/common/capability.d.ts +0 -265
  303. package/dist/types/src/common/capability.d.ts.map +0 -1
  304. package/dist/types/src/common/collaboration.d.ts +0 -26
  305. package/dist/types/src/common/collaboration.d.ts.map +0 -1
  306. package/dist/types/src/common/file.d.ts +0 -14
  307. package/dist/types/src/common/file.d.ts.map +0 -1
  308. package/dist/types/src/common/graph.d.ts +0 -21
  309. package/dist/types/src/common/graph.d.ts.map +0 -1
  310. package/dist/types/src/common/plugin.d.ts +0 -201
  311. package/dist/types/src/common/plugin.d.ts.map +0 -1
  312. package/dist/types/src/common/surface.d.ts.map +0 -1
  313. package/dist/types/src/playground/debug/Debug.d.ts +0 -8
  314. package/dist/types/src/playground/debug/Debug.d.ts.map +0 -1
  315. package/dist/types/src/playground/debug/index.d.ts +0 -2
  316. package/dist/types/src/playground/debug/index.d.ts.map +0 -1
  317. package/dist/types/src/playground/debug/plugin.d.ts +0 -3
  318. package/dist/types/src/playground/debug/plugin.d.ts.map +0 -1
  319. package/dist/types/src/playground/generator/Main.d.ts +0 -8
  320. package/dist/types/src/playground/generator/Main.d.ts.map +0 -1
  321. package/dist/types/src/playground/generator/Toolbar.d.ts +0 -8
  322. package/dist/types/src/playground/generator/Toolbar.d.ts.map +0 -1
  323. package/dist/types/src/playground/generator/generator.d.ts +0 -19
  324. package/dist/types/src/playground/generator/generator.d.ts.map +0 -1
  325. package/dist/types/src/playground/generator/index.d.ts +0 -3
  326. package/dist/types/src/playground/generator/index.d.ts.map +0 -1
  327. package/dist/types/src/playground/generator/plugin.d.ts +0 -3
  328. package/dist/types/src/playground/generator/plugin.d.ts.map +0 -1
  329. package/dist/types/src/playground/layout/Layout.d.ts +0 -10
  330. package/dist/types/src/playground/layout/Layout.d.ts.map +0 -1
  331. package/dist/types/src/playground/layout/index.d.ts +0 -2
  332. package/dist/types/src/playground/layout/index.d.ts.map +0 -1
  333. package/dist/types/src/playground/layout/plugin.d.ts +0 -3
  334. package/dist/types/src/playground/layout/plugin.d.ts.map +0 -1
  335. package/dist/types/src/playground/logger/Toolbar.d.ts +0 -8
  336. package/dist/types/src/playground/logger/Toolbar.d.ts.map +0 -1
  337. package/dist/types/src/playground/logger/index.d.ts +0 -2
  338. package/dist/types/src/playground/logger/index.d.ts.map +0 -1
  339. package/dist/types/src/playground/logger/plugin.d.ts +0 -3
  340. package/dist/types/src/playground/logger/plugin.d.ts.map +0 -1
  341. package/dist/types/src/playground/logger/schema.d.ts +0 -27
  342. package/dist/types/src/playground/logger/schema.d.ts.map +0 -1
  343. package/dist/types/src/playground/playground.stories.d.ts +0 -11
  344. package/dist/types/src/playground/playground.stories.d.ts.map +0 -1
  345. package/dist/types/src/plugin-settings/SettingsPlugin.d.ts +0 -3
  346. package/dist/types/src/plugin-settings/SettingsPlugin.d.ts.map +0 -1
  347. package/dist/types/src/plugin-settings/actions.d.ts +0 -61
  348. package/dist/types/src/plugin-settings/actions.d.ts.map +0 -1
  349. package/dist/types/src/plugin-settings/app-graph-builder.d.ts +0 -6
  350. package/dist/types/src/plugin-settings/app-graph-builder.d.ts.map +0 -1
  351. package/dist/types/src/plugin-settings/index.d.ts +0 -3
  352. package/dist/types/src/plugin-settings/index.d.ts.map +0 -1
  353. package/dist/types/src/plugin-settings/meta.d.ts +0 -3
  354. package/dist/types/src/plugin-settings/meta.d.ts.map +0 -1
  355. package/dist/types/src/plugin-settings/operation-resolver.d.ts +0 -6
  356. package/dist/types/src/plugin-settings/operation-resolver.d.ts.map +0 -1
  357. package/dist/types/src/plugin-settings/translations.d.ts +0 -11
  358. package/dist/types/src/plugin-settings/translations.d.ts.map +0 -1
  359. package/dist/types/src/react/App.d.ts.map +0 -1
  360. package/dist/types/src/react/App.stories.d.ts.map +0 -1
  361. package/dist/types/src/react/DefaultFallback.d.ts +0 -8
  362. package/dist/types/src/react/DefaultFallback.d.ts.map +0 -1
  363. package/dist/types/src/react/ErrorBoundary.d.ts +0 -30
  364. package/dist/types/src/react/ErrorBoundary.d.ts.map +0 -1
  365. package/dist/types/src/react/PluginManagerContext.stories.d.ts.map +0 -1
  366. package/dist/types/src/react/PluginManagerProvider.d.ts.map +0 -1
  367. package/dist/types/src/react/Surface.d.ts +0 -14
  368. package/dist/types/src/react/Surface.d.ts.map +0 -1
  369. package/dist/types/src/react/Surface.stories.d.ts.map +0 -1
  370. package/dist/types/src/react/SurfaceInfo.d.ts.map +0 -1
  371. package/dist/types/src/react/common.d.ts.map +0 -1
  372. package/dist/types/src/react/index.d.ts +0 -9
  373. package/dist/types/src/react/index.d.ts.map +0 -1
  374. package/dist/types/src/react/types.d.ts +0 -12
  375. package/dist/types/src/react/types.d.ts.map +0 -1
  376. package/dist/types/src/react/useApp.d.ts.map +0 -1
  377. package/dist/types/src/react/useCapabilities.d.ts.map +0 -1
  378. package/dist/types/src/react/useLoading.d.ts.map +0 -1
  379. package/dist/types/src/react/useOperationResolver.d.ts +0 -19
  380. package/dist/types/src/react/useOperationResolver.d.ts.map +0 -1
  381. package/src/common/activation-event.ts +0 -99
  382. package/src/common/capability.ts +0 -343
  383. package/src/common/collaboration.ts +0 -31
  384. package/src/common/file.ts +0 -22
  385. package/src/common/graph.ts +0 -30
  386. package/src/common/plugin.ts +0 -364
  387. package/src/playground/debug/Debug.tsx +0 -49
  388. package/src/playground/debug/plugin.ts +0 -16
  389. package/src/playground/generator/Main.tsx +0 -80
  390. package/src/playground/generator/Toolbar.tsx +0 -57
  391. package/src/playground/generator/generator.ts +0 -48
  392. package/src/playground/generator/index.ts +0 -6
  393. package/src/playground/generator/plugin.ts +0 -21
  394. package/src/playground/layout/Layout.tsx +0 -37
  395. package/src/playground/layout/plugin.ts +0 -18
  396. package/src/playground/logger/Toolbar.tsx +0 -33
  397. package/src/playground/logger/index.ts +0 -5
  398. package/src/playground/logger/plugin.ts +0 -42
  399. package/src/playground/logger/schema.ts +0 -22
  400. package/src/playground/playground.stories.tsx +0 -54
  401. package/src/plugin-settings/SettingsPlugin.ts +0 -19
  402. package/src/plugin-settings/actions.ts +0 -64
  403. package/src/plugin-settings/app-graph-builder.ts +0 -140
  404. package/src/plugin-settings/index.ts +0 -6
  405. package/src/plugin-settings/meta.ts +0 -10
  406. package/src/plugin-settings/operation-resolver.ts +0 -55
  407. package/src/plugin-settings/translations.ts +0 -19
  408. package/src/react/App.stories.tsx +0 -63
  409. package/src/react/DefaultFallback.tsx +0 -26
  410. package/src/react/ErrorBoundary.tsx +0 -56
  411. package/src/react/index.ts +0 -14
  412. package/src/react/types.ts +0 -27
  413. package/src/react/useOperationResolver.ts +0 -40
  414. /package/dist/lib/{node-esm/react/index.mjs.map → browser/chunk-RFSO3JRG.mjs.map} +0 -0
  415. /package/dist/lib/{node-esm/common/index.mjs.map → browser/common/activation-events.mjs.map} +0 -0
  416. /package/dist/lib/browser/{react/index.mjs.map → common/capabilities.mjs.map} +0 -0
  417. /package/dist/lib/browser/{common/index.mjs.map → core/url-loader.mjs.map} +0 -0
  418. /package/dist/types/src/{react → ui/components/PluginManager}/PluginManagerContext.stories.d.ts +0 -0
  419. /package/dist/types/src/{react → ui/components/Surface}/SurfaceInfo.d.ts +0 -0
  420. /package/dist/types/src/{react → ui/hooks}/useLoading.d.ts +0 -0
  421. /package/src/{react → ui/hooks}/useLoading.tsx +0 -0
@@ -2,41 +2,39 @@
2
2
  // Copyright 2023 DXOS.org
3
3
  //
4
4
 
5
- import type { PropsWithChildren, ReactNode, RefCallback } from 'react';
5
+ import type { FC, PropsWithChildren, ReactNode, RefCallback } from 'react';
6
6
 
7
7
  import type { MakeOptional, Position } from '@dxos/util';
8
8
 
9
- import type { ErrorBoundary } from '../react';
10
-
11
9
  /**
12
- * SurfaceProps are the props that are passed to the Surface component.
10
+ * Props that are passed to the Surface component.
13
11
  */
14
- export type SurfaceProps<T extends Record<string, any> = Record<string, unknown>> = {
12
+ export type Props<T extends Record<string, any> = Record<string, unknown>> = {
15
13
  /**
16
14
  * If specified, the Surface will be wrapped in an error boundary.
17
15
  * The fallback component will be rendered if an error occurs.
18
16
  */
19
- fallback?: ErrorBoundary['props']['fallback'];
17
+ fallback?: FC<{ error: Error; data?: any }>;
20
18
 
21
19
  /**
22
20
  * If specified, the Surface will be wrapped in a suspense boundary.
23
21
  * The placeholder component will be rendered while the surface component is loading.
24
22
  */
25
23
  placeholder?: ReactNode;
26
- } & MakeOptional<CoreSurfaceProps<T>, 'id' | 'data'> &
24
+ } & MakeOptional<CoreProps<T>, 'id' | 'data'> &
27
25
  /**
28
26
  * Additional props to pass to the component.
29
27
  * These props are not used by Surface itself but may be used by components which resolve the surface.
30
28
  * Exclude known prop names to prevent overriding well-defined props.
31
29
  */
32
30
  {
33
- [K in keyof Record<string, any>]: K extends keyof CoreSurfaceProps<T> | 'fallback' | 'placeholder' ? never : any;
31
+ [K in keyof Record<string, any>]: K extends keyof CoreProps<T> | 'fallback' | 'placeholder' ? never : any;
34
32
  };
35
33
 
36
34
  /**
37
35
  * NOTE: If `[key: string]: unknown` is included in shared types, when re-used other fields become unknown as well.
38
36
  */
39
- export type CoreSurfaceProps<T extends Record<string, any> = Record<string, unknown>> = PropsWithChildren<{
37
+ export type CoreProps<T extends Record<string, any> = Record<string, unknown>> = PropsWithChildren<{
40
38
  /**
41
39
  * ID for debugging.
42
40
  */
@@ -59,33 +57,34 @@ export type CoreSurfaceProps<T extends Record<string, any> = Record<string, unkn
59
57
  limit?: number | undefined;
60
58
  }>;
61
59
 
62
- export type SurfaceComponentProps<T extends Record<string, any> = Record<string, any>> = CoreSurfaceProps<T> & {
60
+ // TODO(burdon): Remove ref since relying on this would be error prone.
61
+ export type ComponentProps<T extends Record<string, any> = Record<string, any>> = CoreProps<T> & {
63
62
  ref?: RefCallback<HTMLElement>;
64
63
  } & Record<string, any>;
65
64
 
66
65
  /**
67
66
  * React component used to render a surface once is has matched.
68
67
  */
69
- export type SurfaceComponent<T extends Record<string, any> = Record<string, any>> = (
70
- props: SurfaceComponentProps<T>,
68
+ export type ComponentFunction<T extends Record<string, any> = Record<string, any>> = (
69
+ props: ComponentProps<T>,
71
70
  ) => ReactNode;
72
71
 
73
72
  /**
74
- * Definition of when a React SurfaceComponent should be rendered.
73
+ * Definition of when a React component surface should be rendered.
75
74
  */
76
- export type ReactSurfaceDefinition<T extends Record<string, any> = any> = Readonly<{
75
+ export type ReactDefinition<T extends Record<string, any> = any> = Readonly<{
77
76
  kind: 'react';
78
77
  id: string;
79
78
  role: string | string[];
80
79
  position?: Position;
81
- component: SurfaceComponent<T>;
80
+ component: ComponentFunction<T>;
82
81
  filter?: (data: Record<string, unknown>) => data is T;
83
82
  }>;
84
83
 
85
84
  /**
86
85
  * Definition of when a Web Component surface should be rendered.
87
86
  */
88
- export type WebComponentSurfaceDefinition<T extends Record<string, any> = any> = Readonly<{
87
+ export type WebComponentDefinition<T extends Record<string, any> = any> = Readonly<{
89
88
  kind: 'web-component';
90
89
  id: string;
91
90
  role: string | string[];
@@ -101,20 +100,18 @@ export type WebComponentSurfaceDefinition<T extends Record<string, any> = any> =
101
100
  /**
102
101
  * Definition of when a surface (React or Web Component) should be rendered.
103
102
  */
104
- export type SurfaceDefinition<T extends Record<string, any> = any> =
105
- | ReactSurfaceDefinition<T>
106
- | WebComponentSurfaceDefinition<T>;
103
+ export type Definition<T extends Record<string, any> = any> = ReactDefinition<T> | WebComponentDefinition<T>;
107
104
 
108
105
  /**
109
106
  * Creates a React surface definition.
110
107
  */
111
- export const createSurface = <T extends Record<string, any> = any>(
112
- definition: Omit<ReactSurfaceDefinition<T>, 'kind'>,
113
- ): ReactSurfaceDefinition<T> => ({ ...definition, kind: 'react' });
108
+ export const create = <T extends Record<string, any> = any>(
109
+ definition: Omit<ReactDefinition<T>, 'kind'>,
110
+ ): ReactDefinition<T> => ({ ...definition, kind: 'react' });
114
111
 
115
112
  /**
116
113
  * Creates a Web Component surface definition.
117
114
  */
118
- export const createWebSurface = <T extends Record<string, any> = any>(
119
- definition: Omit<WebComponentSurfaceDefinition<T>, 'kind'>,
120
- ): WebComponentSurfaceDefinition<T> => ({ ...definition, kind: 'web-component' });
115
+ export const createWeb = <T extends Record<string, any> = any>(
116
+ definition: Omit<WebComponentDefinition<T>, 'kind'>,
117
+ ): WebComponentDefinition<T> => ({ ...definition, kind: 'web-component' });
@@ -0,0 +1,7 @@
1
+ //
2
+ // Copyright 2025 DXOS.org
3
+ //
4
+
5
+ export * from './App';
6
+ export * from './PluginManager';
7
+ export * from './Surface';
@@ -0,0 +1,9 @@
1
+ //
2
+ // Copyright 2025 DXOS.org
3
+ //
4
+
5
+ export * from './useApp';
6
+ export * from './useCapabilities';
7
+ export * from './useLoading';
8
+ export * from './useSettingsState';
9
+ export * from './useSurface';
@@ -0,0 +1,159 @@
1
+ //
2
+ // Copyright 2025 DXOS.org
3
+ //
4
+
5
+ import { assert, describe, it } from '@effect/vitest';
6
+ import { render, waitFor } from '@testing-library/react';
7
+ import * as Effect from 'effect/Effect';
8
+ import React from 'react';
9
+
10
+ import { ActivationEvents, Capabilities } from '../../common';
11
+ import { Capability, Plugin, PluginManager } from '../../core';
12
+ import { useApp } from './useApp';
13
+
14
+ const String = Capability.make<{ string: string }>('org.dxos.test.string');
15
+ const testMeta = { id: 'org.dxos.plugin.test', name: 'Test' };
16
+
17
+ const pluginLoader = (plugins: Plugin.Plugin[]) =>
18
+ Effect.fn(function* (id: string) {
19
+ const plugin = plugins.find((plugin) => plugin.meta.id === id);
20
+ if (!plugin) {
21
+ return yield* Effect.fail(new Error(`Plugin not found: ${id}`));
22
+ }
23
+ return plugin;
24
+ });
25
+
26
+ const TestHost = ({ manager }: { manager: PluginManager.PluginManager }) => {
27
+ const App = useApp({ pluginManager: manager });
28
+ return <App />;
29
+ };
30
+
31
+ describe('useApp cleanup integration', () => {
32
+ it.effect('external manager is not shut down when useApp does not own it', () =>
33
+ Effect.gen(function* () {
34
+ const plugin = Plugin.define(testMeta).pipe(
35
+ Plugin.addModule({
36
+ id: 'Hello',
37
+ activatesOn: ActivationEvents.Startup,
38
+ activate: () => Effect.succeed(Capability.contributes(String, { string: 'hello' })),
39
+ }),
40
+ Plugin.make,
41
+ )();
42
+
43
+ const manager = PluginManager.make({
44
+ pluginLoader: pluginLoader([plugin]),
45
+ plugins: [plugin],
46
+ });
47
+
48
+ manager.capabilities.contribute({
49
+ interface: Capabilities.PluginManager,
50
+ implementation: manager,
51
+ module: 'org.dxos.app-framework.plugin-manager',
52
+ });
53
+ manager.capabilities.contribute({
54
+ interface: Capabilities.AtomRegistry,
55
+ implementation: manager.registry,
56
+ module: 'org.dxos.app-framework.atom-registry',
57
+ });
58
+
59
+ const view = yield* Effect.promise(() => Promise.resolve(render(<TestHost manager={manager} />)));
60
+ yield* Effect.promise(() =>
61
+ waitFor(() => {
62
+ assert.strictEqual(manager.capabilities.getAll(Capabilities.PluginManager).length, 1);
63
+ assert.strictEqual(manager.capabilities.getAll(Capabilities.AtomRegistry).length, 1);
64
+ assert.strictEqual(manager.capabilities.getAll(String).length, 1);
65
+ assert.isTrue(manager.getActive().length > 0);
66
+ }),
67
+ );
68
+
69
+ yield* Effect.promise(() => Promise.resolve(view.unmount()));
70
+ yield* Effect.promise(() =>
71
+ waitFor(() => {
72
+ assert.strictEqual(manager.capabilities.getAll(Capabilities.PluginManager).length, 1);
73
+ assert.strictEqual(manager.capabilities.getAll(Capabilities.AtomRegistry).length, 1);
74
+ assert.strictEqual(manager.capabilities.getAll(String).length, 1);
75
+ assert.isTrue(manager.getActive().length > 0);
76
+ }),
77
+ );
78
+
79
+ yield* manager.shutdown();
80
+
81
+ assert.strictEqual(manager.capabilities.getAll(Capabilities.PluginManager).length, 1);
82
+ assert.strictEqual(manager.capabilities.getAll(Capabilities.AtomRegistry).length, 1);
83
+ assert.strictEqual(manager.capabilities.getAll(String).length, 0);
84
+ assert.deepStrictEqual(manager.getActive(), []);
85
+ }),
86
+ );
87
+
88
+ it.effect('shutdown deactivates modules and clears bookkeeping', () =>
89
+ Effect.gen(function* () {
90
+ const plugin = Plugin.define(testMeta).pipe(
91
+ Plugin.addModule({
92
+ id: 'Hello',
93
+ activatesOn: ActivationEvents.Startup,
94
+ activate: () => Effect.succeed(Capability.contributes(String, { string: 'hello' })),
95
+ }),
96
+ Plugin.make,
97
+ )();
98
+
99
+ const manager = PluginManager.make({
100
+ pluginLoader: pluginLoader([plugin]),
101
+ plugins: [plugin],
102
+ });
103
+
104
+ manager.capabilities.contribute({
105
+ interface: Capabilities.PluginManager,
106
+ implementation: manager,
107
+ module: 'org.dxos.app-framework.plugin-manager',
108
+ });
109
+ manager.capabilities.contribute({
110
+ interface: Capabilities.AtomRegistry,
111
+ implementation: manager.registry,
112
+ module: 'org.dxos.app-framework.atom-registry',
113
+ });
114
+ yield* manager.activate(ActivationEvents.Startup);
115
+
116
+ assert.strictEqual(manager.capabilities.getAll(String).length, 1);
117
+ assert.isTrue(manager.getActive().length > 0);
118
+
119
+ yield* manager.shutdown();
120
+
121
+ assert.strictEqual(manager.capabilities.getAll(String).length, 0);
122
+ assert.deepStrictEqual(manager.getActive(), []);
123
+ assert.deepStrictEqual(manager.getEventsFired(), []);
124
+ }),
125
+ );
126
+
127
+ it.effect('shutdown is idempotent when called multiple times', () =>
128
+ Effect.gen(function* () {
129
+ const plugin = Plugin.define(testMeta).pipe(
130
+ Plugin.addModule({
131
+ id: 'Hello',
132
+ activatesOn: ActivationEvents.Startup,
133
+ activate: () => Effect.succeed(Capability.contributes(String, { string: 'hello' })),
134
+ }),
135
+ Plugin.make,
136
+ )();
137
+
138
+ const manager = PluginManager.make({
139
+ pluginLoader: pluginLoader([plugin]),
140
+ plugins: [plugin],
141
+ });
142
+
143
+ manager.capabilities.contribute({
144
+ interface: Capabilities.PluginManager,
145
+ implementation: manager,
146
+ module: 'org.dxos.app-framework.plugin-manager',
147
+ });
148
+ yield* manager.activate(ActivationEvents.Startup);
149
+
150
+ yield* manager.shutdown();
151
+ assert.deepStrictEqual(manager.getActive(), []);
152
+
153
+ // Second shutdown should succeed without error.
154
+ const result = yield* manager.shutdown();
155
+ assert.isTrue(result);
156
+ assert.deepStrictEqual(manager.getActive(), []);
157
+ }),
158
+ );
159
+ });
@@ -12,19 +12,32 @@ import React, { type FC, useCallback, useEffect, useMemo, useRef, useState } fro
12
12
  import { runAndForwardErrors } from '@dxos/effect';
13
13
  import { invariant } from '@dxos/invariant';
14
14
  import { log } from '@dxos/log';
15
+ import { ErrorBoundary, ErrorFallback, type FallbackProps } from '@dxos/react-error-boundary';
15
16
  import { useAsyncEffect, useDefaultValue } from '@dxos/react-hooks';
16
17
  import { ContextProtocolProvider } from '@dxos/web-context-react';
17
18
 
18
- import * as Common from '../common';
19
- import { PluginManagerContext } from '../context';
20
- import { type Plugin, PluginManager } from '../core';
19
+ import { ActivationEvents, Capabilities } from '../../common';
20
+ import { PluginManagerContext } from '../../context';
21
+ import { type ActivationEvent, type Plugin, PluginManager } from '../../core';
22
+ import { App, PluginManagerProvider } from '../components';
21
23
 
22
- import { App } from './App';
23
- import { DefaultFallback } from './DefaultFallback';
24
- import { ErrorBoundary } from './ErrorBoundary';
25
- import { PluginManagerProvider } from './PluginManagerProvider';
24
+ const ENABLED_KEY = 'org.dxos.app-framework.enabled';
26
25
 
27
- const ENABLED_KEY = 'dxos.org/app-framework/enabled';
26
+ export type StartupProgress = {
27
+ /** Number of modules that have been activated. */
28
+ activated: number;
29
+ /** Total number of modules registered. */
30
+ total: number;
31
+ /** Fractional progress (0-1). */
32
+ progress: number;
33
+ /** Human-readable label for the currently activating module. */
34
+ status?: string;
35
+ };
36
+
37
+ export type PlaceholderProps = {
38
+ stage?: number;
39
+ progress?: StartupProgress;
40
+ };
28
41
 
29
42
  export type UseAppOptions = {
30
43
  pluginManager?: PluginManager.PluginManager;
@@ -32,12 +45,17 @@ export type UseAppOptions = {
32
45
  plugins?: Plugin.Plugin[];
33
46
  core?: string[];
34
47
  defaults?: string[];
35
- placeholder?: FC<{ stage: number }>;
36
- fallback?: ErrorBoundary['props']['fallback'];
48
+ /**
49
+ * Additional activation events to fire before startup.
50
+ * These are fired alongside SetupReactSurface before the Startup event.
51
+ */
52
+ setupEvents?: ActivationEvent.ActivationEvent[];
37
53
  cacheEnabled?: boolean;
38
54
  safeMode?: boolean;
39
55
  debounce?: number;
40
56
  timeout?: number;
57
+ fallback?: FC<FallbackProps>;
58
+ placeholder?: FC<PlaceholderProps>;
41
59
  };
42
60
 
43
61
  /**
@@ -60,10 +78,10 @@ export type UseAppOptions = {
60
78
  * @param params.plugins All plugins available to the application.
61
79
  * @param params.core Core plugins which will always be enabled.
62
80
  * @param params.defaults Default plugins are enabled by default but can be disabled by the user.
63
- * @param params.placeholder Placeholder component to render during startup.
64
- * @param params.fallback Fallback component to render if an error occurs during startup.
65
81
  * @param params.cacheEnabled Whether to cache enabled plugins in localStorage.
66
82
  * @param params.safeMode Whether to enable safe mode, which disables optional plugins.
83
+ * @param params.fallback Fallback component to render if an error occurs during startup.
84
+ * @param params.placeholder Placeholder component to render during startup.
67
85
  */
68
86
  export const useApp = ({
69
87
  pluginManager,
@@ -71,8 +89,9 @@ export const useApp = ({
71
89
  plugins: pluginsProp,
72
90
  core: coreProp,
73
91
  defaults: defaultsProp,
92
+ setupEvents: setupEventsProp,
74
93
  placeholder,
75
- fallback = DefaultFallback,
94
+ fallback = ErrorFallback,
76
95
  cacheEnabled = false,
77
96
  safeMode = false,
78
97
  debounce = 0,
@@ -81,8 +100,8 @@ export const useApp = ({
81
100
  const plugins = useDefaultValue(pluginsProp, () => []);
82
101
  const core = useDefaultValue(coreProp, () => plugins.map(({ meta }) => meta.id));
83
102
  const defaults = useDefaultValue(defaultsProp, () => []);
103
+ const setupEvents = useDefaultValue(setupEventsProp, () => []);
84
104
 
85
- // TODO(wittjosiah): Provide a custom plugin loader which supports loading via url.
86
105
  const pluginLoader = useMemo(
87
106
  () =>
88
107
  pluginLoaderProp ??
@@ -99,16 +118,23 @@ export const useApp = ({
99
118
  const [ready, setReady] = useState(false);
100
119
  const errorRef = useRef<unknown>(null);
101
120
  const [error, setError] = useState<unknown>(null);
121
+ const [startupProgress, setStartupProgress] = useState<StartupProgress>({
122
+ activated: 0,
123
+ total: 0,
124
+ progress: 0,
125
+ });
102
126
  // TODO(wittjosiah): Migrate to Atom.kvs for isomorphic storage.
103
127
  const cached: string[] = useMemo(() => JSON.parse(localStorage.getItem(ENABLED_KEY) ?? '[]'), []);
104
128
  const enabled = useMemo(
105
129
  () => (safeMode ? [] : cacheEnabled && cached.length > 0 ? cached : defaults),
106
130
  [safeMode, cacheEnabled, cached, defaults],
107
131
  );
108
- const manager = useMemo(
109
- () => pluginManager ?? PluginManager.make({ pluginLoader, plugins, core, enabled }),
110
- [pluginManager, pluginLoader, plugins, core, enabled],
111
- );
132
+ const isExternalManager = !!pluginManager;
133
+ const manager = useMemo(() => {
134
+ const mgr = pluginManager ?? PluginManager.make({ pluginLoader, plugins, core, enabled });
135
+ log('useApp: useMemo created/reused manager', { provided: !!pluginManager });
136
+ return mgr;
137
+ }, [pluginManager, pluginLoader, plugins, core, enabled]);
112
138
 
113
139
  useEffect(() => {
114
140
  if (!cacheEnabled) {
@@ -124,28 +150,52 @@ export const useApp = ({
124
150
  }, [manager]);
125
151
 
126
152
  useAsyncEffect(async () => {
153
+ log('useApp: effect mount');
154
+
127
155
  manager.capabilities.contribute({
128
- interface: Common.Capability.PluginManager,
156
+ interface: Capabilities.PluginManager,
129
157
  implementation: manager,
130
- module: 'dxos.org/app-framework/plugin-manager',
158
+ module: 'org.dxos.app-framework.plugin-manager',
131
159
  });
132
160
 
133
161
  manager.capabilities.contribute({
134
- interface: Common.Capability.AtomRegistry,
162
+ interface: Capabilities.AtomRegistry,
135
163
  implementation: manager.registry,
136
- module: 'dxos.org/app-framework/atom-registry',
164
+ module: 'org.dxos.app-framework.atom-registry',
137
165
  });
138
166
 
167
+ // Poll manager atoms for progress (avoids PubSub subscription race).
168
+ const progressInterval = setInterval(() => {
169
+ if (readyRef.current) {
170
+ clearInterval(progressInterval);
171
+ return;
172
+ }
173
+ const active = manager.getActive();
174
+ const modules = manager.getModules();
175
+ const total = modules.length;
176
+ const activated = active.length;
177
+ const lastModule = active.length > 0 ? active[active.length - 1] : undefined;
178
+ setStartupProgress({
179
+ activated,
180
+ total,
181
+ progress: total > 0 ? activated / total : 0,
182
+ status: lastModule ? humanizeModuleId(lastModule) : undefined,
183
+ });
184
+ }, 100);
185
+
139
186
  const fiber = Effect.gen(function* () {
140
187
  const queue = yield* PubSub.subscribe(manager.activation);
141
188
  const listener = yield* Effect.forkDaemon(
142
189
  Queue.take(queue).pipe(
143
190
  Effect.tap(({ event, state, error: error$ }) =>
144
191
  Effect.sync(() => {
145
- if (event === Common.ActivationEvent.Startup.id && state === 'activated') {
192
+ if (event === ActivationEvents.Startup.id && state === 'activated') {
146
193
  clearTimeout(timeoutId);
194
+ clearInterval(progressInterval);
147
195
  setReady(true);
148
196
  readyRef.current = true;
197
+ // Trigger startup profiler dump if available.
198
+ (globalThis as any).composer?.profiler?.dump();
149
199
  }
150
200
  if (error$ && !readyRef.current) {
151
201
  setError(error$);
@@ -158,9 +208,9 @@ export const useApp = ({
158
208
  );
159
209
 
160
210
  yield* Effect.all([
161
- manager.activate(Common.ActivationEvent.SetupSettings),
162
- manager.activate(Common.ActivationEvent.SetupReactSurface),
163
- manager.activate(Common.ActivationEvent.Startup),
211
+ ...setupEvents.map((event) => manager.activate(event)),
212
+ manager.activate(ActivationEvents.SetupReactSurface),
213
+ manager.activate(ActivationEvents.Startup),
164
214
  ]);
165
215
 
166
216
  return yield* Fiber.join(listener);
@@ -180,20 +230,29 @@ export const useApp = ({
180
230
  }, timeout);
181
231
 
182
232
  return () => {
233
+ log('useApp: effect cleanup');
183
234
  clearTimeout(timeoutId);
235
+ clearInterval(progressInterval);
184
236
  void runAndForwardErrors(Fiber.interrupt(fiber));
185
- manager.capabilities.remove(Common.Capability.PluginManager, manager);
186
- manager.capabilities.remove(Common.Capability.AtomRegistry, manager.registry);
237
+ if (!isExternalManager) {
238
+ void runAndForwardErrors(manager.shutdown());
239
+ }
187
240
  };
188
241
  }, [manager]);
189
242
 
190
243
  return useCallback(
191
244
  () => (
192
- <ErrorBoundary fallback={fallback}>
245
+ <ErrorBoundary name='app' FallbackComponent={fallback}>
193
246
  <PluginManagerProvider value={manager}>
194
247
  <ContextProtocolProvider value={manager} context={PluginManagerContext}>
195
248
  <RegistryContext.Provider value={manager.registry}>
196
- <App placeholder={placeholder} ready={ready} error={error} debounce={debounce} />
249
+ <App
250
+ placeholder={placeholder}
251
+ ready={ready}
252
+ error={error}
253
+ debounce={debounce}
254
+ progress={startupProgress}
255
+ />
197
256
  </RegistryContext.Provider>
198
257
  </ContextProtocolProvider>
199
258
  </PluginManagerProvider>
@@ -207,3 +266,24 @@ const setupDevtools = (manager: PluginManager.PluginManager) => {
207
266
  (globalThis as any).composer ??= {};
208
267
  (globalThis as any).composer.manager = manager;
209
268
  };
269
+
270
+ /**
271
+ * Extracts a human-readable label from a module ID.
272
+ * E.g., "org.dxos.plugin.markdown.module.ReactSurface" → "Markdown".
273
+ */
274
+ const humanizeModuleId = (moduleId: string): string => {
275
+ // Extract plugin name from pattern: org.dxos.plugin.<name>.module.<capability>
276
+ const pluginMatch = moduleId.match(/\.plugin\.([^.]+)\./);
277
+ if (pluginMatch) {
278
+ const name = pluginMatch[1];
279
+ // Convert kebab-case to title case.
280
+ return name
281
+ .split('-')
282
+ .map((word) => word.charAt(0).toUpperCase() + word.slice(1))
283
+ .join(' ');
284
+ }
285
+
286
+ // Fallback: use the last segment.
287
+ const parts = moduleId.split('.');
288
+ return parts[parts.length - 1];
289
+ };
@@ -7,10 +7,9 @@ import { useCallback } from 'react';
7
7
 
8
8
  import { invariant } from '@dxos/invariant';
9
9
 
10
- import * as Common from '../common';
11
- import { type Capability } from '../core';
12
-
13
- import { usePluginManager } from './PluginManagerProvider';
10
+ import { Capabilities } from '../../common';
11
+ import { type Capability } from '../../core';
12
+ import { usePluginManager } from '../components';
14
13
 
15
14
  /**
16
15
  * Hook to request capabilities from the plugin context.
@@ -50,7 +49,7 @@ export const useAtomCapability = <T>(atomCapability: Capability.InterfaceDef<Ato
50
49
  export const useAtomCapabilityState = <T>(
51
50
  atomCapability: Capability.InterfaceDef<Atom.Writable<T>>,
52
51
  ): [T, (fn: (current: T) => T) => void] => {
53
- const registry = useCapability(Common.Capability.AtomRegistry);
52
+ const registry = useCapability(Capabilities.AtomRegistry);
54
53
  const atom = useCapability(atomCapability);
55
54
  const value = useAtomValue(atom);
56
55
  const update = useCallback(
@@ -61,3 +60,8 @@ export const useAtomCapabilityState = <T>(
61
60
  );
62
61
  return [value, update];
63
62
  };
63
+
64
+ /**
65
+ * Hook to get the operation invoker capability.
66
+ */
67
+ export const useOperationInvoker = (): Capabilities.OperationInvoker => useCapability(Capabilities.OperationInvoker);
@@ -5,17 +5,6 @@
5
5
  import { type Atom, RegistryContext, useAtomValue } from '@effect-atom/atom-react';
6
6
  import { useCallback, useContext } from 'react';
7
7
 
8
- import * as Common from '../common';
9
-
10
- import { useAtomCapability, useCapability } from './useCapabilities';
11
-
12
- export const useOperationInvoker = (): Common.Capability.OperationInvoker =>
13
- useCapability(Common.Capability.OperationInvoker);
14
-
15
- export const useAppGraph = (): Common.Capability.AppGraph => useCapability(Common.Capability.AppGraph);
16
-
17
- export const useLayout = (): Common.Capability.Layout => useAtomCapability(Common.Capability.Layout);
18
-
19
8
  /**
20
9
  * Hook to read and update a settings atom.
21
10
  * Returns the current value and an update function.
@@ -0,0 +1,13 @@
1
+ //
2
+ // Copyright 2025 DXOS.org
3
+ //
4
+
5
+ import { useContext } from 'react';
6
+
7
+ import { raise } from '@dxos/debug';
8
+
9
+ import { Surface } from '../components';
10
+
11
+ export const useSurface = (): Surface.Context => {
12
+ return useContext(Surface.Context) ?? raise(new Error('Missing SurfaceContext'));
13
+ };
@@ -0,0 +1,6 @@
1
+ //
2
+ // Copyright 2023 DXOS.org
3
+ //
4
+
5
+ export * from './components';
6
+ export * from './hooks';