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