@dxos/app-framework 0.8.4-main.fffef41 → 0.9.0

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 (569) hide show
  1. package/.storybook/main.mts +2 -4
  2. package/.storybook/preview.mts +2 -2
  3. package/LICENSE +102 -5
  4. package/README.md +1 -1
  5. package/dist/lib/browser/capability-BOPAKKWG.mjs +35 -0
  6. package/dist/lib/browser/capability-BOPAKKWG.mjs.map +7 -0
  7. package/dist/lib/browser/chunk-5GY3YOEL.mjs +28 -0
  8. package/dist/lib/browser/chunk-5GY3YOEL.mjs.map +7 -0
  9. package/dist/lib/browser/chunk-66IXTIVK.mjs +48 -0
  10. package/dist/lib/browser/chunk-66IXTIVK.mjs.map +7 -0
  11. package/dist/lib/browser/chunk-CO3XLNUX.mjs +95 -0
  12. package/dist/lib/browser/chunk-CO3XLNUX.mjs.map +7 -0
  13. package/dist/lib/browser/chunk-DC3WRPBV.mjs +227 -0
  14. package/dist/lib/browser/chunk-DC3WRPBV.mjs.map +7 -0
  15. package/dist/lib/browser/chunk-FJ4765WW.mjs +8 -0
  16. package/dist/lib/browser/chunk-FJ4765WW.mjs.map +7 -0
  17. package/dist/lib/browser/chunk-FO3IYSLV.mjs +68 -0
  18. package/dist/lib/browser/chunk-FO3IYSLV.mjs.map +7 -0
  19. package/dist/lib/browser/chunk-HFLKXMT7.mjs +587 -0
  20. package/dist/lib/browser/chunk-HFLKXMT7.mjs.map +7 -0
  21. package/dist/lib/browser/chunk-IW44C7UL.mjs +83 -0
  22. package/dist/lib/browser/chunk-IW44C7UL.mjs.map +7 -0
  23. package/dist/lib/browser/chunk-J5LGTIGS.mjs +10 -0
  24. package/dist/lib/browser/chunk-KZUDO43J.mjs +422 -0
  25. package/dist/lib/browser/chunk-KZUDO43J.mjs.map +7 -0
  26. package/dist/lib/browser/chunk-Q2GLJTVV.mjs +12 -0
  27. package/dist/lib/browser/chunk-Q2GLJTVV.mjs.map +7 -0
  28. package/dist/lib/browser/chunk-SYXIYT6T.mjs +143 -0
  29. package/dist/lib/browser/chunk-SYXIYT6T.mjs.map +7 -0
  30. package/dist/lib/browser/chunk-XHS5KDNX.mjs +1471 -0
  31. package/dist/lib/browser/chunk-XHS5KDNX.mjs.map +7 -0
  32. package/dist/lib/browser/chunk-Y66ELD4U.mjs +476 -0
  33. package/dist/lib/browser/chunk-Y66ELD4U.mjs.map +7 -0
  34. package/dist/lib/browser/cli/index.mjs +74 -0
  35. package/dist/lib/browser/cli/index.mjs.map +7 -0
  36. package/dist/lib/browser/common/activation-events.mjs +20 -0
  37. package/dist/lib/browser/common/capabilities.mjs +56 -0
  38. package/dist/lib/browser/core/activation-event.mjs +20 -0
  39. package/dist/lib/browser/core/capability.mjs +32 -0
  40. package/dist/lib/browser/core/capability.mjs.map +7 -0
  41. package/dist/lib/browser/core/plugin-manager.mjs +19 -0
  42. package/dist/lib/browser/core/plugin-manager.mjs.map +7 -0
  43. package/dist/lib/browser/core/plugin.mjs +41 -0
  44. package/dist/lib/browser/core/plugin.mjs.map +7 -0
  45. package/dist/lib/browser/core/url-loader.mjs +24 -0
  46. package/dist/lib/browser/core/url-loader.mjs.map +7 -0
  47. package/dist/lib/browser/index.mjs +86 -122
  48. package/dist/lib/browser/index.mjs.map +4 -4
  49. package/dist/lib/browser/meta.json +1 -1
  50. package/dist/lib/browser/process-manager-capability-GXNUO7AR.mjs +132 -0
  51. package/dist/lib/browser/process-manager-capability-GXNUO7AR.mjs.map +7 -0
  52. package/dist/lib/browser/testing/index.mjs +316 -47
  53. package/dist/lib/browser/testing/index.mjs.map +4 -4
  54. package/dist/lib/browser/testing/react.mjs +78 -0
  55. package/dist/lib/browser/testing/react.mjs.map +7 -0
  56. package/dist/lib/browser/ui/index.mjs +52 -0
  57. package/dist/lib/browser/ui/index.mjs.map +7 -0
  58. package/dist/lib/node-esm/capability-KZWRTX7R.mjs +36 -0
  59. package/dist/lib/node-esm/capability-KZWRTX7R.mjs.map +7 -0
  60. package/dist/lib/node-esm/chunk-37Z53PXZ.mjs +10 -0
  61. package/dist/lib/node-esm/chunk-37Z53PXZ.mjs.map +7 -0
  62. package/dist/lib/node-esm/chunk-A5CHGAZE.mjs +588 -0
  63. package/dist/lib/node-esm/chunk-A5CHGAZE.mjs.map +7 -0
  64. package/dist/lib/node-esm/chunk-COHOWGGJ.mjs +144 -0
  65. package/dist/lib/node-esm/chunk-COHOWGGJ.mjs.map +7 -0
  66. package/dist/lib/node-esm/chunk-CTKEZHKF.mjs +84 -0
  67. package/dist/lib/node-esm/chunk-CTKEZHKF.mjs.map +7 -0
  68. package/dist/lib/node-esm/chunk-FPW45EZH.mjs +14 -0
  69. package/dist/lib/node-esm/chunk-FPW45EZH.mjs.map +7 -0
  70. package/dist/lib/node-esm/chunk-FSVGKTF6.mjs +477 -0
  71. package/dist/lib/node-esm/chunk-FSVGKTF6.mjs.map +7 -0
  72. package/dist/lib/node-esm/chunk-HSLMI22Q.mjs +11 -0
  73. package/dist/lib/node-esm/chunk-HSLMI22Q.mjs.map +7 -0
  74. package/dist/lib/node-esm/chunk-KFZEB6BV.mjs +29 -0
  75. package/dist/lib/node-esm/chunk-KFZEB6BV.mjs.map +7 -0
  76. package/dist/lib/node-esm/chunk-NULBHQYS.mjs +96 -0
  77. package/dist/lib/node-esm/chunk-NULBHQYS.mjs.map +7 -0
  78. package/dist/lib/node-esm/chunk-SX5NVETP.mjs +1472 -0
  79. package/dist/lib/node-esm/chunk-SX5NVETP.mjs.map +7 -0
  80. package/dist/lib/node-esm/chunk-WK7OIQKI.mjs +70 -0
  81. package/dist/lib/node-esm/chunk-WK7OIQKI.mjs.map +7 -0
  82. package/dist/lib/node-esm/chunk-XGBUKRCK.mjs +423 -0
  83. package/dist/lib/node-esm/chunk-XGBUKRCK.mjs.map +7 -0
  84. package/dist/lib/node-esm/chunk-XIGPWXCQ.mjs +228 -0
  85. package/dist/lib/node-esm/chunk-XIGPWXCQ.mjs.map +7 -0
  86. package/dist/lib/node-esm/chunk-XOCUANHO.mjs +49 -0
  87. package/dist/lib/node-esm/chunk-XOCUANHO.mjs.map +7 -0
  88. package/dist/lib/node-esm/cli/index.mjs +75 -0
  89. package/dist/lib/node-esm/cli/index.mjs.map +7 -0
  90. package/dist/lib/node-esm/common/activation-events.mjs +21 -0
  91. package/dist/lib/node-esm/common/activation-events.mjs.map +7 -0
  92. package/dist/lib/node-esm/common/capabilities.mjs +57 -0
  93. package/dist/lib/node-esm/common/capabilities.mjs.map +7 -0
  94. package/dist/lib/node-esm/core/activation-event.mjs +21 -0
  95. package/dist/lib/node-esm/core/activation-event.mjs.map +7 -0
  96. package/dist/lib/node-esm/core/capability.mjs +33 -0
  97. package/dist/lib/node-esm/core/capability.mjs.map +7 -0
  98. package/dist/lib/node-esm/core/plugin-manager.mjs +20 -0
  99. package/dist/lib/node-esm/core/plugin-manager.mjs.map +7 -0
  100. package/dist/lib/node-esm/core/plugin.mjs +42 -0
  101. package/dist/lib/node-esm/core/plugin.mjs.map +7 -0
  102. package/dist/lib/node-esm/core/url-loader.mjs +25 -0
  103. package/dist/lib/node-esm/core/url-loader.mjs.map +7 -0
  104. package/dist/lib/node-esm/index.mjs +86 -122
  105. package/dist/lib/node-esm/index.mjs.map +4 -4
  106. package/dist/lib/node-esm/meta.json +1 -1
  107. package/dist/lib/node-esm/process-manager-capability-TX5TA6YN.mjs +133 -0
  108. package/dist/lib/node-esm/process-manager-capability-TX5TA6YN.mjs.map +7 -0
  109. package/dist/lib/node-esm/testing/index.mjs +316 -47
  110. package/dist/lib/node-esm/testing/index.mjs.map +4 -4
  111. package/dist/lib/node-esm/testing/react.mjs +79 -0
  112. package/dist/lib/node-esm/testing/react.mjs.map +7 -0
  113. package/dist/lib/node-esm/ui/index.mjs +53 -0
  114. package/dist/lib/node-esm/ui/index.mjs.map +7 -0
  115. package/dist/plugin/node-esm/index.mjs +977 -0
  116. package/dist/plugin/node-esm/index.mjs.map +7 -0
  117. package/dist/plugin/node-esm/meta.json +1 -0
  118. package/dist/types/src/cli/cli.d.ts +37 -0
  119. package/dist/types/src/cli/cli.d.ts.map +1 -0
  120. package/dist/types/src/cli/index.d.ts +2 -0
  121. package/dist/types/src/cli/index.d.ts.map +1 -0
  122. package/dist/types/src/common/activation-events.d.ts +24 -0
  123. package/dist/types/src/common/activation-events.d.ts.map +1 -0
  124. package/dist/types/src/common/annotations.d.ts +1 -0
  125. package/dist/types/src/common/annotations.d.ts.map +1 -0
  126. package/dist/types/src/common/capabilities.d.ts +214 -193
  127. package/dist/types/src/common/capabilities.d.ts.map +1 -1
  128. package/dist/types/src/common/index.d.ts +3 -8
  129. package/dist/types/src/common/index.d.ts.map +1 -1
  130. package/dist/types/src/common/translations.d.ts +7 -7
  131. package/dist/types/src/common/translations.d.ts.map +1 -1
  132. package/dist/types/src/context.d.ts +5 -0
  133. package/dist/types/src/context.d.ts.map +1 -0
  134. package/dist/types/src/core/{events.d.ts → activation-event.d.ts} +11 -11
  135. package/dist/types/src/core/activation-event.d.ts.map +1 -0
  136. package/dist/types/src/core/capability-manager.d.ts +52 -0
  137. package/dist/types/src/core/capability-manager.d.ts.map +1 -0
  138. package/dist/types/src/core/capability-manager.test.d.ts +2 -0
  139. package/dist/types/src/core/capability-manager.test.d.ts.map +1 -0
  140. package/dist/types/src/core/capability.d.ts +161 -0
  141. package/dist/types/src/core/capability.d.ts.map +1 -0
  142. package/dist/types/src/core/edge-registry-plugin-provider.d.ts +30 -0
  143. package/dist/types/src/core/edge-registry-plugin-provider.d.ts.map +1 -0
  144. package/dist/types/src/core/index.d.ts +11 -4
  145. package/dist/types/src/core/index.d.ts.map +1 -1
  146. package/dist/types/src/core/plugin-asset-cache.d.ts +71 -0
  147. package/dist/types/src/core/plugin-asset-cache.d.ts.map +1 -0
  148. package/dist/types/src/core/plugin-manager.d.ts +297 -0
  149. package/dist/types/src/core/plugin-manager.d.ts.map +1 -0
  150. package/dist/types/src/core/plugin-manager.test.d.ts +2 -0
  151. package/dist/types/src/core/plugin-manager.test.d.ts.map +1 -0
  152. package/dist/types/src/core/plugin-manifest.d.ts +101 -0
  153. package/dist/types/src/core/plugin-manifest.d.ts.map +1 -0
  154. package/dist/types/src/core/plugin-manifest.test.d.ts +2 -0
  155. package/dist/types/src/core/plugin-manifest.test.d.ts.map +1 -0
  156. package/dist/types/src/core/plugin.d.ts +303 -43
  157. package/dist/types/src/core/plugin.d.ts.map +1 -1
  158. package/dist/types/src/core/registry.d.ts +107 -0
  159. package/dist/types/src/core/registry.d.ts.map +1 -0
  160. package/dist/types/src/core/url-loader.d.ts +127 -0
  161. package/dist/types/src/core/url-loader.d.ts.map +1 -0
  162. package/dist/types/src/core/url-loader.test.d.ts +2 -0
  163. package/dist/types/src/core/url-loader.test.d.ts.map +1 -0
  164. package/dist/types/src/helpers.d.ts.map +1 -1
  165. package/dist/types/src/index.d.ts +2 -2
  166. package/dist/types/src/index.d.ts.map +1 -1
  167. package/dist/types/src/plugin-process-manager/ProcessManagerPlugin.d.ts +3 -0
  168. package/dist/types/src/plugin-process-manager/ProcessManagerPlugin.d.ts.map +1 -0
  169. package/dist/types/src/plugin-process-manager/history/capability.d.ts +7 -0
  170. package/dist/types/src/plugin-process-manager/history/capability.d.ts.map +1 -0
  171. package/dist/types/src/plugin-process-manager/history/errors.d.ts +32 -0
  172. package/dist/types/src/plugin-process-manager/history/errors.d.ts.map +1 -0
  173. package/dist/types/src/plugin-process-manager/history/history-tracker.d.ts +32 -0
  174. package/dist/types/src/plugin-process-manager/history/history-tracker.d.ts.map +1 -0
  175. package/dist/types/src/plugin-process-manager/history/history-tracker.test.d.ts +2 -0
  176. package/dist/types/src/plugin-process-manager/history/history-tracker.test.d.ts.map +1 -0
  177. package/dist/types/src/plugin-process-manager/history/index.d.ts +6 -0
  178. package/dist/types/src/plugin-process-manager/history/index.d.ts.map +1 -0
  179. package/dist/types/src/plugin-process-manager/history/types.d.ts +13 -0
  180. package/dist/types/src/plugin-process-manager/history/types.d.ts.map +1 -0
  181. package/dist/types/src/plugin-process-manager/history/undo-mapping.d.ts +101 -0
  182. package/dist/types/src/plugin-process-manager/history/undo-mapping.d.ts.map +1 -0
  183. package/dist/types/src/plugin-process-manager/history/undo-registry.d.ts +23 -0
  184. package/dist/types/src/plugin-process-manager/history/undo-registry.d.ts.map +1 -0
  185. package/dist/types/src/plugin-process-manager/history/undo-registry.test.d.ts +2 -0
  186. package/dist/types/src/plugin-process-manager/history/undo-registry.test.d.ts.map +1 -0
  187. package/dist/types/src/plugin-process-manager/idb-key-value-store.d.ts +10 -0
  188. package/dist/types/src/plugin-process-manager/idb-key-value-store.d.ts.map +1 -0
  189. package/dist/types/src/plugin-process-manager/index.d.ts +3 -0
  190. package/dist/types/src/plugin-process-manager/index.d.ts.map +1 -0
  191. package/dist/types/src/plugin-process-manager/meta.d.ts +3 -0
  192. package/dist/types/src/plugin-process-manager/meta.d.ts.map +1 -0
  193. package/dist/types/src/plugin-process-manager/process-manager-capability.d.ts +8 -0
  194. package/dist/types/src/plugin-process-manager/process-manager-capability.d.ts.map +1 -0
  195. package/dist/types/src/plugin-process-manager/testing.d.ts +59 -0
  196. package/dist/types/src/plugin-process-manager/testing.d.ts.map +1 -0
  197. package/dist/types/src/testing/harness.d.ts +79 -0
  198. package/dist/types/src/testing/harness.d.ts.map +1 -0
  199. package/dist/types/src/testing/index.d.ts +3 -0
  200. package/dist/types/src/testing/index.d.ts.map +1 -1
  201. package/dist/types/src/testing/operationCapture.d.ts +64 -0
  202. package/dist/types/src/testing/operationCapture.d.ts.map +1 -0
  203. package/dist/types/src/testing/react.d.ts +27 -0
  204. package/dist/types/src/testing/react.d.ts.map +1 -0
  205. package/dist/types/src/testing/react.test.d.ts +2 -0
  206. package/dist/types/src/testing/react.test.d.ts.map +1 -0
  207. package/dist/types/src/testing/service.d.ts +8 -0
  208. package/dist/types/src/testing/service.d.ts.map +1 -0
  209. package/dist/types/src/testing/withPluginManager.d.ts +4 -4
  210. package/dist/types/src/testing/withPluginManager.d.ts.map +1 -1
  211. package/dist/types/src/testing/withPluginManager.stories.d.ts.map +1 -1
  212. package/dist/types/src/ui/components/App/App.d.ts +41 -0
  213. package/dist/types/src/ui/components/App/App.d.ts.map +1 -0
  214. package/dist/types/src/ui/components/App/App.stories.d.ts +19 -0
  215. package/dist/types/src/ui/components/App/App.stories.d.ts.map +1 -0
  216. package/dist/types/src/ui/components/App/index.d.ts +2 -0
  217. package/dist/types/src/ui/components/App/index.d.ts.map +1 -0
  218. package/dist/types/src/{react/Surface.stories.d.ts → ui/components/PluginManager/PluginManagerContext.stories.d.ts} +2 -3
  219. package/dist/types/src/ui/components/PluginManager/PluginManagerContext.stories.d.ts.map +1 -0
  220. package/dist/types/src/ui/components/PluginManager/PluginManagerProvider.d.ts +10 -0
  221. package/dist/types/src/ui/components/PluginManager/PluginManagerProvider.d.ts.map +1 -0
  222. package/dist/types/src/ui/components/PluginManager/index.d.ts +2 -0
  223. package/dist/types/src/ui/components/PluginManager/index.d.ts.map +1 -0
  224. package/dist/types/src/ui/components/Surface/SurfaceComponent.d.ts +24 -0
  225. package/dist/types/src/ui/components/Surface/SurfaceComponent.d.ts.map +1 -0
  226. package/dist/types/src/{react/App.stories.d.ts → ui/components/Surface/SurfaceComponent.stories.d.ts} +1 -1
  227. package/dist/types/src/ui/components/Surface/SurfaceComponent.stories.d.ts.map +1 -0
  228. package/dist/types/src/ui/components/Surface/SurfaceInfo.d.ts +11 -0
  229. package/dist/types/src/ui/components/Surface/SurfaceInfo.d.ts.map +1 -0
  230. package/dist/types/src/ui/components/Surface/SurfaceProfilerContext.d.ts +48 -0
  231. package/dist/types/src/ui/components/Surface/SurfaceProfilerContext.d.ts.map +1 -0
  232. package/dist/types/src/ui/components/Surface/context.d.ts +5 -0
  233. package/dist/types/src/ui/components/Surface/context.d.ts.map +1 -0
  234. package/dist/types/src/ui/components/Surface/index.d.ts +36 -0
  235. package/dist/types/src/ui/components/Surface/index.d.ts.map +1 -0
  236. package/dist/types/src/ui/components/Surface/types.d.ts +197 -0
  237. package/dist/types/src/ui/components/Surface/types.d.ts.map +1 -0
  238. package/dist/types/src/ui/components/Surface/types.test.d.ts +2 -0
  239. package/dist/types/src/ui/components/Surface/types.test.d.ts.map +1 -0
  240. package/dist/types/src/ui/components/index.d.ts +4 -0
  241. package/dist/types/src/ui/components/index.d.ts.map +1 -0
  242. package/dist/types/src/ui/hooks/index.d.ts +7 -0
  243. package/dist/types/src/ui/hooks/index.d.ts.map +1 -0
  244. package/dist/types/src/ui/hooks/useApp.d.ts +80 -0
  245. package/dist/types/src/ui/hooks/useApp.d.ts.map +1 -0
  246. package/dist/types/src/ui/hooks/useApp.test.d.ts +2 -0
  247. package/dist/types/src/ui/hooks/useApp.test.d.ts.map +1 -0
  248. package/dist/types/src/ui/hooks/useCapabilities.d.ts +31 -0
  249. package/dist/types/src/ui/hooks/useCapabilities.d.ts.map +1 -0
  250. package/dist/types/src/{react → ui/hooks}/useLoading.d.ts +1 -2
  251. package/dist/types/src/ui/hooks/useLoading.d.ts.map +1 -0
  252. package/dist/types/src/ui/hooks/useProcessManagerRuntime.d.ts +30 -0
  253. package/dist/types/src/ui/hooks/useProcessManagerRuntime.d.ts.map +1 -0
  254. package/dist/types/src/ui/hooks/useSettingsState.d.ts +10 -0
  255. package/dist/types/src/ui/hooks/useSettingsState.d.ts.map +1 -0
  256. package/dist/types/src/ui/hooks/useSurface.d.ts +3 -0
  257. package/dist/types/src/ui/hooks/useSurface.d.ts.map +1 -0
  258. package/dist/types/src/ui/index.d.ts +3 -0
  259. package/dist/types/src/ui/index.d.ts.map +1 -0
  260. package/dist/types/src/vite-plugin/boot-loader/index.d.ts +2 -0
  261. package/dist/types/src/vite-plugin/boot-loader/index.d.ts.map +1 -0
  262. package/dist/types/src/vite-plugin/boot-loader/loader.d.ts +59 -0
  263. package/dist/types/src/vite-plugin/boot-loader/loader.d.ts.map +1 -0
  264. package/dist/types/src/vite-plugin/composer/index.d.ts +34 -0
  265. package/dist/types/src/vite-plugin/composer/index.d.ts.map +1 -0
  266. package/dist/types/src/vite-plugin/import-map/index.d.ts +28 -0
  267. package/dist/types/src/vite-plugin/import-map/index.d.ts.map +1 -0
  268. package/dist/types/src/vite-plugin/index.d.ts +5 -0
  269. package/dist/types/src/vite-plugin/index.d.ts.map +1 -0
  270. package/dist/types/src/vite-plugin/manifest.d.ts +41 -0
  271. package/dist/types/src/vite-plugin/manifest.d.ts.map +1 -0
  272. package/dist/types/src/vite-plugin/manifest.test.d.ts +2 -0
  273. package/dist/types/src/vite-plugin/manifest.test.d.ts.map +1 -0
  274. package/dist/types/src/vite-plugin/packages.d.ts +13 -0
  275. package/dist/types/src/vite-plugin/packages.d.ts.map +1 -0
  276. package/dist/types/tsconfig.tsbuildinfo +1 -1
  277. package/moon.yml +25 -6
  278. package/package.json +125 -59
  279. package/src/cli/cli.ts +102 -0
  280. package/src/{playground/debug → cli}/index.ts +1 -1
  281. package/src/common/activation-events.ts +39 -0
  282. package/src/{playground/logger/index.ts → common/annotations.ts} +0 -2
  283. package/src/common/capabilities.ts +287 -192
  284. package/src/common/index.ts +3 -8
  285. package/src/common/translations.ts +17 -9
  286. package/src/context.ts +9 -0
  287. package/src/core/{events.ts → activation-event.ts} +10 -7
  288. package/src/core/capability-manager.test.ts +154 -0
  289. package/src/core/capability-manager.ts +213 -0
  290. package/src/core/capability.ts +254 -0
  291. package/src/core/edge-registry-plugin-provider.ts +92 -0
  292. package/src/core/index.ts +11 -4
  293. package/src/core/plugin-asset-cache.ts +60 -0
  294. package/src/core/plugin-manager.test.ts +1929 -0
  295. package/src/core/plugin-manager.ts +1696 -0
  296. package/src/core/plugin-manifest.test.ts +75 -0
  297. package/src/core/plugin-manifest.ts +134 -0
  298. package/src/core/plugin.ts +449 -48
  299. package/src/core/registry.ts +163 -0
  300. package/src/core/url-loader.test.ts +222 -0
  301. package/src/core/url-loader.ts +388 -0
  302. package/src/index.ts +2 -2
  303. package/src/plugin-process-manager/ProcessManagerPlugin.ts +24 -0
  304. package/src/plugin-process-manager/history/capability.ts +36 -0
  305. package/src/plugin-process-manager/history/errors.ts +7 -0
  306. package/src/plugin-process-manager/history/history-tracker.test.ts +353 -0
  307. package/src/plugin-process-manager/history/history-tracker.ts +144 -0
  308. package/src/plugin-process-manager/history/index.ts +9 -0
  309. package/src/plugin-process-manager/history/types.ts +17 -0
  310. package/src/plugin-process-manager/history/undo-mapping.ts +135 -0
  311. package/src/plugin-process-manager/history/undo-registry.test.ts +74 -0
  312. package/src/plugin-process-manager/history/undo-registry.ts +54 -0
  313. package/src/plugin-process-manager/idb-key-value-store.ts +64 -0
  314. package/src/plugin-process-manager/index.ts +6 -0
  315. package/src/plugin-process-manager/meta.ts +16 -0
  316. package/src/plugin-process-manager/process-manager-capability.ts +178 -0
  317. package/src/plugin-process-manager/testing.ts +156 -0
  318. package/src/testing/harness.ts +247 -0
  319. package/src/testing/index.ts +3 -0
  320. package/src/testing/operationCapture.ts +144 -0
  321. package/src/testing/react.test.tsx +50 -0
  322. package/src/testing/react.tsx +113 -0
  323. package/src/testing/service.ts +52 -0
  324. package/src/testing/withPluginManager.stories.tsx +8 -9
  325. package/src/testing/withPluginManager.tsx +69 -42
  326. package/src/ui/components/App/App.stories.tsx +84 -0
  327. package/src/ui/components/App/App.tsx +144 -0
  328. package/src/{playground/layout → ui/components/App}/index.ts +1 -1
  329. package/src/ui/components/PluginManager/PluginManagerContext.stories.tsx +179 -0
  330. package/src/{react → ui/components/PluginManager}/PluginManagerProvider.ts +3 -3
  331. package/src/ui/components/PluginManager/index.ts +5 -0
  332. package/src/ui/components/Surface/SurfaceComponent.stories.tsx +144 -0
  333. package/src/ui/components/Surface/SurfaceComponent.tsx +303 -0
  334. package/src/ui/components/Surface/SurfaceInfo.tsx +106 -0
  335. package/src/ui/components/Surface/SurfaceProfilerContext.tsx +207 -0
  336. package/src/ui/components/Surface/context.ts +12 -0
  337. package/src/ui/components/Surface/index.ts +54 -0
  338. package/src/ui/components/Surface/types.test.ts +126 -0
  339. package/src/ui/components/Surface/types.ts +290 -0
  340. package/src/ui/components/index.ts +7 -0
  341. package/src/ui/hooks/index.ts +10 -0
  342. package/src/ui/hooks/useApp.test.tsx +161 -0
  343. package/src/ui/hooks/useApp.tsx +404 -0
  344. package/src/ui/hooks/useCapabilities.ts +68 -0
  345. package/src/{react → ui/hooks}/useLoading.tsx +16 -10
  346. package/src/ui/hooks/useProcessManagerRuntime.ts +78 -0
  347. package/src/ui/hooks/useSettingsState.ts +26 -0
  348. package/src/ui/hooks/useSurface.ts +13 -0
  349. package/src/ui/index.ts +6 -0
  350. package/src/vite-plugin/boot-loader/BootLoader.solid-stories.tsx +198 -0
  351. package/src/vite-plugin/boot-loader/index.ts +5 -0
  352. package/src/vite-plugin/boot-loader/loader-app/Loader.tsx +166 -0
  353. package/src/vite-plugin/boot-loader/loader-app/boot-loader.css +311 -0
  354. package/src/vite-plugin/boot-loader/loader-app/bridge.ts +25 -0
  355. package/src/vite-plugin/boot-loader/loader-app/entry.tsx +21 -0
  356. package/src/vite-plugin/boot-loader/loader-app/mount.tsx +70 -0
  357. package/src/vite-plugin/boot-loader/loader-app/store.test.ts +137 -0
  358. package/src/vite-plugin/boot-loader/loader-app/store.ts +149 -0
  359. package/src/vite-plugin/boot-loader/loader-app/tsconfig.json +11 -0
  360. package/src/vite-plugin/boot-loader/loader-app/types.ts +78 -0
  361. package/src/vite-plugin/boot-loader/loader.ts +204 -0
  362. package/src/vite-plugin/composer/index.ts +306 -0
  363. package/src/vite-plugin/import-map/index.ts +527 -0
  364. package/src/vite-plugin/index.ts +10 -0
  365. package/src/vite-plugin/manifest.test.ts +55 -0
  366. package/src/vite-plugin/manifest.ts +63 -0
  367. package/src/vite-plugin/packages.ts +187 -0
  368. package/tsconfig.json +27 -22
  369. package/tsconfig.node.json +2 -4
  370. package/typedoc.json +2 -4
  371. package/vitest.config.ts +1 -1
  372. package/.swc/plugins/linux_x86_64_19.0.0/727453fb3a62f7f1d952a41e051ca8a6f88cadc45cee43c6a4d1aa45f9b75665.wasmer-v7 +0 -0
  373. package/.swc/plugins/linux_x86_64_19.0.0/fce1bdb8e20a094e4af08bad09cc81497ed0e2e7c51223b07d371063cca18429.wasmer-v7 +0 -0
  374. package/dist/lib/browser/app-graph-builder-OIEZZC45.mjs +0 -138
  375. package/dist/lib/browser/app-graph-builder-OIEZZC45.mjs.map +0 -7
  376. package/dist/lib/browser/chunk-6XKO24JP.mjs +0 -483
  377. package/dist/lib/browser/chunk-6XKO24JP.mjs.map +0 -7
  378. package/dist/lib/browser/chunk-SCPE4ZO2.mjs +0 -35
  379. package/dist/lib/browser/chunk-SCPE4ZO2.mjs.map +0 -7
  380. package/dist/lib/browser/chunk-WPW5VVAX.mjs +0 -1651
  381. package/dist/lib/browser/chunk-WPW5VVAX.mjs.map +0 -7
  382. package/dist/lib/browser/intent-dispatcher-LZ4AE66E.mjs +0 -11
  383. package/dist/lib/browser/intent-resolver-QVCKRX6G.mjs +0 -39
  384. package/dist/lib/browser/intent-resolver-QVCKRX6G.mjs.map +0 -7
  385. package/dist/lib/browser/react/index.mjs +0 -34
  386. package/dist/lib/browser/store-CNPHOYTJ.mjs +0 -30
  387. package/dist/lib/browser/store-CNPHOYTJ.mjs.map +0 -7
  388. package/dist/lib/node-esm/app-graph-builder-EBU4NVWD.mjs +0 -139
  389. package/dist/lib/node-esm/app-graph-builder-EBU4NVWD.mjs.map +0 -7
  390. package/dist/lib/node-esm/chunk-3UPX5OIS.mjs +0 -484
  391. package/dist/lib/node-esm/chunk-3UPX5OIS.mjs.map +0 -7
  392. package/dist/lib/node-esm/chunk-XJZGUJ3H.mjs +0 -1653
  393. package/dist/lib/node-esm/chunk-XJZGUJ3H.mjs.map +0 -7
  394. package/dist/lib/node-esm/chunk-ZX63QUGE.mjs +0 -37
  395. package/dist/lib/node-esm/chunk-ZX63QUGE.mjs.map +0 -7
  396. package/dist/lib/node-esm/intent-dispatcher-MGOJ3CHD.mjs +0 -12
  397. package/dist/lib/node-esm/intent-resolver-URF3HN3G.mjs +0 -40
  398. package/dist/lib/node-esm/intent-resolver-URF3HN3G.mjs.map +0 -7
  399. package/dist/lib/node-esm/react/index.mjs +0 -35
  400. package/dist/lib/node-esm/store-RK5B4XEL.mjs +0 -31
  401. package/dist/lib/node-esm/store-RK5B4XEL.mjs.map +0 -7
  402. package/dist/types/src/common/collaboration.d.ts +0 -20
  403. package/dist/types/src/common/collaboration.d.ts.map +0 -1
  404. package/dist/types/src/common/events.d.ts +0 -52
  405. package/dist/types/src/common/events.d.ts.map +0 -1
  406. package/dist/types/src/common/file.d.ts +0 -14
  407. package/dist/types/src/common/file.d.ts.map +0 -1
  408. package/dist/types/src/common/graph.d.ts +0 -21
  409. package/dist/types/src/common/graph.d.ts.map +0 -1
  410. package/dist/types/src/common/layout.d.ts +0 -279
  411. package/dist/types/src/common/layout.d.ts.map +0 -1
  412. package/dist/types/src/common/surface.d.ts +0 -68
  413. package/dist/types/src/common/surface.d.ts.map +0 -1
  414. package/dist/types/src/core/capabilities.d.ts +0 -117
  415. package/dist/types/src/core/capabilities.d.ts.map +0 -1
  416. package/dist/types/src/core/capabilities.test.d.ts +0 -2
  417. package/dist/types/src/core/capabilities.test.d.ts.map +0 -1
  418. package/dist/types/src/core/events.d.ts.map +0 -1
  419. package/dist/types/src/core/manager.d.ts +0 -126
  420. package/dist/types/src/core/manager.d.ts.map +0 -1
  421. package/dist/types/src/core/manager.test.d.ts +0 -2
  422. package/dist/types/src/core/manager.test.d.ts.map +0 -1
  423. package/dist/types/src/playground/debug/Debug.d.ts +0 -6
  424. package/dist/types/src/playground/debug/Debug.d.ts.map +0 -1
  425. package/dist/types/src/playground/debug/index.d.ts +0 -2
  426. package/dist/types/src/playground/debug/index.d.ts.map +0 -1
  427. package/dist/types/src/playground/debug/plugin.d.ts +0 -2
  428. package/dist/types/src/playground/debug/plugin.d.ts.map +0 -1
  429. package/dist/types/src/playground/generator/Main.d.ts +0 -6
  430. package/dist/types/src/playground/generator/Main.d.ts.map +0 -1
  431. package/dist/types/src/playground/generator/Toolbar.d.ts +0 -6
  432. package/dist/types/src/playground/generator/Toolbar.d.ts.map +0 -1
  433. package/dist/types/src/playground/generator/generator.d.ts +0 -7
  434. package/dist/types/src/playground/generator/generator.d.ts.map +0 -1
  435. package/dist/types/src/playground/generator/index.d.ts +0 -3
  436. package/dist/types/src/playground/generator/index.d.ts.map +0 -1
  437. package/dist/types/src/playground/generator/plugin.d.ts +0 -2
  438. package/dist/types/src/playground/generator/plugin.d.ts.map +0 -1
  439. package/dist/types/src/playground/layout/Layout.d.ts +0 -8
  440. package/dist/types/src/playground/layout/Layout.d.ts.map +0 -1
  441. package/dist/types/src/playground/layout/index.d.ts +0 -2
  442. package/dist/types/src/playground/layout/index.d.ts.map +0 -1
  443. package/dist/types/src/playground/layout/plugin.d.ts +0 -2
  444. package/dist/types/src/playground/layout/plugin.d.ts.map +0 -1
  445. package/dist/types/src/playground/logger/Toolbar.d.ts +0 -6
  446. package/dist/types/src/playground/logger/Toolbar.d.ts.map +0 -1
  447. package/dist/types/src/playground/logger/index.d.ts +0 -2
  448. package/dist/types/src/playground/logger/index.d.ts.map +0 -1
  449. package/dist/types/src/playground/logger/plugin.d.ts +0 -2
  450. package/dist/types/src/playground/logger/plugin.d.ts.map +0 -1
  451. package/dist/types/src/playground/logger/schema.d.ts +0 -13
  452. package/dist/types/src/playground/logger/schema.d.ts.map +0 -1
  453. package/dist/types/src/playground/playground.stories.d.ts +0 -11
  454. package/dist/types/src/playground/playground.stories.d.ts.map +0 -1
  455. package/dist/types/src/plugin-intent/IntentPlugin.d.ts +0 -2
  456. package/dist/types/src/plugin-intent/IntentPlugin.d.ts.map +0 -1
  457. package/dist/types/src/plugin-intent/actions.d.ts +0 -36
  458. package/dist/types/src/plugin-intent/actions.d.ts.map +0 -1
  459. package/dist/types/src/plugin-intent/errors.d.ts +0 -16
  460. package/dist/types/src/plugin-intent/errors.d.ts.map +0 -1
  461. package/dist/types/src/plugin-intent/index.d.ts +0 -6
  462. package/dist/types/src/plugin-intent/index.d.ts.map +0 -1
  463. package/dist/types/src/plugin-intent/intent-dispatcher.d.ts +0 -139
  464. package/dist/types/src/plugin-intent/intent-dispatcher.d.ts.map +0 -1
  465. package/dist/types/src/plugin-intent/intent-dispatcher.test.d.ts +0 -2
  466. package/dist/types/src/plugin-intent/intent-dispatcher.test.d.ts.map +0 -1
  467. package/dist/types/src/plugin-intent/intent.d.ts +0 -63
  468. package/dist/types/src/plugin-intent/intent.d.ts.map +0 -1
  469. package/dist/types/src/plugin-intent/meta.d.ts +0 -3
  470. package/dist/types/src/plugin-intent/meta.d.ts.map +0 -1
  471. package/dist/types/src/plugin-settings/SettingsPlugin.d.ts +0 -2
  472. package/dist/types/src/plugin-settings/SettingsPlugin.d.ts.map +0 -1
  473. package/dist/types/src/plugin-settings/actions.d.ts +0 -25
  474. package/dist/types/src/plugin-settings/actions.d.ts.map +0 -1
  475. package/dist/types/src/plugin-settings/app-graph-builder.d.ts +0 -4
  476. package/dist/types/src/plugin-settings/app-graph-builder.d.ts.map +0 -1
  477. package/dist/types/src/plugin-settings/index.d.ts +0 -3
  478. package/dist/types/src/plugin-settings/index.d.ts.map +0 -1
  479. package/dist/types/src/plugin-settings/intent-resolver.d.ts +0 -4
  480. package/dist/types/src/plugin-settings/intent-resolver.d.ts.map +0 -1
  481. package/dist/types/src/plugin-settings/meta.d.ts +0 -3
  482. package/dist/types/src/plugin-settings/meta.d.ts.map +0 -1
  483. package/dist/types/src/plugin-settings/store.d.ts +0 -5
  484. package/dist/types/src/plugin-settings/store.d.ts.map +0 -1
  485. package/dist/types/src/plugin-settings/translations.d.ts +0 -11
  486. package/dist/types/src/plugin-settings/translations.d.ts.map +0 -1
  487. package/dist/types/src/react/App.d.ts +0 -10
  488. package/dist/types/src/react/App.d.ts.map +0 -1
  489. package/dist/types/src/react/App.stories.d.ts.map +0 -1
  490. package/dist/types/src/react/DefaultFallback.d.ts +0 -8
  491. package/dist/types/src/react/DefaultFallback.d.ts.map +0 -1
  492. package/dist/types/src/react/ErrorBoundary.d.ts +0 -30
  493. package/dist/types/src/react/ErrorBoundary.d.ts.map +0 -1
  494. package/dist/types/src/react/IntentContext.d.ts +0 -8
  495. package/dist/types/src/react/IntentContext.d.ts.map +0 -1
  496. package/dist/types/src/react/PluginManagerProvider.d.ts +0 -10
  497. package/dist/types/src/react/PluginManagerProvider.d.ts.map +0 -1
  498. package/dist/types/src/react/Surface.d.ts +0 -12
  499. package/dist/types/src/react/Surface.d.ts.map +0 -1
  500. package/dist/types/src/react/Surface.stories.d.ts.map +0 -1
  501. package/dist/types/src/react/common.d.ts +0 -13
  502. package/dist/types/src/react/common.d.ts.map +0 -1
  503. package/dist/types/src/react/index.d.ts +0 -9
  504. package/dist/types/src/react/index.d.ts.map +0 -1
  505. package/dist/types/src/react/types.d.ts +0 -14
  506. package/dist/types/src/react/types.d.ts.map +0 -1
  507. package/dist/types/src/react/useApp.d.ts +0 -44
  508. package/dist/types/src/react/useApp.d.ts.map +0 -1
  509. package/dist/types/src/react/useCapabilities.d.ts +0 -13
  510. package/dist/types/src/react/useCapabilities.d.ts.map +0 -1
  511. package/dist/types/src/react/useIntentResolver.d.ts +0 -3
  512. package/dist/types/src/react/useIntentResolver.d.ts.map +0 -1
  513. package/dist/types/src/react/useLoading.d.ts.map +0 -1
  514. package/src/common/collaboration.ts +0 -18
  515. package/src/common/events.ts +0 -79
  516. package/src/common/file.ts +0 -22
  517. package/src/common/graph.ts +0 -30
  518. package/src/common/layout.ts +0 -277
  519. package/src/common/surface.ts +0 -88
  520. package/src/core/capabilities.test.ts +0 -136
  521. package/src/core/capabilities.ts +0 -263
  522. package/src/core/manager.test.ts +0 -516
  523. package/src/core/manager.ts +0 -604
  524. package/src/playground/debug/Debug.tsx +0 -39
  525. package/src/playground/debug/plugin.ts +0 -16
  526. package/src/playground/generator/Main.tsx +0 -70
  527. package/src/playground/generator/Toolbar.tsx +0 -47
  528. package/src/playground/generator/generator.ts +0 -48
  529. package/src/playground/generator/index.ts +0 -6
  530. package/src/playground/generator/plugin.ts +0 -22
  531. package/src/playground/layout/Layout.tsx +0 -33
  532. package/src/playground/layout/plugin.ts +0 -18
  533. package/src/playground/logger/Toolbar.tsx +0 -30
  534. package/src/playground/logger/plugin.ts +0 -41
  535. package/src/playground/logger/schema.ts +0 -12
  536. package/src/playground/playground.stories.tsx +0 -46
  537. package/src/plugin-intent/IntentPlugin.ts +0 -20
  538. package/src/plugin-intent/actions.ts +0 -31
  539. package/src/plugin-intent/errors.ts +0 -40
  540. package/src/plugin-intent/index.ts +0 -9
  541. package/src/plugin-intent/intent-dispatcher.test.ts +0 -286
  542. package/src/plugin-intent/intent-dispatcher.ts +0 -342
  543. package/src/plugin-intent/intent.ts +0 -154
  544. package/src/plugin-intent/meta.ts +0 -10
  545. package/src/plugin-settings/SettingsPlugin.ts +0 -34
  546. package/src/plugin-settings/actions.ts +0 -25
  547. package/src/plugin-settings/app-graph-builder.ts +0 -160
  548. package/src/plugin-settings/index.ts +0 -6
  549. package/src/plugin-settings/intent-resolver.ts +0 -35
  550. package/src/plugin-settings/meta.ts +0 -10
  551. package/src/plugin-settings/store.ts +0 -33
  552. package/src/plugin-settings/translations.ts +0 -19
  553. package/src/react/App.stories.tsx +0 -33
  554. package/src/react/App.tsx +0 -59
  555. package/src/react/DefaultFallback.tsx +0 -26
  556. package/src/react/ErrorBoundary.tsx +0 -56
  557. package/src/react/IntentContext.tsx +0 -35
  558. package/src/react/Surface.stories.tsx +0 -125
  559. package/src/react/Surface.tsx +0 -109
  560. package/src/react/common.ts +0 -13
  561. package/src/react/index.ts +0 -14
  562. package/src/react/types.ts +0 -38
  563. package/src/react/useApp.tsx +0 -165
  564. package/src/react/useCapabilities.ts +0 -31
  565. package/src/react/useIntentResolver.ts +0 -22
  566. /package/dist/lib/browser/{intent-dispatcher-LZ4AE66E.mjs.map → chunk-J5LGTIGS.mjs.map} +0 -0
  567. /package/dist/lib/browser/{react/index.mjs.map → common/activation-events.mjs.map} +0 -0
  568. /package/dist/lib/{node-esm/intent-dispatcher-MGOJ3CHD.mjs.map → browser/common/capabilities.mjs.map} +0 -0
  569. /package/dist/lib/{node-esm/react/index.mjs.map → browser/core/activation-event.mjs.map} +0 -0
@@ -1,604 +0,0 @@
1
- //
2
- // Copyright 2025 DXOS.org
3
- //
4
-
5
- import { Registry } from '@effect-atom/atom-react';
6
- import { untracked } from '@preact/signals-core';
7
- import * as Array from 'effect/Array';
8
- import * as Duration from 'effect/Duration';
9
- import * as Effect from 'effect/Effect';
10
- import * as Fiber from 'effect/Fiber';
11
- import * as Function from 'effect/Function';
12
- import * as HashSet from 'effect/HashSet';
13
- import * as Match from 'effect/Match';
14
- import * as Ref from 'effect/Ref';
15
-
16
- import { Event } from '@dxos/async';
17
- import { type Live, live } from '@dxos/live-object';
18
- import { log } from '@dxos/log';
19
- import { type MaybePromise } from '@dxos/util';
20
-
21
- import { type AnyCapability, PluginContext } from './capabilities';
22
- import { type ActivationEvent, eventKey, getEvents, isAllOf } from './events';
23
- import { type Plugin, type PluginModule } from './plugin';
24
-
25
- // TODO(wittjosiah): Factor out?
26
- const isPromise = (value: unknown): value is Promise<unknown> => {
27
- return value !== null && typeof value === 'object' && 'then' in value;
28
- };
29
-
30
- export type PluginManagerOptions = {
31
- pluginLoader: (id: string) => MaybePromise<Plugin>;
32
- plugins?: Plugin[];
33
- core?: string[];
34
- enabled?: string[];
35
- registry?: Registry.Registry;
36
- };
37
-
38
- type PluginManagerState = {
39
- // Plugins
40
- plugins: Plugin[];
41
- core: string[];
42
- enabled: string[];
43
-
44
- // Modules
45
- modules: PluginModule[];
46
- active: string[];
47
-
48
- // Events
49
- eventsFired: string[];
50
- pendingReset: string[];
51
- };
52
-
53
- export class PluginManager {
54
- readonly activation = new Event<{ event: string; state: 'activating' | 'activated' | 'error'; error?: any }>();
55
- readonly context: PluginContext;
56
- readonly registry: Registry.Registry;
57
-
58
- // TODO(wittjosiah): Replace with Atom.
59
- private readonly _state: Live<PluginManagerState>;
60
- private readonly _pluginLoader: PluginManagerOptions['pluginLoader'];
61
- private readonly _capabilities = new Map<string, AnyCapability[]>();
62
- private readonly _moduleMemoMap = new Map<PluginModule['id'], Promise<AnyCapability[]>>();
63
- private readonly _activatingEvents = Effect.runSync(Ref.make<string[]>([]));
64
- private readonly _activatingModules = Effect.runSync(Ref.make<string[]>([]));
65
-
66
- constructor({
67
- pluginLoader,
68
- plugins = [],
69
- core = plugins.map(({ meta }) => meta.id),
70
- enabled = [],
71
- registry,
72
- }: PluginManagerOptions) {
73
- this.registry = registry ?? Registry.make();
74
- this.context = new PluginContext({
75
- registry: this.registry,
76
- activate: (event) => this._activate(event),
77
- reset: (id) => this._reset(id),
78
- });
79
-
80
- this._pluginLoader = pluginLoader;
81
- this._state = live({
82
- plugins,
83
- core,
84
- enabled,
85
- modules: [],
86
- active: [],
87
- eventsFired: [],
88
- pendingReset: [],
89
- });
90
- plugins.forEach((plugin) => this._addPlugin(plugin));
91
- core.forEach((id) => this.enable(id));
92
- enabled.forEach((id) => this.enable(id));
93
- }
94
-
95
- /**
96
- * Plugins that are currently registered.
97
- *
98
- * @reactive
99
- */
100
- get plugins(): Live<readonly Plugin[]> {
101
- return this._state.plugins;
102
- }
103
-
104
- /**
105
- * Ids of plugins that are core and cannot be removed.
106
- *
107
- * @reactive
108
- */
109
- get core(): Live<readonly string[]> {
110
- return this._state.core;
111
- }
112
-
113
- /**
114
- * Ids of plugins that are currently enabled.
115
- *
116
- * @reactive
117
- */
118
- get enabled(): Live<readonly string[]> {
119
- return this._state.enabled;
120
- }
121
-
122
- /**
123
- * Modules of plugins which are currently enabled.
124
- *
125
- * @reactive
126
- */
127
- get modules(): Live<readonly PluginModule[]> {
128
- return this._state.modules;
129
- }
130
-
131
- /**
132
- * Ids of modules which are currently active.
133
- *
134
- * @reactive
135
- */
136
- get active(): Live<readonly string[]> {
137
- return this._state.active;
138
- }
139
-
140
- /**
141
- * Ids of events which have been fired.
142
- *
143
- * @reactive
144
- */
145
- get eventsFired(): Live<readonly string[]> {
146
- return this._state.eventsFired;
147
- }
148
-
149
- /**
150
- * Ids of modules which are pending reset.
151
- *
152
- * @reactive
153
- */
154
- get pendingReset(): Live<readonly string[]> {
155
- return this._state.pendingReset;
156
- }
157
-
158
- /**
159
- * Adds a plugin to the manager via the plugin loader.
160
- * @param id The id of the plugin.
161
- */
162
- async add(id: string): Promise<boolean> {
163
- return untracked(async () => {
164
- log('add plugin', { id });
165
- const plugin = await this._pluginLoader(id);
166
- this._addPlugin(plugin);
167
- return this.enable(id);
168
- });
169
- }
170
-
171
- /**
172
- * Enables a plugin.
173
- * @param id The id of the plugin.
174
- */
175
- enable(id: string): Promise<boolean> {
176
- return untracked(async () => {
177
- log('enable plugin', { id });
178
- const plugin = this._getPlugin(id);
179
- if (!plugin) {
180
- return false;
181
- }
182
-
183
- if (!this._state.enabled.includes(id)) {
184
- this._state.enabled.push(id);
185
- }
186
-
187
- plugin.modules.forEach((module) => {
188
- this._addModule(module);
189
- this._setPendingResetByModule(module);
190
- });
191
-
192
- log('pending reset', { events: [...this.pendingReset] });
193
- await Effect.runPromise(
194
- Effect.all(
195
- this.pendingReset.map((event) => this._activate(event)),
196
- { concurrency: 'unbounded' },
197
- ),
198
- );
199
-
200
- return true;
201
- });
202
- }
203
-
204
- /**
205
- * Removes a plugin from the manager.
206
- * @param id The id of the plugin.
207
- */
208
- remove(id: string): boolean {
209
- return untracked(() => {
210
- log('remove plugin', { id });
211
- const result = this.disable(id);
212
- if (!result) {
213
- return false;
214
- }
215
-
216
- this._removePlugin(id);
217
- return true;
218
- });
219
- }
220
-
221
- /**
222
- * Disables a plugin.
223
- * @param id The id of the plugin.
224
- */
225
- disable(id: string): Promise<boolean> {
226
- return untracked(async () => {
227
- log('disable plugin', { id });
228
- if (this._state.core.includes(id)) {
229
- return false;
230
- }
231
-
232
- const plugin = this._getPlugin(id);
233
- if (!plugin) {
234
- return false;
235
- }
236
-
237
- const enabledIndex = this._state.enabled.findIndex((enabled) => enabled === id);
238
- if (enabledIndex !== -1) {
239
- this._state.enabled.splice(enabledIndex, 1);
240
- await Effect.runPromise(this._deactivate(id));
241
-
242
- plugin.modules.forEach((module) => {
243
- this._removeModule(module.id);
244
- });
245
- }
246
-
247
- return true;
248
- });
249
- }
250
-
251
- /**
252
- * Activates plugins based on the activation event.
253
- * @param event The activation event.
254
- * @returns Whether the activation was successful.
255
- */
256
- activate(event: ActivationEvent | string): Promise<boolean> {
257
- return untracked(() => Effect.runPromise(this._activate(event)));
258
- }
259
-
260
- /**
261
- * Deactivates all of the modules for a plugin.
262
- * @param id The id of the plugin.
263
- * @returns Whether the deactivation was successful.
264
- */
265
- deactivate(id: string): Promise<boolean> {
266
- return untracked(() => Effect.runPromise(this._deactivate(id)));
267
- }
268
-
269
- /**
270
- * Re-activates the modules that were activated by the event.
271
- * @param event The activation event.
272
- * @returns Whether the reset was successful.
273
- */
274
- reset(event: ActivationEvent | string): Promise<boolean> {
275
- return untracked(() => Effect.runPromise(this._reset(event)));
276
- }
277
-
278
- private _addPlugin(plugin: Plugin): void {
279
- untracked(() => {
280
- log('add plugin', { id: plugin.meta.id });
281
- // TODO(wittjosiah): Find a way to add a warning for duplicate plugins that doesn't cause log spam.
282
- if (!this._state.plugins.includes(plugin)) {
283
- this._state.plugins.push(plugin);
284
- }
285
- });
286
- }
287
-
288
- private _removePlugin(id: string): void {
289
- untracked(() => {
290
- log('remove plugin', { id });
291
- const pluginIndex = this._state.plugins.findIndex((plugin) => plugin.meta.id === id);
292
- if (pluginIndex !== -1) {
293
- this._state.plugins.splice(pluginIndex, 1);
294
- }
295
- });
296
- }
297
-
298
- private _addModule(module: PluginModule): void {
299
- untracked(() => {
300
- log('add module', { id: module.id });
301
- // TODO(wittjosiah): Find a way to add a warning for duplicate modules that doesn't cause log spam.
302
- if (!this._state.modules.includes(module)) {
303
- this._state.modules.push(module);
304
- }
305
- });
306
- }
307
-
308
- private _removeModule(id: string): void {
309
- untracked(() => {
310
- log('remove module', { id });
311
- const moduleIndex = this._state.modules.findIndex((module) => module.id === id);
312
- if (moduleIndex !== -1) {
313
- this._state.modules.splice(moduleIndex, 1);
314
- }
315
- });
316
- }
317
-
318
- private _getPlugin(id: string): Plugin | undefined {
319
- return this._state.plugins.find((plugin) => plugin.meta.id === id);
320
- }
321
-
322
- private _getActiveModules(): PluginModule[] {
323
- return this._state.modules.filter((module) => this._state.active.includes(module.id));
324
- }
325
-
326
- private _getInactiveModules(): PluginModule[] {
327
- return this._state.modules.filter((module) => !this._state.active.includes(module.id));
328
- }
329
-
330
- private _getActiveModulesByEvent(key: string): PluginModule[] {
331
- return this._getActiveModules().filter((module) => getEvents(module.activatesOn).map(eventKey).includes(key));
332
- }
333
-
334
- private _getInactiveModulesByEvent(key: string): PluginModule[] {
335
- return this._getInactiveModules().filter((module) => getEvents(module.activatesOn).map(eventKey).includes(key));
336
- }
337
-
338
- private _setPendingResetByModule(module: PluginModule): void {
339
- return untracked(() => {
340
- const activationEvents = getEvents(module.activatesOn)
341
- .map(eventKey)
342
- .filter((key) => this._state.eventsFired.includes(key));
343
-
344
- const pendingReset = Array.fromIterable(new Set(activationEvents)).filter(
345
- (event) => !this._state.pendingReset.includes(event),
346
- );
347
- if (pendingReset.length > 0) {
348
- log('pending reset', { events: pendingReset });
349
- this._state.pendingReset.push(...pendingReset);
350
- }
351
- });
352
- }
353
-
354
- /**
355
- * @internal
356
- */
357
- // TODO(wittjosiah): Improve error typing.
358
- _activate(
359
- event: ActivationEvent | string,
360
- params?: { before?: string; after?: string },
361
- ): Effect.Effect<boolean, Error> {
362
- return Effect.gen(this, function* () {
363
- const key = typeof event === 'string' ? event : eventKey(event);
364
- log('activating', { key, ...params });
365
- yield* Ref.update(this._activatingEvents, (activating) => Array.append(activating, key));
366
- const pendingIndex = this._state.pendingReset.findIndex((event) => event === key);
367
- if (pendingIndex !== -1) {
368
- this._state.pendingReset.splice(pendingIndex, 1);
369
- }
370
-
371
- const activatingEvents = yield* this._activatingEvents;
372
- const activatingModules = yield* this._activatingModules;
373
- const modules = this._getInactiveModulesByEvent(key).filter((module) => {
374
- const allOf = isAllOf(module.activatesOn);
375
- if (!allOf) {
376
- return true;
377
- }
378
-
379
- // Check to see if all of the events in the `allOf` have been fired.
380
- // An event can be considered "fired" if it is in the `eventsFired` list or if it is currently being activated.
381
- const events = module.activatesOn.events.filter((event) => eventKey(event) !== key);
382
- return (
383
- events.every(
384
- (event) => this._state.eventsFired.includes(eventKey(event)) || activatingEvents.includes(eventKey(event)),
385
- ) && !activatingModules.includes(module.id)
386
- );
387
- });
388
- yield* Ref.update(this._activatingModules, (activating) =>
389
- Array.appendAll(
390
- activating,
391
- modules.map((module) => module.id),
392
- ),
393
- );
394
- if (modules.length === 0) {
395
- log('no modules to activate', { key });
396
- if (!this._state.eventsFired.includes(key)) {
397
- this._state.eventsFired.push(key);
398
- }
399
- return false;
400
- }
401
-
402
- log('activating modules', { key, modules: modules.map((module) => module.id) });
403
- this.activation.emit({ event: key, state: 'activating' });
404
-
405
- // Fire activatesBefore events.
406
- yield* Function.pipe(
407
- modules,
408
- Array.flatMap((module) => module.activatesBefore ?? []),
409
- HashSet.fromIterable,
410
- HashSet.toValues,
411
- Array.filter((event) => !activatingEvents.includes(eventKey(event))),
412
- Array.map((event) => this._activate(event, { before: key })),
413
- Effect.allWith({ concurrency: 'unbounded' }),
414
- );
415
-
416
- // Concurrently triggers loading of lazy capabilities.
417
- const getCapabilities = yield* Function.pipe(
418
- modules,
419
- Array.map((mod) => this._loadModule(mod)),
420
- Effect.allWith({ concurrency: 'unbounded' }),
421
- Effect.catchAll((error) => {
422
- this.activation.emit({ event: key, state: 'error', error });
423
- return Effect.fail(error);
424
- }),
425
- );
426
-
427
- // Contribute the capabilities from the activated modules.
428
- yield* Function.pipe(
429
- modules,
430
- Array.zip(getCapabilities),
431
- Array.map(([module, capabilities]) => this._contributeCapabilities(module, capabilities)),
432
- // TODO(wittjosiah): This currently can't be run in parallel.
433
- // Running this with concurrency causes races with `allOf` activation events.
434
- Effect.all,
435
- );
436
-
437
- // Fire activatesAfter events.
438
- yield* Function.pipe(
439
- modules,
440
- Array.flatMap((module) => module.activatesAfter ?? []),
441
- HashSet.fromIterable,
442
- HashSet.toValues,
443
- Array.filter((event) => !activatingEvents.includes(eventKey(event))),
444
- Array.map((event) => this._activate(event, { after: key })),
445
- Effect.allWith({ concurrency: 'unbounded' }),
446
- );
447
-
448
- yield* Ref.update(this._activatingEvents, (activating) => Array.filter(activating, (event) => event !== key));
449
- yield* Ref.update(this._activatingModules, (activating) =>
450
- Array.filter(activating, (module) => !modules.map((module) => module.id).includes(module)),
451
- );
452
-
453
- if (!this._state.eventsFired.includes(key)) {
454
- this._state.eventsFired.push(key);
455
- }
456
-
457
- this.activation.emit({ event: key, state: 'activated' });
458
- log('activated', { key });
459
-
460
- return true;
461
- });
462
- }
463
-
464
- // Memoized with _moduleMemoMap
465
- private _loadModule = (mod: PluginModule): Effect.Effect<AnyCapability[], Error> =>
466
- Effect.tryPromise({
467
- try: async () => {
468
- const entry = this._moduleMemoMap.get(mod.id);
469
- if (entry) {
470
- return entry;
471
- }
472
-
473
- const promise = (async () => {
474
- const start = performance.now();
475
- let failed = false;
476
- try {
477
- log('loading module', { module: mod.id });
478
- // TODO(wittjosiah): Support activation with an effect.
479
- let activationResult = await mod.activate(this.context);
480
- if (typeof activationResult === 'function') {
481
- activationResult = await activationResult();
482
- }
483
- return Array.isArray(activationResult) ? activationResult : [activationResult];
484
- } catch (error) {
485
- failed = true;
486
- throw error;
487
- } finally {
488
- performance.measure('activate-module', {
489
- start,
490
- end: performance.now(),
491
- detail: {
492
- module: mod.id,
493
- },
494
- });
495
- log('loaded module', { module: mod.id, elapsed: performance.now() - start, failed });
496
- }
497
- })();
498
- this._moduleMemoMap.set(mod.id, promise);
499
- return promise;
500
- },
501
- catch: (error) => error as Error,
502
- }).pipe(
503
- Effect.withSpan('PluginManager._loadModule'),
504
- together(
505
- Effect.sleep(Duration.seconds(10)).pipe(
506
- Effect.andThen(Effect.sync(() => log.warn(`module is taking a long time to activate`, { module: mod.id }))),
507
- ),
508
- ),
509
- );
510
-
511
- private _contributeCapabilities(module: PluginModule, capabilities: AnyCapability[]): Effect.Effect<void, Error> {
512
- return Effect.gen(this, function* () {
513
- capabilities.forEach((capability) => {
514
- this.context.contributeCapability({ module: module.id, ...capability });
515
- });
516
- this._state.active.push(module.id);
517
- this._capabilities.set(module.id, capabilities);
518
- });
519
- }
520
-
521
- private _deactivate(id: string): Effect.Effect<boolean, Error> {
522
- return Effect.gen(this, function* () {
523
- const plugin = this._getPlugin(id);
524
- if (!plugin) {
525
- return false;
526
- }
527
-
528
- const modules = plugin.modules;
529
- const results = yield* Effect.all(
530
- modules.map((module) => this._deactivateModule(module)),
531
- { concurrency: 'unbounded' },
532
- );
533
- return results.every((result) => result);
534
- });
535
- }
536
-
537
- private _deactivateModule(module: PluginModule): Effect.Effect<boolean, Error> {
538
- return Effect.gen(this, function* () {
539
- const id = module.id;
540
- log('deactivating', { id });
541
- this._moduleMemoMap.delete(id);
542
-
543
- const capabilities = this._capabilities.get(id);
544
- if (capabilities) {
545
- for (const capability of capabilities) {
546
- this.context.removeCapability(capability.interface, capability.implementation);
547
- const program = capability.deactivate?.();
548
- yield* Match.value(program).pipe(
549
- Match.when(Effect.isEffect, (effect) => effect),
550
- Match.when(isPromise, (promise) =>
551
- Effect.tryPromise({
552
- try: () => promise,
553
- catch: (error) => error as Error,
554
- }),
555
- ),
556
- Match.orElse((program) => Effect.succeed(program)),
557
- );
558
- }
559
- this._capabilities.delete(id);
560
- }
561
-
562
- const activeIndex = this._state.active.findIndex((event) => event === id);
563
- if (activeIndex !== -1) {
564
- this._state.active.splice(activeIndex, 1);
565
- }
566
-
567
- log('deactivated', { id });
568
- return true;
569
- });
570
- }
571
-
572
- private _reset(event: ActivationEvent | string): Effect.Effect<boolean, Error> {
573
- return Effect.gen(this, function* () {
574
- const key = typeof event === 'string' ? event : eventKey(event);
575
- log('reset', { key });
576
- const modules = this._getActiveModulesByEvent(key);
577
- const results = yield* Effect.all(
578
- modules.map((module) => this._deactivateModule(module)),
579
- { concurrency: 'unbounded' },
580
- );
581
-
582
- if (results.every((result) => result)) {
583
- return yield* this._activate(key);
584
- } else {
585
- return false;
586
- }
587
- });
588
- }
589
- }
590
-
591
- /**
592
- * Runs an effect concurrently with another effect.
593
- * If the first effect completes, the second effect is interrupted.
594
- */
595
- // TODO(dmaretskyi): Effect.race > Effect.asVoid
596
- const together =
597
- <R1>(togetherEffect: Effect.Effect<void, never, R1>) =>
598
- <A, E, R2>(effect: Effect.Effect<A, E, R2>): Effect.Effect<A, E, R1 | R2> =>
599
- Effect.gen(function* () {
600
- const togetherFiber = yield* Effect.fork(togetherEffect);
601
- const result = yield* effect;
602
- yield* Fiber.interrupt(togetherFiber);
603
- return result;
604
- });
@@ -1,39 +0,0 @@
1
- //
2
- // Copyright 2025 DXOS.org
3
- //
4
-
5
- import React from 'react';
6
-
7
- import { SyntaxHighlighter } from '@dxos/react-ui-syntax-highlighter';
8
-
9
- import { Capabilities, createSurface } from '../../common';
10
- import { contributes } from '../../core';
11
- import { usePluginManager } from '../../react';
12
-
13
- export const Debug = () => {
14
- const manager = usePluginManager();
15
-
16
- const object = {
17
- core: manager.core,
18
- enabled: manager.enabled,
19
- active: manager.active,
20
- pendingReset: manager.pendingReset,
21
- eventsFired: manager.eventsFired,
22
- };
23
-
24
- return (
25
- <SyntaxHighlighter language='json' classNames='text-xs opacity-75 rounded'>
26
- {JSON.stringify(object, undefined, 2)}
27
- </SyntaxHighlighter>
28
- );
29
- };
30
-
31
- export default () =>
32
- contributes(
33
- Capabilities.ReactSurface,
34
- createSurface({
35
- id: 'dxos.org/test/debug/main',
36
- role: 'secondary',
37
- component: Debug,
38
- }),
39
- );
@@ -1,16 +0,0 @@
1
- //
2
- // Copyright 2025 DXOS.org
3
- //
4
-
5
- import { Events } from '../../common';
6
- import { defineModule, definePlugin, lazy } from '../../core';
7
-
8
- const Debug = lazy(() => import('./Debug'));
9
-
10
- export const DebugPlugin = definePlugin({ id: 'dxos.org/test/plugin-debug', name: 'Debug' }, () => [
11
- defineModule({
12
- id: 'dxos.org/test/debug/main',
13
- activatesOn: Events.Startup,
14
- activate: Debug,
15
- }),
16
- ]);