@dxos/app-framework 0.8.4-main.9be5663bfe → 0.8.4-main.abd8ff62ef

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (278) hide show
  1. package/dist/lib/browser/{capability-BBBBAPDI.mjs → capability-Q5XRXRD2.mjs} +10 -10
  2. package/dist/lib/browser/{capability-OP63CD5N.mjs → capability-V7LR4LQN.mjs} +11 -11
  3. package/dist/lib/browser/capability-V7LR4LQN.mjs.map +7 -0
  4. package/dist/lib/browser/{chunk-T3Y4AEKX.mjs → chunk-23D4SJUE.mjs} +3 -3
  5. package/dist/lib/browser/{chunk-T3Y4AEKX.mjs.map → chunk-23D4SJUE.mjs.map} +1 -1
  6. package/dist/lib/browser/{chunk-2CKCJ6PN.mjs → chunk-3JWJXGLK.mjs} +1 -1
  7. package/dist/lib/browser/{chunk-2CKCJ6PN.mjs.map → chunk-3JWJXGLK.mjs.map} +1 -1
  8. package/dist/lib/browser/{chunk-GX4TUNM6.mjs → chunk-3ZS2A3DN.mjs} +170 -226
  9. package/dist/lib/browser/chunk-3ZS2A3DN.mjs.map +7 -0
  10. package/dist/lib/browser/{chunk-I34GF4NG.mjs → chunk-45CHLTBV.mjs} +2 -2
  11. package/dist/lib/browser/chunk-5LAIGWLU.mjs +467 -0
  12. package/dist/lib/browser/chunk-5LAIGWLU.mjs.map +7 -0
  13. package/dist/lib/browser/{chunk-QSXYHXCE.mjs → chunk-66IXTIVK.mjs} +1 -1
  14. package/dist/lib/browser/{chunk-QSXYHXCE.mjs.map → chunk-66IXTIVK.mjs.map} +2 -2
  15. package/dist/lib/browser/{chunk-TGX63LTL.mjs → chunk-FJ4765WW.mjs} +1 -1
  16. package/dist/lib/browser/{chunk-TGX63LTL.mjs.map → chunk-FJ4765WW.mjs.map} +2 -2
  17. package/dist/lib/browser/chunk-G7SDBRKH.mjs +1 -0
  18. package/dist/lib/browser/chunk-JXCBZSBJ.mjs +372 -0
  19. package/dist/lib/browser/chunk-JXCBZSBJ.mjs.map +7 -0
  20. package/dist/lib/browser/chunk-MX5DKEJH.mjs +584 -0
  21. package/dist/lib/browser/chunk-MX5DKEJH.mjs.map +7 -0
  22. package/dist/lib/browser/{chunk-JKWMHZP6.mjs → chunk-WBHCSOBW.mjs} +2 -2
  23. package/dist/lib/browser/chunk-WBHCSOBW.mjs.map +7 -0
  24. package/dist/lib/browser/{chunk-FU4GAFUQ.mjs → chunk-Z55LVAGN.mjs} +80 -15
  25. package/dist/lib/browser/chunk-Z55LVAGN.mjs.map +7 -0
  26. package/dist/lib/browser/{chunk-F7FW2RK2.mjs → chunk-ZGJAZSNE.mjs} +7 -32
  27. package/dist/lib/browser/chunk-ZGJAZSNE.mjs.map +7 -0
  28. package/dist/lib/browser/cli/index.mjs +11 -27
  29. package/dist/lib/browser/cli/index.mjs.map +2 -2
  30. package/dist/lib/browser/common/activation-events.mjs +7 -7
  31. package/dist/lib/browser/common/capabilities.mjs +7 -7
  32. package/dist/lib/browser/core/activation-event.mjs +1 -1
  33. package/dist/lib/browser/core/capability.mjs +1 -1
  34. package/dist/lib/browser/core/plugin-manager.mjs +6 -4
  35. package/dist/lib/browser/core/plugin.mjs +10 -2
  36. package/dist/lib/browser/core/url-loader.mjs +13 -5
  37. package/dist/lib/browser/index.mjs +22 -18
  38. package/dist/lib/browser/index.mjs.map +3 -3
  39. package/dist/lib/browser/{invoker-capability-H5PPENOC.mjs → invoker-capability-LNX4CGIV.mjs} +12 -11
  40. package/dist/lib/browser/invoker-capability-LNX4CGIV.mjs.map +7 -0
  41. package/dist/lib/browser/meta.json +1 -1
  42. package/dist/lib/browser/testing/index.mjs +144 -27
  43. package/dist/lib/browser/testing/index.mjs.map +4 -4
  44. package/dist/lib/browser/testing/react.mjs +78 -0
  45. package/dist/lib/browser/testing/react.mjs.map +7 -0
  46. package/dist/lib/browser/ui/index.mjs +18 -14
  47. package/dist/lib/node-esm/{capability-AWBEMRYR.mjs → capability-EW5GJCI6.mjs} +10 -10
  48. package/dist/lib/node-esm/{capability-WFEG6CIZ.mjs → capability-YKBMMD53.mjs} +11 -11
  49. package/dist/lib/node-esm/capability-YKBMMD53.mjs.map +7 -0
  50. package/dist/lib/node-esm/{chunk-FKE4Z3D6.mjs → chunk-37Z53PXZ.mjs} +1 -1
  51. package/dist/lib/node-esm/{chunk-FKE4Z3D6.mjs.map → chunk-37Z53PXZ.mjs.map} +2 -2
  52. package/dist/lib/node-esm/{chunk-WZCSOX5Q.mjs → chunk-6XW6LET6.mjs} +2 -2
  53. package/dist/lib/node-esm/{chunk-URWHJQT2.mjs → chunk-D347W3KO.mjs} +7 -32
  54. package/dist/lib/node-esm/chunk-D347W3KO.mjs.map +7 -0
  55. package/dist/lib/node-esm/chunk-D5PO2WXX.mjs +373 -0
  56. package/dist/lib/node-esm/chunk-D5PO2WXX.mjs.map +7 -0
  57. package/dist/lib/node-esm/{chunk-ULUEXB7Q.mjs → chunk-HTBJU5FX.mjs} +80 -15
  58. package/dist/lib/node-esm/chunk-HTBJU5FX.mjs.map +7 -0
  59. package/dist/lib/node-esm/chunk-KM2F6GH6.mjs +468 -0
  60. package/dist/lib/node-esm/chunk-KM2F6GH6.mjs.map +7 -0
  61. package/dist/lib/node-esm/{chunk-EL3R25OQ.mjs → chunk-OZ7DZA5Z.mjs} +1 -1
  62. package/dist/lib/node-esm/{chunk-BCEOLX47.mjs → chunk-Q7XBFII4.mjs} +170 -226
  63. package/dist/lib/node-esm/chunk-Q7XBFII4.mjs.map +7 -0
  64. package/dist/lib/node-esm/{chunk-VKHGNEDB.mjs → chunk-SBS2YMPT.mjs} +3 -3
  65. package/dist/lib/node-esm/{chunk-VKHGNEDB.mjs.map → chunk-SBS2YMPT.mjs.map} +1 -1
  66. package/dist/lib/node-esm/{chunk-42KBWDE4.mjs → chunk-SDJ4B2LU.mjs} +1 -1
  67. package/dist/lib/node-esm/{chunk-42KBWDE4.mjs.map → chunk-SDJ4B2LU.mjs.map} +1 -1
  68. package/dist/lib/node-esm/{chunk-G3RTFSNG.mjs → chunk-WFSRZKBP.mjs} +2 -2
  69. package/dist/lib/node-esm/chunk-WFSRZKBP.mjs.map +7 -0
  70. package/dist/lib/node-esm/chunk-WKTLE7MG.mjs +585 -0
  71. package/dist/lib/node-esm/chunk-WKTLE7MG.mjs.map +7 -0
  72. package/dist/lib/node-esm/{chunk-ZZ7CKK6W.mjs → chunk-XOCUANHO.mjs} +1 -1
  73. package/dist/lib/node-esm/{chunk-ZZ7CKK6W.mjs.map → chunk-XOCUANHO.mjs.map} +2 -2
  74. package/dist/lib/node-esm/cli/index.mjs +11 -27
  75. package/dist/lib/node-esm/cli/index.mjs.map +2 -2
  76. package/dist/lib/node-esm/common/activation-events.mjs +7 -7
  77. package/dist/lib/node-esm/common/capabilities.mjs +7 -7
  78. package/dist/lib/node-esm/core/activation-event.mjs +1 -1
  79. package/dist/lib/node-esm/core/capability.mjs +1 -1
  80. package/dist/lib/node-esm/core/plugin-manager.mjs +6 -4
  81. package/dist/lib/node-esm/core/plugin.mjs +10 -2
  82. package/dist/lib/node-esm/core/url-loader.mjs +13 -5
  83. package/dist/lib/node-esm/index.mjs +22 -18
  84. package/dist/lib/node-esm/index.mjs.map +3 -3
  85. package/dist/lib/node-esm/{invoker-capability-S3ZA527J.mjs → invoker-capability-O4T5PHLA.mjs} +12 -11
  86. package/dist/lib/node-esm/invoker-capability-O4T5PHLA.mjs.map +7 -0
  87. package/dist/lib/node-esm/meta.json +1 -1
  88. package/dist/lib/node-esm/testing/index.mjs +144 -27
  89. package/dist/lib/node-esm/testing/index.mjs.map +4 -4
  90. package/dist/lib/node-esm/testing/react.mjs +79 -0
  91. package/dist/lib/node-esm/testing/react.mjs.map +7 -0
  92. package/dist/lib/node-esm/ui/index.mjs +18 -14
  93. package/dist/plugin/node-esm/index.mjs +480 -32
  94. package/dist/plugin/node-esm/index.mjs.map +4 -4
  95. package/dist/plugin/node-esm/meta.json +1 -1
  96. package/dist/types/src/common/capabilities.d.ts +2 -1
  97. package/dist/types/src/common/capabilities.d.ts.map +1 -1
  98. package/dist/types/src/common/operations.d.ts +1 -1
  99. package/dist/types/src/common/operations.d.ts.map +1 -1
  100. package/dist/types/src/core/activation-event.d.ts +4 -4
  101. package/dist/types/src/core/activation-event.d.ts.map +1 -1
  102. package/dist/types/src/core/capability-manager.d.ts.map +1 -1
  103. package/dist/types/src/core/capability.d.ts +2 -2
  104. package/dist/types/src/core/capability.d.ts.map +1 -1
  105. package/dist/types/src/core/index.d.ts +2 -0
  106. package/dist/types/src/core/index.d.ts.map +1 -1
  107. package/dist/types/src/core/plugin-asset-cache.d.ts +71 -0
  108. package/dist/types/src/core/plugin-asset-cache.d.ts.map +1 -0
  109. package/dist/types/src/core/plugin-manager.d.ts +51 -2
  110. package/dist/types/src/core/plugin-manager.d.ts.map +1 -1
  111. package/dist/types/src/core/plugin-manifest.d.ts +76 -0
  112. package/dist/types/src/core/plugin-manifest.d.ts.map +1 -0
  113. package/dist/types/src/core/plugin-manifest.test.d.ts +2 -0
  114. package/dist/types/src/core/plugin-manifest.test.d.ts.map +1 -0
  115. package/dist/types/src/core/plugin.d.ts +107 -6
  116. package/dist/types/src/core/plugin.d.ts.map +1 -1
  117. package/dist/types/src/core/url-loader.d.ts +90 -3
  118. package/dist/types/src/core/url-loader.d.ts.map +1 -1
  119. package/dist/types/src/helpers.d.ts.map +1 -1
  120. package/dist/types/src/plugin-operation/history/capability.d.ts.map +1 -1
  121. package/dist/types/src/plugin-operation/history/errors.d.ts +6 -6
  122. package/dist/types/src/plugin-operation/history/errors.d.ts.map +1 -1
  123. package/dist/types/src/plugin-operation/history/history-tracker.d.ts +1 -1
  124. package/dist/types/src/plugin-operation/history/history-tracker.d.ts.map +1 -1
  125. package/dist/types/src/plugin-operation/history/types.d.ts +1 -1
  126. package/dist/types/src/plugin-operation/history/types.d.ts.map +1 -1
  127. package/dist/types/src/plugin-operation/history/undo-mapping.d.ts +1 -1
  128. package/dist/types/src/plugin-operation/history/undo-mapping.d.ts.map +1 -1
  129. package/dist/types/src/plugin-operation/history/undo-registry.d.ts +1 -1
  130. package/dist/types/src/plugin-operation/history/undo-registry.d.ts.map +1 -1
  131. package/dist/types/src/plugin-operation/invoker-capability.d.ts +1 -1
  132. package/dist/types/src/plugin-operation/invoker-capability.d.ts.map +1 -1
  133. package/dist/types/src/plugin-operation/testing.d.ts +2 -1
  134. package/dist/types/src/plugin-operation/testing.d.ts.map +1 -1
  135. package/dist/types/src/plugin-runtime/capability.d.ts +1 -1
  136. package/dist/types/src/plugin-runtime/capability.d.ts.map +1 -1
  137. package/dist/types/src/testing/harness.d.ts +67 -0
  138. package/dist/types/src/testing/harness.d.ts.map +1 -0
  139. package/dist/types/src/testing/index.d.ts +1 -0
  140. package/dist/types/src/testing/index.d.ts.map +1 -1
  141. package/dist/types/src/testing/react.d.ts +27 -0
  142. package/dist/types/src/testing/react.d.ts.map +1 -0
  143. package/dist/types/src/testing/react.test.d.ts +2 -0
  144. package/dist/types/src/testing/react.test.d.ts.map +1 -0
  145. package/dist/types/src/testing/service.d.ts.map +1 -1
  146. package/dist/types/src/testing/withPluginManager.d.ts.map +1 -1
  147. package/dist/types/src/testing/withPluginManager.stories.d.ts.map +1 -1
  148. package/dist/types/src/ui/components/App/App.d.ts.map +1 -1
  149. package/dist/types/src/ui/components/App/App.stories.d.ts.map +1 -1
  150. package/dist/types/src/ui/components/Placeholder/Placeholder.d.ts +64 -0
  151. package/dist/types/src/ui/components/Placeholder/Placeholder.d.ts.map +1 -0
  152. package/dist/types/src/ui/components/Placeholder/Placeholder.stories.d.ts +19 -0
  153. package/dist/types/src/ui/components/Placeholder/Placeholder.stories.d.ts.map +1 -0
  154. package/dist/types/src/ui/components/Placeholder/index.d.ts +2 -0
  155. package/dist/types/src/ui/components/Placeholder/index.d.ts.map +1 -0
  156. package/dist/types/src/ui/components/PluginManager/PluginManagerContext.stories.d.ts.map +1 -1
  157. package/dist/types/src/ui/components/Surface/SurfaceComponent.d.ts +16 -4
  158. package/dist/types/src/ui/components/Surface/SurfaceComponent.d.ts.map +1 -1
  159. package/dist/types/src/ui/components/Surface/SurfaceComponent.stories.d.ts.map +1 -1
  160. package/dist/types/src/ui/components/Surface/SurfaceProfilerContext.d.ts.map +1 -1
  161. package/dist/types/src/ui/components/Surface/index.d.ts +16 -6
  162. package/dist/types/src/ui/components/Surface/index.d.ts.map +1 -1
  163. package/dist/types/src/ui/components/Surface/types.d.ts +110 -9
  164. package/dist/types/src/ui/components/Surface/types.d.ts.map +1 -1
  165. package/dist/types/src/ui/components/Surface/types.test.d.ts +2 -0
  166. package/dist/types/src/ui/components/Surface/types.test.d.ts.map +1 -0
  167. package/dist/types/src/ui/components/index.d.ts +1 -0
  168. package/dist/types/src/ui/components/index.d.ts.map +1 -1
  169. package/dist/types/src/ui/hooks/useApp.d.ts +29 -3
  170. package/dist/types/src/ui/hooks/useApp.d.ts.map +1 -1
  171. package/dist/types/src/ui/hooks/useCapabilities.d.ts.map +1 -1
  172. package/dist/types/src/ui/hooks/useLoading.d.ts.map +1 -1
  173. package/dist/types/src/ui/hooks/useSettingsState.d.ts.map +1 -1
  174. package/dist/types/src/vite-plugin/boot-loader/BootLoader.stories.d.ts +34 -0
  175. package/dist/types/src/vite-plugin/boot-loader/BootLoader.stories.d.ts.map +1 -0
  176. package/dist/types/src/vite-plugin/boot-loader/index.d.ts +52 -0
  177. package/dist/types/src/vite-plugin/boot-loader/index.d.ts.map +1 -0
  178. package/dist/types/src/vite-plugin/composer/index.d.ts +34 -0
  179. package/dist/types/src/vite-plugin/composer/index.d.ts.map +1 -0
  180. package/dist/types/src/vite-plugin/import-map/index.d.ts +28 -0
  181. package/dist/types/src/vite-plugin/import-map/index.d.ts.map +1 -0
  182. package/dist/types/src/vite-plugin/index.d.ts +4 -2
  183. package/dist/types/src/vite-plugin/index.d.ts.map +1 -1
  184. package/dist/types/src/vite-plugin/manifest.d.ts +37 -0
  185. package/dist/types/src/vite-plugin/manifest.d.ts.map +1 -0
  186. package/dist/types/src/vite-plugin/manifest.test.d.ts +2 -0
  187. package/dist/types/src/vite-plugin/manifest.test.d.ts.map +1 -0
  188. package/dist/types/src/vite-plugin/packages.d.ts +10 -4
  189. package/dist/types/src/vite-plugin/packages.d.ts.map +1 -1
  190. package/dist/types/tsconfig.tsbuildinfo +1 -1
  191. package/moon.yml +1 -0
  192. package/package.json +33 -59
  193. package/src/common/capabilities.ts +2 -1
  194. package/src/common/operations.ts +1 -1
  195. package/src/core/capability.ts +1 -1
  196. package/src/core/index.ts +2 -0
  197. package/src/core/plugin-asset-cache.ts +60 -0
  198. package/src/core/plugin-manager.test.ts +246 -5
  199. package/src/core/plugin-manager.ts +167 -25
  200. package/src/core/plugin-manifest.test.ts +48 -0
  201. package/src/core/plugin-manifest.ts +102 -0
  202. package/src/core/plugin.ts +135 -10
  203. package/src/core/url-loader.test.ts +104 -5
  204. package/src/core/url-loader.ts +226 -37
  205. package/src/plugin-operation/OperationPlugin.ts +2 -2
  206. package/src/plugin-operation/history/capability.ts +1 -1
  207. package/src/plugin-operation/history/history-tracker.test.ts +2 -1
  208. package/src/plugin-operation/history/history-tracker.ts +1 -1
  209. package/src/plugin-operation/history/types.ts +1 -1
  210. package/src/plugin-operation/history/undo-mapping.ts +1 -1
  211. package/src/plugin-operation/history/undo-registry.ts +1 -1
  212. package/src/plugin-operation/invoker-capability.ts +2 -1
  213. package/src/plugin-operation/testing.ts +2 -1
  214. package/src/plugin-runtime/RuntimePlugin.ts +2 -2
  215. package/src/testing/harness.ts +229 -0
  216. package/src/testing/index.ts +1 -0
  217. package/src/testing/react.test.tsx +48 -0
  218. package/src/testing/react.tsx +113 -0
  219. package/src/testing/withPluginManager.stories.tsx +1 -1
  220. package/src/ui/components/App/App.stories.tsx +1 -1
  221. package/src/ui/components/App/App.tsx +25 -2
  222. package/src/ui/components/Placeholder/Placeholder.stories.tsx +77 -0
  223. package/src/ui/components/Placeholder/Placeholder.tsx +155 -0
  224. package/src/ui/components/Placeholder/index.ts +5 -0
  225. package/src/ui/components/PluginManager/PluginManagerContext.stories.tsx +4 -2
  226. package/src/ui/components/Surface/SurfaceComponent.stories.tsx +1 -1
  227. package/src/ui/components/Surface/SurfaceComponent.tsx +83 -46
  228. package/src/ui/components/Surface/index.ts +20 -1
  229. package/src/ui/components/Surface/types.test.ts +126 -0
  230. package/src/ui/components/Surface/types.ts +164 -12
  231. package/src/ui/components/index.ts +1 -0
  232. package/src/ui/hooks/useApp.tsx +165 -41
  233. package/src/ui/hooks/useLoading.tsx +14 -6
  234. package/src/vite-plugin/boot-loader/BootLoader.stories.tsx +263 -0
  235. package/src/vite-plugin/boot-loader/boot-loader.css +294 -0
  236. package/src/vite-plugin/boot-loader/boot-loader.js +274 -0
  237. package/src/vite-plugin/boot-loader/index.ts +112 -0
  238. package/src/vite-plugin/composer/index.ts +277 -0
  239. package/src/vite-plugin/import-map/index.ts +524 -0
  240. package/src/vite-plugin/index.ts +6 -2
  241. package/src/vite-plugin/manifest.test.ts +24 -0
  242. package/src/vite-plugin/manifest.ts +50 -0
  243. package/src/vite-plugin/packages.ts +169 -10
  244. package/tsconfig.json +9 -0
  245. package/.swc/plugins/linux_x86_64_19.0.0/727453fb3a62f7f1d952a41e051ca8a6f88cadc45cee43c6a4d1aa45f9b75665.wasmer-v7 +0 -0
  246. package/dist/lib/browser/capability-OP63CD5N.mjs.map +0 -7
  247. package/dist/lib/browser/chunk-F7FW2RK2.mjs.map +0 -7
  248. package/dist/lib/browser/chunk-FU4GAFUQ.mjs.map +0 -7
  249. package/dist/lib/browser/chunk-GX4TUNM6.mjs.map +0 -7
  250. package/dist/lib/browser/chunk-JKWMHZP6.mjs.map +0 -7
  251. package/dist/lib/browser/chunk-LVJW5EFU.mjs +0 -157
  252. package/dist/lib/browser/chunk-LVJW5EFU.mjs.map +0 -7
  253. package/dist/lib/browser/chunk-RFSO3JRG.mjs +0 -1
  254. package/dist/lib/browser/chunk-WPE6AL7I.mjs +0 -905
  255. package/dist/lib/browser/chunk-WPE6AL7I.mjs.map +0 -7
  256. package/dist/lib/browser/invoker-capability-H5PPENOC.mjs.map +0 -7
  257. package/dist/lib/node-esm/capability-WFEG6CIZ.mjs.map +0 -7
  258. package/dist/lib/node-esm/chunk-4A3ZCMI3.mjs +0 -158
  259. package/dist/lib/node-esm/chunk-4A3ZCMI3.mjs.map +0 -7
  260. package/dist/lib/node-esm/chunk-BCEOLX47.mjs.map +0 -7
  261. package/dist/lib/node-esm/chunk-G3RTFSNG.mjs.map +0 -7
  262. package/dist/lib/node-esm/chunk-LQKOTNJW.mjs +0 -906
  263. package/dist/lib/node-esm/chunk-LQKOTNJW.mjs.map +0 -7
  264. package/dist/lib/node-esm/chunk-ULUEXB7Q.mjs.map +0 -7
  265. package/dist/lib/node-esm/chunk-URWHJQT2.mjs.map +0 -7
  266. package/dist/lib/node-esm/invoker-capability-S3ZA527J.mjs.map +0 -7
  267. package/dist/types/src/vite-plugin/composer-plugin.d.ts +0 -18
  268. package/dist/types/src/vite-plugin/composer-plugin.d.ts.map +0 -1
  269. package/dist/types/src/vite-plugin/import-map-plugin.d.ts +0 -16
  270. package/dist/types/src/vite-plugin/import-map-plugin.d.ts.map +0 -1
  271. package/src/vite-plugin/composer-plugin.ts +0 -128
  272. package/src/vite-plugin/import-map-plugin.ts +0 -314
  273. /package/dist/lib/browser/{capability-BBBBAPDI.mjs.map → capability-Q5XRXRD2.mjs.map} +0 -0
  274. /package/dist/lib/browser/{chunk-I34GF4NG.mjs.map → chunk-45CHLTBV.mjs.map} +0 -0
  275. /package/dist/lib/browser/{chunk-RFSO3JRG.mjs.map → chunk-G7SDBRKH.mjs.map} +0 -0
  276. /package/dist/lib/node-esm/{capability-AWBEMRYR.mjs.map → capability-EW5GJCI6.mjs.map} +0 -0
  277. /package/dist/lib/node-esm/{chunk-WZCSOX5Q.mjs.map → chunk-6XW6LET6.mjs.map} +0 -0
  278. /package/dist/lib/node-esm/{chunk-EL3R25OQ.mjs.map → chunk-OZ7DZA5Z.mjs.map} +0 -0
@@ -0,0 +1,584 @@
1
+ import {
2
+ capabilities_exports
3
+ } from "./chunk-WBHCSOBW.mjs";
4
+
5
+ // src/helpers.ts
6
+ var topologicalSort = (nodes) => {
7
+ const getDependencies = (nodeId, seen = /* @__PURE__ */ new Set(), path = /* @__PURE__ */ new Set()) => {
8
+ if (path.has(nodeId)) {
9
+ throw new Error(`Circular dependency detected involving ${nodeId}`);
10
+ }
11
+ if (seen.has(nodeId)) {
12
+ return [];
13
+ }
14
+ const node = nodes.find((n) => n.id === nodeId);
15
+ if (!node) {
16
+ throw new Error(`Node ${nodeId} not found but is listed as a dependency`);
17
+ }
18
+ const newPath = /* @__PURE__ */ new Set([
19
+ ...path,
20
+ nodeId
21
+ ]);
22
+ const newSeen = /* @__PURE__ */ new Set([
23
+ ...seen,
24
+ nodeId
25
+ ]);
26
+ const dependsOn = node.dependsOn ?? [];
27
+ return [
28
+ ...dependsOn.flatMap((depId) => getDependencies(depId, newSeen, newPath)),
29
+ nodeId
30
+ ];
31
+ };
32
+ const allDependencies = nodes.map((node) => node.id).flatMap((id) => getDependencies(id)).filter((id, index, self) => self.indexOf(id) === index);
33
+ return allDependencies.map((id) => nodes.find((node) => node.id === id)).filter((node) => node !== void 0);
34
+ };
35
+
36
+ // src/ui/hooks/useSurface.ts
37
+ import { useContext as useContext3 } from "react";
38
+ import { raise as raise2 } from "@dxos/debug";
39
+
40
+ // src/ui/components/PluginManager/PluginManagerProvider.ts
41
+ import { createContext, useContext } from "react";
42
+ import { raise } from "@dxos/debug";
43
+ var PluginManagerContext = createContext(void 0);
44
+ var usePluginManager = () => useContext(PluginManagerContext) ?? raise(new Error("Missing PluginManagerContext"));
45
+ var PluginManagerProvider = PluginManagerContext.Provider;
46
+
47
+ // src/ui/components/Surface/context.ts
48
+ import { createContext as createContext2 } from "react";
49
+ var SurfaceContext = createContext2(void 0);
50
+
51
+ // src/ui/components/Surface/SurfaceComponent.tsx
52
+ import { useAtomValue } from "@effect-atom/atom-react";
53
+ import React3, { Fragment, Profiler, Suspense, forwardRef as forwardRef2, memo, useEffect, useMemo as useMemo2, useRef as useRef2 } from "react";
54
+ import { log } from "@dxos/log";
55
+ import { ErrorBoundary } from "@dxos/react-error-boundary";
56
+ import { useDefaultValue } from "@dxos/react-hooks";
57
+ import { byPosition } from "@dxos/util";
58
+
59
+ // src/ui/components/Surface/SurfaceInfo.tsx
60
+ import React, { cloneElement, forwardRef, useCallback, useLayoutEffect, useState } from "react";
61
+ import { createPortal } from "react-dom";
62
+ import { addEventListener, combine } from "@dxos/async";
63
+ import { useMergeRefs } from "@dxos/react-hooks";
64
+ var SurfaceInfo = /* @__PURE__ */ forwardRef(({ children }, forwardedRef) => {
65
+ const [rect, setRect] = useState(null);
66
+ const [expand, setExpand] = useState(false);
67
+ const info = useSurface();
68
+ const [root, setRoot] = useState(null);
69
+ const measureRef = useCallback((node) => setRoot(node), []);
70
+ const mergedRef = useMergeRefs([
71
+ measureRef,
72
+ forwardedRef
73
+ ]);
74
+ const childWithRef = /* @__PURE__ */ cloneElement(children, {
75
+ ref: mergedRef
76
+ });
77
+ useLayoutEffect(() => {
78
+ if (!root) {
79
+ setRect(null);
80
+ return;
81
+ }
82
+ const measure = () => {
83
+ setRect(root.getBoundingClientRect());
84
+ };
85
+ const observer = new ResizeObserver(measure);
86
+ observer.observe(root);
87
+ measure();
88
+ return combine(addEventListener(window, "scroll", measure, true), addEventListener(window, "resize", measure), () => {
89
+ observer.disconnect();
90
+ });
91
+ }, [
92
+ root
93
+ ]);
94
+ const padding = 0;
95
+ return /* @__PURE__ */ React.createElement(React.Fragment, null, childWithRef, rect && /* @__PURE__ */ createPortal(
96
+ /* @__PURE__ */ React.createElement("div", {
97
+ role: "none",
98
+ className: "z-[100] fixed flex flex-col-reverse scrollbar-none overflow-auto pointer-events-none",
99
+ style: {
100
+ top: rect.top + padding,
101
+ left: rect.left + padding,
102
+ width: rect.width - padding * 2,
103
+ height: rect.height - padding * 2
104
+ }
105
+ }, expand ? /* @__PURE__ */ React.createElement("div", {
106
+ className: "absolute inset-0 bg-deck-surface border border-green-500 cursor-pointer pointer-events-auto overflow-auto",
107
+ onPointerDown: (ev) => ev.stopPropagation(),
108
+ onClick: (ev) => {
109
+ ev.stopPropagation();
110
+ setExpand(false);
111
+ }
112
+ }, /* @__PURE__ */ React.createElement("pre", {
113
+ className: "p-2 text-xs text-description font-mono"
114
+ }, JSON.stringify({
115
+ info
116
+ }, null, 2))) : /* @__PURE__ */ React.createElement("span", {
117
+ 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",
118
+ title: info.id,
119
+ onPointerDown: (ev) => ev.stopPropagation(),
120
+ onClick: (ev) => {
121
+ ev.stopPropagation();
122
+ setExpand(true);
123
+ }
124
+ }, "\u24D8")),
125
+ // TODO(burdon): Create well-known element to gather all debug portals.
126
+ document.body
127
+ ));
128
+ });
129
+
130
+ // src/ui/components/Surface/SurfaceProfilerContext.tsx
131
+ import React2, { createContext as createContext3, useContext as useContext2, useMemo, useRef, useSyncExternalStore } from "react";
132
+ var MAX_ENTRIES = 500;
133
+ var SurfaceProfilerStore = class {
134
+ _entries = [];
135
+ _listeners = /* @__PURE__ */ new Set();
136
+ _snapshot = [];
137
+ _pendingNotify = false;
138
+ /** Records an entry and schedules a deferred notification to avoid re-render loops. */
139
+ record(entry) {
140
+ this._entries.push(entry);
141
+ if (this._entries.length > MAX_ENTRIES) {
142
+ this._entries = this._entries.slice(-MAX_ENTRIES);
143
+ }
144
+ this._snapshot = [
145
+ ...this._entries
146
+ ];
147
+ this._scheduleNotify();
148
+ }
149
+ clear() {
150
+ this._entries = [];
151
+ this._snapshot = [];
152
+ this._notifySync();
153
+ }
154
+ subscribe = (listener) => {
155
+ this._listeners.add(listener);
156
+ return () => {
157
+ this._listeners.delete(listener);
158
+ };
159
+ };
160
+ getSnapshot = () => {
161
+ return this._snapshot;
162
+ };
163
+ /**
164
+ * Defers notification to the next animation frame to break the
165
+ * Profiler onRender → record → notify → re-render → onRender loop.
166
+ */
167
+ _scheduleNotify() {
168
+ if (!this._pendingNotify) {
169
+ this._pendingNotify = true;
170
+ requestAnimationFrame(() => {
171
+ this._pendingNotify = false;
172
+ this._notifySync();
173
+ });
174
+ }
175
+ }
176
+ _notifySync() {
177
+ for (const listener of this._listeners) {
178
+ listener();
179
+ }
180
+ }
181
+ };
182
+ var SurfaceProfilerContext = /* @__PURE__ */ createContext3(void 0);
183
+ var SurfaceProfilerProvider = ({ children }) => {
184
+ const storeRef = useRef(null);
185
+ if (!storeRef.current) {
186
+ storeRef.current = new SurfaceProfilerStore();
187
+ }
188
+ return /* @__PURE__ */ React2.createElement(SurfaceProfilerContext.Provider, {
189
+ value: {
190
+ store: storeRef.current
191
+ }
192
+ }, children);
193
+ };
194
+ var useSurfaceProfilerCallback = () => {
195
+ const store = useContext2(SurfaceProfilerContext)?.store;
196
+ return useMemo(() => {
197
+ if (!store) {
198
+ return void 0;
199
+ }
200
+ return (id, phase, actualDuration, baseDuration, startTime, commitTime) => {
201
+ store.record({
202
+ id,
203
+ phase,
204
+ actualDuration,
205
+ baseDuration,
206
+ startTime,
207
+ commitTime,
208
+ timestamp: Date.now()
209
+ });
210
+ };
211
+ }, [
212
+ store
213
+ ]);
214
+ };
215
+ var useSurfaceProfilerEntries = () => {
216
+ const context = useContext2(SurfaceProfilerContext);
217
+ return useSyncExternalStore(context?.store.subscribe ?? noop, context?.store.getSnapshot ?? emptySnapshot);
218
+ };
219
+ var useSurfaceProfilerStats = () => {
220
+ const entries = useSurfaceProfilerEntries();
221
+ const statsMap = /* @__PURE__ */ new Map();
222
+ for (const entry of entries) {
223
+ let stats = statsMap.get(entry.id);
224
+ if (!stats) {
225
+ stats = {
226
+ id: entry.id,
227
+ mountCount: 0,
228
+ updateCount: 0,
229
+ totalRenders: 0,
230
+ avgActualDuration: 0,
231
+ maxActualDuration: 0,
232
+ avgBaseDuration: 0,
233
+ lastActualDuration: 0,
234
+ lastCommitTime: 0
235
+ };
236
+ statsMap.set(entry.id, stats);
237
+ }
238
+ if (entry.phase === "mount") {
239
+ stats.mountCount++;
240
+ } else {
241
+ stats.updateCount++;
242
+ }
243
+ stats.totalRenders++;
244
+ stats.avgActualDuration = (stats.avgActualDuration * (stats.totalRenders - 1) + entry.actualDuration) / stats.totalRenders;
245
+ stats.avgBaseDuration = (stats.avgBaseDuration * (stats.totalRenders - 1) + entry.baseDuration) / stats.totalRenders;
246
+ stats.maxActualDuration = Math.max(stats.maxActualDuration, entry.actualDuration);
247
+ stats.lastActualDuration = entry.actualDuration;
248
+ stats.lastCommitTime = entry.commitTime;
249
+ }
250
+ return [
251
+ ...statsMap.values()
252
+ ].sort((a, b) => b.maxActualDuration - a.maxActualDuration);
253
+ };
254
+ var useSurfaceProfilerClear = () => {
255
+ const store = useContext2(SurfaceProfilerContext)?.store;
256
+ return useMemo(() => store ? () => store.clear() : void 0, [
257
+ store
258
+ ]);
259
+ };
260
+ var noop = () => () => {
261
+ };
262
+ var EMPTY_SNAPSHOT = [];
263
+ var emptySnapshot = () => EMPTY_SNAPSHOT;
264
+
265
+ // src/ui/components/Surface/SurfaceComponent.tsx
266
+ var __dxlog_file = "/__w/dxos/dxos/packages/sdk/app-framework/src/ui/components/Surface/SurfaceComponent.tsx";
267
+ var DEBUG = import.meta.env.VITE_DEBUG;
268
+ var DEFAULT_PLACEHOLDER = /* @__PURE__ */ React3.createElement(Fragment, null);
269
+ var WebComponentWrapper = /* @__PURE__ */ memo(/* @__PURE__ */ forwardRef2(({ id, role, data, limit, definition, ...rest }, forwardedRef) => {
270
+ const containerRef = useRef2(null);
271
+ const elementRef = useRef2(null);
272
+ const propsRef = useRef2({
273
+ id,
274
+ role,
275
+ data,
276
+ limit,
277
+ ...rest
278
+ });
279
+ propsRef.current = {
280
+ id,
281
+ role,
282
+ data,
283
+ limit,
284
+ ...rest
285
+ };
286
+ useEffect(() => {
287
+ if (!containerRef.current || elementRef.current) {
288
+ return;
289
+ }
290
+ const element = document.createElement(definition.tagName);
291
+ elementRef.current = element;
292
+ Object.assign(element, propsRef.current);
293
+ containerRef.current.appendChild(element);
294
+ if (typeof forwardedRef === "function") {
295
+ forwardedRef(element);
296
+ } else if (forwardedRef) {
297
+ forwardedRef.current = element;
298
+ }
299
+ return () => {
300
+ if (elementRef.current && containerRef.current?.contains(elementRef.current)) {
301
+ containerRef.current.removeChild(elementRef.current);
302
+ }
303
+ if (typeof forwardedRef === "function") {
304
+ forwardedRef(null);
305
+ } else if (forwardedRef) {
306
+ forwardedRef.current = null;
307
+ }
308
+ elementRef.current = null;
309
+ };
310
+ }, [
311
+ definition.tagName,
312
+ forwardedRef
313
+ ]);
314
+ useEffect(() => {
315
+ const element = elementRef.current;
316
+ if (!element) {
317
+ return;
318
+ }
319
+ Object.assign(element, propsRef.current);
320
+ });
321
+ return /* @__PURE__ */ React3.createElement("div", {
322
+ ref: containerRef
323
+ });
324
+ }));
325
+ WebComponentWrapper.displayName = "WebComponentWrapper";
326
+ var SurfaceContextProvider = /* @__PURE__ */ memo(/* @__PURE__ */ forwardRef2(({ id, role, data, limit, fallback = ErrorFallback, definition, ...rest }, forwardedRef) => {
327
+ const contextValue = useMemo2(() => ({
328
+ id,
329
+ role,
330
+ data
331
+ }), [
332
+ id,
333
+ role,
334
+ data
335
+ ]);
336
+ const onProfilerRender = useSurfaceProfilerCallback();
337
+ const profilerId = `surface/${id}/${role}`;
338
+ if (definition.kind === "web-component") {
339
+ return /* @__PURE__ */ React3.createElement(ErrorBoundary, {
340
+ name: "surface",
341
+ resetKeys: [
342
+ data
343
+ ],
344
+ FallbackComponent: fallback
345
+ }, /* @__PURE__ */ React3.createElement(SurfaceContext.Provider, {
346
+ value: contextValue
347
+ }, /* @__PURE__ */ React3.createElement(WebComponentWrapper, {
348
+ id,
349
+ role,
350
+ data,
351
+ limit,
352
+ definition,
353
+ ref: forwardedRef,
354
+ ...rest
355
+ })));
356
+ }
357
+ const Component = definition.component;
358
+ const debug = DEBUG || "__DX_DEBUG__" in window;
359
+ if (debug) {
360
+ return /* @__PURE__ */ React3.createElement(ErrorBoundary, {
361
+ name: "surface",
362
+ resetKeys: [
363
+ data
364
+ ],
365
+ FallbackComponent: fallback
366
+ }, /* @__PURE__ */ React3.createElement("div", {
367
+ role: "none",
368
+ className: "contents",
369
+ "data-id": id,
370
+ "data-role": role
371
+ }, /* @__PURE__ */ React3.createElement(SurfaceContext.Provider, {
372
+ value: contextValue
373
+ }, /* @__PURE__ */ React3.createElement(SurfaceInfo, {
374
+ ref: forwardedRef
375
+ }, onProfilerRender && !profilerId.includes("org.dxos.plugin.debug") ? /* @__PURE__ */ React3.createElement(Profiler, {
376
+ id: profilerId,
377
+ onRender: onProfilerRender
378
+ }, /* @__PURE__ */ React3.createElement(Component, {
379
+ id,
380
+ role,
381
+ data,
382
+ limit,
383
+ ...rest
384
+ })) : /* @__PURE__ */ React3.createElement(Component, {
385
+ id,
386
+ role,
387
+ data,
388
+ limit,
389
+ ...rest
390
+ })))));
391
+ }
392
+ return /* @__PURE__ */ React3.createElement(ErrorBoundary, {
393
+ name: "surface",
394
+ resetKeys: [
395
+ data
396
+ ],
397
+ FallbackComponent: fallback
398
+ }, /* @__PURE__ */ React3.createElement("div", {
399
+ role: "none",
400
+ className: "contents",
401
+ "data-id": id,
402
+ "data-role": role
403
+ }, /* @__PURE__ */ React3.createElement(SurfaceContext.Provider, {
404
+ value: contextValue
405
+ }, /* @__PURE__ */ React3.createElement(Component, {
406
+ id,
407
+ role,
408
+ data,
409
+ limit,
410
+ ...rest,
411
+ ref: forwardedRef
412
+ }))));
413
+ }));
414
+ SurfaceContextProvider.displayName = "SurfaceContextProvider";
415
+ var SurfaceComponent = /* @__PURE__ */ memo(/* @__PURE__ */ forwardRef2(({ id: _id, role, type, data: dataProp, limit, placeholder = DEFAULT_PLACEHOLDER, ...rest }, forwardedRef) => {
416
+ const data = useDefaultValue(dataProp, () => ({}));
417
+ const surfaces = useSurfaces();
418
+ const effectiveRole = role ?? type?.role;
419
+ if (effectiveRole == null) {
420
+ if (DEBUG) {
421
+ log.warn("Surface has neither `role` nor `type` prop", {
422
+ id: _id
423
+ }, { "~LogMeta": "~LogMeta", F: __dxlog_file, L: 196, S: void 0 });
424
+ }
425
+ return null;
426
+ }
427
+ const definitions = findCandidates(surfaces, {
428
+ role: effectiveRole,
429
+ data
430
+ });
431
+ const candidates = limit ? definitions.slice(0, limit) : definitions;
432
+ if (DEBUG && candidates.length === 0) {
433
+ log.warn("no candidates for surface", {
434
+ role: effectiveRole,
435
+ data
436
+ }, { "~LogMeta": "~LogMeta", F: __dxlog_file, L: 209, S: void 0 });
437
+ return null;
438
+ }
439
+ return /* @__PURE__ */ React3.createElement(Suspense, {
440
+ fallback: placeholder
441
+ }, candidates.map((definition) => /* @__PURE__ */ React3.createElement(SurfaceContextProvider, {
442
+ key: definition.id,
443
+ id: definition.id,
444
+ role: effectiveRole,
445
+ data,
446
+ limit,
447
+ definition,
448
+ ref: forwardedRef,
449
+ ...rest
450
+ })));
451
+ }));
452
+ SurfaceComponent.displayName = "Surface";
453
+ var ErrorFallback = ({ error }) => {
454
+ const { message } = error instanceof Error ? error : {
455
+ message: String(error)
456
+ };
457
+ return /* @__PURE__ */ React3.createElement("div", {
458
+ role: "alert",
459
+ "data-testid": "error-boundary-fallback"
460
+ }, /* @__PURE__ */ React3.createElement("h1", {
461
+ className: "flex gap-2 text-sm mt-2 text-info-text"
462
+ }, message));
463
+ };
464
+ var findCandidates = (surfaces, { role, data }) => {
465
+ return Object.values(surfaces).filter((definition) => Array.isArray(definition.role) ? definition.role.includes(role) : definition.role === role).filter(({ filter }) => filter ? filter(data ?? {}, role) : true).toSorted(byPosition);
466
+ };
467
+ var useSurfaces = () => {
468
+ const manager = usePluginManager();
469
+ const surfacesByModule = useAtomValue(manager.capabilities.atomByModule(capabilities_exports.ReactSurface));
470
+ return useMemo2(() => {
471
+ const result = [];
472
+ for (const [moduleId, surfaces] of Object.entries(surfacesByModule)) {
473
+ for (const def of surfaces.flat()) {
474
+ result.push({
475
+ ...def,
476
+ id: `${moduleId}.${def.id}`
477
+ });
478
+ }
479
+ }
480
+ return result;
481
+ }, [
482
+ surfacesByModule
483
+ ]);
484
+ };
485
+ function isSurfaceAvailable(capabilityManager, { role, type, data }) {
486
+ const effectiveRole = role ?? type?.role;
487
+ if (effectiveRole == null) {
488
+ return false;
489
+ }
490
+ const surfaces = capabilityManager.getAll(capabilities_exports.ReactSurface);
491
+ const candidates = findCandidates(surfaces.flat(), {
492
+ role: effectiveRole,
493
+ data
494
+ });
495
+ return candidates.length > 0;
496
+ }
497
+
498
+ // src/ui/components/Surface/types.ts
499
+ var isSurfaceFilter = (value) => typeof value === "object" && value !== null && Array.isArray(value.bindings);
500
+ var makeType = (role) => ({
501
+ role
502
+ });
503
+ var expandBindings = (filter) => {
504
+ const bindings = filter.bindings;
505
+ const roles = Array.from(new Set(bindings.map((binding) => binding.role)));
506
+ const guard = (data, role) => {
507
+ if (role != null) {
508
+ return bindings.some((entry) => entry.role === role && entry.guard(data));
509
+ }
510
+ return bindings.some((entry) => entry.guard(data));
511
+ };
512
+ return {
513
+ role: roles.length === 1 ? roles[0] : roles,
514
+ guard
515
+ };
516
+ };
517
+ function create(definition) {
518
+ if (isSurfaceFilter(definition.filter)) {
519
+ const { id, filter, component, position } = definition;
520
+ const { role, guard } = expandBindings(filter);
521
+ return {
522
+ kind: "react",
523
+ id,
524
+ role,
525
+ position,
526
+ component,
527
+ filter: guard
528
+ };
529
+ }
530
+ return {
531
+ ...definition,
532
+ kind: "react"
533
+ };
534
+ }
535
+ function createWeb(definition) {
536
+ if (isSurfaceFilter(definition.filter)) {
537
+ const { id, filter, tagName, position } = definition;
538
+ const { role, guard } = expandBindings(filter);
539
+ return {
540
+ kind: "web-component",
541
+ id,
542
+ role,
543
+ position,
544
+ tagName,
545
+ filter: guard
546
+ };
547
+ }
548
+ return {
549
+ ...definition,
550
+ kind: "web-component"
551
+ };
552
+ }
553
+
554
+ // src/ui/components/Surface/index.ts
555
+ (function(Surface2) {
556
+ Surface2.create = create;
557
+ Surface2.createWeb = createWeb;
558
+ Surface2.Context = SurfaceContext;
559
+ Surface2.Surface = SurfaceComponent;
560
+ Surface2.isAvailable = isSurfaceAvailable;
561
+ Surface2.makeType = makeType;
562
+ Surface2.isFilter = isSurfaceFilter;
563
+ Surface2.ProfilerProvider = SurfaceProfilerProvider;
564
+ Surface2.useProfilerCallback = useSurfaceProfilerCallback;
565
+ Surface2.useProfilerEntries = useSurfaceProfilerEntries;
566
+ Surface2.useProfilerStats = useSurfaceProfilerStats;
567
+ Surface2.useProfilerClear = useSurfaceProfilerClear;
568
+ })(Surface || (Surface = {}));
569
+ var Surface;
570
+
571
+ // src/ui/hooks/useSurface.ts
572
+ var useSurface = () => {
573
+ return useContext3(Surface.Context) ?? raise2(new Error("Missing SurfaceContext"));
574
+ };
575
+
576
+ export {
577
+ topologicalSort,
578
+ useSurface,
579
+ usePluginManager,
580
+ PluginManagerProvider,
581
+ SurfaceComponent,
582
+ Surface
583
+ };
584
+ //# sourceMappingURL=chunk-MX5DKEJH.mjs.map