@dxos/app-framework 0.8.4-main.c85a9c8dae → 0.8.4-main.d05539e30a

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 (387) hide show
  1. package/LICENSE +102 -5
  2. package/README.md +1 -1
  3. package/dist/lib/browser/{capability-7RLVE42K.mjs → capability-K5XIVCQU.mjs} +12 -11
  4. package/dist/lib/browser/capability-K5XIVCQU.mjs.map +7 -0
  5. package/dist/lib/browser/chunk-5AHASNDW.mjs +95 -0
  6. package/dist/lib/browser/chunk-5AHASNDW.mjs.map +7 -0
  7. package/dist/lib/browser/chunk-5GY3YOEL.mjs +28 -0
  8. package/dist/lib/browser/chunk-5GY3YOEL.mjs.map +7 -0
  9. package/dist/lib/browser/{chunk-PKQT6C53.mjs → chunk-66IXTIVK.mjs} +3 -2
  10. package/dist/lib/browser/chunk-66IXTIVK.mjs.map +7 -0
  11. package/dist/lib/browser/{chunk-ZRWBPIZG.mjs → chunk-BRK6GYNB.mjs} +14 -42
  12. package/dist/lib/browser/chunk-BRK6GYNB.mjs.map +7 -0
  13. package/dist/lib/browser/chunk-FJ4765WW.mjs +8 -0
  14. package/dist/lib/browser/{chunk-FHQTHCX7.mjs.map → chunk-FJ4765WW.mjs.map} +3 -3
  15. package/dist/lib/browser/chunk-FO3IYSLV.mjs +68 -0
  16. package/dist/lib/browser/chunk-FO3IYSLV.mjs.map +7 -0
  17. package/dist/lib/browser/{chunk-YNFPIQGB.mjs → chunk-IW44C7UL.mjs} +9 -2
  18. package/dist/lib/browser/chunk-IW44C7UL.mjs.map +7 -0
  19. package/dist/lib/browser/{chunk-5RJNZV7K.mjs → chunk-KFDF7KR3.mjs} +11 -13
  20. package/dist/lib/browser/{chunk-5RJNZV7K.mjs.map → chunk-KFDF7KR3.mjs.map} +3 -3
  21. package/dist/lib/browser/chunk-KLHQNYJ2.mjs +422 -0
  22. package/dist/lib/browser/chunk-KLHQNYJ2.mjs.map +7 -0
  23. package/dist/lib/browser/chunk-QLML5QFJ.mjs +581 -0
  24. package/dist/lib/browser/chunk-QLML5QFJ.mjs.map +7 -0
  25. package/dist/lib/browser/{chunk-FNKT2QQ2.mjs → chunk-SLX73WRZ.mjs} +90 -17
  26. package/dist/lib/browser/chunk-SLX73WRZ.mjs.map +7 -0
  27. package/dist/lib/browser/chunk-UVTGHZQF.mjs +513 -0
  28. package/dist/lib/browser/chunk-UVTGHZQF.mjs.map +7 -0
  29. package/dist/lib/browser/chunk-VJ5PFAWC.mjs +1446 -0
  30. package/dist/lib/browser/chunk-VJ5PFAWC.mjs.map +7 -0
  31. package/dist/lib/browser/cli/index.mjs +17 -32
  32. package/dist/lib/browser/cli/index.mjs.map +3 -3
  33. package/dist/lib/browser/common/activation-events.mjs +11 -14
  34. package/dist/lib/browser/common/capabilities.mjs +19 -8
  35. package/dist/lib/browser/core/activation-event.mjs +1 -1
  36. package/dist/lib/browser/core/capability.mjs +5 -1
  37. package/dist/lib/browser/core/plugin-manager.mjs +8 -4
  38. package/dist/lib/browser/core/plugin.mjs +16 -4
  39. package/dist/lib/browser/core/url-loader.mjs +24 -0
  40. package/dist/lib/browser/index.mjs +47 -49
  41. package/dist/lib/browser/index.mjs.map +4 -4
  42. package/dist/lib/browser/meta.json +1 -1
  43. package/dist/lib/browser/process-manager-capability-JIWLN7SU.mjs +89 -0
  44. package/dist/lib/browser/process-manager-capability-JIWLN7SU.mjs.map +7 -0
  45. package/dist/lib/browser/testing/index.mjs +199 -56
  46. package/dist/lib/browser/testing/index.mjs.map +4 -4
  47. package/dist/lib/browser/testing/react.mjs +78 -0
  48. package/dist/lib/browser/testing/react.mjs.map +7 -0
  49. package/dist/lib/browser/ui/index.mjs +24 -15
  50. package/dist/lib/node-esm/{capability-EVZK4REM.mjs → capability-RLKFFLTB.mjs} +12 -11
  51. package/dist/lib/node-esm/capability-RLKFFLTB.mjs.map +7 -0
  52. package/dist/lib/node-esm/{chunk-UEWJDI2L.mjs → chunk-37Z53PXZ.mjs} +2 -2
  53. package/dist/lib/node-esm/{chunk-UEWJDI2L.mjs.map → chunk-37Z53PXZ.mjs.map} +3 -3
  54. package/dist/lib/node-esm/chunk-42UNAKYO.mjs +423 -0
  55. package/dist/lib/node-esm/chunk-42UNAKYO.mjs.map +7 -0
  56. package/dist/lib/node-esm/{chunk-CJCQS2YL.mjs → chunk-6S45OMUP.mjs} +90 -17
  57. package/dist/lib/node-esm/chunk-6S45OMUP.mjs.map +7 -0
  58. package/dist/lib/node-esm/{chunk-2A4PRBIX.mjs → chunk-BYHYYJZH.mjs} +14 -42
  59. package/dist/lib/node-esm/chunk-BYHYYJZH.mjs.map +7 -0
  60. package/dist/lib/node-esm/{chunk-SB5ODNPX.mjs → chunk-CTKEZHKF.mjs} +9 -2
  61. package/dist/lib/node-esm/chunk-CTKEZHKF.mjs.map +7 -0
  62. package/dist/lib/node-esm/chunk-JNT72ZCN.mjs +514 -0
  63. package/dist/lib/node-esm/chunk-JNT72ZCN.mjs.map +7 -0
  64. package/dist/lib/node-esm/chunk-KFZEB6BV.mjs +29 -0
  65. package/dist/lib/node-esm/chunk-KFZEB6BV.mjs.map +7 -0
  66. package/dist/lib/node-esm/chunk-LJNUFNDO.mjs +582 -0
  67. package/dist/lib/node-esm/chunk-LJNUFNDO.mjs.map +7 -0
  68. package/dist/lib/node-esm/{chunk-VUIUFIGT.mjs → chunk-OUEMWPIW.mjs} +11 -13
  69. package/dist/lib/node-esm/{chunk-VUIUFIGT.mjs.map → chunk-OUEMWPIW.mjs.map} +3 -3
  70. package/dist/lib/node-esm/chunk-PW2VYGOS.mjs +96 -0
  71. package/dist/lib/node-esm/chunk-PW2VYGOS.mjs.map +7 -0
  72. package/dist/lib/node-esm/chunk-SFYCO3PT.mjs +1447 -0
  73. package/dist/lib/node-esm/chunk-SFYCO3PT.mjs.map +7 -0
  74. package/dist/lib/node-esm/chunk-WK7OIQKI.mjs +70 -0
  75. package/dist/lib/node-esm/chunk-WK7OIQKI.mjs.map +7 -0
  76. package/dist/lib/node-esm/{chunk-7OWSHPYK.mjs → chunk-XOCUANHO.mjs} +3 -2
  77. package/dist/lib/node-esm/chunk-XOCUANHO.mjs.map +7 -0
  78. package/dist/lib/node-esm/cli/index.mjs +17 -32
  79. package/dist/lib/node-esm/cli/index.mjs.map +3 -3
  80. package/dist/lib/node-esm/common/activation-events.mjs +11 -14
  81. package/dist/lib/node-esm/common/capabilities.mjs +19 -8
  82. package/dist/lib/node-esm/core/activation-event.mjs +1 -1
  83. package/dist/lib/node-esm/core/capability.mjs +5 -1
  84. package/dist/lib/node-esm/core/plugin-manager.mjs +8 -4
  85. package/dist/lib/node-esm/core/plugin.mjs +16 -4
  86. package/dist/lib/node-esm/core/url-loader.mjs +25 -0
  87. package/dist/lib/node-esm/index.mjs +47 -49
  88. package/dist/lib/node-esm/index.mjs.map +4 -4
  89. package/dist/lib/node-esm/meta.json +1 -1
  90. package/dist/lib/node-esm/process-manager-capability-PHKLO2BL.mjs +90 -0
  91. package/dist/lib/node-esm/process-manager-capability-PHKLO2BL.mjs.map +7 -0
  92. package/dist/lib/node-esm/testing/index.mjs +199 -56
  93. package/dist/lib/node-esm/testing/index.mjs.map +4 -4
  94. package/dist/lib/node-esm/testing/react.mjs +79 -0
  95. package/dist/lib/node-esm/testing/react.mjs.map +7 -0
  96. package/dist/lib/node-esm/ui/index.mjs +24 -15
  97. package/dist/plugin/node-esm/index.mjs +893 -0
  98. package/dist/plugin/node-esm/index.mjs.map +7 -0
  99. package/dist/plugin/node-esm/meta.json +1 -0
  100. package/dist/types/src/cli/cli.d.ts +1 -3
  101. package/dist/types/src/cli/cli.d.ts.map +1 -1
  102. package/dist/types/src/common/activation-events.d.ts +10 -13
  103. package/dist/types/src/common/activation-events.d.ts.map +1 -1
  104. package/dist/types/src/common/annotations.d.ts +1 -0
  105. package/dist/types/src/common/annotations.d.ts.map +1 -0
  106. package/dist/types/src/common/capabilities.d.ts +113 -12
  107. package/dist/types/src/common/capabilities.d.ts.map +1 -1
  108. package/dist/types/src/common/operations.d.ts +8 -22
  109. package/dist/types/src/common/operations.d.ts.map +1 -1
  110. package/dist/types/src/core/activation-event.d.ts +5 -5
  111. package/dist/types/src/core/activation-event.d.ts.map +1 -1
  112. package/dist/types/src/core/capability-manager.d.ts +5 -0
  113. package/dist/types/src/core/capability-manager.d.ts.map +1 -1
  114. package/dist/types/src/core/capability.d.ts +13 -2
  115. package/dist/types/src/core/capability.d.ts.map +1 -1
  116. package/dist/types/src/core/edge-registry-plugin-provider.d.ts +30 -0
  117. package/dist/types/src/core/edge-registry-plugin-provider.d.ts.map +1 -0
  118. package/dist/types/src/core/index.d.ts +6 -0
  119. package/dist/types/src/core/index.d.ts.map +1 -1
  120. package/dist/types/src/core/plugin-asset-cache.d.ts +71 -0
  121. package/dist/types/src/core/plugin-asset-cache.d.ts.map +1 -0
  122. package/dist/types/src/core/plugin-manager.d.ts +238 -7
  123. package/dist/types/src/core/plugin-manager.d.ts.map +1 -1
  124. package/dist/types/src/core/plugin-manifest.d.ts +101 -0
  125. package/dist/types/src/core/plugin-manifest.d.ts.map +1 -0
  126. package/dist/types/src/core/plugin-manifest.test.d.ts +2 -0
  127. package/dist/types/src/core/plugin-manifest.test.d.ts.map +1 -0
  128. package/dist/types/src/core/plugin.d.ts +182 -7
  129. package/dist/types/src/core/plugin.d.ts.map +1 -1
  130. package/dist/types/src/core/registry.d.ts +107 -0
  131. package/dist/types/src/core/registry.d.ts.map +1 -0
  132. package/dist/types/src/core/url-loader.d.ts +127 -0
  133. package/dist/types/src/core/url-loader.d.ts.map +1 -0
  134. package/dist/types/src/core/url-loader.test.d.ts +2 -0
  135. package/dist/types/src/core/url-loader.test.d.ts.map +1 -0
  136. package/dist/types/src/helpers.d.ts.map +1 -1
  137. package/dist/types/src/index.d.ts +1 -2
  138. package/dist/types/src/index.d.ts.map +1 -1
  139. package/dist/types/src/plugin-process-manager/ProcessManagerPlugin.d.ts +3 -0
  140. package/dist/types/src/plugin-process-manager/ProcessManagerPlugin.d.ts.map +1 -0
  141. package/dist/types/src/plugin-process-manager/history/capability.d.ts.map +1 -0
  142. package/dist/types/src/plugin-process-manager/history/errors.d.ts +32 -0
  143. package/dist/types/src/plugin-process-manager/history/errors.d.ts.map +1 -0
  144. package/dist/types/src/{plugin-operation → plugin-process-manager}/history/history-tracker.d.ts +1 -1
  145. package/dist/types/src/plugin-process-manager/history/history-tracker.d.ts.map +1 -0
  146. package/dist/types/src/plugin-process-manager/history/history-tracker.test.d.ts.map +1 -0
  147. package/dist/types/src/plugin-process-manager/history/index.d.ts.map +1 -0
  148. package/dist/types/src/{plugin-operation → plugin-process-manager}/history/types.d.ts +1 -1
  149. package/dist/types/src/plugin-process-manager/history/types.d.ts.map +1 -0
  150. package/dist/types/src/{plugin-operation → plugin-process-manager}/history/undo-mapping.d.ts +1 -1
  151. package/dist/types/src/plugin-process-manager/history/undo-mapping.d.ts.map +1 -0
  152. package/dist/types/src/{plugin-operation → plugin-process-manager}/history/undo-registry.d.ts +1 -1
  153. package/dist/types/src/plugin-process-manager/history/undo-registry.d.ts.map +1 -0
  154. package/dist/types/src/plugin-process-manager/history/undo-registry.test.d.ts.map +1 -0
  155. package/dist/types/src/plugin-process-manager/index.d.ts +3 -0
  156. package/dist/types/src/plugin-process-manager/index.d.ts.map +1 -0
  157. package/dist/types/src/plugin-process-manager/meta.d.ts.map +1 -0
  158. package/dist/types/src/plugin-process-manager/process-manager-capability.d.ts +8 -0
  159. package/dist/types/src/plugin-process-manager/process-manager-capability.d.ts.map +1 -0
  160. package/dist/types/src/plugin-process-manager/testing.d.ts +59 -0
  161. package/dist/types/src/plugin-process-manager/testing.d.ts.map +1 -0
  162. package/dist/types/src/testing/harness.d.ts +79 -0
  163. package/dist/types/src/testing/harness.d.ts.map +1 -0
  164. package/dist/types/src/testing/index.d.ts +1 -0
  165. package/dist/types/src/testing/index.d.ts.map +1 -1
  166. package/dist/types/src/testing/react.d.ts +27 -0
  167. package/dist/types/src/testing/react.d.ts.map +1 -0
  168. package/dist/types/src/testing/react.test.d.ts +2 -0
  169. package/dist/types/src/testing/react.test.d.ts.map +1 -0
  170. package/dist/types/src/testing/service.d.ts.map +1 -1
  171. package/dist/types/src/testing/withPluginManager.d.ts.map +1 -1
  172. package/dist/types/src/testing/withPluginManager.stories.d.ts.map +1 -1
  173. package/dist/types/src/ui/components/App/App.d.ts +3 -2
  174. package/dist/types/src/ui/components/App/App.d.ts.map +1 -1
  175. package/dist/types/src/ui/components/App/App.stories.d.ts +2 -2
  176. package/dist/types/src/ui/components/App/App.stories.d.ts.map +1 -1
  177. package/dist/types/src/ui/components/Placeholder/Placeholder.d.ts +64 -0
  178. package/dist/types/src/ui/components/Placeholder/Placeholder.d.ts.map +1 -0
  179. package/dist/types/src/ui/components/Placeholder/Placeholder.stories.d.ts +19 -0
  180. package/dist/types/src/ui/components/Placeholder/Placeholder.stories.d.ts.map +1 -0
  181. package/dist/types/src/ui/components/Placeholder/index.d.ts +2 -0
  182. package/dist/types/src/ui/components/Placeholder/index.d.ts.map +1 -0
  183. package/dist/types/src/ui/components/PluginManager/PluginManagerContext.stories.d.ts.map +1 -1
  184. package/dist/types/src/ui/components/Surface/SurfaceComponent.d.ts +16 -4
  185. package/dist/types/src/ui/components/Surface/SurfaceComponent.d.ts.map +1 -1
  186. package/dist/types/src/ui/components/Surface/SurfaceComponent.stories.d.ts.map +1 -1
  187. package/dist/types/src/ui/components/Surface/SurfaceInfo.d.ts.map +1 -1
  188. package/dist/types/src/ui/components/Surface/SurfaceProfilerContext.d.ts +48 -0
  189. package/dist/types/src/ui/components/Surface/SurfaceProfilerContext.d.ts.map +1 -0
  190. package/dist/types/src/ui/components/Surface/index.d.ts +22 -6
  191. package/dist/types/src/ui/components/Surface/index.d.ts.map +1 -1
  192. package/dist/types/src/ui/components/Surface/types.d.ts +110 -9
  193. package/dist/types/src/ui/components/Surface/types.d.ts.map +1 -1
  194. package/dist/types/src/ui/components/Surface/types.test.d.ts +2 -0
  195. package/dist/types/src/ui/components/Surface/types.test.d.ts.map +1 -0
  196. package/dist/types/src/ui/components/index.d.ts +1 -0
  197. package/dist/types/src/ui/components/index.d.ts.map +1 -1
  198. package/dist/types/src/ui/hooks/index.d.ts +1 -1
  199. package/dist/types/src/ui/hooks/index.d.ts.map +1 -1
  200. package/dist/types/src/ui/hooks/useApp.d.ts +47 -11
  201. package/dist/types/src/ui/hooks/useApp.d.ts.map +1 -1
  202. package/dist/types/src/ui/hooks/useApp.test.d.ts +2 -0
  203. package/dist/types/src/ui/hooks/useApp.test.d.ts.map +1 -0
  204. package/dist/types/src/ui/hooks/useCapabilities.d.ts.map +1 -1
  205. package/dist/types/src/ui/hooks/useLoading.d.ts.map +1 -1
  206. package/dist/types/src/ui/hooks/useProcessManagerRuntime.d.ts +24 -0
  207. package/dist/types/src/ui/hooks/useProcessManagerRuntime.d.ts.map +1 -0
  208. package/dist/types/src/ui/hooks/useSettingsState.d.ts.map +1 -1
  209. package/dist/types/src/vite-plugin/boot-loader/BootLoader.stories.d.ts +34 -0
  210. package/dist/types/src/vite-plugin/boot-loader/BootLoader.stories.d.ts.map +1 -0
  211. package/dist/types/src/vite-plugin/boot-loader/index.d.ts +2 -0
  212. package/dist/types/src/vite-plugin/boot-loader/index.d.ts.map +1 -0
  213. package/dist/types/src/vite-plugin/boot-loader/loader.d.ts +51 -0
  214. package/dist/types/src/vite-plugin/boot-loader/loader.d.ts.map +1 -0
  215. package/dist/types/src/vite-plugin/composer/index.d.ts +34 -0
  216. package/dist/types/src/vite-plugin/composer/index.d.ts.map +1 -0
  217. package/dist/types/src/vite-plugin/import-map/index.d.ts +28 -0
  218. package/dist/types/src/vite-plugin/import-map/index.d.ts.map +1 -0
  219. package/dist/types/src/vite-plugin/index.d.ts +5 -0
  220. package/dist/types/src/vite-plugin/index.d.ts.map +1 -0
  221. package/dist/types/src/vite-plugin/manifest.d.ts +41 -0
  222. package/dist/types/src/vite-plugin/manifest.d.ts.map +1 -0
  223. package/dist/types/src/vite-plugin/manifest.test.d.ts +2 -0
  224. package/dist/types/src/vite-plugin/manifest.test.d.ts.map +1 -0
  225. package/dist/types/src/vite-plugin/packages.d.ts +13 -0
  226. package/dist/types/src/vite-plugin/packages.d.ts.map +1 -0
  227. package/dist/types/tsconfig.tsbuildinfo +1 -1
  228. package/moon.yml +15 -0
  229. package/package.json +53 -54
  230. package/src/cli/cli.ts +4 -9
  231. package/src/common/activation-events.ts +12 -17
  232. package/src/common/annotations.ts +3 -0
  233. package/src/common/capabilities.ts +160 -29
  234. package/src/common/operations.ts +7 -10
  235. package/src/context.ts +1 -1
  236. package/src/core/activation-event.ts +5 -2
  237. package/src/core/capability-manager.test.ts +1 -1
  238. package/src/core/capability-manager.ts +22 -1
  239. package/src/core/capability.ts +20 -2
  240. package/src/core/edge-registry-plugin-provider.ts +92 -0
  241. package/src/core/index.ts +6 -0
  242. package/src/core/plugin-asset-cache.ts +60 -0
  243. package/src/core/plugin-manager.test.ts +1085 -31
  244. package/src/core/plugin-manager.ts +1170 -198
  245. package/src/core/plugin-manifest.test.ts +75 -0
  246. package/src/core/plugin-manifest.ts +134 -0
  247. package/src/core/plugin.ts +194 -12
  248. package/src/core/registry.ts +163 -0
  249. package/src/core/url-loader.test.ts +221 -0
  250. package/src/core/url-loader.ts +388 -0
  251. package/src/index.ts +1 -2
  252. package/src/plugin-process-manager/ProcessManagerPlugin.ts +24 -0
  253. package/src/{plugin-operation → plugin-process-manager}/history/capability.ts +1 -2
  254. package/src/plugin-process-manager/history/errors.ts +7 -0
  255. package/src/{plugin-operation → plugin-process-manager}/history/history-tracker.test.ts +37 -43
  256. package/src/{plugin-operation → plugin-process-manager}/history/history-tracker.ts +1 -2
  257. package/src/{plugin-operation → plugin-process-manager}/history/types.ts +1 -1
  258. package/src/{plugin-operation → plugin-process-manager}/history/undo-mapping.ts +1 -1
  259. package/src/{plugin-operation → plugin-process-manager}/history/undo-registry.test.ts +3 -4
  260. package/src/{plugin-operation → plugin-process-manager}/history/undo-registry.ts +1 -1
  261. package/src/{plugin-operation → plugin-process-manager}/index.ts +1 -1
  262. package/src/plugin-process-manager/meta.ts +14 -0
  263. package/src/plugin-process-manager/process-manager-capability.ts +178 -0
  264. package/src/{plugin-operation → plugin-process-manager}/testing.ts +26 -45
  265. package/src/testing/harness.ts +247 -0
  266. package/src/testing/index.ts +1 -0
  267. package/src/testing/react.test.tsx +48 -0
  268. package/src/testing/react.tsx +113 -0
  269. package/src/testing/service.ts +4 -4
  270. package/src/testing/withPluginManager.stories.tsx +1 -2
  271. package/src/testing/withPluginManager.tsx +45 -20
  272. package/src/ui/components/App/App.stories.tsx +7 -13
  273. package/src/ui/components/App/App.tsx +29 -5
  274. package/src/ui/components/Placeholder/Placeholder.stories.tsx +77 -0
  275. package/src/ui/components/Placeholder/Placeholder.tsx +155 -0
  276. package/src/{plugin-runtime → ui/components/Placeholder}/index.ts +1 -1
  277. package/src/ui/components/PluginManager/PluginManagerContext.stories.tsx +8 -7
  278. package/src/ui/components/Surface/SurfaceComponent.stories.tsx +16 -15
  279. package/src/ui/components/Surface/SurfaceComponent.tsx +111 -55
  280. package/src/ui/components/Surface/SurfaceInfo.tsx +0 -1
  281. package/src/ui/components/Surface/SurfaceProfilerContext.tsx +207 -0
  282. package/src/ui/components/Surface/index.ts +35 -1
  283. package/src/ui/components/Surface/types.test.ts +126 -0
  284. package/src/ui/components/Surface/types.ts +164 -12
  285. package/src/ui/components/index.ts +1 -0
  286. package/src/ui/hooks/index.ts +1 -1
  287. package/src/ui/hooks/useApp.test.tsx +159 -0
  288. package/src/ui/hooks/useApp.tsx +229 -24
  289. package/src/ui/hooks/useLoading.tsx +14 -6
  290. package/src/ui/hooks/useProcessManagerRuntime.ts +68 -0
  291. package/src/vite-plugin/boot-loader/BootLoader.stories.tsx +270 -0
  292. package/src/vite-plugin/boot-loader/boot-loader.css +320 -0
  293. package/src/vite-plugin/boot-loader/boot-loader.js +325 -0
  294. package/src/vite-plugin/boot-loader/index.ts +5 -0
  295. package/src/vite-plugin/boot-loader/loader.ts +123 -0
  296. package/src/vite-plugin/composer/index.ts +306 -0
  297. package/src/vite-plugin/import-map/index.ts +527 -0
  298. package/src/vite-plugin/index.ts +10 -0
  299. package/src/vite-plugin/manifest.test.ts +46 -0
  300. package/src/vite-plugin/manifest.ts +57 -0
  301. package/src/vite-plugin/packages.ts +187 -0
  302. package/tsconfig.json +25 -1
  303. package/tsconfig.node.json +1 -1
  304. package/vitest.config.ts +1 -1
  305. package/.swc/plugins/linux_x86_64_19.0.0/727453fb3a62f7f1d952a41e051ca8a6f88cadc45cee43c6a4d1aa45f9b75665.wasmer-v7 +0 -0
  306. package/dist/lib/browser/capability-2GL5JAGJ.mjs +0 -37
  307. package/dist/lib/browser/capability-2GL5JAGJ.mjs.map +0 -7
  308. package/dist/lib/browser/capability-7RLVE42K.mjs.map +0 -7
  309. package/dist/lib/browser/chunk-4CTRO67U.mjs +0 -703
  310. package/dist/lib/browser/chunk-4CTRO67U.mjs.map +0 -7
  311. package/dist/lib/browser/chunk-FHQTHCX7.mjs +0 -8
  312. package/dist/lib/browser/chunk-FNKT2QQ2.mjs.map +0 -7
  313. package/dist/lib/browser/chunk-HE27PNNQ.mjs +0 -824
  314. package/dist/lib/browser/chunk-HE27PNNQ.mjs.map +0 -7
  315. package/dist/lib/browser/chunk-NPUEVX42.mjs +0 -34
  316. package/dist/lib/browser/chunk-NPUEVX42.mjs.map +0 -7
  317. package/dist/lib/browser/chunk-PKQT6C53.mjs.map +0 -7
  318. package/dist/lib/browser/chunk-REORGDJT.mjs +0 -80
  319. package/dist/lib/browser/chunk-REORGDJT.mjs.map +0 -7
  320. package/dist/lib/browser/chunk-YAFEA4GV.mjs +0 -1
  321. package/dist/lib/browser/chunk-YNFPIQGB.mjs.map +0 -7
  322. package/dist/lib/browser/chunk-ZRWBPIZG.mjs.map +0 -7
  323. package/dist/lib/browser/invoker-capability-BNLVNYHU.mjs +0 -36
  324. package/dist/lib/browser/invoker-capability-BNLVNYHU.mjs.map +0 -7
  325. package/dist/lib/node-esm/capability-CHIMU6LX.mjs +0 -38
  326. package/dist/lib/node-esm/capability-CHIMU6LX.mjs.map +0 -7
  327. package/dist/lib/node-esm/capability-EVZK4REM.mjs.map +0 -7
  328. package/dist/lib/node-esm/chunk-2A4PRBIX.mjs.map +0 -7
  329. package/dist/lib/node-esm/chunk-7CPNAEGV.mjs +0 -704
  330. package/dist/lib/node-esm/chunk-7CPNAEGV.mjs.map +0 -7
  331. package/dist/lib/node-esm/chunk-7OWSHPYK.mjs.map +0 -7
  332. package/dist/lib/node-esm/chunk-CJCQS2YL.mjs.map +0 -7
  333. package/dist/lib/node-esm/chunk-DTCHT2X2.mjs +0 -825
  334. package/dist/lib/node-esm/chunk-DTCHT2X2.mjs.map +0 -7
  335. package/dist/lib/node-esm/chunk-JAZVHID3.mjs +0 -35
  336. package/dist/lib/node-esm/chunk-JAZVHID3.mjs.map +0 -7
  337. package/dist/lib/node-esm/chunk-SB5ODNPX.mjs.map +0 -7
  338. package/dist/lib/node-esm/chunk-UFW652GS.mjs +0 -81
  339. package/dist/lib/node-esm/chunk-UFW652GS.mjs.map +0 -7
  340. package/dist/lib/node-esm/chunk-Z4TJPSMP.mjs +0 -2
  341. package/dist/lib/node-esm/invoker-capability-VF6SP44V.mjs +0 -37
  342. package/dist/lib/node-esm/invoker-capability-VF6SP44V.mjs.map +0 -7
  343. package/dist/types/src/plugin-operation/OperationPlugin.d.ts +0 -3
  344. package/dist/types/src/plugin-operation/OperationPlugin.d.ts.map +0 -1
  345. package/dist/types/src/plugin-operation/history/capability.d.ts.map +0 -1
  346. package/dist/types/src/plugin-operation/history/errors.d.ts +0 -5
  347. package/dist/types/src/plugin-operation/history/errors.d.ts.map +0 -1
  348. package/dist/types/src/plugin-operation/history/history-tracker.d.ts.map +0 -1
  349. package/dist/types/src/plugin-operation/history/history-tracker.test.d.ts.map +0 -1
  350. package/dist/types/src/plugin-operation/history/index.d.ts.map +0 -1
  351. package/dist/types/src/plugin-operation/history/types.d.ts.map +0 -1
  352. package/dist/types/src/plugin-operation/history/undo-mapping.d.ts.map +0 -1
  353. package/dist/types/src/plugin-operation/history/undo-registry.d.ts.map +0 -1
  354. package/dist/types/src/plugin-operation/history/undo-registry.test.d.ts.map +0 -1
  355. package/dist/types/src/plugin-operation/index.d.ts +0 -3
  356. package/dist/types/src/plugin-operation/index.d.ts.map +0 -1
  357. package/dist/types/src/plugin-operation/invoker-capability.d.ts +0 -6
  358. package/dist/types/src/plugin-operation/invoker-capability.d.ts.map +0 -1
  359. package/dist/types/src/plugin-operation/meta.d.ts.map +0 -1
  360. package/dist/types/src/plugin-operation/testing.d.ts +0 -109
  361. package/dist/types/src/plugin-operation/testing.d.ts.map +0 -1
  362. package/dist/types/src/plugin-runtime/RuntimePlugin.d.ts +0 -3
  363. package/dist/types/src/plugin-runtime/RuntimePlugin.d.ts.map +0 -1
  364. package/dist/types/src/plugin-runtime/capability.d.ts +0 -6
  365. package/dist/types/src/plugin-runtime/capability.d.ts.map +0 -1
  366. package/dist/types/src/plugin-runtime/index.d.ts +0 -2
  367. package/dist/types/src/plugin-runtime/index.d.ts.map +0 -1
  368. package/dist/types/src/plugin-runtime/meta.d.ts +0 -3
  369. package/dist/types/src/plugin-runtime/meta.d.ts.map +0 -1
  370. package/dist/types/src/ui/hooks/useOperationResolver.d.ts +0 -19
  371. package/dist/types/src/ui/hooks/useOperationResolver.d.ts.map +0 -1
  372. package/src/plugin-operation/OperationPlugin.ts +0 -25
  373. package/src/plugin-operation/history/errors.ts +0 -11
  374. package/src/plugin-operation/invoker-capability.ts +0 -40
  375. package/src/plugin-operation/meta.ts +0 -11
  376. package/src/plugin-runtime/RuntimePlugin.ts +0 -20
  377. package/src/plugin-runtime/capability.ts +0 -53
  378. package/src/plugin-runtime/meta.ts +0 -11
  379. package/src/ui/hooks/useOperationResolver.ts +0 -40
  380. /package/dist/lib/browser/{chunk-YAFEA4GV.mjs.map → core/url-loader.mjs.map} +0 -0
  381. /package/dist/lib/node-esm/{chunk-Z4TJPSMP.mjs.map → core/url-loader.mjs.map} +0 -0
  382. /package/dist/types/src/{plugin-operation → plugin-process-manager}/history/capability.d.ts +0 -0
  383. /package/dist/types/src/{plugin-operation → plugin-process-manager}/history/history-tracker.test.d.ts +0 -0
  384. /package/dist/types/src/{plugin-operation → plugin-process-manager}/history/index.d.ts +0 -0
  385. /package/dist/types/src/{plugin-operation → plugin-process-manager}/history/undo-registry.test.d.ts +0 -0
  386. /package/dist/types/src/{plugin-operation → plugin-process-manager}/meta.d.ts +0 -0
  387. /package/src/{plugin-operation → plugin-process-manager}/history/index.ts +0 -0
@@ -6,8 +6,63 @@ import type { FC, PropsWithChildren, ReactNode, RefCallback } from 'react';
6
6
 
7
7
  import type { MakeOptional, Position } from '@dxos/util';
8
8
 
9
+ /**
10
+ * A typed role token. Carries a role string for runtime dispatch plus a phantom
11
+ * data type so consumers using `type={SomeToken}` and providers using
12
+ * `AppSurface.object(SomeToken, ...)` share a single type-level contract.
13
+ *
14
+ * Mint via {@link makeType}.
15
+ */
16
+ export type RoleToken<TData> = {
17
+ readonly role: string;
18
+ /** Covariant phantom; never accessed at runtime. */
19
+ readonly _phantom?: TData;
20
+ };
21
+
22
+ /**
23
+ * One entry in a {@link SurfaceFilter} — a role plus the guard that validates
24
+ * the data shape when the Surface dispatcher is matching that role.
25
+ */
26
+ export type SurfaceBinding = {
27
+ readonly role: string;
28
+ readonly guard: (data: unknown) => boolean;
29
+ };
30
+
31
+ /**
32
+ * Typed filter binding for {@link create}. Combines one or more `(role, guard)`
33
+ * pairs so a provider can register against multiple roles while keeping the
34
+ * role and its data shape in a single expression.
35
+ */
36
+ export type SurfaceFilter<TData> = {
37
+ readonly bindings: ReadonlyArray<SurfaceBinding>;
38
+ /** Covariant phantom; never accessed at runtime. */
39
+ readonly _phantom?: TData;
40
+ };
41
+
42
+ /**
43
+ * Narrow data type carried by a role token.
44
+ */
45
+ export type TokenData<T> = T extends RoleToken<infer D> ? D : never;
46
+
47
+ /**
48
+ * Runtime guard for {@link SurfaceFilter}. Distinguishes new-style filter
49
+ * bindings from legacy predicate filters.
50
+ */
51
+ export const isSurfaceFilter = (value: unknown): value is SurfaceFilter<any> =>
52
+ typeof value === 'object' && value !== null && Array.isArray((value as { bindings?: unknown }).bindings);
53
+
54
+ /**
55
+ * Mints a typed role token. Identity is structural; all tokens with the same
56
+ * `role` string are interchangeable at runtime.
57
+ */
58
+ export const makeType = <TData>(role: string): RoleToken<TData> => ({ role });
59
+
9
60
  /**
10
61
  * Props that are passed to the Surface component.
62
+ *
63
+ * The role can be provided either as a string via `role` or as a typed
64
+ * {@link RoleToken} via `type`. The typed form narrows `data` to the token's
65
+ * declared shape.
11
66
  */
12
67
  export type Props<T extends Record<string, any> = Record<string, unknown>> = {
13
68
  /**
@@ -21,16 +76,46 @@ export type Props<T extends Record<string, any> = Record<string, unknown>> = {
21
76
  * The placeholder component will be rendered while the surface component is loading.
22
77
  */
23
78
  placeholder?: ReactNode;
24
- } & MakeOptional<CoreProps<T>, 'id' | 'data'> &
25
- /**
79
+ } & MakeOptional<CoreProps<T>, 'id' | 'data' | 'role'> & {
80
+ /**
81
+ * Explicitly disallow `type` on the untyped Props overload — if the caller
82
+ * provides `type={AppSurface.X}`, TypeScript must route to the typed
83
+ * overload (where `data` is narrowed by the token). Without this, the
84
+ * catch-all index signature below would accept any `type` value and mask
85
+ * the typed overload entirely.
86
+ */
87
+ type?: undefined;
88
+ } /**
26
89
  * Additional props to pass to the component.
27
90
  * These props are not used by Surface itself but may be used by components which resolve the surface.
28
91
  * Exclude known prop names to prevent overriding well-defined props.
29
- */
30
- {
31
- [K in keyof Record<string, any>]: K extends keyof CoreProps<T> | 'fallback' | 'placeholder' ? never : any;
92
+ */ & {
93
+ [K in keyof Record<string, any>]: K extends keyof CoreProps<T> | 'fallback' | 'placeholder' | 'type' ? never : any;
32
94
  };
33
95
 
96
+ /**
97
+ * Typed Surface consumer props — carries the role/data-shape contract via a
98
+ * {@link RoleToken}. Available as a typed overload of the Surface component so
99
+ * ad-hoc `type` fields on arbitrary spread props don't conflict with the
100
+ * untyped consumer form.
101
+ */
102
+ export type TypedProps<TToken extends RoleToken<any>> = {
103
+ fallback?: FC<{ error: Error; data?: any }>;
104
+ placeholder?: ReactNode;
105
+ id?: string;
106
+ type: TToken;
107
+ data?: TokenData<TToken>;
108
+ limit?: number | undefined;
109
+ } & {
110
+ /**
111
+ * Additional pass-through props. Known prop names are excluded so the
112
+ * catch-all doesn't widen `data` / `type` / etc. to `any` at the intersection.
113
+ */
114
+ [K in keyof Record<string, any>]: K extends 'fallback' | 'placeholder' | 'id' | 'type' | 'data' | 'limit'
115
+ ? never
116
+ : any;
117
+ };
118
+
34
119
  /**
35
120
  * NOTE: If `[key: string]: unknown` is included in shared types, when re-used other fields become unknown as well.
36
121
  */
@@ -41,7 +126,10 @@ export type CoreProps<T extends Record<string, any> = Record<string, unknown>> =
41
126
  id: string;
42
127
 
43
128
  /**
44
- * Role defines how the data should be rendered.
129
+ * Role defines how the data should be rendered. For new code, prefer the
130
+ * typed overload of the Surface component which takes a {@link RoleToken}
131
+ * via the `type` prop instead — it enforces a role/data contract at compile
132
+ * time.
45
133
  */
46
134
  role: string;
47
135
 
@@ -71,6 +159,10 @@ export type ComponentFunction<T extends Record<string, any> = Record<string, any
71
159
 
72
160
  /**
73
161
  * Definition of when a React component surface should be rendered.
162
+ *
163
+ * The optional `filter` receives the consumer-supplied `role` as its second
164
+ * argument so a single definition can encode role-specific guards (used by the
165
+ * {@link SurfaceFilter}-based `create` overload).
74
166
  */
75
167
  export type ReactDefinition<T extends Record<string, any> = any> = Readonly<{
76
168
  kind: 'react';
@@ -78,7 +170,7 @@ export type ReactDefinition<T extends Record<string, any> = any> = Readonly<{
78
170
  role: string | string[];
79
171
  position?: Position;
80
172
  component: ComponentFunction<T>;
81
- filter?: (data: Record<string, unknown>) => data is T;
173
+ filter?: (data: Record<string, unknown>, role?: string) => data is T;
82
174
  }>;
83
175
 
84
176
  /**
@@ -94,7 +186,7 @@ export type WebComponentDefinition<T extends Record<string, any> = any> = Readon
94
186
  * The Web Component will receive the same props as React surfaces via properties/attributes.
95
187
  */
96
188
  tagName: string;
97
- filter?: (data: Record<string, unknown>) => data is T;
189
+ filter?: (data: Record<string, unknown>, role?: string) => data is T;
98
190
  }>;
99
191
 
100
192
  /**
@@ -102,16 +194,76 @@ export type WebComponentDefinition<T extends Record<string, any> = any> = Readon
102
194
  */
103
195
  export type Definition<T extends Record<string, any> = any> = ReactDefinition<T> | WebComponentDefinition<T>;
104
196
 
197
+ /**
198
+ * Typed React surface definition — role is derived from the filter's bindings.
199
+ */
200
+ export type TypedReactDefinition<T extends Record<string, any> = any> = Readonly<{
201
+ id: string;
202
+ filter: SurfaceFilter<T>;
203
+ component: ComponentFunction<T>;
204
+ position?: Position;
205
+ }>;
206
+
207
+ /**
208
+ * Typed Web Component surface definition.
209
+ */
210
+ export type TypedWebComponentDefinition<T extends Record<string, any> = any> = Readonly<{
211
+ id: string;
212
+ filter: SurfaceFilter<T>;
213
+ tagName: string;
214
+ position?: Position;
215
+ }>;
216
+
217
+ const expandBindings = <T extends Record<string, any>>(
218
+ filter: SurfaceFilter<T>,
219
+ ): { role: string | string[]; guard: (data: Record<string, unknown>, role?: string) => data is T } => {
220
+ const bindings = filter.bindings;
221
+ const roles = Array.from(new Set(bindings.map((binding) => binding.role)));
222
+ const guard = (data: Record<string, unknown>, role?: string): data is T => {
223
+ if (role != null) {
224
+ // Multiple bindings may share a role (e.g. via `oneOf` of same-role filters);
225
+ // the role matches if ANY of them passes.
226
+ return bindings.some((entry) => entry.role === role && entry.guard(data));
227
+ }
228
+ return bindings.some((entry) => entry.guard(data));
229
+ };
230
+ return { role: roles.length === 1 ? roles[0] : roles, guard };
231
+ };
232
+
105
233
  /**
106
234
  * Creates a React surface definition.
107
235
  */
108
- export const create = <T extends Record<string, any> = any>(
236
+ export function create<T extends Record<string, any> = any>(definition: TypedReactDefinition<T>): ReactDefinition<T>;
237
+ export function create<T extends Record<string, any> = any>(
109
238
  definition: Omit<ReactDefinition<T>, 'kind'>,
110
- ): ReactDefinition<T> => ({ ...definition, kind: 'react' });
239
+ ): ReactDefinition<T>;
240
+ export function create<T extends Record<string, any> = any>(
241
+ definition: TypedReactDefinition<T> | Omit<ReactDefinition<T>, 'kind'>,
242
+ ): ReactDefinition<T> {
243
+ if (isSurfaceFilter(definition.filter)) {
244
+ const { id, filter, component, position } = definition as TypedReactDefinition<T>;
245
+ const { role, guard } = expandBindings(filter);
246
+ return { kind: 'react', id, role, position, component, filter: guard };
247
+ }
248
+ return { ...(definition as Omit<ReactDefinition<T>, 'kind'>), kind: 'react' };
249
+ }
111
250
 
112
251
  /**
113
252
  * Creates a Web Component surface definition.
114
253
  */
115
- export const createWeb = <T extends Record<string, any> = any>(
254
+ export function createWeb<T extends Record<string, any> = any>(
255
+ definition: TypedWebComponentDefinition<T>,
256
+ ): WebComponentDefinition<T>;
257
+ export function createWeb<T extends Record<string, any> = any>(
116
258
  definition: Omit<WebComponentDefinition<T>, 'kind'>,
117
- ): WebComponentDefinition<T> => ({ ...definition, kind: 'web-component' });
259
+ ): WebComponentDefinition<T>;
260
+ export function createWeb<T extends Record<string, any> = any>(
261
+ definition: TypedWebComponentDefinition<T> | Omit<WebComponentDefinition<T>, 'kind'>,
262
+ ): WebComponentDefinition<T> {
263
+ if (isSurfaceFilter(definition.filter)) {
264
+ const { id, filter, tagName, position } = definition as TypedWebComponentDefinition<T>;
265
+ const { role, guard } = expandBindings(filter);
266
+ return { kind: 'web-component', id, role, position, tagName, filter: guard };
267
+ }
268
+ return { ...(definition as Omit<WebComponentDefinition<T>, 'kind'>), kind: 'web-component' };
269
+ }
@@ -3,5 +3,6 @@
3
3
  //
4
4
 
5
5
  export * from './App';
6
+ export * from './Placeholder';
6
7
  export * from './PluginManager';
7
8
  export * from './Surface';
@@ -5,6 +5,6 @@
5
5
  export * from './useApp';
6
6
  export * from './useCapabilities';
7
7
  export * from './useLoading';
8
- export * from './useOperationResolver';
8
+ export * from './useProcessManagerRuntime';
9
9
  export * from './useSettingsState';
10
10
  export * from './useSurface';
@@ -0,0 +1,159 @@
1
+ //
2
+ // Copyright 2025 DXOS.org
3
+ //
4
+
5
+ import { assert, describe, it } from '@effect/vitest';
6
+ import { render, waitFor } from '@testing-library/react';
7
+ import * as Effect from 'effect/Effect';
8
+ import React from 'react';
9
+
10
+ import { ActivationEvents, Capabilities } from '../../common';
11
+ import { Capability, Plugin, PluginManager } from '../../core';
12
+ import { useApp } from './useApp';
13
+
14
+ const String = Capability.make<{ string: string }>('org.dxos.test.string');
15
+ const testMeta = { id: 'org.dxos.plugin.test', name: 'Test', tags: ['system'] };
16
+
17
+ const pluginLoader = (plugins: Plugin.Plugin[]) =>
18
+ Effect.fn(function* (id: string) {
19
+ const plugin = plugins.find((plugin) => plugin.meta.id === id);
20
+ if (!plugin) {
21
+ return yield* Effect.fail(new Error(`Plugin not found: ${id}`));
22
+ }
23
+ return { plugin };
24
+ });
25
+
26
+ const TestHost = ({ manager }: { manager: PluginManager.PluginManager }) => {
27
+ const App = useApp({ pluginManager: manager });
28
+ return <App />;
29
+ };
30
+
31
+ describe('useApp cleanup integration', () => {
32
+ it.effect('external manager is not shut down when useApp does not own it', () =>
33
+ Effect.gen(function* () {
34
+ const plugin = Plugin.define(testMeta).pipe(
35
+ Plugin.addModule({
36
+ id: 'Hello',
37
+ activatesOn: ActivationEvents.Startup,
38
+ activate: () => Effect.succeed(Capability.contributes(String, { string: 'hello' })),
39
+ }),
40
+ Plugin.make,
41
+ )();
42
+
43
+ const manager = PluginManager.make({
44
+ pluginLoader: pluginLoader([plugin]),
45
+ plugins: [plugin],
46
+ });
47
+
48
+ manager.capabilities.contribute({
49
+ interface: Capabilities.PluginManager,
50
+ implementation: manager,
51
+ module: 'org.dxos.app-framework.plugin-manager',
52
+ });
53
+ manager.capabilities.contribute({
54
+ interface: Capabilities.AtomRegistry,
55
+ implementation: manager.registry,
56
+ module: 'org.dxos.app-framework.atom-registry',
57
+ });
58
+
59
+ const view = yield* Effect.promise(() => Promise.resolve(render(<TestHost manager={manager} />)));
60
+ yield* Effect.promise(() =>
61
+ waitFor(() => {
62
+ assert.strictEqual(manager.capabilities.getAll(Capabilities.PluginManager).length, 1);
63
+ assert.strictEqual(manager.capabilities.getAll(Capabilities.AtomRegistry).length, 1);
64
+ assert.strictEqual(manager.capabilities.getAll(String).length, 1);
65
+ assert.isTrue(manager.getActive().length > 0);
66
+ }),
67
+ );
68
+
69
+ yield* Effect.promise(() => Promise.resolve(view.unmount()));
70
+ yield* Effect.promise(() =>
71
+ waitFor(() => {
72
+ assert.strictEqual(manager.capabilities.getAll(Capabilities.PluginManager).length, 1);
73
+ assert.strictEqual(manager.capabilities.getAll(Capabilities.AtomRegistry).length, 1);
74
+ assert.strictEqual(manager.capabilities.getAll(String).length, 1);
75
+ assert.isTrue(manager.getActive().length > 0);
76
+ }),
77
+ );
78
+
79
+ yield* manager.shutdown();
80
+
81
+ assert.strictEqual(manager.capabilities.getAll(Capabilities.PluginManager).length, 1);
82
+ assert.strictEqual(manager.capabilities.getAll(Capabilities.AtomRegistry).length, 1);
83
+ assert.strictEqual(manager.capabilities.getAll(String).length, 0);
84
+ assert.deepStrictEqual(manager.getActive(), []);
85
+ }),
86
+ );
87
+
88
+ it.effect('shutdown deactivates modules and clears bookkeeping', () =>
89
+ Effect.gen(function* () {
90
+ const plugin = Plugin.define(testMeta).pipe(
91
+ Plugin.addModule({
92
+ id: 'Hello',
93
+ activatesOn: ActivationEvents.Startup,
94
+ activate: () => Effect.succeed(Capability.contributes(String, { string: 'hello' })),
95
+ }),
96
+ Plugin.make,
97
+ )();
98
+
99
+ const manager = PluginManager.make({
100
+ pluginLoader: pluginLoader([plugin]),
101
+ plugins: [plugin],
102
+ });
103
+
104
+ manager.capabilities.contribute({
105
+ interface: Capabilities.PluginManager,
106
+ implementation: manager,
107
+ module: 'org.dxos.app-framework.plugin-manager',
108
+ });
109
+ manager.capabilities.contribute({
110
+ interface: Capabilities.AtomRegistry,
111
+ implementation: manager.registry,
112
+ module: 'org.dxos.app-framework.atom-registry',
113
+ });
114
+ yield* manager.activate(ActivationEvents.Startup);
115
+
116
+ assert.strictEqual(manager.capabilities.getAll(String).length, 1);
117
+ assert.isTrue(manager.getActive().length > 0);
118
+
119
+ yield* manager.shutdown();
120
+
121
+ assert.strictEqual(manager.capabilities.getAll(String).length, 0);
122
+ assert.deepStrictEqual(manager.getActive(), []);
123
+ assert.deepStrictEqual(manager.getEventsFired(), []);
124
+ }),
125
+ );
126
+
127
+ it.effect('shutdown is idempotent when called multiple times', () =>
128
+ Effect.gen(function* () {
129
+ const plugin = Plugin.define(testMeta).pipe(
130
+ Plugin.addModule({
131
+ id: 'Hello',
132
+ activatesOn: ActivationEvents.Startup,
133
+ activate: () => Effect.succeed(Capability.contributes(String, { string: 'hello' })),
134
+ }),
135
+ Plugin.make,
136
+ )();
137
+
138
+ const manager = PluginManager.make({
139
+ pluginLoader: pluginLoader([plugin]),
140
+ plugins: [plugin],
141
+ });
142
+
143
+ manager.capabilities.contribute({
144
+ interface: Capabilities.PluginManager,
145
+ implementation: manager,
146
+ module: 'org.dxos.app-framework.plugin-manager',
147
+ });
148
+ yield* manager.activate(ActivationEvents.Startup);
149
+
150
+ yield* manager.shutdown();
151
+ assert.deepStrictEqual(manager.getActive(), []);
152
+
153
+ // Second shutdown should succeed without error.
154
+ const result = yield* manager.shutdown();
155
+ assert.isTrue(result);
156
+ assert.deepStrictEqual(manager.getActive(), []);
157
+ }),
158
+ );
159
+ });