@dxos/app-framework 0.8.4-main.72ec0f3 → 0.8.4-main.74a063c4e0

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 (512) hide show
  1. package/.storybook/main.mts +2 -4
  2. package/.storybook/preview.mts +2 -2
  3. package/dist/lib/browser/capability-BBBBAPDI.mjs +38 -0
  4. package/dist/lib/browser/capability-BBBBAPDI.mjs.map +7 -0
  5. package/dist/lib/browser/capability-OP63CD5N.mjs +35 -0
  6. package/dist/lib/browser/capability-OP63CD5N.mjs.map +7 -0
  7. package/dist/lib/browser/chunk-2CKCJ6PN.mjs +79 -0
  8. package/dist/lib/browser/chunk-2CKCJ6PN.mjs.map +7 -0
  9. package/dist/lib/browser/chunk-F7FW2RK2.mjs +167 -0
  10. package/dist/lib/browser/chunk-F7FW2RK2.mjs.map +7 -0
  11. package/dist/lib/browser/chunk-FU4GAFUQ.mjs +148 -0
  12. package/dist/lib/browser/chunk-FU4GAFUQ.mjs.map +7 -0
  13. package/dist/lib/browser/chunk-GX4TUNM6.mjs +963 -0
  14. package/dist/lib/browser/chunk-GX4TUNM6.mjs.map +7 -0
  15. package/dist/lib/browser/chunk-I34GF4NG.mjs +34 -0
  16. package/dist/lib/browser/chunk-I34GF4NG.mjs.map +7 -0
  17. package/dist/lib/browser/chunk-J5LGTIGS.mjs +10 -0
  18. package/dist/lib/browser/chunk-JKWMHZP6.mjs +80 -0
  19. package/dist/lib/browser/chunk-JKWMHZP6.mjs.map +7 -0
  20. package/dist/lib/browser/chunk-LVJW5EFU.mjs +157 -0
  21. package/dist/lib/browser/chunk-LVJW5EFU.mjs.map +7 -0
  22. package/dist/lib/browser/chunk-QSXYHXCE.mjs +48 -0
  23. package/dist/lib/browser/chunk-QSXYHXCE.mjs.map +7 -0
  24. package/dist/lib/browser/chunk-RFSO3JRG.mjs +1 -0
  25. package/dist/lib/browser/chunk-T3Y4AEKX.mjs +42 -0
  26. package/dist/lib/browser/chunk-T3Y4AEKX.mjs.map +7 -0
  27. package/dist/lib/browser/chunk-TGX63LTL.mjs +8 -0
  28. package/dist/lib/browser/chunk-TGX63LTL.mjs.map +7 -0
  29. package/dist/lib/browser/chunk-WPE6AL7I.mjs +905 -0
  30. package/dist/lib/browser/chunk-WPE6AL7I.mjs.map +7 -0
  31. package/dist/lib/browser/cli/index.mjs +90 -0
  32. package/dist/lib/browser/cli/index.mjs.map +7 -0
  33. package/dist/lib/browser/common/activation-events.mjs +24 -0
  34. package/dist/lib/browser/common/capabilities.mjs +46 -0
  35. package/dist/lib/browser/core/activation-event.mjs +20 -0
  36. package/dist/lib/browser/core/activation-event.mjs.map +7 -0
  37. package/dist/lib/browser/core/capability.mjs +30 -0
  38. package/dist/lib/browser/core/capability.mjs.map +7 -0
  39. package/dist/lib/browser/core/plugin-manager.mjs +15 -0
  40. package/dist/lib/browser/core/plugin-manager.mjs.map +7 -0
  41. package/dist/lib/browser/core/plugin.mjs +29 -0
  42. package/dist/lib/browser/core/plugin.mjs.map +7 -0
  43. package/dist/lib/browser/core/url-loader.mjs +12 -0
  44. package/dist/lib/browser/core/url-loader.mjs.map +7 -0
  45. package/dist/lib/browser/index.mjs +92 -121
  46. package/dist/lib/browser/index.mjs.map +4 -4
  47. package/dist/lib/browser/invoker-capability-H5PPENOC.mjs +43 -0
  48. package/dist/lib/browser/invoker-capability-H5PPENOC.mjs.map +7 -0
  49. package/dist/lib/browser/meta.json +1 -1
  50. package/dist/lib/browser/testing/index.mjs +108 -40
  51. package/dist/lib/browser/testing/index.mjs.map +4 -4
  52. package/dist/lib/browser/ui/index.mjs +44 -0
  53. package/dist/lib/browser/ui/index.mjs.map +7 -0
  54. package/dist/lib/node-esm/capability-AWBEMRYR.mjs +39 -0
  55. package/dist/lib/node-esm/capability-AWBEMRYR.mjs.map +7 -0
  56. package/dist/lib/node-esm/capability-WFEG6CIZ.mjs +36 -0
  57. package/dist/lib/node-esm/capability-WFEG6CIZ.mjs.map +7 -0
  58. package/dist/lib/node-esm/chunk-42KBWDE4.mjs +80 -0
  59. package/dist/lib/node-esm/chunk-42KBWDE4.mjs.map +7 -0
  60. package/dist/lib/node-esm/chunk-4A3ZCMI3.mjs +158 -0
  61. package/dist/lib/node-esm/chunk-4A3ZCMI3.mjs.map +7 -0
  62. package/dist/lib/node-esm/chunk-BCEOLX47.mjs +964 -0
  63. package/dist/lib/node-esm/chunk-BCEOLX47.mjs.map +7 -0
  64. package/dist/lib/node-esm/chunk-EL3R25OQ.mjs +2 -0
  65. package/dist/lib/node-esm/chunk-EL3R25OQ.mjs.map +7 -0
  66. package/dist/lib/node-esm/chunk-FKE4Z3D6.mjs +10 -0
  67. package/dist/lib/node-esm/chunk-FKE4Z3D6.mjs.map +7 -0
  68. package/dist/lib/node-esm/chunk-G3RTFSNG.mjs +81 -0
  69. package/dist/lib/node-esm/chunk-G3RTFSNG.mjs.map +7 -0
  70. package/dist/lib/node-esm/chunk-HSLMI22Q.mjs +11 -0
  71. package/dist/lib/node-esm/chunk-HSLMI22Q.mjs.map +7 -0
  72. package/dist/lib/node-esm/chunk-LQKOTNJW.mjs +906 -0
  73. package/dist/lib/node-esm/chunk-LQKOTNJW.mjs.map +7 -0
  74. package/dist/lib/node-esm/chunk-ULUEXB7Q.mjs +149 -0
  75. package/dist/lib/node-esm/chunk-ULUEXB7Q.mjs.map +7 -0
  76. package/dist/lib/node-esm/chunk-URWHJQT2.mjs +168 -0
  77. package/dist/lib/node-esm/chunk-URWHJQT2.mjs.map +7 -0
  78. package/dist/lib/node-esm/chunk-VKHGNEDB.mjs +43 -0
  79. package/dist/lib/node-esm/chunk-VKHGNEDB.mjs.map +7 -0
  80. package/dist/lib/node-esm/chunk-WZCSOX5Q.mjs +35 -0
  81. package/dist/lib/node-esm/chunk-WZCSOX5Q.mjs.map +7 -0
  82. package/dist/lib/node-esm/chunk-ZZ7CKK6W.mjs +49 -0
  83. package/dist/lib/node-esm/chunk-ZZ7CKK6W.mjs.map +7 -0
  84. package/dist/lib/node-esm/cli/index.mjs +91 -0
  85. package/dist/lib/node-esm/cli/index.mjs.map +7 -0
  86. package/dist/lib/node-esm/common/activation-events.mjs +25 -0
  87. package/dist/lib/node-esm/common/activation-events.mjs.map +7 -0
  88. package/dist/lib/node-esm/common/capabilities.mjs +47 -0
  89. package/dist/lib/node-esm/common/capabilities.mjs.map +7 -0
  90. package/dist/lib/node-esm/core/activation-event.mjs +21 -0
  91. package/dist/lib/node-esm/core/activation-event.mjs.map +7 -0
  92. package/dist/lib/node-esm/core/capability.mjs +31 -0
  93. package/dist/lib/node-esm/core/capability.mjs.map +7 -0
  94. package/dist/lib/node-esm/core/plugin-manager.mjs +16 -0
  95. package/dist/lib/node-esm/core/plugin-manager.mjs.map +7 -0
  96. package/dist/lib/node-esm/core/plugin.mjs +30 -0
  97. package/dist/lib/node-esm/core/plugin.mjs.map +7 -0
  98. package/dist/lib/node-esm/core/url-loader.mjs +13 -0
  99. package/dist/lib/node-esm/core/url-loader.mjs.map +7 -0
  100. package/dist/lib/node-esm/index.mjs +92 -121
  101. package/dist/lib/node-esm/index.mjs.map +4 -4
  102. package/dist/lib/node-esm/invoker-capability-S3ZA527J.mjs +44 -0
  103. package/dist/lib/node-esm/invoker-capability-S3ZA527J.mjs.map +7 -0
  104. package/dist/lib/node-esm/meta.json +1 -1
  105. package/dist/lib/node-esm/testing/index.mjs +108 -40
  106. package/dist/lib/node-esm/testing/index.mjs.map +4 -4
  107. package/dist/lib/node-esm/ui/index.mjs +45 -0
  108. package/dist/lib/node-esm/ui/index.mjs.map +7 -0
  109. package/dist/plugin/node-esm/index.mjs +384 -0
  110. package/dist/plugin/node-esm/index.mjs.map +7 -0
  111. package/dist/plugin/node-esm/meta.json +1 -0
  112. package/dist/types/src/cli/cli.d.ts +39 -0
  113. package/dist/types/src/cli/cli.d.ts.map +1 -0
  114. package/dist/types/src/cli/index.d.ts +2 -0
  115. package/dist/types/src/cli/index.d.ts.map +1 -0
  116. package/dist/types/src/common/activation-events.d.ts +27 -0
  117. package/dist/types/src/common/activation-events.d.ts.map +1 -0
  118. package/dist/types/src/common/capabilities.d.ts +109 -194
  119. package/dist/types/src/common/capabilities.d.ts.map +1 -1
  120. package/dist/types/src/common/index.d.ts +4 -8
  121. package/dist/types/src/common/index.d.ts.map +1 -1
  122. package/dist/types/src/common/operations.d.ts +19 -0
  123. package/dist/types/src/common/operations.d.ts.map +1 -0
  124. package/dist/types/src/common/translations.d.ts +7 -7
  125. package/dist/types/src/common/translations.d.ts.map +1 -1
  126. package/dist/types/src/context.d.ts +5 -0
  127. package/dist/types/src/context.d.ts.map +1 -0
  128. package/dist/types/src/core/{events.d.ts → activation-event.d.ts} +7 -7
  129. package/dist/types/src/core/activation-event.d.ts.map +1 -0
  130. package/dist/types/src/core/capability-manager.d.ts +48 -0
  131. package/dist/types/src/core/capability-manager.d.ts.map +1 -0
  132. package/dist/types/src/core/capability-manager.test.d.ts +2 -0
  133. package/dist/types/src/core/capability-manager.test.d.ts.map +1 -0
  134. package/dist/types/src/core/capability.d.ts +156 -0
  135. package/dist/types/src/core/capability.d.ts.map +1 -0
  136. package/dist/types/src/core/index.d.ts +6 -4
  137. package/dist/types/src/core/index.d.ts.map +1 -1
  138. package/dist/types/src/core/plugin-manager.d.ts +73 -0
  139. package/dist/types/src/core/plugin-manager.d.ts.map +1 -0
  140. package/dist/types/src/core/plugin-manager.test.d.ts +2 -0
  141. package/dist/types/src/core/plugin-manager.test.d.ts.map +1 -0
  142. package/dist/types/src/core/plugin.d.ts +98 -35
  143. package/dist/types/src/core/plugin.d.ts.map +1 -1
  144. package/dist/types/src/core/url-loader.d.ts +25 -0
  145. package/dist/types/src/core/url-loader.d.ts.map +1 -0
  146. package/dist/types/src/core/url-loader.test.d.ts +2 -0
  147. package/dist/types/src/core/url-loader.test.d.ts.map +1 -0
  148. package/dist/types/src/index.d.ts +3 -2
  149. package/dist/types/src/index.d.ts.map +1 -1
  150. package/dist/types/src/plugin-operation/OperationPlugin.d.ts +3 -0
  151. package/dist/types/src/plugin-operation/OperationPlugin.d.ts.map +1 -0
  152. package/dist/types/src/plugin-operation/history/capability.d.ts +7 -0
  153. package/dist/types/src/plugin-operation/history/capability.d.ts.map +1 -0
  154. package/dist/types/src/plugin-operation/history/errors.d.ts +32 -0
  155. package/dist/types/src/plugin-operation/history/errors.d.ts.map +1 -0
  156. package/dist/types/src/plugin-operation/history/history-tracker.d.ts +18 -0
  157. package/dist/types/src/plugin-operation/history/history-tracker.d.ts.map +1 -0
  158. package/dist/types/src/plugin-operation/history/history-tracker.test.d.ts +2 -0
  159. package/dist/types/src/plugin-operation/history/history-tracker.test.d.ts.map +1 -0
  160. package/dist/types/src/plugin-operation/history/index.d.ts +6 -0
  161. package/dist/types/src/plugin-operation/history/index.d.ts.map +1 -0
  162. package/dist/types/src/plugin-operation/history/types.d.ts +13 -0
  163. package/dist/types/src/plugin-operation/history/types.d.ts.map +1 -0
  164. package/dist/types/src/plugin-operation/history/undo-mapping.d.ts +101 -0
  165. package/dist/types/src/plugin-operation/history/undo-mapping.d.ts.map +1 -0
  166. package/dist/types/src/plugin-operation/history/undo-registry.d.ts +23 -0
  167. package/dist/types/src/plugin-operation/history/undo-registry.d.ts.map +1 -0
  168. package/dist/types/src/plugin-operation/history/undo-registry.test.d.ts +2 -0
  169. package/dist/types/src/plugin-operation/history/undo-registry.test.d.ts.map +1 -0
  170. package/dist/types/src/plugin-operation/index.d.ts +3 -0
  171. package/dist/types/src/plugin-operation/index.d.ts.map +1 -0
  172. package/dist/types/src/plugin-operation/invoker-capability.d.ts +6 -0
  173. package/dist/types/src/plugin-operation/invoker-capability.d.ts.map +1 -0
  174. package/dist/types/src/plugin-operation/meta.d.ts +3 -0
  175. package/dist/types/src/plugin-operation/meta.d.ts.map +1 -0
  176. package/dist/types/src/plugin-operation/testing.d.ts +58 -0
  177. package/dist/types/src/plugin-operation/testing.d.ts.map +1 -0
  178. package/dist/types/src/plugin-runtime/RuntimePlugin.d.ts +3 -0
  179. package/dist/types/src/plugin-runtime/RuntimePlugin.d.ts.map +1 -0
  180. package/dist/types/src/plugin-runtime/capability.d.ts +6 -0
  181. package/dist/types/src/plugin-runtime/capability.d.ts.map +1 -0
  182. package/dist/types/src/plugin-runtime/index.d.ts +2 -0
  183. package/dist/types/src/plugin-runtime/index.d.ts.map +1 -0
  184. package/dist/types/src/plugin-runtime/meta.d.ts +3 -0
  185. package/dist/types/src/plugin-runtime/meta.d.ts.map +1 -0
  186. package/dist/types/src/testing/index.d.ts +1 -0
  187. package/dist/types/src/testing/index.d.ts.map +1 -1
  188. package/dist/types/src/testing/service.d.ts +8 -0
  189. package/dist/types/src/testing/service.d.ts.map +1 -0
  190. package/dist/types/src/testing/withPluginManager.d.ts +4 -4
  191. package/dist/types/src/testing/withPluginManager.d.ts.map +1 -1
  192. package/dist/types/src/testing/withPluginManager.stories.d.ts.map +1 -1
  193. package/dist/types/src/ui/components/App/App.d.ts +9 -0
  194. package/dist/types/src/ui/components/App/App.d.ts.map +1 -0
  195. package/dist/types/src/ui/components/App/App.stories.d.ts +19 -0
  196. package/dist/types/src/ui/components/App/App.stories.d.ts.map +1 -0
  197. package/dist/types/src/ui/components/App/index.d.ts +2 -0
  198. package/dist/types/src/ui/components/App/index.d.ts.map +1 -0
  199. package/dist/types/src/{react/Surface.stories.d.ts → ui/components/PluginManager/PluginManagerContext.stories.d.ts} +2 -3
  200. package/dist/types/src/ui/components/PluginManager/PluginManagerContext.stories.d.ts.map +1 -0
  201. package/dist/types/src/ui/components/PluginManager/PluginManagerProvider.d.ts +10 -0
  202. package/dist/types/src/ui/components/PluginManager/PluginManagerProvider.d.ts.map +1 -0
  203. package/dist/types/src/ui/components/PluginManager/index.d.ts +2 -0
  204. package/dist/types/src/ui/components/PluginManager/index.d.ts.map +1 -0
  205. package/dist/types/src/ui/components/Surface/SurfaceComponent.d.ts +12 -0
  206. package/dist/types/src/ui/components/Surface/SurfaceComponent.d.ts.map +1 -0
  207. package/dist/types/src/{react/App.stories.d.ts → ui/components/Surface/SurfaceComponent.stories.d.ts} +1 -1
  208. package/dist/types/src/ui/components/Surface/SurfaceComponent.stories.d.ts.map +1 -0
  209. package/dist/types/src/ui/components/Surface/SurfaceInfo.d.ts +11 -0
  210. package/dist/types/src/ui/components/Surface/SurfaceInfo.d.ts.map +1 -0
  211. package/dist/types/src/ui/components/Surface/SurfaceProfilerContext.d.ts +48 -0
  212. package/dist/types/src/ui/components/Surface/SurfaceProfilerContext.d.ts.map +1 -0
  213. package/dist/types/src/ui/components/Surface/context.d.ts +5 -0
  214. package/dist/types/src/ui/components/Surface/context.d.ts.map +1 -0
  215. package/dist/types/src/ui/components/Surface/index.d.ts +26 -0
  216. package/dist/types/src/ui/components/Surface/index.d.ts.map +1 -0
  217. package/dist/types/src/ui/components/Surface/types.d.ts +96 -0
  218. package/dist/types/src/ui/components/Surface/types.d.ts.map +1 -0
  219. package/dist/types/src/ui/components/index.d.ts +4 -0
  220. package/dist/types/src/ui/components/index.d.ts.map +1 -0
  221. package/dist/types/src/ui/hooks/index.d.ts +6 -0
  222. package/dist/types/src/ui/hooks/index.d.ts.map +1 -0
  223. package/dist/types/src/{react → ui/hooks}/useApp.d.ts +30 -12
  224. package/dist/types/src/ui/hooks/useApp.d.ts.map +1 -0
  225. package/dist/types/src/ui/hooks/useApp.test.d.ts +2 -0
  226. package/dist/types/src/ui/hooks/useApp.test.d.ts.map +1 -0
  227. package/dist/types/src/ui/hooks/useCapabilities.d.ts +31 -0
  228. package/dist/types/src/ui/hooks/useCapabilities.d.ts.map +1 -0
  229. package/dist/types/src/{react → ui/hooks}/useLoading.d.ts +1 -2
  230. package/dist/types/src/ui/hooks/useLoading.d.ts.map +1 -0
  231. package/dist/types/src/ui/hooks/useSettingsState.d.ts +10 -0
  232. package/dist/types/src/ui/hooks/useSettingsState.d.ts.map +1 -0
  233. package/dist/types/src/ui/hooks/useSurface.d.ts +3 -0
  234. package/dist/types/src/ui/hooks/useSurface.d.ts.map +1 -0
  235. package/dist/types/src/ui/index.d.ts +3 -0
  236. package/dist/types/src/ui/index.d.ts.map +1 -0
  237. package/dist/types/src/vite-plugin/composer-plugin.d.ts +18 -0
  238. package/dist/types/src/vite-plugin/composer-plugin.d.ts.map +1 -0
  239. package/dist/types/src/vite-plugin/import-map-plugin.d.ts +16 -0
  240. package/dist/types/src/vite-plugin/import-map-plugin.d.ts.map +1 -0
  241. package/dist/types/src/vite-plugin/index.d.ts +3 -0
  242. package/dist/types/src/vite-plugin/index.d.ts.map +1 -0
  243. package/dist/types/src/vite-plugin/packages.d.ts +7 -0
  244. package/dist/types/src/vite-plugin/packages.d.ts.map +1 -0
  245. package/dist/types/tsconfig.tsbuildinfo +1 -1
  246. package/moon.yml +24 -6
  247. package/package.json +130 -50
  248. package/src/cli/cli.ts +107 -0
  249. package/src/{playground/debug → cli}/index.ts +1 -1
  250. package/src/common/activation-events.ts +44 -0
  251. package/src/common/capabilities.ts +168 -210
  252. package/src/common/index.ts +4 -8
  253. package/src/common/operations.ts +35 -0
  254. package/src/common/translations.ts +17 -9
  255. package/src/context.ts +9 -0
  256. package/src/core/{events.ts → activation-event.ts} +10 -7
  257. package/src/core/capability-manager.test.ts +151 -0
  258. package/src/core/capability-manager.ts +192 -0
  259. package/src/core/capability.ts +247 -0
  260. package/src/core/index.ts +6 -4
  261. package/src/core/plugin-manager.test.ts +1113 -0
  262. package/src/core/plugin-manager.ts +883 -0
  263. package/src/core/plugin.ts +230 -40
  264. package/src/core/url-loader.test.ts +79 -0
  265. package/src/core/url-loader.ts +148 -0
  266. package/src/index.ts +3 -2
  267. package/src/plugin-operation/OperationPlugin.ts +24 -0
  268. package/src/plugin-operation/history/capability.ts +36 -0
  269. package/src/plugin-operation/history/errors.ts +7 -0
  270. package/src/plugin-operation/history/history-tracker.test.ts +373 -0
  271. package/src/plugin-operation/history/history-tracker.ts +128 -0
  272. package/src/plugin-operation/history/index.ts +9 -0
  273. package/src/plugin-operation/history/types.ts +17 -0
  274. package/src/plugin-operation/history/undo-mapping.ts +135 -0
  275. package/src/plugin-operation/history/undo-registry.test.ts +72 -0
  276. package/src/plugin-operation/history/undo-registry.ts +54 -0
  277. package/src/plugin-operation/index.ts +6 -0
  278. package/src/plugin-operation/invoker-capability.ts +54 -0
  279. package/src/plugin-operation/meta.ts +11 -0
  280. package/src/plugin-operation/testing.ts +154 -0
  281. package/src/plugin-runtime/RuntimePlugin.ts +19 -0
  282. package/src/plugin-runtime/capability.ts +53 -0
  283. package/src/{playground/logger → plugin-runtime}/index.ts +1 -1
  284. package/src/plugin-runtime/meta.ts +11 -0
  285. package/src/testing/index.ts +1 -0
  286. package/src/testing/service.ts +52 -0
  287. package/src/testing/withPluginManager.stories.tsx +7 -8
  288. package/src/testing/withPluginManager.tsx +63 -38
  289. package/src/ui/components/App/App.stories.tsx +92 -0
  290. package/src/{react → ui/components/App}/App.tsx +11 -12
  291. package/src/{playground/layout → ui/components/App}/index.ts +1 -1
  292. package/src/ui/components/PluginManager/PluginManagerContext.stories.tsx +183 -0
  293. package/src/{react → ui/components/PluginManager}/PluginManagerProvider.ts +3 -3
  294. package/src/ui/components/PluginManager/index.ts +5 -0
  295. package/src/{react/Surface.stories.tsx → ui/components/Surface/SurfaceComponent.stories.tsx} +55 -36
  296. package/src/ui/components/Surface/SurfaceComponent.tsx +266 -0
  297. package/src/ui/components/Surface/SurfaceInfo.tsx +107 -0
  298. package/src/ui/components/Surface/SurfaceProfilerContext.tsx +207 -0
  299. package/src/ui/components/Surface/context.ts +12 -0
  300. package/src/ui/components/Surface/index.ts +35 -0
  301. package/src/ui/components/Surface/types.ts +117 -0
  302. package/src/ui/components/index.ts +7 -0
  303. package/src/ui/hooks/index.ts +9 -0
  304. package/src/ui/hooks/useApp.test.tsx +159 -0
  305. package/src/ui/hooks/useApp.tsx +289 -0
  306. package/src/ui/hooks/useCapabilities.ts +67 -0
  307. package/src/{react → ui/hooks}/useLoading.tsx +4 -6
  308. package/src/ui/hooks/useSettingsState.ts +26 -0
  309. package/src/ui/hooks/useSurface.ts +13 -0
  310. package/src/ui/index.ts +6 -0
  311. package/src/vite-plugin/composer-plugin.ts +128 -0
  312. package/src/vite-plugin/import-map-plugin.ts +314 -0
  313. package/src/vite-plugin/index.ts +6 -0
  314. package/src/vite-plugin/packages.ts +29 -0
  315. package/tsconfig.json +12 -27
  316. package/tsconfig.node.json +2 -4
  317. package/typedoc.json +2 -4
  318. package/vitest.config.ts +1 -1
  319. package/.swc/plugins/linux_x86_64_19.0.0/fce1bdb8e20a094e4af08bad09cc81497ed0e2e7c51223b07d371063cca18429.wasmer-v7 +0 -0
  320. package/dist/lib/browser/app-graph-builder-OIEZZC45.mjs +0 -138
  321. package/dist/lib/browser/app-graph-builder-OIEZZC45.mjs.map +0 -7
  322. package/dist/lib/browser/chunk-SCPE4ZO2.mjs +0 -35
  323. package/dist/lib/browser/chunk-SCPE4ZO2.mjs.map +0 -7
  324. package/dist/lib/browser/chunk-VFUKEZIN.mjs +0 -483
  325. package/dist/lib/browser/chunk-VFUKEZIN.mjs.map +0 -7
  326. package/dist/lib/browser/chunk-WPW5VVAX.mjs +0 -1651
  327. package/dist/lib/browser/chunk-WPW5VVAX.mjs.map +0 -7
  328. package/dist/lib/browser/intent-dispatcher-LZ4AE66E.mjs +0 -11
  329. package/dist/lib/browser/intent-resolver-QVCKRX6G.mjs +0 -39
  330. package/dist/lib/browser/intent-resolver-QVCKRX6G.mjs.map +0 -7
  331. package/dist/lib/browser/react/index.mjs +0 -34
  332. package/dist/lib/browser/store-CNPHOYTJ.mjs +0 -30
  333. package/dist/lib/browser/store-CNPHOYTJ.mjs.map +0 -7
  334. package/dist/lib/node-esm/app-graph-builder-EBU4NVWD.mjs +0 -139
  335. package/dist/lib/node-esm/app-graph-builder-EBU4NVWD.mjs.map +0 -7
  336. package/dist/lib/node-esm/chunk-IJOHO66N.mjs +0 -484
  337. package/dist/lib/node-esm/chunk-IJOHO66N.mjs.map +0 -7
  338. package/dist/lib/node-esm/chunk-XJZGUJ3H.mjs +0 -1653
  339. package/dist/lib/node-esm/chunk-XJZGUJ3H.mjs.map +0 -7
  340. package/dist/lib/node-esm/chunk-ZX63QUGE.mjs +0 -37
  341. package/dist/lib/node-esm/chunk-ZX63QUGE.mjs.map +0 -7
  342. package/dist/lib/node-esm/intent-dispatcher-MGOJ3CHD.mjs +0 -12
  343. package/dist/lib/node-esm/intent-resolver-URF3HN3G.mjs +0 -40
  344. package/dist/lib/node-esm/intent-resolver-URF3HN3G.mjs.map +0 -7
  345. package/dist/lib/node-esm/react/index.mjs +0 -35
  346. package/dist/lib/node-esm/store-RK5B4XEL.mjs +0 -31
  347. package/dist/lib/node-esm/store-RK5B4XEL.mjs.map +0 -7
  348. package/dist/types/src/common/collaboration.d.ts +0 -20
  349. package/dist/types/src/common/collaboration.d.ts.map +0 -1
  350. package/dist/types/src/common/events.d.ts +0 -52
  351. package/dist/types/src/common/events.d.ts.map +0 -1
  352. package/dist/types/src/common/file.d.ts +0 -14
  353. package/dist/types/src/common/file.d.ts.map +0 -1
  354. package/dist/types/src/common/graph.d.ts +0 -21
  355. package/dist/types/src/common/graph.d.ts.map +0 -1
  356. package/dist/types/src/common/layout.d.ts +0 -279
  357. package/dist/types/src/common/layout.d.ts.map +0 -1
  358. package/dist/types/src/common/surface.d.ts +0 -68
  359. package/dist/types/src/common/surface.d.ts.map +0 -1
  360. package/dist/types/src/core/capabilities.d.ts +0 -117
  361. package/dist/types/src/core/capabilities.d.ts.map +0 -1
  362. package/dist/types/src/core/capabilities.test.d.ts +0 -2
  363. package/dist/types/src/core/capabilities.test.d.ts.map +0 -1
  364. package/dist/types/src/core/events.d.ts.map +0 -1
  365. package/dist/types/src/core/manager.d.ts +0 -126
  366. package/dist/types/src/core/manager.d.ts.map +0 -1
  367. package/dist/types/src/core/manager.test.d.ts +0 -2
  368. package/dist/types/src/core/manager.test.d.ts.map +0 -1
  369. package/dist/types/src/playground/debug/Debug.d.ts +0 -6
  370. package/dist/types/src/playground/debug/Debug.d.ts.map +0 -1
  371. package/dist/types/src/playground/debug/index.d.ts +0 -2
  372. package/dist/types/src/playground/debug/index.d.ts.map +0 -1
  373. package/dist/types/src/playground/debug/plugin.d.ts +0 -2
  374. package/dist/types/src/playground/debug/plugin.d.ts.map +0 -1
  375. package/dist/types/src/playground/generator/Main.d.ts +0 -6
  376. package/dist/types/src/playground/generator/Main.d.ts.map +0 -1
  377. package/dist/types/src/playground/generator/Toolbar.d.ts +0 -6
  378. package/dist/types/src/playground/generator/Toolbar.d.ts.map +0 -1
  379. package/dist/types/src/playground/generator/generator.d.ts +0 -7
  380. package/dist/types/src/playground/generator/generator.d.ts.map +0 -1
  381. package/dist/types/src/playground/generator/index.d.ts +0 -3
  382. package/dist/types/src/playground/generator/index.d.ts.map +0 -1
  383. package/dist/types/src/playground/generator/plugin.d.ts +0 -2
  384. package/dist/types/src/playground/generator/plugin.d.ts.map +0 -1
  385. package/dist/types/src/playground/layout/Layout.d.ts +0 -8
  386. package/dist/types/src/playground/layout/Layout.d.ts.map +0 -1
  387. package/dist/types/src/playground/layout/index.d.ts +0 -2
  388. package/dist/types/src/playground/layout/index.d.ts.map +0 -1
  389. package/dist/types/src/playground/layout/plugin.d.ts +0 -2
  390. package/dist/types/src/playground/layout/plugin.d.ts.map +0 -1
  391. package/dist/types/src/playground/logger/Toolbar.d.ts +0 -6
  392. package/dist/types/src/playground/logger/Toolbar.d.ts.map +0 -1
  393. package/dist/types/src/playground/logger/index.d.ts +0 -2
  394. package/dist/types/src/playground/logger/index.d.ts.map +0 -1
  395. package/dist/types/src/playground/logger/plugin.d.ts +0 -2
  396. package/dist/types/src/playground/logger/plugin.d.ts.map +0 -1
  397. package/dist/types/src/playground/logger/schema.d.ts +0 -13
  398. package/dist/types/src/playground/logger/schema.d.ts.map +0 -1
  399. package/dist/types/src/playground/playground.stories.d.ts +0 -11
  400. package/dist/types/src/playground/playground.stories.d.ts.map +0 -1
  401. package/dist/types/src/plugin-intent/IntentPlugin.d.ts +0 -2
  402. package/dist/types/src/plugin-intent/IntentPlugin.d.ts.map +0 -1
  403. package/dist/types/src/plugin-intent/actions.d.ts +0 -36
  404. package/dist/types/src/plugin-intent/actions.d.ts.map +0 -1
  405. package/dist/types/src/plugin-intent/errors.d.ts +0 -16
  406. package/dist/types/src/plugin-intent/errors.d.ts.map +0 -1
  407. package/dist/types/src/plugin-intent/index.d.ts +0 -6
  408. package/dist/types/src/plugin-intent/index.d.ts.map +0 -1
  409. package/dist/types/src/plugin-intent/intent-dispatcher.d.ts +0 -139
  410. package/dist/types/src/plugin-intent/intent-dispatcher.d.ts.map +0 -1
  411. package/dist/types/src/plugin-intent/intent-dispatcher.test.d.ts +0 -2
  412. package/dist/types/src/plugin-intent/intent-dispatcher.test.d.ts.map +0 -1
  413. package/dist/types/src/plugin-intent/intent.d.ts +0 -63
  414. package/dist/types/src/plugin-intent/intent.d.ts.map +0 -1
  415. package/dist/types/src/plugin-intent/meta.d.ts +0 -3
  416. package/dist/types/src/plugin-intent/meta.d.ts.map +0 -1
  417. package/dist/types/src/plugin-settings/SettingsPlugin.d.ts +0 -2
  418. package/dist/types/src/plugin-settings/SettingsPlugin.d.ts.map +0 -1
  419. package/dist/types/src/plugin-settings/actions.d.ts +0 -25
  420. package/dist/types/src/plugin-settings/actions.d.ts.map +0 -1
  421. package/dist/types/src/plugin-settings/app-graph-builder.d.ts +0 -4
  422. package/dist/types/src/plugin-settings/app-graph-builder.d.ts.map +0 -1
  423. package/dist/types/src/plugin-settings/index.d.ts +0 -3
  424. package/dist/types/src/plugin-settings/index.d.ts.map +0 -1
  425. package/dist/types/src/plugin-settings/intent-resolver.d.ts +0 -4
  426. package/dist/types/src/plugin-settings/intent-resolver.d.ts.map +0 -1
  427. package/dist/types/src/plugin-settings/meta.d.ts +0 -3
  428. package/dist/types/src/plugin-settings/meta.d.ts.map +0 -1
  429. package/dist/types/src/plugin-settings/store.d.ts +0 -5
  430. package/dist/types/src/plugin-settings/store.d.ts.map +0 -1
  431. package/dist/types/src/plugin-settings/translations.d.ts +0 -11
  432. package/dist/types/src/plugin-settings/translations.d.ts.map +0 -1
  433. package/dist/types/src/react/App.d.ts +0 -10
  434. package/dist/types/src/react/App.d.ts.map +0 -1
  435. package/dist/types/src/react/App.stories.d.ts.map +0 -1
  436. package/dist/types/src/react/DefaultFallback.d.ts +0 -8
  437. package/dist/types/src/react/DefaultFallback.d.ts.map +0 -1
  438. package/dist/types/src/react/ErrorBoundary.d.ts +0 -30
  439. package/dist/types/src/react/ErrorBoundary.d.ts.map +0 -1
  440. package/dist/types/src/react/IntentContext.d.ts +0 -8
  441. package/dist/types/src/react/IntentContext.d.ts.map +0 -1
  442. package/dist/types/src/react/PluginManagerProvider.d.ts +0 -10
  443. package/dist/types/src/react/PluginManagerProvider.d.ts.map +0 -1
  444. package/dist/types/src/react/Surface.d.ts +0 -12
  445. package/dist/types/src/react/Surface.d.ts.map +0 -1
  446. package/dist/types/src/react/Surface.stories.d.ts.map +0 -1
  447. package/dist/types/src/react/common.d.ts +0 -13
  448. package/dist/types/src/react/common.d.ts.map +0 -1
  449. package/dist/types/src/react/index.d.ts +0 -9
  450. package/dist/types/src/react/index.d.ts.map +0 -1
  451. package/dist/types/src/react/types.d.ts +0 -14
  452. package/dist/types/src/react/types.d.ts.map +0 -1
  453. package/dist/types/src/react/useApp.d.ts.map +0 -1
  454. package/dist/types/src/react/useCapabilities.d.ts +0 -13
  455. package/dist/types/src/react/useCapabilities.d.ts.map +0 -1
  456. package/dist/types/src/react/useIntentResolver.d.ts +0 -3
  457. package/dist/types/src/react/useIntentResolver.d.ts.map +0 -1
  458. package/dist/types/src/react/useLoading.d.ts.map +0 -1
  459. package/src/common/collaboration.ts +0 -18
  460. package/src/common/events.ts +0 -79
  461. package/src/common/file.ts +0 -22
  462. package/src/common/graph.ts +0 -30
  463. package/src/common/layout.ts +0 -277
  464. package/src/common/surface.ts +0 -88
  465. package/src/core/capabilities.test.ts +0 -136
  466. package/src/core/capabilities.ts +0 -263
  467. package/src/core/manager.test.ts +0 -516
  468. package/src/core/manager.ts +0 -604
  469. package/src/playground/debug/Debug.tsx +0 -39
  470. package/src/playground/debug/plugin.ts +0 -16
  471. package/src/playground/generator/Main.tsx +0 -70
  472. package/src/playground/generator/Toolbar.tsx +0 -47
  473. package/src/playground/generator/generator.ts +0 -48
  474. package/src/playground/generator/index.ts +0 -6
  475. package/src/playground/generator/plugin.ts +0 -22
  476. package/src/playground/layout/Layout.tsx +0 -33
  477. package/src/playground/layout/plugin.ts +0 -18
  478. package/src/playground/logger/Toolbar.tsx +0 -30
  479. package/src/playground/logger/plugin.ts +0 -41
  480. package/src/playground/logger/schema.ts +0 -12
  481. package/src/playground/playground.stories.tsx +0 -46
  482. package/src/plugin-intent/IntentPlugin.ts +0 -20
  483. package/src/plugin-intent/actions.ts +0 -31
  484. package/src/plugin-intent/errors.ts +0 -40
  485. package/src/plugin-intent/index.ts +0 -9
  486. package/src/plugin-intent/intent-dispatcher.test.ts +0 -286
  487. package/src/plugin-intent/intent-dispatcher.ts +0 -342
  488. package/src/plugin-intent/intent.ts +0 -154
  489. package/src/plugin-intent/meta.ts +0 -10
  490. package/src/plugin-settings/SettingsPlugin.ts +0 -34
  491. package/src/plugin-settings/actions.ts +0 -25
  492. package/src/plugin-settings/app-graph-builder.ts +0 -160
  493. package/src/plugin-settings/index.ts +0 -6
  494. package/src/plugin-settings/intent-resolver.ts +0 -35
  495. package/src/plugin-settings/meta.ts +0 -10
  496. package/src/plugin-settings/store.ts +0 -33
  497. package/src/plugin-settings/translations.ts +0 -19
  498. package/src/react/App.stories.tsx +0 -33
  499. package/src/react/DefaultFallback.tsx +0 -26
  500. package/src/react/ErrorBoundary.tsx +0 -56
  501. package/src/react/IntentContext.tsx +0 -35
  502. package/src/react/Surface.tsx +0 -109
  503. package/src/react/common.ts +0 -13
  504. package/src/react/index.ts +0 -14
  505. package/src/react/types.ts +0 -37
  506. package/src/react/useApp.tsx +0 -165
  507. package/src/react/useCapabilities.ts +0 -31
  508. package/src/react/useIntentResolver.ts +0 -22
  509. /package/dist/lib/browser/{intent-dispatcher-LZ4AE66E.mjs.map → chunk-J5LGTIGS.mjs.map} +0 -0
  510. /package/dist/lib/browser/{react/index.mjs.map → chunk-RFSO3JRG.mjs.map} +0 -0
  511. /package/dist/lib/{node-esm/intent-dispatcher-MGOJ3CHD.mjs.map → browser/common/activation-events.mjs.map} +0 -0
  512. /package/dist/lib/{node-esm/react/index.mjs.map → browser/common/capabilities.mjs.map} +0 -0
@@ -0,0 +1,906 @@
1
+ import { createRequire } from 'node:module';const require = createRequire(import.meta.url);
2
+ import {
3
+ PluginManagerContext
4
+ } from "./chunk-FKE4Z3D6.mjs";
5
+ import {
6
+ capabilities_exports
7
+ } from "./chunk-G3RTFSNG.mjs";
8
+ import {
9
+ activation_events_exports
10
+ } from "./chunk-WZCSOX5Q.mjs";
11
+ import {
12
+ plugin_manager_exports
13
+ } from "./chunk-BCEOLX47.mjs";
14
+
15
+ // src/ui/components/App/App.tsx
16
+ import React2 from "react";
17
+
18
+ // src/helpers.ts
19
+ var topologicalSort = (nodes) => {
20
+ const getDependencies = (nodeId, seen = /* @__PURE__ */ new Set(), path = /* @__PURE__ */ new Set()) => {
21
+ if (path.has(nodeId)) {
22
+ throw new Error(`Circular dependency detected involving ${nodeId}`);
23
+ }
24
+ if (seen.has(nodeId)) {
25
+ return [];
26
+ }
27
+ const node = nodes.find((n) => n.id === nodeId);
28
+ if (!node) {
29
+ throw new Error(`Node ${nodeId} not found but is listed as a dependency`);
30
+ }
31
+ const newPath = /* @__PURE__ */ new Set([
32
+ ...path,
33
+ nodeId
34
+ ]);
35
+ const newSeen = /* @__PURE__ */ new Set([
36
+ ...seen,
37
+ nodeId
38
+ ]);
39
+ const dependsOn = node.dependsOn ?? [];
40
+ return [
41
+ ...dependsOn.flatMap((depId) => getDependencies(depId, newSeen, newPath)),
42
+ nodeId
43
+ ];
44
+ };
45
+ const allDependencies = nodes.map((node) => node.id).flatMap((id) => getDependencies(id)).filter((id, index, self) => self.indexOf(id) === index);
46
+ return allDependencies.map((id) => nodes.find((node) => node.id === id)).filter((node) => node !== void 0);
47
+ };
48
+
49
+ // src/ui/hooks/useApp.tsx
50
+ import { RegistryContext } from "@effect-atom/atom-react";
51
+ import * as Effect from "effect/Effect";
52
+ import * as Fiber from "effect/Fiber";
53
+ import * as PubSub from "effect/PubSub";
54
+ import * as Queue from "effect/Queue";
55
+ import React, { useCallback, useEffect, useMemo, useRef, useState } from "react";
56
+ import { runAndForwardErrors } from "@dxos/effect";
57
+ import { invariant } from "@dxos/invariant";
58
+ import { log } from "@dxos/log";
59
+ import { ErrorBoundary, ErrorFallback } from "@dxos/react-error-boundary";
60
+ import { useAsyncEffect, useDefaultValue } from "@dxos/react-hooks";
61
+ import { ContextProtocolProvider } from "@dxos/web-context-react";
62
+ var __dxlog_file = "/__w/dxos/dxos/packages/sdk/app-framework/src/ui/hooks/useApp.tsx";
63
+ var ENABLED_KEY = "org.dxos.app-framework.enabled";
64
+ var useApp = ({ pluginManager, pluginLoader: pluginLoaderProp, plugins: pluginsProp, core: coreProp, defaults: defaultsProp, setupEvents: setupEventsProp, placeholder, fallback = ErrorFallback, cacheEnabled = false, safeMode = false, debounce = 0, timeout = 3e4 }) => {
65
+ const plugins = useDefaultValue(pluginsProp, () => []);
66
+ const core = useDefaultValue(coreProp, () => plugins.map(({ meta }) => meta.id));
67
+ const defaults = useDefaultValue(defaultsProp, () => []);
68
+ const setupEvents = useDefaultValue(setupEventsProp, () => []);
69
+ const pluginLoader = useMemo(() => pluginLoaderProp ?? ((id) => Effect.sync(() => {
70
+ const plugin = plugins.find((plugin2) => plugin2.meta.id === id);
71
+ invariant(plugin, `Plugin not found: ${id}`, {
72
+ F: __dxlog_file,
73
+ L: 111,
74
+ S: void 0,
75
+ A: [
76
+ "plugin",
77
+ "`Plugin not found: ${id}`"
78
+ ]
79
+ });
80
+ return plugin;
81
+ })), [
82
+ pluginLoaderProp,
83
+ plugins
84
+ ]);
85
+ const readyRef = useRef(false);
86
+ const [ready, setReady] = useState(false);
87
+ const errorRef = useRef(null);
88
+ const [error, setError] = useState(null);
89
+ const [startupProgress, setStartupProgress] = useState({
90
+ activated: 0,
91
+ total: 0,
92
+ progress: 0
93
+ });
94
+ const cached = useMemo(() => JSON.parse(localStorage.getItem(ENABLED_KEY) ?? "[]"), []);
95
+ const enabled = useMemo(() => safeMode ? [] : cacheEnabled && cached.length > 0 ? cached : defaults, [
96
+ safeMode,
97
+ cacheEnabled,
98
+ cached,
99
+ defaults
100
+ ]);
101
+ const isExternalManager = !!pluginManager;
102
+ const manager = useMemo(() => {
103
+ const mgr = pluginManager ?? plugin_manager_exports.make({
104
+ pluginLoader,
105
+ plugins,
106
+ core,
107
+ enabled
108
+ });
109
+ log("useApp: useMemo created/reused manager", {
110
+ provided: !!pluginManager
111
+ }, {
112
+ F: __dxlog_file,
113
+ L: 135,
114
+ S: void 0,
115
+ C: (f, a) => f(...a)
116
+ });
117
+ return mgr;
118
+ }, [
119
+ pluginManager,
120
+ pluginLoader,
121
+ plugins,
122
+ core,
123
+ enabled
124
+ ]);
125
+ useEffect(() => {
126
+ if (!cacheEnabled) {
127
+ return;
128
+ }
129
+ return manager.registry.subscribe(manager.enabled, (value) => {
130
+ localStorage.setItem(ENABLED_KEY, JSON.stringify(value));
131
+ });
132
+ }, [
133
+ cacheEnabled,
134
+ manager
135
+ ]);
136
+ useEffect(() => {
137
+ setupDevtools(manager);
138
+ }, [
139
+ manager
140
+ ]);
141
+ useAsyncEffect(async () => {
142
+ log("useApp: effect mount", void 0, {
143
+ F: __dxlog_file,
144
+ L: 153,
145
+ S: void 0,
146
+ C: (f, a) => f(...a)
147
+ });
148
+ manager.capabilities.contribute({
149
+ interface: capabilities_exports.PluginManager,
150
+ implementation: manager,
151
+ module: "org.dxos.app-framework.plugin-manager"
152
+ });
153
+ manager.capabilities.contribute({
154
+ interface: capabilities_exports.AtomRegistry,
155
+ implementation: manager.registry,
156
+ module: "org.dxos.app-framework.atom-registry"
157
+ });
158
+ const progressInterval = setInterval(() => {
159
+ if (readyRef.current) {
160
+ clearInterval(progressInterval);
161
+ return;
162
+ }
163
+ const active = manager.getActive();
164
+ const modules = manager.getModules();
165
+ const total = modules.length;
166
+ const activated = active.length;
167
+ const lastModule = active.length > 0 ? active[active.length - 1] : void 0;
168
+ setStartupProgress({
169
+ activated,
170
+ total,
171
+ progress: total > 0 ? activated / total : 0,
172
+ status: lastModule ? humanizeModuleId(lastModule) : void 0
173
+ });
174
+ }, 100);
175
+ const fiber = Effect.gen(function* () {
176
+ const queue = yield* PubSub.subscribe(manager.activation);
177
+ const listener = yield* Effect.forkDaemon(Queue.take(queue).pipe(Effect.tap(({ event, state, error: error$ }) => Effect.sync(() => {
178
+ if (event === activation_events_exports.Startup.id && state === "activated") {
179
+ clearTimeout(timeoutId);
180
+ clearInterval(progressInterval);
181
+ setReady(true);
182
+ readyRef.current = true;
183
+ globalThis.composer?.profiler?.dump();
184
+ }
185
+ if (error$ && !readyRef.current) {
186
+ setError(error$);
187
+ errorRef.current = error$;
188
+ }
189
+ })), Effect.forever));
190
+ yield* Effect.all([
191
+ ...setupEvents.map((event) => manager.activate(event)),
192
+ manager.activate(activation_events_exports.SetupReactSurface),
193
+ manager.activate(activation_events_exports.Startup)
194
+ ]);
195
+ return yield* Fiber.join(listener);
196
+ }).pipe(Effect.scoped, Effect.runFork);
197
+ const timeoutId = setTimeout(() => {
198
+ if (!readyRef.current && !errorRef.current) {
199
+ log.warn("startup timeout diagnostic", {
200
+ eventsFired: manager.getEventsFired(),
201
+ activeModules: manager.getActive(),
202
+ pendingReset: manager.getPendingReset()
203
+ }, {
204
+ F: __dxlog_file,
205
+ L: 222,
206
+ S: void 0,
207
+ C: (f, a) => f(...a)
208
+ });
209
+ void runAndForwardErrors(Fiber.interrupt(fiber));
210
+ setError(new Error(`Startup timed out after ${timeout}ms`));
211
+ }
212
+ }, timeout);
213
+ return () => {
214
+ log("useApp: effect cleanup", void 0, {
215
+ F: __dxlog_file,
216
+ L: 233,
217
+ S: void 0,
218
+ C: (f, a) => f(...a)
219
+ });
220
+ clearTimeout(timeoutId);
221
+ clearInterval(progressInterval);
222
+ void runAndForwardErrors(Fiber.interrupt(fiber));
223
+ if (!isExternalManager) {
224
+ void runAndForwardErrors(manager.shutdown());
225
+ }
226
+ };
227
+ }, [
228
+ manager
229
+ ]);
230
+ return useCallback(() => /* @__PURE__ */ React.createElement(ErrorBoundary, {
231
+ name: "app",
232
+ FallbackComponent: fallback
233
+ }, /* @__PURE__ */ React.createElement(PluginManagerProvider, {
234
+ value: manager
235
+ }, /* @__PURE__ */ React.createElement(ContextProtocolProvider, {
236
+ value: manager,
237
+ context: PluginManagerContext
238
+ }, /* @__PURE__ */ React.createElement(RegistryContext.Provider, {
239
+ value: manager.registry
240
+ }, /* @__PURE__ */ React.createElement(App, {
241
+ placeholder,
242
+ ready,
243
+ error,
244
+ debounce,
245
+ progress: startupProgress
246
+ }))))), [
247
+ fallback,
248
+ manager,
249
+ placeholder,
250
+ ready,
251
+ error
252
+ ]);
253
+ };
254
+ var setupDevtools = (manager) => {
255
+ globalThis.composer ??= {};
256
+ globalThis.composer.manager = manager;
257
+ };
258
+ var humanizeModuleId = (moduleId) => {
259
+ const pluginMatch = moduleId.match(/\.plugin\.([^.]+)\./);
260
+ if (pluginMatch) {
261
+ const name = pluginMatch[1];
262
+ return name.split("-").map((word) => word.charAt(0).toUpperCase() + word.slice(1)).join(" ");
263
+ }
264
+ const parts = moduleId.split(".");
265
+ return parts[parts.length - 1];
266
+ };
267
+
268
+ // src/ui/hooks/useCapabilities.ts
269
+ import { useAtomValue } from "@effect-atom/atom-react";
270
+ import { useCallback as useCallback2 } from "react";
271
+ import { invariant as invariant2 } from "@dxos/invariant";
272
+ var __dxlog_file2 = "/__w/dxos/dxos/packages/sdk/app-framework/src/ui/hooks/useCapabilities.ts";
273
+ var useCapabilities = (interfaceDef) => {
274
+ const manager = usePluginManager();
275
+ return useAtomValue(manager.capabilities.atom(interfaceDef));
276
+ };
277
+ var useCapability = (interfaceDef) => {
278
+ const capabilities = useCapabilities(interfaceDef);
279
+ invariant2(capabilities.length > 0, `No capability found for ${interfaceDef.identifier}`, {
280
+ F: __dxlog_file2,
281
+ L: 30,
282
+ S: void 0,
283
+ A: [
284
+ "capabilities.length > 0",
285
+ "`No capability found for ${interfaceDef.identifier}`"
286
+ ]
287
+ });
288
+ return capabilities[0];
289
+ };
290
+ var useAtomCapability = (atomCapability) => {
291
+ const atom = useCapability(atomCapability);
292
+ return useAtomValue(atom);
293
+ };
294
+ var useAtomCapabilityState = (atomCapability) => {
295
+ const registry = useCapability(capabilities_exports.AtomRegistry);
296
+ const atom = useCapability(atomCapability);
297
+ const value = useAtomValue(atom);
298
+ const update = useCallback2((fn) => {
299
+ registry.set(atom, fn(registry.get(atom)));
300
+ }, [
301
+ registry,
302
+ atom
303
+ ]);
304
+ return [
305
+ value,
306
+ update
307
+ ];
308
+ };
309
+ var useOperationInvoker = () => useCapability(capabilities_exports.OperationInvoker);
310
+
311
+ // src/ui/hooks/useLoading.tsx
312
+ import { useEffect as useEffect2, useState as useState2 } from "react";
313
+ var LoadingState = /* @__PURE__ */ (function(LoadingState2) {
314
+ LoadingState2[LoadingState2["Loading"] = 0] = "Loading";
315
+ LoadingState2[LoadingState2["FadeIn"] = 1] = "FadeIn";
316
+ LoadingState2[LoadingState2["FadeOut"] = 2] = "FadeOut";
317
+ LoadingState2[LoadingState2["Done"] = 3] = "Done";
318
+ return LoadingState2;
319
+ })({});
320
+ var useLoading = (ready, debounce = 0) => {
321
+ const [stage, setStage] = useState2(0);
322
+ useEffect2(() => {
323
+ if (!debounce) {
324
+ return;
325
+ }
326
+ const i = setInterval(() => {
327
+ setStage((stage2) => {
328
+ switch (stage2) {
329
+ case 0: {
330
+ if (!ready) {
331
+ return 1;
332
+ } else {
333
+ clearInterval(i);
334
+ return 3;
335
+ }
336
+ }
337
+ case 1: {
338
+ if (ready) {
339
+ return 2;
340
+ }
341
+ break;
342
+ }
343
+ case 2: {
344
+ clearInterval(i);
345
+ return 3;
346
+ }
347
+ }
348
+ return stage2;
349
+ });
350
+ }, debounce);
351
+ return () => clearInterval(i);
352
+ }, [
353
+ debounce
354
+ ]);
355
+ if (!debounce) {
356
+ return ready ? 3 : 0;
357
+ }
358
+ return stage;
359
+ };
360
+
361
+ // src/ui/hooks/useSettingsState.ts
362
+ import { RegistryContext as RegistryContext2, useAtomValue as useAtomValue2 } from "@effect-atom/atom-react";
363
+ import { useCallback as useCallback3, useContext } from "react";
364
+ var useSettingsState = (atom) => {
365
+ const registry = useContext(RegistryContext2);
366
+ const settings = useAtomValue2(atom);
367
+ const updateSettings = useCallback3((fn) => {
368
+ registry.set(atom, fn(registry.get(atom)));
369
+ }, [
370
+ registry,
371
+ atom
372
+ ]);
373
+ return {
374
+ settings,
375
+ updateSettings
376
+ };
377
+ };
378
+
379
+ // src/ui/hooks/useSurface.ts
380
+ import { useContext as useContext2 } from "react";
381
+ import { raise } from "@dxos/debug";
382
+ var useSurface = () => {
383
+ return useContext2(Surface.Context) ?? raise(new Error("Missing SurfaceContext"));
384
+ };
385
+
386
+ // src/ui/components/App/App.tsx
387
+ var App = ({ placeholder: Placeholder, ready, error, debounce, progress }) => {
388
+ const reactContexts = useCapabilities(capabilities_exports.ReactContext);
389
+ const reactRoots = useCapabilities(capabilities_exports.ReactRoot);
390
+ const stage = useLoading(ready, debounce);
391
+ if (error) {
392
+ throw error;
393
+ }
394
+ if (stage < LoadingState.Done) {
395
+ if (!Placeholder) {
396
+ return null;
397
+ }
398
+ return /* @__PURE__ */ React2.createElement(Placeholder, {
399
+ stage,
400
+ progress
401
+ });
402
+ }
403
+ const ComposedContext = composeContexts(reactContexts);
404
+ return /* @__PURE__ */ React2.createElement(ComposedContext, null, reactRoots.map(({ id, root: Component }) => /* @__PURE__ */ React2.createElement(Component, {
405
+ key: id
406
+ })));
407
+ };
408
+ var composeContexts = (contexts) => {
409
+ if (contexts.length === 0) {
410
+ return ({ children }) => /* @__PURE__ */ React2.createElement(React2.Fragment, null, children);
411
+ }
412
+ return topologicalSort(contexts).map(({ context }) => context).reduce((Acc, Next) => ({ children }) => /* @__PURE__ */ React2.createElement(Acc, null, /* @__PURE__ */ React2.createElement(Next, null, children)));
413
+ };
414
+
415
+ // src/ui/components/PluginManager/PluginManagerProvider.ts
416
+ import { createContext, useContext as useContext3 } from "react";
417
+ import { raise as raise2 } from "@dxos/debug";
418
+ var PluginManagerContext2 = createContext(void 0);
419
+ var usePluginManager = () => useContext3(PluginManagerContext2) ?? raise2(new Error("Missing PluginManagerContext"));
420
+ var PluginManagerProvider = PluginManagerContext2.Provider;
421
+
422
+ // src/ui/components/Surface/context.ts
423
+ import { createContext as createContext2 } from "react";
424
+ var SurfaceContext = createContext2(void 0);
425
+
426
+ // src/ui/components/Surface/SurfaceComponent.tsx
427
+ import { useAtomValue as useAtomValue3 } from "@effect-atom/atom-react";
428
+ import React5, { Fragment, Profiler, Suspense, forwardRef as forwardRef2, memo, useEffect as useEffect3, useMemo as useMemo3, useRef as useRef3 } from "react";
429
+ import { log as log2 } from "@dxos/log";
430
+ import { ErrorBoundary as ErrorBoundary2 } from "@dxos/react-error-boundary";
431
+ import { useDefaultValue as useDefaultValue2 } from "@dxos/react-hooks";
432
+ import { byPosition } from "@dxos/util";
433
+
434
+ // src/ui/components/Surface/SurfaceInfo.tsx
435
+ import React3, { cloneElement, forwardRef, useCallback as useCallback4, useLayoutEffect, useState as useState3 } from "react";
436
+ import { createPortal } from "react-dom";
437
+ import { addEventListener, combine } from "@dxos/async";
438
+ import { useMergeRefs } from "@dxos/react-hooks";
439
+ var SurfaceInfo = /* @__PURE__ */ forwardRef(({ children }, forwardedRef) => {
440
+ const [rect, setRect] = useState3(null);
441
+ const [expand, setExpand] = useState3(false);
442
+ const info = useSurface();
443
+ const [root, setRoot] = useState3(null);
444
+ const measureRef = useCallback4((node) => setRoot(node), []);
445
+ const mergedRef = useMergeRefs([
446
+ measureRef,
447
+ forwardedRef
448
+ ]);
449
+ const childWithRef = /* @__PURE__ */ cloneElement(children, {
450
+ ref: mergedRef
451
+ });
452
+ useLayoutEffect(() => {
453
+ if (!root) {
454
+ setRect(null);
455
+ return;
456
+ }
457
+ const measure = () => {
458
+ setRect(root.getBoundingClientRect());
459
+ };
460
+ const observer = new ResizeObserver(measure);
461
+ observer.observe(root);
462
+ measure();
463
+ return combine(addEventListener(window, "scroll", measure, true), addEventListener(window, "resize", measure), () => {
464
+ observer.disconnect();
465
+ });
466
+ }, [
467
+ root
468
+ ]);
469
+ const padding = 0;
470
+ return /* @__PURE__ */ React3.createElement(React3.Fragment, null, childWithRef, rect && /* @__PURE__ */ createPortal(
471
+ /* @__PURE__ */ React3.createElement("div", {
472
+ role: "none",
473
+ className: "z-[100] fixed flex flex-col-reverse scrollbar-none overflow-auto pointer-events-none",
474
+ style: {
475
+ top: rect.top + padding,
476
+ left: rect.left + padding,
477
+ width: rect.width - padding * 2,
478
+ height: rect.height - padding * 2
479
+ }
480
+ }, expand ? /* @__PURE__ */ React3.createElement("div", {
481
+ className: "absolute inset-0 bg-deck-surface border border-green-500 cursor-pointer pointer-events-auto overflow-auto",
482
+ onPointerDown: (ev) => ev.stopPropagation(),
483
+ onClick: (ev) => {
484
+ ev.stopPropagation();
485
+ setExpand(false);
486
+ }
487
+ }, /* @__PURE__ */ React3.createElement("pre", {
488
+ className: "p-2 text-xs text-description font-mono"
489
+ }, JSON.stringify({
490
+ info
491
+ }, null, 2))) : /* @__PURE__ */ React3.createElement("span", {
492
+ className: "absolute right-1 bottom-0 flex items-center p-1 text-green-500 opacity-80 hover:opacity-100 text-xl cursor-pointer pointer-events-auto",
493
+ title: info.id,
494
+ onPointerDown: (ev) => ev.stopPropagation(),
495
+ onClick: (ev) => {
496
+ ev.stopPropagation();
497
+ setExpand(true);
498
+ }
499
+ }, "\u24D8")),
500
+ // TODO(burdon): Create well-known element to gather all debug portals.
501
+ document.body
502
+ ));
503
+ });
504
+
505
+ // src/ui/components/Surface/SurfaceProfilerContext.tsx
506
+ import React4, { createContext as createContext3, useContext as useContext4, useMemo as useMemo2, useRef as useRef2, useSyncExternalStore } from "react";
507
+ var MAX_ENTRIES = 500;
508
+ var SurfaceProfilerStore = class {
509
+ _entries = [];
510
+ _listeners = /* @__PURE__ */ new Set();
511
+ _snapshot = [];
512
+ _pendingNotify = false;
513
+ /** Records an entry and schedules a deferred notification to avoid re-render loops. */
514
+ record(entry) {
515
+ this._entries.push(entry);
516
+ if (this._entries.length > MAX_ENTRIES) {
517
+ this._entries = this._entries.slice(-MAX_ENTRIES);
518
+ }
519
+ this._snapshot = [
520
+ ...this._entries
521
+ ];
522
+ this._scheduleNotify();
523
+ }
524
+ clear() {
525
+ this._entries = [];
526
+ this._snapshot = [];
527
+ this._notifySync();
528
+ }
529
+ subscribe = (listener) => {
530
+ this._listeners.add(listener);
531
+ return () => {
532
+ this._listeners.delete(listener);
533
+ };
534
+ };
535
+ getSnapshot = () => {
536
+ return this._snapshot;
537
+ };
538
+ /**
539
+ * Defers notification to the next animation frame to break the
540
+ * Profiler onRender → record → notify → re-render → onRender loop.
541
+ */
542
+ _scheduleNotify() {
543
+ if (!this._pendingNotify) {
544
+ this._pendingNotify = true;
545
+ requestAnimationFrame(() => {
546
+ this._pendingNotify = false;
547
+ this._notifySync();
548
+ });
549
+ }
550
+ }
551
+ _notifySync() {
552
+ for (const listener of this._listeners) {
553
+ listener();
554
+ }
555
+ }
556
+ };
557
+ var SurfaceProfilerContext = /* @__PURE__ */ createContext3(void 0);
558
+ var SurfaceProfilerProvider = ({ children }) => {
559
+ const storeRef = useRef2(null);
560
+ if (!storeRef.current) {
561
+ storeRef.current = new SurfaceProfilerStore();
562
+ }
563
+ return /* @__PURE__ */ React4.createElement(SurfaceProfilerContext.Provider, {
564
+ value: {
565
+ store: storeRef.current
566
+ }
567
+ }, children);
568
+ };
569
+ var useSurfaceProfilerCallback = () => {
570
+ const store = useContext4(SurfaceProfilerContext)?.store;
571
+ return useMemo2(() => {
572
+ if (!store) {
573
+ return void 0;
574
+ }
575
+ return (id, phase, actualDuration, baseDuration, startTime, commitTime) => {
576
+ store.record({
577
+ id,
578
+ phase,
579
+ actualDuration,
580
+ baseDuration,
581
+ startTime,
582
+ commitTime,
583
+ timestamp: Date.now()
584
+ });
585
+ };
586
+ }, [
587
+ store
588
+ ]);
589
+ };
590
+ var useSurfaceProfilerEntries = () => {
591
+ const context = useContext4(SurfaceProfilerContext);
592
+ return useSyncExternalStore(context?.store.subscribe ?? noop, context?.store.getSnapshot ?? emptySnapshot);
593
+ };
594
+ var useSurfaceProfilerStats = () => {
595
+ const entries = useSurfaceProfilerEntries();
596
+ const statsMap = /* @__PURE__ */ new Map();
597
+ for (const entry of entries) {
598
+ let stats = statsMap.get(entry.id);
599
+ if (!stats) {
600
+ stats = {
601
+ id: entry.id,
602
+ mountCount: 0,
603
+ updateCount: 0,
604
+ totalRenders: 0,
605
+ avgActualDuration: 0,
606
+ maxActualDuration: 0,
607
+ avgBaseDuration: 0,
608
+ lastActualDuration: 0,
609
+ lastCommitTime: 0
610
+ };
611
+ statsMap.set(entry.id, stats);
612
+ }
613
+ if (entry.phase === "mount") {
614
+ stats.mountCount++;
615
+ } else {
616
+ stats.updateCount++;
617
+ }
618
+ stats.totalRenders++;
619
+ stats.avgActualDuration = (stats.avgActualDuration * (stats.totalRenders - 1) + entry.actualDuration) / stats.totalRenders;
620
+ stats.avgBaseDuration = (stats.avgBaseDuration * (stats.totalRenders - 1) + entry.baseDuration) / stats.totalRenders;
621
+ stats.maxActualDuration = Math.max(stats.maxActualDuration, entry.actualDuration);
622
+ stats.lastActualDuration = entry.actualDuration;
623
+ stats.lastCommitTime = entry.commitTime;
624
+ }
625
+ return [
626
+ ...statsMap.values()
627
+ ].sort((a, b) => b.maxActualDuration - a.maxActualDuration);
628
+ };
629
+ var useSurfaceProfilerClear = () => {
630
+ const store = useContext4(SurfaceProfilerContext)?.store;
631
+ return useMemo2(() => store ? () => store.clear() : void 0, [
632
+ store
633
+ ]);
634
+ };
635
+ var noop = () => () => {
636
+ };
637
+ var EMPTY_SNAPSHOT = [];
638
+ var emptySnapshot = () => EMPTY_SNAPSHOT;
639
+
640
+ // src/ui/components/Surface/SurfaceComponent.tsx
641
+ var __dxlog_file3 = "/__w/dxos/dxos/packages/sdk/app-framework/src/ui/components/Surface/SurfaceComponent.tsx";
642
+ var DEBUG = import.meta.env.VITE_DEBUG;
643
+ var DEFAULT_PLACEHOLDER = /* @__PURE__ */ React5.createElement(Fragment, null);
644
+ var WebComponentWrapper = /* @__PURE__ */ memo(/* @__PURE__ */ forwardRef2(({ id, role, data, limit, definition, ...rest }, forwardedRef) => {
645
+ const containerRef = useRef3(null);
646
+ const elementRef = useRef3(null);
647
+ const propsRef = useRef3({
648
+ id,
649
+ role,
650
+ data,
651
+ limit,
652
+ ...rest
653
+ });
654
+ propsRef.current = {
655
+ id,
656
+ role,
657
+ data,
658
+ limit,
659
+ ...rest
660
+ };
661
+ useEffect3(() => {
662
+ if (!containerRef.current || elementRef.current) {
663
+ return;
664
+ }
665
+ const element = document.createElement(definition.tagName);
666
+ elementRef.current = element;
667
+ Object.assign(element, propsRef.current);
668
+ containerRef.current.appendChild(element);
669
+ if (typeof forwardedRef === "function") {
670
+ forwardedRef(element);
671
+ } else if (forwardedRef) {
672
+ forwardedRef.current = element;
673
+ }
674
+ return () => {
675
+ if (elementRef.current && containerRef.current?.contains(elementRef.current)) {
676
+ containerRef.current.removeChild(elementRef.current);
677
+ }
678
+ if (typeof forwardedRef === "function") {
679
+ forwardedRef(null);
680
+ } else if (forwardedRef) {
681
+ forwardedRef.current = null;
682
+ }
683
+ elementRef.current = null;
684
+ };
685
+ }, [
686
+ definition.tagName,
687
+ forwardedRef
688
+ ]);
689
+ useEffect3(() => {
690
+ const element = elementRef.current;
691
+ if (!element) {
692
+ return;
693
+ }
694
+ Object.assign(element, propsRef.current);
695
+ });
696
+ return /* @__PURE__ */ React5.createElement("div", {
697
+ ref: containerRef
698
+ });
699
+ }));
700
+ WebComponentWrapper.displayName = "WebComponentWrapper";
701
+ var SurfaceContextProvider = /* @__PURE__ */ memo(/* @__PURE__ */ forwardRef2(({ id, role, data, limit, fallback = ErrorFallback2, definition, ...rest }, forwardedRef) => {
702
+ const contextValue = useMemo3(() => ({
703
+ id,
704
+ role,
705
+ data
706
+ }), [
707
+ id,
708
+ role,
709
+ data
710
+ ]);
711
+ const onProfilerRender = useSurfaceProfilerCallback();
712
+ const profilerId = `surface/${id}/${role}`;
713
+ if (definition.kind === "web-component") {
714
+ return /* @__PURE__ */ React5.createElement(ErrorBoundary2, {
715
+ name: "surface",
716
+ resetKeys: [
717
+ data
718
+ ],
719
+ FallbackComponent: fallback
720
+ }, /* @__PURE__ */ React5.createElement(SurfaceContext.Provider, {
721
+ value: contextValue
722
+ }, /* @__PURE__ */ React5.createElement(WebComponentWrapper, {
723
+ id,
724
+ role,
725
+ data,
726
+ limit,
727
+ definition,
728
+ ref: forwardedRef,
729
+ ...rest
730
+ })));
731
+ }
732
+ const Component = definition.component;
733
+ const debug = DEBUG || "__DX_DEBUG__" in window;
734
+ if (debug) {
735
+ return /* @__PURE__ */ React5.createElement(ErrorBoundary2, {
736
+ name: "surface",
737
+ resetKeys: [
738
+ data
739
+ ],
740
+ FallbackComponent: fallback
741
+ }, /* @__PURE__ */ React5.createElement("div", {
742
+ role: "none",
743
+ className: "contents",
744
+ "data-id": id,
745
+ "data-role": role
746
+ }, /* @__PURE__ */ React5.createElement(SurfaceContext.Provider, {
747
+ value: contextValue
748
+ }, /* @__PURE__ */ React5.createElement(SurfaceInfo, {
749
+ ref: forwardedRef
750
+ }, onProfilerRender && !profilerId.includes("org.dxos.plugin.debug") ? /* @__PURE__ */ React5.createElement(Profiler, {
751
+ id: profilerId,
752
+ onRender: onProfilerRender
753
+ }, /* @__PURE__ */ React5.createElement(Component, {
754
+ id,
755
+ role,
756
+ data,
757
+ limit,
758
+ ...rest
759
+ })) : /* @__PURE__ */ React5.createElement(Component, {
760
+ id,
761
+ role,
762
+ data,
763
+ limit,
764
+ ...rest
765
+ })))));
766
+ }
767
+ return /* @__PURE__ */ React5.createElement(ErrorBoundary2, {
768
+ name: "surface",
769
+ resetKeys: [
770
+ data
771
+ ],
772
+ FallbackComponent: fallback
773
+ }, /* @__PURE__ */ React5.createElement("div", {
774
+ role: "none",
775
+ className: "contents",
776
+ "data-id": id,
777
+ "data-role": role
778
+ }, /* @__PURE__ */ React5.createElement(SurfaceContext.Provider, {
779
+ value: contextValue
780
+ }, /* @__PURE__ */ React5.createElement(Component, {
781
+ id,
782
+ role,
783
+ data,
784
+ limit,
785
+ ...rest,
786
+ ref: forwardedRef
787
+ }))));
788
+ }));
789
+ SurfaceContextProvider.displayName = "SurfaceContextProvider";
790
+ var SurfaceComponent = /* @__PURE__ */ memo(/* @__PURE__ */ forwardRef2(({ id: _id, role, data: dataProp, limit, placeholder = DEFAULT_PLACEHOLDER, ...rest }, forwardedRef) => {
791
+ const data = useDefaultValue2(dataProp, () => ({}));
792
+ const surfaces = useSurfaces();
793
+ const definitions = findCandidates(surfaces, {
794
+ role,
795
+ data
796
+ });
797
+ const candidates = limit ? definitions.slice(0, limit) : definitions;
798
+ if (DEBUG && candidates.length === 0) {
799
+ log2.warn("no candidates for surface", {
800
+ role,
801
+ data
802
+ }, {
803
+ F: __dxlog_file3,
804
+ L: 195,
805
+ S: void 0,
806
+ C: (f, a) => f(...a)
807
+ });
808
+ return null;
809
+ }
810
+ return /* @__PURE__ */ React5.createElement(Suspense, {
811
+ fallback: placeholder
812
+ }, candidates.map((definition) => /* @__PURE__ */ React5.createElement(SurfaceContextProvider, {
813
+ key: definition.id,
814
+ id: definition.id,
815
+ role,
816
+ data,
817
+ limit,
818
+ definition,
819
+ ref: forwardedRef,
820
+ ...rest
821
+ })));
822
+ }));
823
+ SurfaceComponent.displayName = "Surface";
824
+ var ErrorFallback2 = ({ error }) => {
825
+ const { message } = error instanceof Error ? error : {
826
+ message: String(error)
827
+ };
828
+ return /* @__PURE__ */ React5.createElement("div", {
829
+ role: "alert",
830
+ "data-testid": "error-boundary-fallback"
831
+ }, /* @__PURE__ */ React5.createElement("h1", {
832
+ className: "flex gap-2 text-sm mt-2 text-info-text"
833
+ }, message));
834
+ };
835
+ var findCandidates = (surfaces, { role, data }) => {
836
+ return Object.values(surfaces).filter((definition) => Array.isArray(definition.role) ? definition.role.includes(role) : definition.role === role).filter(({ filter }) => filter ? filter(data ?? {}) : true).toSorted(byPosition);
837
+ };
838
+ var useSurfaces = () => {
839
+ const manager = usePluginManager();
840
+ const surfacesByModule = useAtomValue3(manager.capabilities.atomByModule(capabilities_exports.ReactSurface));
841
+ return useMemo3(() => {
842
+ const result = [];
843
+ for (const [moduleId, surfaces] of Object.entries(surfacesByModule)) {
844
+ for (const def of surfaces.flat()) {
845
+ result.push({
846
+ ...def,
847
+ id: `${moduleId}.${def.id}`
848
+ });
849
+ }
850
+ }
851
+ return result;
852
+ }, [
853
+ surfacesByModule
854
+ ]);
855
+ };
856
+ var isSurfaceAvailable = (capabilityManager, { role, data }) => {
857
+ const surfaces = capabilityManager.getAll(capabilities_exports.ReactSurface);
858
+ const candidates = findCandidates(surfaces.flat(), {
859
+ role,
860
+ data
861
+ });
862
+ return candidates.length > 0;
863
+ };
864
+
865
+ // src/ui/components/Surface/types.ts
866
+ var create = (definition) => ({
867
+ ...definition,
868
+ kind: "react"
869
+ });
870
+ var createWeb = (definition) => ({
871
+ ...definition,
872
+ kind: "web-component"
873
+ });
874
+
875
+ // src/ui/components/Surface/index.ts
876
+ (function(Surface2) {
877
+ Surface2.create = create;
878
+ Surface2.createWeb = createWeb;
879
+ Surface2.Context = SurfaceContext;
880
+ Surface2.Surface = SurfaceComponent;
881
+ Surface2.isAvailable = isSurfaceAvailable;
882
+ Surface2.ProfilerProvider = SurfaceProfilerProvider;
883
+ Surface2.useProfilerCallback = useSurfaceProfilerCallback;
884
+ Surface2.useProfilerEntries = useSurfaceProfilerEntries;
885
+ Surface2.useProfilerStats = useSurfaceProfilerStats;
886
+ Surface2.useProfilerClear = useSurfaceProfilerClear;
887
+ })(Surface || (Surface = {}));
888
+ var Surface;
889
+
890
+ export {
891
+ useApp,
892
+ useCapabilities,
893
+ useCapability,
894
+ useAtomCapability,
895
+ useAtomCapabilityState,
896
+ useOperationInvoker,
897
+ LoadingState,
898
+ useLoading,
899
+ useSettingsState,
900
+ useSurface,
901
+ App,
902
+ usePluginManager,
903
+ PluginManagerProvider,
904
+ Surface
905
+ };
906
+ //# sourceMappingURL=chunk-LQKOTNJW.mjs.map