@dxos/app-framework 0.8.4-main.a4bbb77 → 0.8.4-main.abd8ff62ef

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