@dxos/app-framework 0.8.4-main.f9ba587 → 0.8.4-main.fcfe5033a5

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 (701) hide show
  1. package/.storybook/main.mts +9 -0
  2. package/.storybook/preview.mts +8 -0
  3. package/.swc/plugins/linux_x86_64_19.0.0/727453fb3a62f7f1d952a41e051ca8a6f88cadc45cee43c6a4d1aa45f9b75665.wasmer-v7 +0 -0
  4. package/dist/lib/browser/capability-EYY7KYU5.mjs +35 -0
  5. package/dist/lib/browser/capability-EYY7KYU5.mjs.map +7 -0
  6. package/dist/lib/browser/capability-W7NPZR6A.mjs +38 -0
  7. package/dist/lib/browser/capability-W7NPZR6A.mjs.map +7 -0
  8. package/dist/lib/browser/chunk-2CKCJ6PN.mjs +79 -0
  9. package/dist/lib/browser/chunk-2CKCJ6PN.mjs.map +7 -0
  10. package/dist/lib/browser/chunk-4D6YAWLP.mjs +393 -0
  11. package/dist/lib/browser/chunk-4D6YAWLP.mjs.map +7 -0
  12. package/dist/lib/browser/chunk-56CEL32L.mjs +963 -0
  13. package/dist/lib/browser/chunk-56CEL32L.mjs.map +7 -0
  14. package/dist/lib/browser/chunk-F7FW2RK2.mjs +167 -0
  15. package/dist/lib/browser/chunk-F7FW2RK2.mjs.map +7 -0
  16. package/dist/lib/browser/chunk-I34GF4NG.mjs +34 -0
  17. package/dist/lib/browser/chunk-I34GF4NG.mjs.map +7 -0
  18. package/dist/lib/browser/chunk-J5LGTIGS.mjs +10 -0
  19. package/dist/lib/browser/chunk-JKWMHZP6.mjs +80 -0
  20. package/dist/lib/browser/chunk-JKWMHZP6.mjs.map +7 -0
  21. package/dist/lib/browser/chunk-QRTB4Q3U.mjs +594 -0
  22. package/dist/lib/browser/chunk-QRTB4Q3U.mjs.map +7 -0
  23. package/dist/lib/browser/chunk-QSXYHXCE.mjs +48 -0
  24. package/dist/lib/browser/chunk-QSXYHXCE.mjs.map +7 -0
  25. package/dist/lib/browser/chunk-RFSO3JRG.mjs +1 -0
  26. package/dist/lib/browser/chunk-RHQGPRWN.mjs +174 -0
  27. package/dist/lib/browser/chunk-RHQGPRWN.mjs.map +7 -0
  28. package/dist/lib/browser/chunk-T3Y4AEKX.mjs +42 -0
  29. package/dist/lib/browser/chunk-T3Y4AEKX.mjs.map +7 -0
  30. package/dist/lib/browser/chunk-TGX63LTL.mjs +8 -0
  31. package/dist/lib/browser/chunk-TGX63LTL.mjs.map +7 -0
  32. package/dist/lib/browser/chunk-ZBA6IH6L.mjs +148 -0
  33. package/dist/lib/browser/chunk-ZBA6IH6L.mjs.map +7 -0
  34. package/dist/lib/browser/cli/index.mjs +90 -0
  35. package/dist/lib/browser/cli/index.mjs.map +7 -0
  36. package/dist/lib/browser/common/activation-events.mjs +24 -0
  37. package/dist/lib/browser/common/capabilities.mjs +46 -0
  38. package/dist/lib/browser/core/activation-event.mjs +20 -0
  39. package/dist/lib/browser/core/activation-event.mjs.map +7 -0
  40. package/dist/lib/browser/core/capability.mjs +30 -0
  41. package/dist/lib/browser/core/capability.mjs.map +7 -0
  42. package/dist/lib/browser/core/plugin-manager.mjs +15 -0
  43. package/dist/lib/browser/core/plugin-manager.mjs.map +7 -0
  44. package/dist/lib/browser/core/plugin.mjs +29 -0
  45. package/dist/lib/browser/core/plugin.mjs.map +7 -0
  46. package/dist/lib/browser/core/url-loader.mjs +16 -0
  47. package/dist/lib/browser/core/url-loader.mjs.map +7 -0
  48. package/dist/lib/browser/index.mjs +91 -156
  49. package/dist/lib/browser/index.mjs.map +4 -4
  50. package/dist/lib/browser/invoker-capability-35BJSGXJ.mjs +43 -0
  51. package/dist/lib/browser/invoker-capability-35BJSGXJ.mjs.map +7 -0
  52. package/dist/lib/browser/meta.json +1 -1
  53. package/dist/lib/browser/testing/index.mjs +248 -51
  54. package/dist/lib/browser/testing/index.mjs.map +4 -4
  55. package/dist/lib/browser/testing/react.mjs +78 -0
  56. package/dist/lib/browser/testing/react.mjs.map +7 -0
  57. package/dist/lib/browser/ui/index.mjs +46 -0
  58. package/dist/lib/browser/ui/index.mjs.map +7 -0
  59. package/dist/lib/node-esm/capability-IY3YIHIO.mjs +39 -0
  60. package/dist/lib/node-esm/capability-IY3YIHIO.mjs.map +7 -0
  61. package/dist/lib/node-esm/capability-RDCTCARS.mjs +36 -0
  62. package/dist/lib/node-esm/capability-RDCTCARS.mjs.map +7 -0
  63. package/dist/lib/node-esm/chunk-42KBWDE4.mjs +80 -0
  64. package/dist/lib/node-esm/chunk-42KBWDE4.mjs.map +7 -0
  65. package/dist/lib/node-esm/chunk-DAYWQOOQ.mjs +149 -0
  66. package/dist/lib/node-esm/chunk-DAYWQOOQ.mjs.map +7 -0
  67. package/dist/lib/node-esm/chunk-DER2JDBT.mjs +175 -0
  68. package/dist/lib/node-esm/chunk-DER2JDBT.mjs.map +7 -0
  69. package/dist/lib/node-esm/chunk-EL3R25OQ.mjs +2 -0
  70. package/dist/lib/node-esm/chunk-EL3R25OQ.mjs.map +7 -0
  71. package/dist/lib/node-esm/chunk-FKE4Z3D6.mjs +10 -0
  72. package/dist/lib/node-esm/chunk-FKE4Z3D6.mjs.map +7 -0
  73. package/dist/lib/node-esm/chunk-G3RTFSNG.mjs +81 -0
  74. package/dist/lib/node-esm/chunk-G3RTFSNG.mjs.map +7 -0
  75. package/dist/lib/node-esm/chunk-HSLMI22Q.mjs +11 -0
  76. package/dist/lib/node-esm/chunk-HSLMI22Q.mjs.map +7 -0
  77. package/dist/lib/node-esm/chunk-JPWVIQ5I.mjs +595 -0
  78. package/dist/lib/node-esm/chunk-JPWVIQ5I.mjs.map +7 -0
  79. package/dist/lib/node-esm/chunk-LX6YJOSO.mjs +394 -0
  80. package/dist/lib/node-esm/chunk-LX6YJOSO.mjs.map +7 -0
  81. package/dist/lib/node-esm/chunk-URWHJQT2.mjs +168 -0
  82. package/dist/lib/node-esm/chunk-URWHJQT2.mjs.map +7 -0
  83. package/dist/lib/node-esm/chunk-VKHGNEDB.mjs +43 -0
  84. package/dist/lib/node-esm/chunk-VKHGNEDB.mjs.map +7 -0
  85. package/dist/lib/node-esm/chunk-W4K4RU4S.mjs +964 -0
  86. package/dist/lib/node-esm/chunk-W4K4RU4S.mjs.map +7 -0
  87. package/dist/lib/node-esm/chunk-WZCSOX5Q.mjs +35 -0
  88. package/dist/lib/node-esm/chunk-WZCSOX5Q.mjs.map +7 -0
  89. package/dist/lib/node-esm/chunk-ZZ7CKK6W.mjs +49 -0
  90. package/dist/lib/node-esm/chunk-ZZ7CKK6W.mjs.map +7 -0
  91. package/dist/lib/node-esm/cli/index.mjs +91 -0
  92. package/dist/lib/node-esm/cli/index.mjs.map +7 -0
  93. package/dist/lib/node-esm/common/activation-events.mjs +25 -0
  94. package/dist/lib/node-esm/common/activation-events.mjs.map +7 -0
  95. package/dist/lib/node-esm/common/capabilities.mjs +47 -0
  96. package/dist/lib/node-esm/common/capabilities.mjs.map +7 -0
  97. package/dist/lib/node-esm/core/activation-event.mjs +21 -0
  98. package/dist/lib/node-esm/core/activation-event.mjs.map +7 -0
  99. package/dist/lib/node-esm/core/capability.mjs +31 -0
  100. package/dist/lib/node-esm/core/capability.mjs.map +7 -0
  101. package/dist/lib/node-esm/core/plugin-manager.mjs +16 -0
  102. package/dist/lib/node-esm/core/plugin-manager.mjs.map +7 -0
  103. package/dist/lib/node-esm/core/plugin.mjs +30 -0
  104. package/dist/lib/node-esm/core/plugin.mjs.map +7 -0
  105. package/dist/lib/node-esm/core/url-loader.mjs +17 -0
  106. package/dist/lib/node-esm/core/url-loader.mjs.map +7 -0
  107. package/dist/lib/node-esm/index.mjs +91 -156
  108. package/dist/lib/node-esm/index.mjs.map +4 -4
  109. package/dist/lib/node-esm/invoker-capability-3QWBSM5Q.mjs +44 -0
  110. package/dist/lib/node-esm/invoker-capability-3QWBSM5Q.mjs.map +7 -0
  111. package/dist/lib/node-esm/meta.json +1 -1
  112. package/dist/lib/node-esm/testing/index.mjs +248 -51
  113. package/dist/lib/node-esm/testing/index.mjs.map +4 -4
  114. package/dist/lib/node-esm/testing/react.mjs +79 -0
  115. package/dist/lib/node-esm/testing/react.mjs.map +7 -0
  116. package/dist/lib/node-esm/ui/index.mjs +47 -0
  117. package/dist/lib/node-esm/ui/index.mjs.map +7 -0
  118. package/dist/plugin/node-esm/index.mjs +730 -0
  119. package/dist/plugin/node-esm/index.mjs.map +7 -0
  120. package/dist/plugin/node-esm/meta.json +1 -0
  121. package/dist/types/src/cli/cli.d.ts +39 -0
  122. package/dist/types/src/cli/cli.d.ts.map +1 -0
  123. package/dist/types/src/cli/index.d.ts +2 -0
  124. package/dist/types/src/cli/index.d.ts.map +1 -0
  125. package/dist/types/src/common/activation-events.d.ts +27 -0
  126. package/dist/types/src/common/activation-events.d.ts.map +1 -0
  127. package/dist/types/src/common/capabilities.d.ts +109 -121
  128. package/dist/types/src/common/capabilities.d.ts.map +1 -1
  129. package/dist/types/src/common/index.d.ts +4 -8
  130. package/dist/types/src/common/index.d.ts.map +1 -1
  131. package/dist/types/src/common/operations.d.ts +19 -0
  132. package/dist/types/src/common/operations.d.ts.map +1 -0
  133. package/dist/types/src/common/translations.d.ts +8 -8
  134. package/dist/types/src/common/translations.d.ts.map +1 -1
  135. package/dist/types/src/context.d.ts +5 -0
  136. package/dist/types/src/context.d.ts.map +1 -0
  137. package/dist/types/src/core/{events.d.ts → activation-event.d.ts} +7 -7
  138. package/dist/types/src/core/activation-event.d.ts.map +1 -0
  139. package/dist/types/src/core/capability-manager.d.ts +48 -0
  140. package/dist/types/src/core/capability-manager.d.ts.map +1 -0
  141. package/dist/types/src/core/capability-manager.test.d.ts +2 -0
  142. package/dist/types/src/core/capability-manager.test.d.ts.map +1 -0
  143. package/dist/types/src/core/capability.d.ts +156 -0
  144. package/dist/types/src/core/capability.d.ts.map +1 -0
  145. package/dist/types/src/core/index.d.ts +6 -4
  146. package/dist/types/src/core/index.d.ts.map +1 -1
  147. package/dist/types/src/core/plugin-manager.d.ts +73 -0
  148. package/dist/types/src/core/plugin-manager.d.ts.map +1 -0
  149. package/dist/types/src/core/plugin-manager.test.d.ts +2 -0
  150. package/dist/types/src/core/plugin-manager.test.d.ts.map +1 -0
  151. package/dist/types/src/core/plugin.d.ts +124 -37
  152. package/dist/types/src/core/plugin.d.ts.map +1 -1
  153. package/dist/types/src/core/url-loader.d.ts +42 -0
  154. package/dist/types/src/core/url-loader.d.ts.map +1 -0
  155. package/dist/types/src/core/url-loader.test.d.ts +2 -0
  156. package/dist/types/src/core/url-loader.test.d.ts.map +1 -0
  157. package/dist/types/src/index.d.ts +3 -4
  158. package/dist/types/src/index.d.ts.map +1 -1
  159. package/dist/types/src/plugin-operation/OperationPlugin.d.ts +3 -0
  160. package/dist/types/src/plugin-operation/OperationPlugin.d.ts.map +1 -0
  161. package/dist/types/src/plugin-operation/history/capability.d.ts +7 -0
  162. package/dist/types/src/plugin-operation/history/capability.d.ts.map +1 -0
  163. package/dist/types/src/plugin-operation/history/errors.d.ts +32 -0
  164. package/dist/types/src/plugin-operation/history/errors.d.ts.map +1 -0
  165. package/dist/types/src/plugin-operation/history/history-tracker.d.ts +18 -0
  166. package/dist/types/src/plugin-operation/history/history-tracker.d.ts.map +1 -0
  167. package/dist/types/src/plugin-operation/history/history-tracker.test.d.ts +2 -0
  168. package/dist/types/src/plugin-operation/history/history-tracker.test.d.ts.map +1 -0
  169. package/dist/types/src/plugin-operation/history/index.d.ts +6 -0
  170. package/dist/types/src/plugin-operation/history/index.d.ts.map +1 -0
  171. package/dist/types/src/plugin-operation/history/types.d.ts +13 -0
  172. package/dist/types/src/plugin-operation/history/types.d.ts.map +1 -0
  173. package/dist/types/src/plugin-operation/history/undo-mapping.d.ts +101 -0
  174. package/dist/types/src/plugin-operation/history/undo-mapping.d.ts.map +1 -0
  175. package/dist/types/src/plugin-operation/history/undo-registry.d.ts +23 -0
  176. package/dist/types/src/plugin-operation/history/undo-registry.d.ts.map +1 -0
  177. package/dist/types/src/plugin-operation/history/undo-registry.test.d.ts +2 -0
  178. package/dist/types/src/plugin-operation/history/undo-registry.test.d.ts.map +1 -0
  179. package/dist/types/src/plugin-operation/index.d.ts +3 -0
  180. package/dist/types/src/plugin-operation/index.d.ts.map +1 -0
  181. package/dist/types/src/plugin-operation/invoker-capability.d.ts +6 -0
  182. package/dist/types/src/plugin-operation/invoker-capability.d.ts.map +1 -0
  183. package/dist/types/src/plugin-operation/meta.d.ts +3 -0
  184. package/dist/types/src/plugin-operation/meta.d.ts.map +1 -0
  185. package/dist/types/src/plugin-operation/testing.d.ts +58 -0
  186. package/dist/types/src/plugin-operation/testing.d.ts.map +1 -0
  187. package/dist/types/src/plugin-runtime/RuntimePlugin.d.ts +3 -0
  188. package/dist/types/src/plugin-runtime/RuntimePlugin.d.ts.map +1 -0
  189. package/dist/types/src/plugin-runtime/capability.d.ts +6 -0
  190. package/dist/types/src/plugin-runtime/capability.d.ts.map +1 -0
  191. package/dist/types/src/plugin-runtime/index.d.ts +2 -0
  192. package/dist/types/src/plugin-runtime/index.d.ts.map +1 -0
  193. package/dist/types/src/plugin-runtime/meta.d.ts +3 -0
  194. package/dist/types/src/plugin-runtime/meta.d.ts.map +1 -0
  195. package/dist/types/src/testing/harness.d.ts +67 -0
  196. package/dist/types/src/testing/harness.d.ts.map +1 -0
  197. package/dist/types/src/testing/index.d.ts +2 -0
  198. package/dist/types/src/testing/index.d.ts.map +1 -1
  199. package/dist/types/src/testing/react.d.ts +27 -0
  200. package/dist/types/src/testing/react.d.ts.map +1 -0
  201. package/dist/types/src/testing/react.test.d.ts +2 -0
  202. package/dist/types/src/testing/react.test.d.ts.map +1 -0
  203. package/dist/types/src/testing/service.d.ts +8 -0
  204. package/dist/types/src/testing/service.d.ts.map +1 -0
  205. package/dist/types/src/testing/withPluginManager.d.ts +11 -10
  206. package/dist/types/src/testing/withPluginManager.d.ts.map +1 -1
  207. package/dist/types/src/testing/withPluginManager.stories.d.ts +9 -3
  208. package/dist/types/src/testing/withPluginManager.stories.d.ts.map +1 -1
  209. package/dist/types/src/ui/components/App/App.d.ts +9 -0
  210. package/dist/types/src/ui/components/App/App.d.ts.map +1 -0
  211. package/dist/types/src/ui/components/App/App.stories.d.ts +19 -0
  212. package/dist/types/src/ui/components/App/App.stories.d.ts.map +1 -0
  213. package/dist/types/src/ui/components/App/index.d.ts +2 -0
  214. package/dist/types/src/ui/components/App/index.d.ts.map +1 -0
  215. package/dist/types/src/ui/components/PluginManager/PluginManagerContext.stories.d.ts +13 -0
  216. package/dist/types/src/ui/components/PluginManager/PluginManagerContext.stories.d.ts.map +1 -0
  217. package/dist/types/src/ui/components/PluginManager/PluginManagerProvider.d.ts +10 -0
  218. package/dist/types/src/ui/components/PluginManager/PluginManagerProvider.d.ts.map +1 -0
  219. package/dist/types/src/ui/components/PluginManager/index.d.ts +2 -0
  220. package/dist/types/src/ui/components/PluginManager/index.d.ts.map +1 -0
  221. package/dist/types/src/ui/components/Surface/SurfaceComponent.d.ts +24 -0
  222. package/dist/types/src/ui/components/Surface/SurfaceComponent.d.ts.map +1 -0
  223. package/dist/types/src/ui/components/Surface/SurfaceComponent.stories.d.ts +14 -0
  224. package/dist/types/src/ui/components/Surface/SurfaceComponent.stories.d.ts.map +1 -0
  225. package/dist/types/src/ui/components/Surface/SurfaceInfo.d.ts +11 -0
  226. package/dist/types/src/ui/components/Surface/SurfaceInfo.d.ts.map +1 -0
  227. package/dist/types/src/ui/components/Surface/SurfaceProfilerContext.d.ts +48 -0
  228. package/dist/types/src/ui/components/Surface/SurfaceProfilerContext.d.ts.map +1 -0
  229. package/dist/types/src/ui/components/Surface/context.d.ts +5 -0
  230. package/dist/types/src/ui/components/Surface/context.d.ts.map +1 -0
  231. package/dist/types/src/ui/components/Surface/index.d.ts +36 -0
  232. package/dist/types/src/ui/components/Surface/index.d.ts.map +1 -0
  233. package/dist/types/src/ui/components/Surface/types.d.ts +197 -0
  234. package/dist/types/src/ui/components/Surface/types.d.ts.map +1 -0
  235. package/dist/types/src/ui/components/Surface/types.test.d.ts +2 -0
  236. package/dist/types/src/ui/components/Surface/types.test.d.ts.map +1 -0
  237. package/dist/types/src/ui/components/index.d.ts +4 -0
  238. package/dist/types/src/ui/components/index.d.ts.map +1 -0
  239. package/dist/types/src/ui/hooks/index.d.ts +6 -0
  240. package/dist/types/src/ui/hooks/index.d.ts.map +1 -0
  241. package/dist/types/src/ui/hooks/useApp.d.ts +62 -0
  242. package/dist/types/src/ui/hooks/useApp.d.ts.map +1 -0
  243. package/dist/types/src/ui/hooks/useApp.test.d.ts +2 -0
  244. package/dist/types/src/ui/hooks/useApp.test.d.ts.map +1 -0
  245. package/dist/types/src/ui/hooks/useCapabilities.d.ts +31 -0
  246. package/dist/types/src/ui/hooks/useCapabilities.d.ts.map +1 -0
  247. package/dist/types/src/ui/hooks/useLoading.d.ts +18 -0
  248. package/dist/types/src/ui/hooks/useLoading.d.ts.map +1 -0
  249. package/dist/types/src/ui/hooks/useSettingsState.d.ts +10 -0
  250. package/dist/types/src/ui/hooks/useSettingsState.d.ts.map +1 -0
  251. package/dist/types/src/ui/hooks/useSurface.d.ts +3 -0
  252. package/dist/types/src/ui/hooks/useSurface.d.ts.map +1 -0
  253. package/dist/types/src/ui/index.d.ts +3 -0
  254. package/dist/types/src/ui/index.d.ts.map +1 -0
  255. package/dist/types/src/vite-plugin/composer-plugin.d.ts +34 -0
  256. package/dist/types/src/vite-plugin/composer-plugin.d.ts.map +1 -0
  257. package/dist/types/src/vite-plugin/import-map-plugin.d.ts +16 -0
  258. package/dist/types/src/vite-plugin/import-map-plugin.d.ts.map +1 -0
  259. package/dist/types/src/vite-plugin/index.d.ts +4 -0
  260. package/dist/types/src/vite-plugin/index.d.ts.map +1 -0
  261. package/dist/types/src/vite-plugin/manifest.d.ts +16 -0
  262. package/dist/types/src/vite-plugin/manifest.d.ts.map +1 -0
  263. package/dist/types/src/vite-plugin/manifest.test.d.ts +2 -0
  264. package/dist/types/src/vite-plugin/manifest.test.d.ts.map +1 -0
  265. package/dist/types/src/vite-plugin/packages.d.ts +13 -0
  266. package/dist/types/src/vite-plugin/packages.d.ts.map +1 -0
  267. package/dist/types/tsconfig.tsbuildinfo +1 -1
  268. package/moon.yml +26 -3
  269. package/package.json +144 -44
  270. package/src/cli/cli.ts +107 -0
  271. package/src/{playground/layout → cli}/index.ts +1 -1
  272. package/src/common/activation-events.ts +44 -0
  273. package/src/common/capabilities.ts +168 -109
  274. package/src/common/index.ts +4 -8
  275. package/src/common/operations.ts +35 -0
  276. package/src/common/translations.ts +18 -10
  277. package/src/context.ts +9 -0
  278. package/src/core/{events.ts → activation-event.ts} +10 -7
  279. package/src/core/capability-manager.test.ts +151 -0
  280. package/src/core/capability-manager.ts +192 -0
  281. package/src/core/capability.ts +247 -0
  282. package/src/core/index.ts +6 -4
  283. package/src/core/plugin-manager.test.ts +1113 -0
  284. package/src/core/plugin-manager.ts +883 -0
  285. package/src/core/plugin.ts +261 -43
  286. package/src/core/url-loader.test.ts +112 -0
  287. package/src/core/url-loader.ts +178 -0
  288. package/src/helpers.test.ts +1 -1
  289. package/src/index.ts +3 -4
  290. package/src/plugin-operation/OperationPlugin.ts +24 -0
  291. package/src/plugin-operation/history/capability.ts +36 -0
  292. package/src/plugin-operation/history/errors.ts +7 -0
  293. package/src/plugin-operation/history/history-tracker.test.ts +373 -0
  294. package/src/plugin-operation/history/history-tracker.ts +128 -0
  295. package/src/plugin-operation/history/index.ts +9 -0
  296. package/src/plugin-operation/history/types.ts +17 -0
  297. package/src/plugin-operation/history/undo-mapping.ts +135 -0
  298. package/src/plugin-operation/history/undo-registry.test.ts +72 -0
  299. package/src/plugin-operation/history/undo-registry.ts +54 -0
  300. package/src/plugin-operation/index.ts +6 -0
  301. package/src/plugin-operation/invoker-capability.ts +54 -0
  302. package/src/plugin-operation/meta.ts +11 -0
  303. package/src/plugin-operation/testing.ts +154 -0
  304. package/src/plugin-runtime/RuntimePlugin.ts +19 -0
  305. package/src/plugin-runtime/capability.ts +53 -0
  306. package/src/{playground/debug → plugin-runtime}/index.ts +1 -1
  307. package/src/plugin-runtime/meta.ts +11 -0
  308. package/src/testing/harness.ts +229 -0
  309. package/src/testing/index.ts +2 -0
  310. package/src/testing/react.test.tsx +48 -0
  311. package/src/testing/react.tsx +113 -0
  312. package/src/testing/service.ts +52 -0
  313. package/src/testing/withPluginManager.stories.tsx +14 -11
  314. package/src/testing/withPluginManager.tsx +78 -54
  315. package/src/ui/components/App/App.stories.tsx +92 -0
  316. package/src/ui/components/App/App.tsx +58 -0
  317. package/src/{playground/logger → ui/components/App}/index.ts +1 -1
  318. package/src/ui/components/PluginManager/PluginManagerContext.stories.tsx +183 -0
  319. package/src/{react → ui/components/PluginManager}/PluginManagerProvider.ts +3 -3
  320. package/src/ui/components/PluginManager/index.ts +5 -0
  321. package/src/ui/components/Surface/SurfaceComponent.stories.tsx +144 -0
  322. package/src/ui/components/Surface/SurfaceComponent.tsx +303 -0
  323. package/src/ui/components/Surface/SurfaceInfo.tsx +107 -0
  324. package/src/ui/components/Surface/SurfaceProfilerContext.tsx +207 -0
  325. package/src/ui/components/Surface/context.ts +12 -0
  326. package/src/ui/components/Surface/index.ts +54 -0
  327. package/src/ui/components/Surface/types.test.ts +126 -0
  328. package/src/ui/components/Surface/types.ts +269 -0
  329. package/src/ui/components/index.ts +7 -0
  330. package/src/ui/hooks/index.ts +9 -0
  331. package/src/ui/hooks/useApp.test.tsx +159 -0
  332. package/src/ui/hooks/useApp.tsx +289 -0
  333. package/src/ui/hooks/useCapabilities.ts +67 -0
  334. package/src/ui/hooks/useLoading.tsx +68 -0
  335. package/src/ui/hooks/useSettingsState.ts +26 -0
  336. package/src/ui/hooks/useSurface.ts +13 -0
  337. package/src/ui/index.ts +6 -0
  338. package/src/vite-plugin/composer-plugin.ts +284 -0
  339. package/src/vite-plugin/import-map-plugin.ts +490 -0
  340. package/src/vite-plugin/index.ts +7 -0
  341. package/src/vite-plugin/manifest.test.ts +23 -0
  342. package/src/vite-plugin/manifest.ts +20 -0
  343. package/src/vite-plugin/packages.ts +181 -0
  344. package/tsconfig.json +15 -25
  345. package/tsconfig.node.json +2 -4
  346. package/typedoc.json +2 -4
  347. package/vitest.config.ts +8 -6
  348. package/.eslintrc.cjs +0 -9
  349. package/.swc/plugins/v7_linux_x86_64_13.0.0/f45bdff002284d9e8f9ef3f0be909de12da36c049cbcf261ac78fc00abb09a2d +0 -0
  350. package/.swc/plugins/v7_linux_x86_64_13.0.0/fce1bdb8e20a094e4af08bad09cc81497ed0e2e7c51223b07d371063cca18429 +0 -0
  351. package/dist/lib/browser/app-graph-builder-BGGXLD6T.mjs +0 -137
  352. package/dist/lib/browser/app-graph-builder-BGGXLD6T.mjs.map +0 -7
  353. package/dist/lib/browser/chunk-2636QSIK.mjs +0 -1518
  354. package/dist/lib/browser/chunk-2636QSIK.mjs.map +0 -7
  355. package/dist/lib/browser/chunk-DHZB7HG7.mjs +0 -413
  356. package/dist/lib/browser/chunk-DHZB7HG7.mjs.map +0 -7
  357. package/dist/lib/browser/chunk-ORWHM7CO.mjs +0 -32
  358. package/dist/lib/browser/chunk-ORWHM7CO.mjs.map +0 -7
  359. package/dist/lib/browser/intent-dispatcher-TWKB22NI.mjs +0 -11
  360. package/dist/lib/browser/intent-resolver-O67UANYP.mjs +0 -39
  361. package/dist/lib/browser/intent-resolver-O67UANYP.mjs.map +0 -7
  362. package/dist/lib/browser/store-LFKDWHUQ.mjs +0 -30
  363. package/dist/lib/browser/store-LFKDWHUQ.mjs.map +0 -7
  364. package/dist/lib/browser/worker.mjs +0 -79
  365. package/dist/lib/node-esm/app-graph-builder-QHIJUYYW.mjs +0 -138
  366. package/dist/lib/node-esm/app-graph-builder-QHIJUYYW.mjs.map +0 -7
  367. package/dist/lib/node-esm/chunk-NJAFK626.mjs +0 -414
  368. package/dist/lib/node-esm/chunk-NJAFK626.mjs.map +0 -7
  369. package/dist/lib/node-esm/chunk-UMZQERLE.mjs +0 -34
  370. package/dist/lib/node-esm/chunk-UMZQERLE.mjs.map +0 -7
  371. package/dist/lib/node-esm/chunk-VSKRV3NW.mjs +0 -1520
  372. package/dist/lib/node-esm/chunk-VSKRV3NW.mjs.map +0 -7
  373. package/dist/lib/node-esm/intent-dispatcher-5PRM3KGH.mjs +0 -12
  374. package/dist/lib/node-esm/intent-resolver-K3D4BXQQ.mjs +0 -40
  375. package/dist/lib/node-esm/intent-resolver-K3D4BXQQ.mjs.map +0 -7
  376. package/dist/lib/node-esm/store-53XDUBMD.mjs +0 -31
  377. package/dist/lib/node-esm/store-53XDUBMD.mjs.map +0 -7
  378. package/dist/lib/node-esm/worker.mjs +0 -80
  379. package/dist/types/src/App.d.ts +0 -43
  380. package/dist/types/src/App.d.ts.map +0 -1
  381. package/dist/types/src/common/collaboration.d.ts +0 -19
  382. package/dist/types/src/common/collaboration.d.ts.map +0 -1
  383. package/dist/types/src/common/events.d.ts +0 -52
  384. package/dist/types/src/common/events.d.ts.map +0 -1
  385. package/dist/types/src/common/file.d.ts +0 -14
  386. package/dist/types/src/common/file.d.ts.map +0 -1
  387. package/dist/types/src/common/graph.d.ts +0 -21
  388. package/dist/types/src/common/graph.d.ts.map +0 -1
  389. package/dist/types/src/common/layout.d.ts +0 -281
  390. package/dist/types/src/common/layout.d.ts.map +0 -1
  391. package/dist/types/src/common/surface.d.ts +0 -65
  392. package/dist/types/src/common/surface.d.ts.map +0 -1
  393. package/dist/types/src/core/capabilities.d.ts +0 -114
  394. package/dist/types/src/core/capabilities.d.ts.map +0 -1
  395. package/dist/types/src/core/capabilities.test.d.ts +0 -2
  396. package/dist/types/src/core/capabilities.test.d.ts.map +0 -1
  397. package/dist/types/src/core/events.d.ts.map +0 -1
  398. package/dist/types/src/core/manager.d.ts +0 -122
  399. package/dist/types/src/core/manager.d.ts.map +0 -1
  400. package/dist/types/src/core/manager.test.d.ts +0 -2
  401. package/dist/types/src/core/manager.test.d.ts.map +0 -1
  402. package/dist/types/src/playground/debug/Debug.d.ts +0 -6
  403. package/dist/types/src/playground/debug/Debug.d.ts.map +0 -1
  404. package/dist/types/src/playground/debug/index.d.ts +0 -2
  405. package/dist/types/src/playground/debug/index.d.ts.map +0 -1
  406. package/dist/types/src/playground/debug/plugin.d.ts +0 -2
  407. package/dist/types/src/playground/debug/plugin.d.ts.map +0 -1
  408. package/dist/types/src/playground/generator/Main.d.ts +0 -6
  409. package/dist/types/src/playground/generator/Main.d.ts.map +0 -1
  410. package/dist/types/src/playground/generator/Toolbar.d.ts +0 -6
  411. package/dist/types/src/playground/generator/Toolbar.d.ts.map +0 -1
  412. package/dist/types/src/playground/generator/generator.d.ts +0 -7
  413. package/dist/types/src/playground/generator/generator.d.ts.map +0 -1
  414. package/dist/types/src/playground/generator/index.d.ts +0 -3
  415. package/dist/types/src/playground/generator/index.d.ts.map +0 -1
  416. package/dist/types/src/playground/generator/plugin.d.ts +0 -2
  417. package/dist/types/src/playground/generator/plugin.d.ts.map +0 -1
  418. package/dist/types/src/playground/layout/Layout.d.ts +0 -8
  419. package/dist/types/src/playground/layout/Layout.d.ts.map +0 -1
  420. package/dist/types/src/playground/layout/index.d.ts +0 -2
  421. package/dist/types/src/playground/layout/index.d.ts.map +0 -1
  422. package/dist/types/src/playground/layout/plugin.d.ts +0 -2
  423. package/dist/types/src/playground/layout/plugin.d.ts.map +0 -1
  424. package/dist/types/src/playground/logger/Toolbar.d.ts +0 -6
  425. package/dist/types/src/playground/logger/Toolbar.d.ts.map +0 -1
  426. package/dist/types/src/playground/logger/index.d.ts +0 -2
  427. package/dist/types/src/playground/logger/index.d.ts.map +0 -1
  428. package/dist/types/src/playground/logger/plugin.d.ts +0 -2
  429. package/dist/types/src/playground/logger/plugin.d.ts.map +0 -1
  430. package/dist/types/src/playground/logger/schema.d.ts +0 -13
  431. package/dist/types/src/playground/logger/schema.d.ts.map +0 -1
  432. package/dist/types/src/playground/playground.stories.d.ts +0 -10
  433. package/dist/types/src/playground/playground.stories.d.ts.map +0 -1
  434. package/dist/types/src/plugin-intent/IntentPlugin.d.ts +0 -2
  435. package/dist/types/src/plugin-intent/IntentPlugin.d.ts.map +0 -1
  436. package/dist/types/src/plugin-intent/actions.d.ts +0 -38
  437. package/dist/types/src/plugin-intent/actions.d.ts.map +0 -1
  438. package/dist/types/src/plugin-intent/errors.d.ts +0 -16
  439. package/dist/types/src/plugin-intent/errors.d.ts.map +0 -1
  440. package/dist/types/src/plugin-intent/index.d.ts +0 -5
  441. package/dist/types/src/plugin-intent/index.d.ts.map +0 -1
  442. package/dist/types/src/plugin-intent/intent-dispatcher.d.ts +0 -139
  443. package/dist/types/src/plugin-intent/intent-dispatcher.d.ts.map +0 -1
  444. package/dist/types/src/plugin-intent/intent-dispatcher.test.d.ts +0 -2
  445. package/dist/types/src/plugin-intent/intent-dispatcher.test.d.ts.map +0 -1
  446. package/dist/types/src/plugin-intent/intent.d.ts +0 -63
  447. package/dist/types/src/plugin-intent/intent.d.ts.map +0 -1
  448. package/dist/types/src/plugin-settings/SettingsPlugin.d.ts +0 -2
  449. package/dist/types/src/plugin-settings/SettingsPlugin.d.ts.map +0 -1
  450. package/dist/types/src/plugin-settings/actions.d.ts +0 -27
  451. package/dist/types/src/plugin-settings/actions.d.ts.map +0 -1
  452. package/dist/types/src/plugin-settings/app-graph-builder.d.ts +0 -4
  453. package/dist/types/src/plugin-settings/app-graph-builder.d.ts.map +0 -1
  454. package/dist/types/src/plugin-settings/index.d.ts +0 -3
  455. package/dist/types/src/plugin-settings/index.d.ts.map +0 -1
  456. package/dist/types/src/plugin-settings/intent-resolver.d.ts +0 -4
  457. package/dist/types/src/plugin-settings/intent-resolver.d.ts.map +0 -1
  458. package/dist/types/src/plugin-settings/store.d.ts +0 -5
  459. package/dist/types/src/plugin-settings/store.d.ts.map +0 -1
  460. package/dist/types/src/plugin-settings/translations.d.ts +0 -10
  461. package/dist/types/src/plugin-settings/translations.d.ts.map +0 -1
  462. package/dist/types/src/react/ErrorBoundary.d.ts +0 -31
  463. package/dist/types/src/react/ErrorBoundary.d.ts.map +0 -1
  464. package/dist/types/src/react/IntentContext.d.ts +0 -8
  465. package/dist/types/src/react/IntentContext.d.ts.map +0 -1
  466. package/dist/types/src/react/PluginManagerProvider.d.ts +0 -10
  467. package/dist/types/src/react/PluginManagerProvider.d.ts.map +0 -1
  468. package/dist/types/src/react/Surface.d.ts +0 -12
  469. package/dist/types/src/react/Surface.d.ts.map +0 -1
  470. package/dist/types/src/react/Surface.stories.d.ts +0 -16
  471. package/dist/types/src/react/Surface.stories.d.ts.map +0 -1
  472. package/dist/types/src/react/common.d.ts +0 -13
  473. package/dist/types/src/react/common.d.ts.map +0 -1
  474. package/dist/types/src/react/index.d.ts +0 -7
  475. package/dist/types/src/react/index.d.ts.map +0 -1
  476. package/dist/types/src/react/useCapabilities.d.ts +0 -13
  477. package/dist/types/src/react/useCapabilities.d.ts.map +0 -1
  478. package/dist/types/src/react/useIntentResolver.d.ts +0 -3
  479. package/dist/types/src/react/useIntentResolver.d.ts.map +0 -1
  480. package/dist/types/src/worker.d.ts +0 -4
  481. package/dist/types/src/worker.d.ts.map +0 -1
  482. package/src/App.tsx +0 -276
  483. package/src/common/collaboration.ts +0 -21
  484. package/src/common/events.ts +0 -77
  485. package/src/common/file.ts +0 -22
  486. package/src/common/graph.ts +0 -30
  487. package/src/common/layout.ts +0 -278
  488. package/src/common/surface.ts +0 -86
  489. package/src/core/capabilities.test.ts +0 -136
  490. package/src/core/capabilities.ts +0 -254
  491. package/src/core/manager.test.ts +0 -515
  492. package/src/core/manager.ts +0 -519
  493. package/src/playground/debug/Debug.tsx +0 -39
  494. package/src/playground/debug/plugin.ts +0 -17
  495. package/src/playground/generator/Main.tsx +0 -71
  496. package/src/playground/generator/Toolbar.tsx +0 -46
  497. package/src/playground/generator/generator.ts +0 -48
  498. package/src/playground/generator/index.ts +0 -6
  499. package/src/playground/generator/plugin.ts +0 -23
  500. package/src/playground/layout/Layout.tsx +0 -33
  501. package/src/playground/layout/plugin.ts +0 -17
  502. package/src/playground/logger/Toolbar.tsx +0 -29
  503. package/src/playground/logger/plugin.ts +0 -36
  504. package/src/playground/logger/schema.ts +0 -12
  505. package/src/playground/playground.stories.tsx +0 -42
  506. package/src/plugin-intent/IntentPlugin.ts +0 -20
  507. package/src/plugin-intent/actions.ts +0 -33
  508. package/src/plugin-intent/errors.ts +0 -39
  509. package/src/plugin-intent/index.ts +0 -8
  510. package/src/plugin-intent/intent-dispatcher.test.ts +0 -279
  511. package/src/plugin-intent/intent-dispatcher.ts +0 -333
  512. package/src/plugin-intent/intent.ts +0 -154
  513. package/src/plugin-settings/SettingsPlugin.ts +0 -35
  514. package/src/plugin-settings/actions.ts +0 -29
  515. package/src/plugin-settings/app-graph-builder.ts +0 -157
  516. package/src/plugin-settings/index.ts +0 -6
  517. package/src/plugin-settings/intent-resolver.ts +0 -34
  518. package/src/plugin-settings/store.ts +0 -33
  519. package/src/plugin-settings/translations.ts +0 -19
  520. package/src/react/ErrorBoundary.tsx +0 -45
  521. package/src/react/IntentContext.tsx +0 -34
  522. package/src/react/Surface.stories.tsx +0 -96
  523. package/src/react/Surface.tsx +0 -77
  524. package/src/react/common.ts +0 -12
  525. package/src/react/index.ts +0 -10
  526. package/src/react/useCapabilities.ts +0 -30
  527. package/src/react/useIntentResolver.ts +0 -22
  528. package/src/worker.ts +0 -11
  529. package/typedoc/.nojekyll +0 -1
  530. package/typedoc/assets/hierarchy.js +0 -1
  531. package/typedoc/assets/highlight.css +0 -106
  532. package/typedoc/assets/icons.js +0 -18
  533. package/typedoc/assets/icons.svg +0 -1
  534. package/typedoc/assets/main.js +0 -60
  535. package/typedoc/assets/navigation.js +0 -1
  536. package/typedoc/assets/search.js +0 -1
  537. package/typedoc/assets/style.css +0 -1640
  538. package/typedoc/classes/CollaborationActions.InsertContent.html +0 -421
  539. package/typedoc/classes/ErrorBoundary.html +0 -125
  540. package/typedoc/classes/IntentAction.ShowUndo.html +0 -227
  541. package/typedoc/classes/IntentAction.Track.html +0 -266
  542. package/typedoc/classes/LayoutAction.AddToast.html +0 -265
  543. package/typedoc/classes/LayoutAction.Close.html +0 -382
  544. package/typedoc/classes/LayoutAction.Expose.html +0 -265
  545. package/typedoc/classes/LayoutAction.Open.html +0 -1123
  546. package/typedoc/classes/LayoutAction.RevertWorkspace.html +0 -343
  547. package/typedoc/classes/LayoutAction.ScrollIntoView.html +0 -460
  548. package/typedoc/classes/LayoutAction.Set.html +0 -460
  549. package/typedoc/classes/LayoutAction.SetLayoutMode.html +0 -499
  550. package/typedoc/classes/LayoutAction.SwitchWorkspace.html +0 -265
  551. package/typedoc/classes/LayoutAction.UpdateComplementary.html +0 -616
  552. package/typedoc/classes/LayoutAction.UpdateDialog.html +0 -1123
  553. package/typedoc/classes/LayoutAction.UpdateLayout.html +0 -461
  554. package/typedoc/classes/LayoutAction.UpdatePopover.html +0 -1435
  555. package/typedoc/classes/LayoutAction.UpdateSidebar.html +0 -616
  556. package/typedoc/classes/Plugin.html +0 -6
  557. package/typedoc/classes/PluginContext.html +0 -38
  558. package/typedoc/classes/PluginManager.html +0 -43
  559. package/typedoc/classes/PluginModule.html +0 -18
  560. package/typedoc/classes/SettingsAction.Open.html +0 -226
  561. package/typedoc/classes/SettingsAction.OpenPluginRegistry.html +0 -265
  562. package/typedoc/functions/Events.createStateEvent.html +0 -2
  563. package/typedoc/functions/IntentPlugin.html +0 -1
  564. package/typedoc/functions/SettingsPlugin.html +0 -1
  565. package/typedoc/functions/allOf.html +0 -2
  566. package/typedoc/functions/chain.html +0 -3
  567. package/typedoc/functions/contributes.html +0 -2
  568. package/typedoc/functions/createDispatcher.html +0 -3
  569. package/typedoc/functions/createIntent.html +0 -6
  570. package/typedoc/functions/createResolver.html +0 -2
  571. package/typedoc/functions/createSurface.html +0 -2
  572. package/typedoc/functions/defineCapability.html +0 -2
  573. package/typedoc/functions/defineEvent.html +0 -2
  574. package/typedoc/functions/defineModule.html +0 -2
  575. package/typedoc/functions/definePlugin.html +0 -2
  576. package/typedoc/functions/eventKey.html +0 -2
  577. package/typedoc/functions/getEvents.html +0 -2
  578. package/typedoc/functions/isAllOf.html +0 -2
  579. package/typedoc/functions/isOneOf.html +0 -2
  580. package/typedoc/functions/isSurfaceAvailable.html +0 -2
  581. package/typedoc/functions/lazy.html +0 -2
  582. package/typedoc/functions/oneOf.html +0 -2
  583. package/typedoc/functions/useApp.html +0 -6
  584. package/typedoc/functions/useAppGraph.html +0 -1
  585. package/typedoc/functions/useCapabilities.html +0 -3
  586. package/typedoc/functions/useCapability.html +0 -4
  587. package/typedoc/functions/useIntentDispatcher.html +0 -1
  588. package/typedoc/functions/useIntentResolver.html +0 -1
  589. package/typedoc/functions/useLayout.html +0 -1
  590. package/typedoc/functions/usePluginManager.html +0 -2
  591. package/typedoc/hierarchy.html +0 -1
  592. package/typedoc/index.html +0 -12
  593. package/typedoc/interfaces/LayoutAction.Toast.html +0 -10
  594. package/typedoc/media/LICENSE +0 -8
  595. package/typedoc/modules/Capabilities.html +0 -1
  596. package/typedoc/modules/CollaborationActions.html +0 -1
  597. package/typedoc/modules/Events.html +0 -1
  598. package/typedoc/modules/IntentAction.html +0 -1
  599. package/typedoc/modules/LayoutAction.html +0 -2
  600. package/typedoc/modules/SettingsAction.html +0 -1
  601. package/typedoc/modules.html +0 -1
  602. package/typedoc/types/ActivationEvent.html +0 -8
  603. package/typedoc/types/ActivationEvents.html +0 -2
  604. package/typedoc/types/AnyCapability.html +0 -1
  605. package/typedoc/types/AnyIntent.html +0 -1
  606. package/typedoc/types/AnyIntentChain.html +0 -1
  607. package/typedoc/types/AnyIntentEffectResult.html +0 -1
  608. package/typedoc/types/AnyIntentResolver.html +0 -1
  609. package/typedoc/types/AnyIntentResult.html +0 -1
  610. package/typedoc/types/Capabilities.FileUploader.html +0 -1
  611. package/typedoc/types/Capabilities.IntentResolver.html +0 -1
  612. package/typedoc/types/Capabilities.Layout.html +0 -1
  613. package/typedoc/types/Capabilities.Metadata.html +0 -1
  614. package/typedoc/types/Capabilities.ReactContext.html +0 -1
  615. package/typedoc/types/Capabilities.ReactRoot.html +0 -1
  616. package/typedoc/types/Capabilities.ReactSurface.html +0 -1
  617. package/typedoc/types/Capabilities.Settings.html +0 -4
  618. package/typedoc/types/Capability.html +0 -9
  619. package/typedoc/types/CreateAppOptions.html +0 -10
  620. package/typedoc/types/FileInfo.html +0 -1
  621. package/typedoc/types/Intent.html +0 -10
  622. package/typedoc/types/IntentChain.html +0 -6
  623. package/typedoc/types/IntentContext.html +0 -5
  624. package/typedoc/types/IntentData.html +0 -1
  625. package/typedoc/types/IntentDispatcher.html +0 -2
  626. package/typedoc/types/IntentDispatcherResult.html +0 -2
  627. package/typedoc/types/IntentEffectDefinition.html +0 -2
  628. package/typedoc/types/IntentEffectResult.html +0 -15
  629. package/typedoc/types/IntentParams.html +0 -3
  630. package/typedoc/types/IntentResolver.html +0 -2
  631. package/typedoc/types/IntentResultData.html +0 -1
  632. package/typedoc/types/IntentSchema.html +0 -1
  633. package/typedoc/types/IntentUndo.html +0 -2
  634. package/typedoc/types/InterfaceDef.html +0 -4
  635. package/typedoc/types/Label.html +0 -1
  636. package/typedoc/types/NodeSerializer.html +0 -8
  637. package/typedoc/types/PluginManagerOptions.html +0 -6
  638. package/typedoc/types/PluginMeta.html +0 -21
  639. package/typedoc/types/PromiseIntentDispatcher.html +0 -2
  640. package/typedoc/types/PromiseIntentUndo.html +0 -2
  641. package/typedoc/types/Resource.html +0 -1
  642. package/typedoc/types/ResourceKey.html +0 -1
  643. package/typedoc/types/ResourceLanguage.html +0 -1
  644. package/typedoc/types/SerializedNode.html +0 -4
  645. package/typedoc/types/SurfaceComponent.html +0 -2
  646. package/typedoc/types/SurfaceDefinition.html +0 -2
  647. package/typedoc/types/SurfaceProps.html +0 -4
  648. package/typedoc/variables/Capabilities.AnchorSort.html +0 -1
  649. package/typedoc/variables/Capabilities.AppGraph.html +0 -1
  650. package/typedoc/variables/Capabilities.AppGraphBuilder.html +0 -1
  651. package/typedoc/variables/Capabilities.AppGraphSerializer.html +0 -1
  652. package/typedoc/variables/Capabilities.ArtifactDefinition.html +0 -1
  653. package/typedoc/variables/Capabilities.FileUploader.html +0 -1
  654. package/typedoc/variables/Capabilities.IntentDispatcher.html +0 -1
  655. package/typedoc/variables/Capabilities.IntentResolver.html +0 -1
  656. package/typedoc/variables/Capabilities.Layout.html +0 -1
  657. package/typedoc/variables/Capabilities.Metadata.html +0 -1
  658. package/typedoc/variables/Capabilities.Null.html +0 -1
  659. package/typedoc/variables/Capabilities.PluginManager.html +0 -1
  660. package/typedoc/variables/Capabilities.ReactContext.html +0 -1
  661. package/typedoc/variables/Capabilities.ReactRoot.html +0 -1
  662. package/typedoc/variables/Capabilities.ReactSurface.html +0 -1
  663. package/typedoc/variables/Capabilities.RxRegistry.html +0 -1
  664. package/typedoc/variables/Capabilities.Settings.html +0 -1
  665. package/typedoc/variables/Capabilities.SettingsStore.html +0 -1
  666. package/typedoc/variables/Capabilities.Tools.html +0 -1
  667. package/typedoc/variables/Capabilities.Translations.html +0 -1
  668. package/typedoc/variables/Events.AppGraphReady.html +0 -2
  669. package/typedoc/variables/Events.DispatcherReady.html +0 -2
  670. package/typedoc/variables/Events.LayoutReady.html +0 -1
  671. package/typedoc/variables/Events.SettingsReady.html +0 -2
  672. package/typedoc/variables/Events.SetupAppGraph.html +0 -2
  673. package/typedoc/variables/Events.SetupArtifactDefinition.html +0 -2
  674. package/typedoc/variables/Events.SetupIntentResolver.html +0 -2
  675. package/typedoc/variables/Events.SetupMetadata.html +0 -2
  676. package/typedoc/variables/Events.SetupReactSurface.html +0 -2
  677. package/typedoc/variables/Events.SetupSettings.html +0 -2
  678. package/typedoc/variables/Events.SetupTranslations.html +0 -2
  679. package/typedoc/variables/Events.Startup.html +0 -2
  680. package/typedoc/variables/FileInfoSchema.html +0 -1
  681. package/typedoc/variables/INTENT_ACTION.html +0 -1
  682. package/typedoc/variables/INTENT_PLUGIN.html +0 -1
  683. package/typedoc/variables/LAYOUT_ACTION.html +0 -1
  684. package/typedoc/variables/LAYOUT_PLUGIN.html +0 -1
  685. package/typedoc/variables/Label.html +0 -1
  686. package/typedoc/variables/LayoutAction.Toast.html +0 -1
  687. package/typedoc/variables/LayoutAction.UPDATE_LAYOUT.html +0 -1
  688. package/typedoc/variables/PluginManagerProvider.html +0 -2
  689. package/typedoc/variables/Resource.html +0 -2
  690. package/typedoc/variables/ResourceKey.html +0 -1
  691. package/typedoc/variables/ResourceLanguage.html +0 -1
  692. package/typedoc/variables/SETTINGS_ACTION.html +0 -1
  693. package/typedoc/variables/SETTINGS_ID.html +0 -1
  694. package/typedoc/variables/SETTINGS_KEY.html +0 -1
  695. package/typedoc/variables/SETTINGS_PLUGIN.html +0 -1
  696. package/typedoc/variables/Surface.html +0 -2
  697. package/typedoc/variables/defaultFileTypes.html +0 -1
  698. /package/dist/lib/browser/{intent-dispatcher-TWKB22NI.mjs.map → chunk-J5LGTIGS.mjs.map} +0 -0
  699. /package/dist/lib/browser/{worker.mjs.map → chunk-RFSO3JRG.mjs.map} +0 -0
  700. /package/dist/lib/{node-esm/intent-dispatcher-5PRM3KGH.mjs.map → browser/common/activation-events.mjs.map} +0 -0
  701. /package/dist/lib/{node-esm/worker.mjs.map → browser/common/capabilities.mjs.map} +0 -0
@@ -0,0 +1,1113 @@
1
+ //
2
+ // Copyright 2025 DXOS.org
3
+ //
4
+
5
+ import { type Atom, Registry } from '@effect-atom/atom-react';
6
+ import { afterEach, assert, describe, it } from '@effect/vitest';
7
+ import * as Cause from 'effect/Cause';
8
+ import * as Duration from 'effect/Duration';
9
+ import * as Effect from 'effect/Effect';
10
+ import * as Exit from 'effect/Exit';
11
+ import * as Fiber from 'effect/Fiber';
12
+ import * as Match from 'effect/Match';
13
+ import * as PubSub from 'effect/PubSub';
14
+ import * as Queue from 'effect/Queue';
15
+ import * as TestClock from 'effect/TestClock';
16
+
17
+ import { invariant } from '@dxos/invariant';
18
+ import { type LogConfig, type LogEntry, LogLevel, log } from '@dxos/log';
19
+
20
+ import { ActivationEvents } from '../common';
21
+ import * as ActivationEvent from './activation-event';
22
+ import * as Capability from './capability';
23
+ import type * as CapabilityManager from './capability-manager';
24
+ import * as Plugin from './plugin';
25
+ import * as PluginManager from './plugin-manager';
26
+
27
+ const String = Capability.make<{ string: string }>('org.dxos.test.string');
28
+ const Number = Capability.make<{ number: number }>('org.dxos.test.number');
29
+ const Total = Capability.make<{ total: number }>('org.dxos.test.total');
30
+
31
+ const CountEvent = ActivationEvent.make('org.dxos.test.count');
32
+ const FailEvent = ActivationEvent.make('org.dxos.test.fail');
33
+
34
+ const testMeta = { id: 'org.dxos.plugin.test', name: 'Test' };
35
+
36
+ // TODO(wittjosiah): Factor out?
37
+ const atomCounter = (registry: Registry.Registry, atom: Atom.Atom<any>) => {
38
+ let count = 0;
39
+ let initial = true;
40
+ const dispose = registry.subscribe(
41
+ atom,
42
+ () => {
43
+ if (initial) {
44
+ initial = false;
45
+ return;
46
+ }
47
+ count++;
48
+ },
49
+ { immediate: true },
50
+ );
51
+ return {
52
+ get count() {
53
+ return count;
54
+ },
55
+ [Symbol.dispose]: dispose,
56
+ };
57
+ };
58
+
59
+ describe('PluginManager', () => {
60
+ let plugins: Plugin.Plugin[] = [];
61
+ const pluginLoader = Effect.fn(function* (id: string) {
62
+ const plugin = plugins.find((plugin) => plugin.meta.id === id);
63
+ invariant(plugin, `Plugin not found: ${id}`);
64
+ return plugin;
65
+ });
66
+
67
+ afterEach(() => {
68
+ plugins = [];
69
+ });
70
+
71
+ it.effect('should be able to add and remove plugins', () =>
72
+ Effect.gen(function* () {
73
+ const Test = Plugin.make(Plugin.define(testMeta));
74
+ const testPlugin = Test();
75
+ plugins = [testPlugin];
76
+
77
+ const manager = PluginManager.make({ pluginLoader });
78
+ const added = yield* manager.add(testMeta.id);
79
+ assert.isTrue(added);
80
+ assert.deepStrictEqual(manager.getPlugins(), [testPlugin]);
81
+ const removed = manager.remove(testMeta.id);
82
+ assert.isTrue(removed);
83
+ assert.deepStrictEqual(manager.getPlugins(), []);
84
+ }),
85
+ );
86
+
87
+ it.effect('should add plugin when locator differs from meta.id', () =>
88
+ Effect.gen(function* () {
89
+ const Test = Plugin.make(Plugin.define(testMeta));
90
+ const testPlugin = Test();
91
+
92
+ const urlLocator = 'https://example.com/plugin.mjs';
93
+ const urlLoader = Effect.fn(function* (locator: string) {
94
+ if (locator === urlLocator) {
95
+ return testPlugin;
96
+ }
97
+ return yield* Effect.fail(new Error(`Unknown locator: ${locator}`));
98
+ });
99
+
100
+ const manager = PluginManager.make({ pluginLoader: urlLoader });
101
+ const added = yield* manager.add(urlLocator);
102
+ assert.isTrue(added);
103
+ assert.deepStrictEqual(manager.getPlugins(), [testPlugin]);
104
+ assert.deepStrictEqual(manager.getEnabled(), [testMeta.id]);
105
+ }),
106
+ );
107
+
108
+ it.effect('should support factory pattern with options', () =>
109
+ Effect.gen(function* () {
110
+ type TestPluginOptions = { count: number };
111
+ const TestPluginFactory = Plugin.define<TestPluginOptions>(testMeta).pipe(
112
+ Plugin.addModule((options: TestPluginOptions) => ({
113
+ id: 'Hello',
114
+ activatesOn: ActivationEvents.Startup,
115
+ activate: () => Effect.succeed(Capability.contributes(String, { string: `hello-${options.count}` })),
116
+ })),
117
+ Plugin.addModule({
118
+ id: 'World',
119
+ activatesOn: ActivationEvents.Startup,
120
+ activate: () => Effect.succeed(Capability.contributes(String, { string: 'world' })),
121
+ }),
122
+ Plugin.make,
123
+ );
124
+
125
+ const plugin = TestPluginFactory({ count: 5 });
126
+ plugins = [plugin];
127
+
128
+ const manager = PluginManager.make({ plugins: [plugin], core: [], pluginLoader });
129
+ yield* manager.enable(testMeta.id);
130
+ yield* manager.activate(ActivationEvents.Startup);
131
+ const strings = manager.capabilities.getAll(String);
132
+ assert.strictEqual(strings.length, 2);
133
+ assert.strictEqual(strings[0].string, 'hello-5');
134
+ assert.strictEqual(strings[1].string, 'world');
135
+ }),
136
+ );
137
+
138
+ it.effect('should be able to enable and disable plugins', () =>
139
+ Effect.gen(function* () {
140
+ const Test = Plugin.define(testMeta).pipe(
141
+ Plugin.addModule({
142
+ id: 'Hello',
143
+ activatesOn: ActivationEvents.Startup,
144
+ activate: () => Effect.succeed(Capability.contributes(String, { string: 'hello' })),
145
+ }),
146
+ Plugin.make,
147
+ );
148
+
149
+ const testPlugin = Test();
150
+ const manager = PluginManager.make({ plugins: [testPlugin], core: [], pluginLoader });
151
+ yield* manager.enable(testMeta.id);
152
+ assert.deepStrictEqual(manager.getEnabled(), [Test.meta.id]);
153
+ assert.deepStrictEqual(manager.getModules(), [testPlugin.modules[0]]);
154
+ yield* manager.disable(testMeta.id);
155
+ assert.deepStrictEqual(manager.getEnabled(), []);
156
+ assert.deepStrictEqual(manager.getModules(), []);
157
+ }),
158
+ );
159
+
160
+ it.effect('should be able to activate plugins', () =>
161
+ Effect.gen(function* () {
162
+ const Test = Plugin.define(testMeta).pipe(
163
+ Plugin.addModule({
164
+ id: 'Hello',
165
+ activatesOn: ActivationEvents.Startup,
166
+ activate: () => Effect.succeed(Capability.contributes(String, { string: 'hello' })),
167
+ }),
168
+ Plugin.make,
169
+ );
170
+
171
+ const testPlugin = Test();
172
+ const manager = PluginManager.make({ plugins: [testPlugin], pluginLoader });
173
+ yield* manager.enable(Test.meta.id);
174
+ assert.deepStrictEqual(manager.getPlugins(), [testPlugin]);
175
+ assert.deepStrictEqual(manager.getEnabled(), [Test.meta.id]);
176
+ assert.deepStrictEqual(manager.getModules(), [testPlugin.modules[0]]);
177
+ assert.deepStrictEqual(manager.getActive(), []);
178
+ assert.deepStrictEqual(manager.getEventsFired(), []);
179
+ yield* manager.activate(ActivationEvents.Startup);
180
+ assert.deepStrictEqual(manager.getActive(), [testPlugin.modules[0].id]);
181
+ assert.deepStrictEqual(manager.getEventsFired(), [ActivationEvents.Startup.id]);
182
+ }),
183
+ );
184
+
185
+ it.effect('should handle activate returning void', () =>
186
+ Effect.gen(function* () {
187
+ const Test = Plugin.define(testMeta).pipe(
188
+ Plugin.addModule({
189
+ id: 'NoCapabilities',
190
+ activatesOn: ActivationEvents.Startup,
191
+ activate: Effect.fnUntraced(function* () {}),
192
+ }),
193
+ Plugin.make,
194
+ );
195
+
196
+ const testPlugin = Test();
197
+ const manager = PluginManager.make({ plugins: [testPlugin], pluginLoader });
198
+ yield* manager.enable(Test.meta.id);
199
+
200
+ const result = yield* manager.activate(ActivationEvents.Startup);
201
+ assert.isTrue(result);
202
+ assert.deepStrictEqual(manager.getActive(), [testPlugin.modules[0].id]);
203
+ assert.strictEqual(manager.capabilities.getAll(String).length, 0);
204
+ }),
205
+ );
206
+
207
+ it.effect('should propagate errors thrown by module activate callbacks', () =>
208
+ Effect.gen(function* () {
209
+ plugins = [
210
+ Plugin.define(testMeta).pipe(
211
+ Plugin.addModule({
212
+ activatesOn: FailEvent,
213
+ id: 'Fail',
214
+ activate: () => Effect.fail(new Error('test')),
215
+ }),
216
+ Plugin.make,
217
+ )(),
218
+ ];
219
+
220
+ const manager = PluginManager.make({ pluginLoader });
221
+ yield* manager.add(testMeta.id);
222
+ const error = yield* Effect.flip(manager.activate(FailEvent));
223
+ assert.strictEqual(error.message, 'test');
224
+ }),
225
+ );
226
+
227
+ it.effect('should catch and log defects (synchronous throws) in module activation', () =>
228
+ Effect.gen(function* () {
229
+ const DefectEvent = ActivationEvent.make('org.dxos.test.defect');
230
+ const capturedErrors: LogEntry[] = [];
231
+ const removeProcessor = log.addProcessor((_config: LogConfig, entry: LogEntry) => {
232
+ if (entry.level === LogLevel.ERROR) {
233
+ capturedErrors.push(entry);
234
+ }
235
+ });
236
+
237
+ plugins = [
238
+ Plugin.define(testMeta).pipe(
239
+ Plugin.addModule({
240
+ activatesOn: DefectEvent,
241
+ id: 'DefectInEffectSync',
242
+ activate: () =>
243
+ Effect.sync(() => {
244
+ // This is a defect - a synchronous throw inside Effect.sync.
245
+ throw new Error('defect in Effect.sync');
246
+ }),
247
+ }),
248
+ Plugin.make,
249
+ )(),
250
+ ];
251
+
252
+ const manager = PluginManager.make({ pluginLoader });
253
+ yield* manager.add(testMeta.id);
254
+ const error = yield* Effect.flip(manager.activate(DefectEvent));
255
+
256
+ // Verify the error was caught and propagated.
257
+ assert.strictEqual(error.message, 'defect in Effect.sync');
258
+
259
+ // Verify the error was logged with isDefect: true.
260
+ const defectLog = capturedErrors.find(
261
+ (entry) =>
262
+ entry.message?.includes('module failed to activate') &&
263
+ entry.context?.module === 'org.dxos.plugin.test.module.DefectInEffectSync',
264
+ );
265
+ assert.isNotNull(defectLog, 'Expected error log for defect');
266
+ assert.strictEqual(defectLog?.context?.isDefect, true, 'Expected isDefect to be true for synchronous throw');
267
+
268
+ removeProcessor();
269
+ }),
270
+ );
271
+
272
+ it.effect('should catch and log defects when activate throws before returning Effect', () =>
273
+ Effect.gen(function* () {
274
+ const DefectEvent = ActivationEvent.make('org.dxos.test.defect-immediate');
275
+ const capturedErrors: LogEntry[] = [];
276
+ const removeProcessor = log.addProcessor((_config: LogConfig, entry: LogEntry) => {
277
+ if (entry.level === LogLevel.ERROR) {
278
+ capturedErrors.push(entry);
279
+ }
280
+ });
281
+
282
+ plugins = [
283
+ Plugin.define(testMeta).pipe(
284
+ Plugin.addModule({
285
+ activatesOn: DefectEvent,
286
+ id: 'DefectImmediate',
287
+ activate: () => {
288
+ // This throws immediately before even returning an Effect.
289
+ // This is the most severe type of defect.
290
+ throw new Error('immediate throw before Effect');
291
+ return Effect.succeed(undefined);
292
+ },
293
+ }),
294
+ Plugin.make,
295
+ )(),
296
+ ];
297
+
298
+ const manager = PluginManager.make({ pluginLoader });
299
+ yield* manager.add(testMeta.id);
300
+ const error = yield* Effect.flip(manager.activate(DefectEvent));
301
+
302
+ // Verify the error was caught and propagated.
303
+ assert.strictEqual(error.message, 'immediate throw before Effect');
304
+
305
+ // Verify the error was logged with isDefect: true.
306
+ const defectLog = capturedErrors.find(
307
+ (entry) =>
308
+ entry.message?.includes('module failed to activate') &&
309
+ entry.context?.module === 'org.dxos.plugin.test.module.DefectImmediate',
310
+ );
311
+ assert.isNotNull(defectLog, 'Expected error log for immediate defect');
312
+ assert.strictEqual(
313
+ defectLog?.context?.isDefect,
314
+ true,
315
+ 'Expected isDefect to be true for immediate throw before Effect',
316
+ );
317
+
318
+ removeProcessor();
319
+ }),
320
+ );
321
+
322
+ it.effect('should fire activation events', () =>
323
+ Effect.gen(function* () {
324
+ plugins = [
325
+ Plugin.define(testMeta).pipe(
326
+ Plugin.addModule({
327
+ id: 'Hello',
328
+ activatesOn: ActivationEvents.Startup,
329
+ activate: () => Effect.succeed(Capability.contributes(String, { string: 'hello' })),
330
+ }),
331
+ Plugin.addModule({
332
+ activatesOn: FailEvent,
333
+ id: 'Fail',
334
+ activate: () => Effect.fail(new Error('test')),
335
+ }),
336
+ Plugin.make,
337
+ )(),
338
+ ];
339
+
340
+ const manager = PluginManager.make({ pluginLoader });
341
+ const activating = yield* Effect.makeLatch(false);
342
+ const activated = yield* Effect.makeLatch(false);
343
+ const error = yield* Effect.makeLatch(false);
344
+
345
+ const activationFiber = PubSub.subscribe(manager.activation).pipe(
346
+ Effect.flatMap((queue) =>
347
+ Queue.take(queue).pipe(
348
+ Effect.flatMap(({ state }) =>
349
+ Match.value(state).pipe(
350
+ Match.when('activating', () => activating.open),
351
+ Match.when('activated', () => activated.open),
352
+ Match.when('error', () => error.open),
353
+ Match.orElse(() => Effect.succeed(undefined)),
354
+ ),
355
+ ),
356
+ Effect.forever,
357
+ ),
358
+ ),
359
+ Effect.scoped,
360
+ Effect.runFork,
361
+ );
362
+
363
+ yield* manager.add(testMeta.id);
364
+ yield* manager.activate(ActivationEvents.Startup);
365
+ yield* activating.await;
366
+ yield* activated.await;
367
+
368
+ const activating2 = yield* Effect.makeLatch(false);
369
+ const activationFiber2 = PubSub.subscribe(manager.activation).pipe(
370
+ Effect.flatMap((queue) =>
371
+ Queue.take(queue).pipe(
372
+ Effect.flatMap(({ state }) =>
373
+ Match.value(state).pipe(
374
+ Match.when('activating', () => activating2.open),
375
+ Match.orElse(() => Effect.succeed(undefined)),
376
+ ),
377
+ ),
378
+ Effect.forever,
379
+ ),
380
+ ),
381
+ Effect.scoped,
382
+ Effect.runFork,
383
+ );
384
+
385
+ yield* manager.activate(FailEvent).pipe(Effect.catchAll(() => Effect.succeed(false)));
386
+ yield* activating2.await;
387
+ yield* error.await;
388
+ yield* Fiber.interrupt(activationFiber);
389
+ yield* Fiber.interrupt(activationFiber2);
390
+ }),
391
+ );
392
+
393
+ it.effect('should be able to reset an activation event', () =>
394
+ Effect.gen(function* () {
395
+ let count = 0;
396
+ const Test = Plugin.define(testMeta).pipe(
397
+ Plugin.addModule({
398
+ id: 'Hello',
399
+ activatesOn: ActivationEvents.Startup,
400
+ activate: () => {
401
+ count++;
402
+ return Effect.succeed(Capability.contributes(String, { string: 'hello' }));
403
+ },
404
+ }),
405
+ Plugin.make,
406
+ );
407
+ const testPlugin = Test();
408
+ plugins = [testPlugin];
409
+
410
+ const manager = PluginManager.make({ pluginLoader });
411
+
412
+ {
413
+ yield* manager.add(testMeta.id);
414
+ const result = yield* manager.activate(ActivationEvents.Startup);
415
+ assert.isTrue(result);
416
+ assert.deepStrictEqual(manager.getActive(), [testPlugin.modules[0].id]);
417
+ assert.strictEqual(count, 1);
418
+ }
419
+
420
+ {
421
+ const result = yield* manager.activate(ActivationEvents.Startup);
422
+ assert.isFalse(result);
423
+ }
424
+
425
+ {
426
+ const result = yield* manager.reset(ActivationEvents.Startup);
427
+ assert.isTrue(result);
428
+ assert.strictEqual(count, 2);
429
+ }
430
+ }),
431
+ );
432
+
433
+ it.effect('should not fire an unknown event', () =>
434
+ Effect.gen(function* () {
435
+ const manager = PluginManager.make({ pluginLoader });
436
+ const UnknownEvent = ActivationEvent.make('unknown');
437
+ const result = yield* manager.activate(UnknownEvent);
438
+ assert.isFalse(result);
439
+ }),
440
+ );
441
+
442
+ it.effect('should be able to fire custom activation events', () =>
443
+ Effect.gen(function* () {
444
+ const Plugin1 = Plugin.define({ id: 'org.dxos.test.plugin-1', name: 'Plugin 1' }).pipe(
445
+ Plugin.addModule({
446
+ activatesOn: CountEvent,
447
+ id: 'Plugin1',
448
+ activate: () => Effect.succeed([Capability.contributes(Number, { number: 1 })]),
449
+ }),
450
+ Plugin.make,
451
+ );
452
+ const Plugin2 = Plugin.define({ id: 'org.dxos.test.plugin-2', name: 'Plugin 2' }).pipe(
453
+ Plugin.addModule({
454
+ activatesOn: CountEvent,
455
+ id: 'Plugin2',
456
+ activate: () => Effect.succeed([Capability.contributes(Number, { number: 2 })]),
457
+ }),
458
+ Plugin.make,
459
+ );
460
+ const Plugin3 = Plugin.define({ id: 'org.dxos.test.plugin-3', name: 'Plugin 3' }).pipe(
461
+ Plugin.addModule({
462
+ activatesOn: CountEvent,
463
+ id: 'Plugin3',
464
+ activate: () => Effect.succeed([Capability.contributes(Number, { number: 3 })]),
465
+ }),
466
+ Plugin.make,
467
+ );
468
+ const plugin1 = Plugin1();
469
+ const plugin2 = Plugin2();
470
+ const plugin3 = Plugin3();
471
+ plugins = [plugin1, plugin2, plugin3];
472
+
473
+ const manager = PluginManager.make({ pluginLoader });
474
+ assert.deepStrictEqual(manager.getActive(), []);
475
+ assert.strictEqual(manager.capabilities.getAll(Number).length, 0);
476
+
477
+ yield* manager.add(Plugin1.meta.id);
478
+ yield* manager.activate(CountEvent);
479
+ assert.deepStrictEqual(manager.getActive(), [plugin1.modules[0].id]);
480
+ assert.strictEqual(manager.capabilities.getAll(Number).length, 1);
481
+
482
+ yield* manager.add(Plugin2.meta.id);
483
+ yield* manager.activate(CountEvent);
484
+ assert.deepStrictEqual(manager.getActive(), [plugin1.modules[0].id, plugin2.modules[0].id]);
485
+ assert.strictEqual(manager.capabilities.getAll(Number).length, 2);
486
+
487
+ yield* manager.add(Plugin3.meta.id);
488
+ yield* manager.activate(CountEvent);
489
+ assert.deepStrictEqual(manager.getActive(), [
490
+ plugin1.modules[0].id,
491
+ plugin2.modules[0].id,
492
+ plugin3.modules[0].id,
493
+ ]);
494
+ assert.strictEqual(manager.capabilities.getAll(Number).length, 3);
495
+ }),
496
+ );
497
+
498
+ it.effect('should only activate modules after all activatation events have been fired', () =>
499
+ Effect.gen(function* () {
500
+ const Test = Plugin.define(testMeta).pipe(
501
+ Plugin.addModule({
502
+ activatesOn: ActivationEvent.allOf(ActivationEvents.Startup, CountEvent),
503
+ id: 'Hello',
504
+ activate: () => {
505
+ return Effect.succeed(Capability.contributes(String, { string: 'hello' }));
506
+ },
507
+ }),
508
+ Plugin.make,
509
+ );
510
+ const testPlugin = Test();
511
+ plugins = [testPlugin];
512
+
513
+ const manager = PluginManager.make({ pluginLoader });
514
+ assert.deepStrictEqual(manager.getActive(), []);
515
+ assert.strictEqual(manager.capabilities.getAll(String).length, 0);
516
+
517
+ yield* manager.add(testMeta.id);
518
+ yield* manager.activate(ActivationEvents.Startup);
519
+ assert.deepStrictEqual(manager.getActive(), []);
520
+ assert.strictEqual(manager.capabilities.getAll(String).length, 0);
521
+
522
+ yield* manager.activate(CountEvent);
523
+ assert.deepStrictEqual(manager.getActive(), [testPlugin.modules[0].id]);
524
+ assert.strictEqual(manager.capabilities.getAll(String).length, 1);
525
+ }),
526
+ );
527
+
528
+ it.effect('should only activate modules once when multiple activatation events have been fired', () =>
529
+ Effect.gen(function* () {
530
+ let count = 0;
531
+ const Test = Plugin.define(testMeta).pipe(
532
+ Plugin.addModule({
533
+ id: 'Hello',
534
+ activatesOn: ActivationEvent.oneOf(ActivationEvents.Startup, CountEvent),
535
+ activate: () => {
536
+ count++;
537
+ return Effect.succeed(Capability.contributes(String, { string: 'hello' }));
538
+ },
539
+ }),
540
+ Plugin.make,
541
+ );
542
+ const testPlugin = Test();
543
+ plugins = [testPlugin];
544
+
545
+ const manager = PluginManager.make({ pluginLoader });
546
+ assert.deepStrictEqual(manager.getActive(), []);
547
+ assert.strictEqual(manager.capabilities.getAll(String).length, 0);
548
+ assert.strictEqual(count, 0);
549
+
550
+ yield* manager.add(testMeta.id);
551
+ yield* manager.activate(CountEvent);
552
+ assert.deepStrictEqual(manager.getActive(), [testPlugin.modules[0].id]);
553
+ assert.strictEqual(manager.capabilities.getAll(String).length, 1);
554
+ assert.strictEqual(count, 1);
555
+
556
+ yield* manager.activate(ActivationEvents.Startup);
557
+ assert.deepStrictEqual(manager.getActive(), [testPlugin.modules[0].id]);
558
+ assert.strictEqual(manager.capabilities.getAll(String).length, 1);
559
+ assert.strictEqual(count, 1);
560
+ }),
561
+ );
562
+
563
+ it.effect('should be able to disable and re-enable an active plugin', () =>
564
+ Effect.gen(function* () {
565
+ const state = { total: 0 };
566
+ const computeTotal = (capabilityManager: CapabilityManager.CapabilityManager) => {
567
+ const numbers = capabilityManager.getAll(Number);
568
+ state.total = numbers.reduce((acc: number, n: { number: number }) => acc + n.number, 0);
569
+ };
570
+
571
+ const Count = Plugin.define({ id: 'org.dxos.test.count', name: 'Count' }).pipe(
572
+ Plugin.addModule({
573
+ id: 'Count',
574
+ activatesOn: ActivationEvents.Startup,
575
+ firesBeforeActivation: [CountEvent],
576
+ activate: Effect.fnUntraced(function* () {
577
+ const capabilityManager = yield* Capability.Service;
578
+ computeTotal(capabilityManager);
579
+ return Capability.contributes(Total, state);
580
+ }),
581
+ }),
582
+ Plugin.make,
583
+ );
584
+
585
+ const Test = Plugin.define(testMeta).pipe(
586
+ Plugin.addModule({
587
+ activatesOn: CountEvent,
588
+ id: 'Test1',
589
+ activate: () => Effect.succeed(Capability.contributes(Number, { number: 1 })),
590
+ }),
591
+ Plugin.addModule({
592
+ id: 'Test2',
593
+ activatesOn: CountEvent,
594
+ activate: () => Effect.succeed(Capability.contributes(Number, { number: 2 })),
595
+ }),
596
+ Plugin.addModule({
597
+ id: 'Test3',
598
+ activatesOn: CountEvent,
599
+ activate: () => Effect.succeed(Capability.contributes(Number, { number: 3 })),
600
+ }),
601
+ Plugin.make,
602
+ );
603
+ const countPlugin = Count();
604
+ const testPlugin = Test();
605
+ plugins = [countPlugin, testPlugin];
606
+
607
+ const manager = PluginManager.make({ pluginLoader });
608
+ {
609
+ yield* manager.add(Test.meta.id);
610
+ yield* manager.add(Count.meta.id);
611
+ yield* manager.activate(ActivationEvents.Startup);
612
+ assert.deepStrictEqual(manager.getActive(), [
613
+ ...testPlugin.modules.map((m) => m.id),
614
+ countPlugin.modules[0].id,
615
+ ]);
616
+ assert.deepStrictEqual(manager.getPendingReset(), []);
617
+
618
+ const totals = manager.capabilities.getAll(Total);
619
+ assert.strictEqual(totals.length, 1);
620
+ assert.strictEqual(totals[0].total, 6);
621
+ }
622
+
623
+ {
624
+ yield* manager.disable(Test.meta.id);
625
+ assert.deepStrictEqual(manager.getActive(), [countPlugin.modules[0].id]);
626
+ assert.deepStrictEqual(manager.getPendingReset(), []);
627
+
628
+ const totals = manager.capabilities.getAll(Total);
629
+ assert.strictEqual(totals.length, 1);
630
+ // Total doesn't change because it is not reactive.
631
+ assert.strictEqual(totals[0].total, 6);
632
+ }
633
+
634
+ {
635
+ yield* manager.enable(Test.meta.id);
636
+ assert.deepStrictEqual(manager.getActive(), [
637
+ countPlugin.modules[0].id,
638
+ ...testPlugin.modules.map((m) => m.id),
639
+ ]);
640
+ assert.deepStrictEqual(manager.getPendingReset(), []);
641
+
642
+ const totals = manager.capabilities.getAll(Total);
643
+ assert.strictEqual(totals.length, 1);
644
+ assert.strictEqual(totals[0].total, 6);
645
+ }
646
+ }),
647
+ );
648
+
649
+ it.effect('should be reactive', () =>
650
+ Effect.gen(function* () {
651
+ const Plugin1 = Plugin.define({ id: 'org.dxos.test.plugin-1', name: 'Plugin 1' }).pipe(
652
+ Plugin.addModule({
653
+ activatesOn: CountEvent,
654
+ id: 'Plugin1',
655
+ activate: () => Effect.succeed([Capability.contributes(Number, { number: 1 })]),
656
+ }),
657
+ Plugin.make,
658
+ );
659
+ const Plugin2 = Plugin.define({ id: 'org.dxos.test.plugin-2', name: 'Plugin 2' }).pipe(
660
+ Plugin.addModule({
661
+ activatesOn: CountEvent,
662
+ id: 'Plugin2',
663
+ activate: () => Effect.succeed([Capability.contributes(Number, { number: 2 })]),
664
+ }),
665
+ Plugin.make,
666
+ );
667
+ const Plugin3 = Plugin.define({ id: 'org.dxos.test.plugin-3', name: 'Plugin 3' }).pipe(
668
+ Plugin.addModule({
669
+ activatesOn: CountEvent,
670
+ id: 'Plugin3',
671
+ activate: () => Effect.succeed([Capability.contributes(Number, { number: 3 })]),
672
+ }),
673
+ Plugin.make,
674
+ );
675
+ plugins = [Plugin1(), Plugin2(), Plugin3()];
676
+
677
+ const registry = Registry.make();
678
+ const manager = PluginManager.make({ pluginLoader, registry });
679
+ using pluginUpdates = atomCounter(registry, manager.plugins);
680
+ using enabledUpdates = atomCounter(registry, manager.enabled);
681
+ using modulesUpdates = atomCounter(registry, manager.modules);
682
+ using activeUpdates = atomCounter(registry, manager.active);
683
+ using eventsFiredUpdates = atomCounter(registry, manager.eventsFired);
684
+ using pendingResetUpdates = atomCounter(registry, manager.pendingReset);
685
+ assert.strictEqual(pluginUpdates.count, 0);
686
+ assert.strictEqual(enabledUpdates.count, 0);
687
+ assert.strictEqual(modulesUpdates.count, 0);
688
+ assert.strictEqual(activeUpdates.count, 0);
689
+ assert.strictEqual(eventsFiredUpdates.count, 0);
690
+ assert.strictEqual(pendingResetUpdates.count, 0);
691
+
692
+ yield* manager.add(Plugin1.meta.id);
693
+ assert.strictEqual(pluginUpdates.count, 1);
694
+ assert.strictEqual(enabledUpdates.count, 1);
695
+ assert.strictEqual(modulesUpdates.count, 1);
696
+ assert.strictEqual(activeUpdates.count, 0);
697
+ assert.strictEqual(eventsFiredUpdates.count, 0);
698
+ assert.strictEqual(pendingResetUpdates.count, 0);
699
+
700
+ yield* manager.activate(CountEvent);
701
+ assert.strictEqual(pluginUpdates.count, 1);
702
+ assert.strictEqual(enabledUpdates.count, 1);
703
+ assert.strictEqual(modulesUpdates.count, 1);
704
+ assert.strictEqual(activeUpdates.count, 1);
705
+ assert.strictEqual(eventsFiredUpdates.count, 1);
706
+ assert.strictEqual(pendingResetUpdates.count, 0);
707
+
708
+ yield* manager.add(Plugin2.meta.id);
709
+ assert.strictEqual(pluginUpdates.count, 2);
710
+ assert.strictEqual(enabledUpdates.count, 2);
711
+ assert.strictEqual(modulesUpdates.count, 2);
712
+ assert.strictEqual(activeUpdates.count, 2);
713
+ assert.strictEqual(eventsFiredUpdates.count, 1);
714
+ assert.strictEqual(pendingResetUpdates.count, 2);
715
+
716
+ yield* manager.activate(CountEvent);
717
+ assert.strictEqual(pluginUpdates.count, 2);
718
+ assert.strictEqual(enabledUpdates.count, 2);
719
+ assert.strictEqual(modulesUpdates.count, 2);
720
+ assert.strictEqual(activeUpdates.count, 2);
721
+ assert.strictEqual(eventsFiredUpdates.count, 1);
722
+ assert.strictEqual(pendingResetUpdates.count, 2);
723
+
724
+ yield* manager.add(Plugin3.meta.id);
725
+ assert.strictEqual(pluginUpdates.count, 3);
726
+ assert.strictEqual(enabledUpdates.count, 3);
727
+ assert.strictEqual(modulesUpdates.count, 3);
728
+ assert.strictEqual(activeUpdates.count, 3);
729
+ assert.strictEqual(eventsFiredUpdates.count, 1);
730
+ assert.strictEqual(pendingResetUpdates.count, 4);
731
+
732
+ yield* manager.reset(CountEvent);
733
+ assert.strictEqual(pluginUpdates.count, 3);
734
+ assert.strictEqual(enabledUpdates.count, 3);
735
+ assert.strictEqual(modulesUpdates.count, 3);
736
+ // Starts at 3, plus deactivates 3, plus activates 3.
737
+ assert.strictEqual(activeUpdates.count, 9);
738
+ assert.strictEqual(eventsFiredUpdates.count, 1);
739
+ assert.strictEqual(pendingResetUpdates.count, 4);
740
+
741
+ yield* manager.disable(Plugin1.meta.id);
742
+ assert.strictEqual(pluginUpdates.count, 3);
743
+ assert.strictEqual(enabledUpdates.count, 4);
744
+ assert.strictEqual(modulesUpdates.count, 4);
745
+ assert.strictEqual(activeUpdates.count, 10);
746
+ assert.strictEqual(eventsFiredUpdates.count, 1);
747
+ assert.strictEqual(pendingResetUpdates.count, 4);
748
+
749
+ manager.remove(Plugin1.meta.id);
750
+ assert.strictEqual(pluginUpdates.count, 4);
751
+ assert.strictEqual(enabledUpdates.count, 4);
752
+ assert.strictEqual(modulesUpdates.count, 4);
753
+ assert.strictEqual(activeUpdates.count, 10);
754
+ assert.strictEqual(eventsFiredUpdates.count, 1);
755
+ assert.strictEqual(pendingResetUpdates.count, 4);
756
+
757
+ yield* manager.reset(CountEvent);
758
+ assert.strictEqual(pluginUpdates.count, 4);
759
+ assert.strictEqual(enabledUpdates.count, 4);
760
+ assert.strictEqual(modulesUpdates.count, 4);
761
+ // Starts at 10, plus deactivates 2, plus activates 2.
762
+ assert.strictEqual(activeUpdates.count, 14);
763
+ assert.strictEqual(eventsFiredUpdates.count, 1);
764
+ assert.strictEqual(pendingResetUpdates.count, 4);
765
+ }),
766
+ );
767
+
768
+ it.effect('should log a warning when a module takes too long to activate', () =>
769
+ Effect.gen(function* () {
770
+ const capturedWarnings: LogEntry[] = [];
771
+ const removeProcessor = log.addProcessor((_config: LogConfig, entry: LogEntry) => {
772
+ if (entry.level === LogLevel.WARN) {
773
+ capturedWarnings.push(entry);
774
+ }
775
+ });
776
+
777
+ const SlowEvent = ActivationEvent.make('org.dxos.test.slow');
778
+ const SlowPlugin = Plugin.define({ id: 'org.dxos.test.slow-plugin', name: 'Slow Plugin' }).pipe(
779
+ Plugin.addModule({
780
+ id: 'SlowModule',
781
+ activatesOn: SlowEvent,
782
+ activate: Effect.fnUntraced(function* () {
783
+ // Simulate a slow activation that takes 15 seconds.
784
+ yield* Effect.sleep(Duration.seconds(15));
785
+ return Capability.contributes(String, { string: 'slow' });
786
+ }),
787
+ }),
788
+ Plugin.make,
789
+ );
790
+
791
+ const slowPlugin = SlowPlugin();
792
+ plugins = [slowPlugin];
793
+
794
+ const manager = PluginManager.make({ pluginLoader });
795
+ yield* manager.add(SlowPlugin.meta.id);
796
+
797
+ // Fork the activation so we can control time with TestClock.
798
+ const activationFiber = yield* Effect.fork(manager.activate(SlowEvent));
799
+
800
+ // Advance time past the 10 second warning threshold.
801
+ yield* TestClock.adjust(Duration.seconds(11));
802
+
803
+ // Check that the warning was logged.
804
+ assert.isTrue(
805
+ capturedWarnings.some((entry) => entry.message?.includes('module is taking a long time to activate')),
806
+ 'Expected a warning about slow module activation',
807
+ );
808
+
809
+ // Advance time to let the module finish activating.
810
+ yield* TestClock.adjust(Duration.seconds(5));
811
+ yield* Fiber.join(activationFiber);
812
+
813
+ removeProcessor();
814
+ }),
815
+ );
816
+
817
+ it.effect('should prevent concurrent loads of the same module via semaphore', () =>
818
+ Effect.gen(function* () {
819
+ // Two different events that both can trigger the same module.
820
+ const EventA = ActivationEvent.make('org.dxos.test.event-a');
821
+ const EventB = ActivationEvent.make('org.dxos.test.event-b');
822
+
823
+ let activateCallCount = 0;
824
+ const ConcurrentPlugin = Plugin.define({ id: 'org.dxos.test.concurrent-plugin', name: 'Concurrent Plugin' }).pipe(
825
+ Plugin.addModule({
826
+ id: 'ConcurrentModule',
827
+ // Module activates on either event - this allows two different events to race.
828
+ activatesOn: ActivationEvent.oneOf(EventA, EventB),
829
+ activate: Effect.fnUntraced(function* () {
830
+ activateCallCount++;
831
+ // Simulate slow activation to create window for race condition.
832
+ yield* Effect.sleep(Duration.seconds(5));
833
+ return Capability.contributes(String, { string: 'concurrent' });
834
+ }),
835
+ }),
836
+ Plugin.make,
837
+ );
838
+
839
+ const concurrentPlugin = ConcurrentPlugin();
840
+ plugins = [concurrentPlugin];
841
+
842
+ const manager = PluginManager.make({ pluginLoader });
843
+ yield* manager.add(ConcurrentPlugin.meta.id);
844
+
845
+ // Fork two concurrent activations with DIFFERENT events.
846
+ // Both events trigger the same module, so both will try to call _loadModule.
847
+ // Without the semaphore, both would start loading the same module.
848
+ const fiber1 = yield* Effect.fork(manager.activate(EventA));
849
+ const fiber2 = yield* Effect.fork(manager.activate(EventB));
850
+
851
+ // Advance time to let both activations complete.
852
+ yield* TestClock.adjust(Duration.seconds(6));
853
+
854
+ yield* Fiber.join(fiber1);
855
+ yield* Fiber.join(fiber2);
856
+
857
+ // The semaphore should ensure the module's activate function is only called once,
858
+ // even when two different events race to load the same module.
859
+ assert.strictEqual(activateCallCount, 1, 'module activate should only be called once due to semaphore');
860
+
861
+ // Verify the capability was contributed.
862
+ const strings = manager.capabilities.getAll(String);
863
+ assert.isTrue(strings.length >= 1, 'capability should be contributed');
864
+ assert.strictEqual(strings[0].string, 'concurrent');
865
+ }),
866
+ );
867
+
868
+ it.effect('should deactivate all active modules on shutdown', () =>
869
+ Effect.gen(function* () {
870
+ const Plugin1 = Plugin.define({ id: 'org.dxos.test.plugin-1', name: 'Plugin 1' }).pipe(
871
+ Plugin.addModule({
872
+ activatesOn: ActivationEvents.Startup,
873
+ id: 'Plugin1',
874
+ activate: () => Effect.succeed(Capability.contributes(String, { string: 'hello' })),
875
+ }),
876
+ Plugin.make,
877
+ );
878
+ const Plugin2 = Plugin.define({ id: 'org.dxos.test.plugin-2', name: 'Plugin 2' }).pipe(
879
+ Plugin.addModule({
880
+ activatesOn: ActivationEvents.Startup,
881
+ id: 'Plugin2',
882
+ activate: () => Effect.succeed(Capability.contributes(Number, { number: 42 })),
883
+ }),
884
+ Plugin.make,
885
+ );
886
+ const plugin1 = Plugin1();
887
+ const plugin2 = Plugin2();
888
+ plugins = [plugin1, plugin2];
889
+
890
+ const manager = PluginManager.make({ pluginLoader });
891
+ yield* manager.add(Plugin1.meta.id);
892
+ yield* manager.add(Plugin2.meta.id);
893
+ yield* manager.activate(ActivationEvents.Startup);
894
+ assert.strictEqual(manager.getActive().length, 2);
895
+ assert.strictEqual(manager.capabilities.getAll(String).length, 1);
896
+ assert.strictEqual(manager.capabilities.getAll(Number).length, 1);
897
+
898
+ const result = yield* manager.shutdown();
899
+ assert.isTrue(result);
900
+ assert.deepStrictEqual(manager.getActive(), []);
901
+ assert.strictEqual(manager.capabilities.getAll(String).length, 0);
902
+ assert.strictEqual(manager.capabilities.getAll(Number).length, 0);
903
+ }),
904
+ );
905
+
906
+ it.effect('should run capability deactivate hooks during shutdown', () =>
907
+ Effect.gen(function* () {
908
+ let deactivated = false;
909
+ const Test = Plugin.define(testMeta).pipe(
910
+ Plugin.addModule({
911
+ id: 'WithDeactivate',
912
+ activatesOn: ActivationEvents.Startup,
913
+ activate: () =>
914
+ Effect.succeed(
915
+ Capability.contributes(String, { string: 'hello' }, () =>
916
+ Effect.sync(() => {
917
+ deactivated = true;
918
+ }),
919
+ ),
920
+ ),
921
+ }),
922
+ Plugin.make,
923
+ );
924
+ const testPlugin = Test();
925
+ plugins = [testPlugin];
926
+
927
+ const manager = PluginManager.make({ pluginLoader });
928
+ yield* manager.add(testMeta.id);
929
+ yield* manager.activate(ActivationEvents.Startup);
930
+ assert.isFalse(deactivated);
931
+
932
+ yield* manager.shutdown();
933
+ assert.isTrue(deactivated);
934
+ }),
935
+ );
936
+
937
+ it.effect('should deactivate modules in reverse activation order during shutdown', () =>
938
+ Effect.gen(function* () {
939
+ const deactivationOrder: string[] = [];
940
+ const Plugin1 = Plugin.define({ id: 'org.dxos.test.plugin-1', name: 'Plugin 1' }).pipe(
941
+ Plugin.addModule({
942
+ activatesOn: ActivationEvents.Startup,
943
+ id: 'First',
944
+ activate: () =>
945
+ Effect.succeed(
946
+ Capability.contributes(String, { string: 'first' }, () =>
947
+ Effect.sync(() => {
948
+ deactivationOrder.push('First');
949
+ }),
950
+ ),
951
+ ),
952
+ }),
953
+ Plugin.make,
954
+ );
955
+ const Plugin2 = Plugin.define({ id: 'org.dxos.test.plugin-2', name: 'Plugin 2' }).pipe(
956
+ Plugin.addModule({
957
+ activatesOn: ActivationEvents.Startup,
958
+ id: 'Second',
959
+ activate: () =>
960
+ Effect.succeed(
961
+ Capability.contributes(Number, { number: 2 }, () =>
962
+ Effect.sync(() => {
963
+ deactivationOrder.push('Second');
964
+ }),
965
+ ),
966
+ ),
967
+ }),
968
+ Plugin.make,
969
+ );
970
+ plugins = [Plugin1(), Plugin2()];
971
+
972
+ const manager = PluginManager.make({ pluginLoader });
973
+ yield* manager.add(Plugin1.meta.id);
974
+ yield* manager.add(Plugin2.meta.id);
975
+ yield* manager.activate(ActivationEvents.Startup);
976
+
977
+ yield* manager.shutdown();
978
+ assert.deepStrictEqual(deactivationOrder, ['Second', 'First']);
979
+ }),
980
+ );
981
+
982
+ it.effect('should clear lifecycle bookkeeping during shutdown', () =>
983
+ Effect.gen(function* () {
984
+ const Test = Plugin.define(testMeta).pipe(
985
+ Plugin.addModule({
986
+ id: 'Hello',
987
+ activatesOn: ActivationEvents.Startup,
988
+ activate: () => Effect.succeed(Capability.contributes(String, { string: 'hello' })),
989
+ }),
990
+ Plugin.make,
991
+ );
992
+ const testPlugin = Test();
993
+ plugins = [testPlugin];
994
+
995
+ const manager = PluginManager.make({ pluginLoader });
996
+ yield* manager.add(testMeta.id);
997
+ yield* manager.activate(ActivationEvents.Startup);
998
+ assert.isTrue(manager.getEventsFired().length > 0);
999
+
1000
+ yield* manager.shutdown();
1001
+ assert.deepStrictEqual(manager.getEventsFired(), []);
1002
+ assert.deepStrictEqual(manager.getPendingReset(), []);
1003
+ assert.deepStrictEqual(manager.getActive(), []);
1004
+ }),
1005
+ );
1006
+
1007
+ it.effect('should interrupt in-flight activation during shutdown', () =>
1008
+ Effect.gen(function* () {
1009
+ const activationStarted = yield* Effect.makeLatch(false);
1010
+ const allowActivationToComplete = yield* Effect.makeLatch(false);
1011
+ const Test = Plugin.define(testMeta).pipe(
1012
+ Plugin.addModule({
1013
+ id: 'Hello',
1014
+ activatesOn: ActivationEvents.Startup,
1015
+ activate: () =>
1016
+ Effect.gen(function* () {
1017
+ yield* activationStarted.open;
1018
+ yield* allowActivationToComplete.await;
1019
+ return Capability.contributes(String, { string: 'hello' });
1020
+ }),
1021
+ }),
1022
+ Plugin.make,
1023
+ );
1024
+ const testPlugin = Test();
1025
+ plugins = [testPlugin];
1026
+
1027
+ const manager = PluginManager.make({ pluginLoader });
1028
+ yield* manager.add(testMeta.id);
1029
+
1030
+ const activationFiber = yield* Effect.fork(manager.activate(ActivationEvents.Startup));
1031
+ yield* activationStarted.await;
1032
+
1033
+ const shutdownFiber = yield* Effect.fork(manager.shutdown());
1034
+ yield* allowActivationToComplete.open;
1035
+
1036
+ const shutdownResult = yield* Fiber.join(shutdownFiber);
1037
+ const activationExit = yield* Fiber.await(activationFiber);
1038
+
1039
+ assert.isTrue(shutdownResult);
1040
+ assert.isTrue(Exit.isFailure(activationExit));
1041
+ if (Exit.isFailure(activationExit)) {
1042
+ assert.isTrue(Cause.isInterruptedOnly(activationExit.cause));
1043
+ }
1044
+ assert.strictEqual(manager.capabilities.getAll(String).length, 0);
1045
+ assert.deepStrictEqual(manager.getActive(), []);
1046
+ assert.deepStrictEqual(manager.getEventsFired(), []);
1047
+ }),
1048
+ );
1049
+
1050
+ it.effect('should preserve plugins, core, enabled, and modules after shutdown', () =>
1051
+ Effect.gen(function* () {
1052
+ const Test = Plugin.define(testMeta).pipe(
1053
+ Plugin.addModule({
1054
+ id: 'Hello',
1055
+ activatesOn: ActivationEvents.Startup,
1056
+ activate: () => Effect.succeed(Capability.contributes(String, { string: 'hello' })),
1057
+ }),
1058
+ Plugin.make,
1059
+ );
1060
+ const testPlugin = Test();
1061
+ plugins = [testPlugin];
1062
+
1063
+ const manager = PluginManager.make({ pluginLoader });
1064
+ yield* manager.add(testMeta.id);
1065
+ yield* manager.activate(ActivationEvents.Startup);
1066
+
1067
+ const pluginsBefore = manager.getPlugins();
1068
+ const coreBefore = manager.getCore();
1069
+ const enabledBefore = manager.getEnabled();
1070
+ const modulesBefore = manager.getModules();
1071
+
1072
+ yield* manager.shutdown();
1073
+
1074
+ assert.deepStrictEqual(manager.getPlugins(), pluginsBefore);
1075
+ assert.deepStrictEqual(manager.getCore(), coreBefore);
1076
+ assert.deepStrictEqual(manager.getEnabled(), enabledBefore);
1077
+ assert.deepStrictEqual(manager.getModules(), modulesBefore);
1078
+ }),
1079
+ );
1080
+
1081
+ it.effect('should allow re-activation after shutdown', () =>
1082
+ Effect.gen(function* () {
1083
+ let activateCount = 0;
1084
+ const Test = Plugin.define(testMeta).pipe(
1085
+ Plugin.addModule({
1086
+ id: 'Hello',
1087
+ activatesOn: ActivationEvents.Startup,
1088
+ activate: () => {
1089
+ activateCount++;
1090
+ return Effect.succeed(Capability.contributes(String, { string: 'hello' }));
1091
+ },
1092
+ }),
1093
+ Plugin.make,
1094
+ );
1095
+ const testPlugin = Test();
1096
+ plugins = [testPlugin];
1097
+
1098
+ const manager = PluginManager.make({ pluginLoader });
1099
+ yield* manager.add(testMeta.id);
1100
+ yield* manager.activate(ActivationEvents.Startup);
1101
+ assert.strictEqual(activateCount, 1);
1102
+ assert.deepStrictEqual(manager.getActive(), [testPlugin.modules[0].id]);
1103
+
1104
+ yield* manager.shutdown();
1105
+ assert.deepStrictEqual(manager.getActive(), []);
1106
+
1107
+ yield* manager.activate(ActivationEvents.Startup);
1108
+ assert.strictEqual(activateCount, 2);
1109
+ assert.deepStrictEqual(manager.getActive(), [testPlugin.modules[0].id]);
1110
+ assert.strictEqual(manager.capabilities.getAll(String).length, 1);
1111
+ }),
1112
+ );
1113
+ });