@dxos/plugin-space 0.8.2-main.f11618f → 0.8.2-staging.42af850

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 (290) hide show
  1. package/dist/lib/browser/app-graph-builder-DCWUULKX.mjs +328 -0
  2. package/dist/lib/browser/app-graph-builder-DCWUULKX.mjs.map +7 -0
  3. package/dist/lib/browser/{app-graph-serializer-UUJH7JRN.mjs → app-graph-serializer-MLU7XI2P.mjs} +6 -6
  4. package/dist/lib/browser/app-graph-serializer-MLU7XI2P.mjs.map +7 -0
  5. package/dist/lib/browser/{chunk-KVRYWFZU.mjs → chunk-3LN4LJN6.mjs} +3 -8
  6. package/dist/lib/{node-esm/chunk-PIYAWT5N.mjs.map → browser/chunk-3LN4LJN6.mjs.map} +3 -3
  7. package/dist/lib/browser/chunk-7Y4M7GXO.mjs +94 -0
  8. package/dist/lib/browser/chunk-7Y4M7GXO.mjs.map +7 -0
  9. package/dist/lib/browser/{chunk-JS6ZV4GV.mjs → chunk-N5QMRLKI.mjs} +24 -38
  10. package/dist/lib/browser/chunk-N5QMRLKI.mjs.map +7 -0
  11. package/dist/lib/browser/chunk-Q4BTFH2P.mjs +1900 -0
  12. package/dist/lib/browser/chunk-Q4BTFH2P.mjs.map +7 -0
  13. package/dist/lib/browser/{chunk-DIJ7LMCS.mjs → chunk-VEBKN45O.mjs} +3 -4
  14. package/dist/lib/browser/chunk-VEBKN45O.mjs.map +7 -0
  15. package/dist/lib/browser/chunk-W46VVHFM.mjs +288 -0
  16. package/dist/lib/browser/chunk-W46VVHFM.mjs.map +7 -0
  17. package/dist/lib/browser/{identity-created-NRVE4XLL.mjs → identity-created-O63SIYOF.mjs} +3 -3
  18. package/dist/lib/browser/identity-created-O63SIYOF.mjs.map +7 -0
  19. package/dist/lib/browser/index.mjs +27 -26
  20. package/dist/lib/browser/index.mjs.map +3 -3
  21. package/dist/lib/browser/{intent-resolver-NP55M7C7.mjs → intent-resolver-KBF3YU6I.mjs} +33 -35
  22. package/dist/lib/browser/intent-resolver-KBF3YU6I.mjs.map +7 -0
  23. package/dist/lib/browser/meta.json +1 -1
  24. package/dist/lib/browser/{react-root-XKAUZ3X2.mjs → react-root-PVKJE4EZ.mjs} +6 -5
  25. package/dist/lib/browser/{react-surface-2DW2UDRX.mjs → react-surface-252P4NCK.mjs} +6 -13
  26. package/dist/lib/browser/react-surface-252P4NCK.mjs.map +7 -0
  27. package/dist/lib/browser/schema-defs-JMN74RNK.mjs +26 -0
  28. package/dist/lib/browser/schema-defs-JMN74RNK.mjs.map +7 -0
  29. package/dist/lib/browser/{schema-tools-YAXPRIXP.mjs → schema-tools-JIEMHUXV.mjs} +26 -26
  30. package/dist/lib/browser/schema-tools-JIEMHUXV.mjs.map +7 -0
  31. package/dist/lib/browser/{settings-MVT32NP6.mjs → settings-2IN2WLUK.mjs} +2 -2
  32. package/dist/lib/browser/{spaces-ready-ERNSICUW.mjs → spaces-ready-L4QAGTDE.mjs} +18 -17
  33. package/dist/lib/browser/spaces-ready-L4QAGTDE.mjs.map +7 -0
  34. package/dist/lib/browser/{state-CYV6QCTN.mjs → state-6HOSHLIN.mjs} +3 -3
  35. package/dist/lib/browser/state-6HOSHLIN.mjs.map +7 -0
  36. package/dist/lib/browser/types/index.mjs +1 -7
  37. package/dist/lib/node/app-graph-builder-WC445X77.cjs +328 -0
  38. package/dist/lib/node/app-graph-builder-WC445X77.cjs.map +7 -0
  39. package/dist/lib/node/{app-graph-serializer-M6Z2OPA4.cjs → app-graph-serializer-UPQOQVMJ.cjs} +22 -22
  40. package/dist/lib/node/app-graph-serializer-UPQOQVMJ.cjs.map +7 -0
  41. package/dist/lib/node/chunk-5WLAXYE3.cjs +125 -0
  42. package/dist/lib/node/chunk-5WLAXYE3.cjs.map +7 -0
  43. package/dist/lib/node/{chunk-IKIDS6XF.cjs → chunk-7GQGM4ZF.cjs} +7 -13
  44. package/dist/lib/node/{chunk-IKIDS6XF.cjs.map → chunk-7GQGM4ZF.cjs.map} +3 -3
  45. package/dist/lib/node/{chunk-XADZLQAJ.cjs → chunk-COQYISES.cjs} +46 -61
  46. package/dist/lib/node/chunk-COQYISES.cjs.map +7 -0
  47. package/dist/lib/node/{chunk-UOCR4G2D.cjs → chunk-DXL5TDFP.cjs} +7 -8
  48. package/dist/lib/node/chunk-DXL5TDFP.cjs.map +7 -0
  49. package/dist/lib/node/chunk-FXHI7JNY.cjs +315 -0
  50. package/dist/lib/node/chunk-FXHI7JNY.cjs.map +7 -0
  51. package/dist/lib/node/chunk-Q3YZEYZT.cjs +1904 -0
  52. package/dist/lib/node/chunk-Q3YZEYZT.cjs.map +7 -0
  53. package/dist/lib/node/{identity-created-YDTRMOMX.cjs → identity-created-UXEAUGC7.cjs} +7 -7
  54. package/dist/lib/node/identity-created-UXEAUGC7.cjs.map +7 -0
  55. package/dist/lib/node/index.cjs +77 -78
  56. package/dist/lib/node/index.cjs.map +3 -3
  57. package/dist/lib/node/{intent-resolver-3J52ARFL.cjs → intent-resolver-SVFJKUH7.cjs} +80 -81
  58. package/dist/lib/node/intent-resolver-SVFJKUH7.cjs.map +7 -0
  59. package/dist/lib/node/meta.json +1 -1
  60. package/dist/lib/node/{react-root-XUE2J7HT.cjs → react-root-DDPDUMCG.cjs} +11 -10
  61. package/dist/lib/node/{react-root-XUE2J7HT.cjs.map → react-root-DDPDUMCG.cjs.map} +1 -1
  62. package/dist/lib/node/{react-surface-IWSTOZ2E.cjs → react-surface-JUIU37BX.cjs} +44 -49
  63. package/dist/lib/node/react-surface-JUIU37BX.cjs.map +7 -0
  64. package/dist/lib/node/{schema-PPJ5BZ3A.cjs → schema-defs-XLFBG3XK.cjs} +14 -12
  65. package/dist/lib/node/schema-defs-XLFBG3XK.cjs.map +7 -0
  66. package/dist/lib/node/{schema-tools-BLIMOZYY.cjs → schema-tools-ZG6Z2QRC.cjs} +32 -32
  67. package/dist/lib/node/schema-tools-ZG6Z2QRC.cjs.map +7 -0
  68. package/dist/lib/node/{settings-JLV7YT6Q.cjs → settings-FOH7EB5C.cjs} +6 -6
  69. package/dist/lib/node/{spaces-ready-6EBR4SM4.cjs → spaces-ready-VXQYCBII.cjs} +26 -25
  70. package/dist/lib/node/spaces-ready-VXQYCBII.cjs.map +7 -0
  71. package/dist/lib/node/{state-JLN7TGRR.cjs → state-ZT3MTZXB.cjs} +7 -7
  72. package/dist/lib/node/state-ZT3MTZXB.cjs.map +7 -0
  73. package/dist/lib/node/types/index.cjs +12 -18
  74. package/dist/lib/node/types/index.cjs.map +2 -2
  75. package/dist/lib/node-esm/app-graph-builder-E7CCGPQJ.mjs +329 -0
  76. package/dist/lib/node-esm/app-graph-builder-E7CCGPQJ.mjs.map +7 -0
  77. package/dist/lib/node-esm/{app-graph-serializer-J3B4WSXU.mjs → app-graph-serializer-UCMSLPIA.mjs} +6 -6
  78. package/dist/lib/node-esm/app-graph-serializer-UCMSLPIA.mjs.map +7 -0
  79. package/dist/lib/node-esm/{chunk-PIYAWT5N.mjs → chunk-4X4Y63ND.mjs} +3 -8
  80. package/dist/lib/{browser/chunk-KVRYWFZU.mjs.map → node-esm/chunk-4X4Y63ND.mjs.map} +3 -3
  81. package/dist/lib/node-esm/chunk-FTELJGEG.mjs +289 -0
  82. package/dist/lib/node-esm/chunk-FTELJGEG.mjs.map +7 -0
  83. package/dist/lib/node-esm/chunk-GH2FGJXH.mjs +96 -0
  84. package/dist/lib/node-esm/chunk-GH2FGJXH.mjs.map +7 -0
  85. package/dist/lib/node-esm/chunk-HL2Z2GNW.mjs +1901 -0
  86. package/dist/lib/node-esm/chunk-HL2Z2GNW.mjs.map +7 -0
  87. package/dist/lib/node-esm/{chunk-OLISVDCF.mjs → chunk-OSPEGYX3.mjs} +3 -4
  88. package/dist/lib/node-esm/chunk-OSPEGYX3.mjs.map +7 -0
  89. package/dist/lib/node-esm/{chunk-ABTVMAG5.mjs → chunk-XAZNQ3QN.mjs} +24 -38
  90. package/dist/lib/node-esm/chunk-XAZNQ3QN.mjs.map +7 -0
  91. package/dist/lib/node-esm/{identity-created-EC6SVYB5.mjs → identity-created-ZECO4NH3.mjs} +3 -3
  92. package/dist/lib/node-esm/identity-created-ZECO4NH3.mjs.map +7 -0
  93. package/dist/lib/node-esm/index.mjs +27 -26
  94. package/dist/lib/node-esm/index.mjs.map +3 -3
  95. package/dist/lib/node-esm/{intent-resolver-MXQIFIRC.mjs → intent-resolver-K2UDBF2R.mjs} +33 -35
  96. package/dist/lib/node-esm/intent-resolver-K2UDBF2R.mjs.map +7 -0
  97. package/dist/lib/node-esm/meta.json +1 -1
  98. package/dist/lib/node-esm/{react-root-ZBCJCEFS.mjs → react-root-6F7B3OVO.mjs} +6 -5
  99. package/dist/lib/{browser/react-root-XKAUZ3X2.mjs.map → node-esm/react-root-6F7B3OVO.mjs.map} +1 -1
  100. package/dist/lib/node-esm/{react-surface-JCHDAPGM.mjs → react-surface-NP3Y6BNZ.mjs} +6 -13
  101. package/dist/lib/node-esm/react-surface-NP3Y6BNZ.mjs.map +7 -0
  102. package/dist/lib/node-esm/schema-defs-QZJS6UXN.mjs +27 -0
  103. package/dist/lib/node-esm/schema-defs-QZJS6UXN.mjs.map +7 -0
  104. package/dist/lib/node-esm/{schema-tools-IU7EX5A5.mjs → schema-tools-2Y4D42PD.mjs} +26 -26
  105. package/dist/lib/node-esm/schema-tools-2Y4D42PD.mjs.map +7 -0
  106. package/dist/lib/node-esm/{settings-AILIMHTE.mjs → settings-Q4XDFSYD.mjs} +2 -2
  107. package/dist/lib/node-esm/{spaces-ready-5PXESKHX.mjs → spaces-ready-JHKPD4PH.mjs} +18 -17
  108. package/dist/lib/node-esm/spaces-ready-JHKPD4PH.mjs.map +7 -0
  109. package/dist/lib/node-esm/{state-YZPY5T5A.mjs → state-4ATRHSKA.mjs} +3 -3
  110. package/dist/lib/node-esm/state-4ATRHSKA.mjs.map +7 -0
  111. package/dist/lib/node-esm/types/index.mjs +1 -7
  112. package/dist/types/src/SpacePlugin.d.ts.map +1 -1
  113. package/dist/types/src/capabilities/app-graph-builder.d.ts +2 -179
  114. package/dist/types/src/capabilities/app-graph-builder.d.ts.map +1 -1
  115. package/dist/types/src/capabilities/app-graph-serializer.d.ts +2 -2
  116. package/dist/types/src/capabilities/app-graph-serializer.d.ts.map +1 -1
  117. package/dist/types/src/capabilities/capabilities.d.ts +0 -8
  118. package/dist/types/src/capabilities/capabilities.d.ts.map +1 -1
  119. package/dist/types/src/capabilities/identity-created.d.ts +2 -2
  120. package/dist/types/src/capabilities/identity-created.d.ts.map +1 -1
  121. package/dist/types/src/capabilities/index.d.ts +8 -184
  122. package/dist/types/src/capabilities/index.d.ts.map +1 -1
  123. package/dist/types/src/capabilities/intent-resolver.d.ts +2 -2
  124. package/dist/types/src/capabilities/intent-resolver.d.ts.map +1 -1
  125. package/dist/types/src/capabilities/react-surface.d.ts.map +1 -1
  126. package/dist/types/src/capabilities/schema-defs.d.ts +4 -0
  127. package/dist/types/src/capabilities/schema-defs.d.ts.map +1 -0
  128. package/dist/types/src/capabilities/schema-tools.d.ts +3 -3
  129. package/dist/types/src/capabilities/schema-tools.d.ts.map +1 -1
  130. package/dist/types/src/capabilities/spaces-ready.d.ts +2 -2
  131. package/dist/types/src/capabilities/spaces-ready.d.ts.map +1 -1
  132. package/dist/types/src/capabilities/state.d.ts +2 -2
  133. package/dist/types/src/capabilities/state.d.ts.map +1 -1
  134. package/dist/types/src/components/AwaitingObject.d.ts.map +1 -1
  135. package/dist/types/src/components/CollectionMain.d.ts.map +1 -1
  136. package/dist/types/src/components/CollectionSection.d.ts.map +1 -1
  137. package/dist/types/src/components/CreateDialog/CreateObjectDialog.d.ts.map +1 -1
  138. package/dist/types/src/components/CreateDialog/CreateObjectPanel.d.ts.map +1 -1
  139. package/dist/types/src/components/CreateDialog/CreateSpaceDialog.d.ts.map +1 -1
  140. package/dist/types/src/components/JoinDialog.d.ts.map +1 -1
  141. package/dist/types/src/components/MembersContainer.d.ts.map +1 -1
  142. package/dist/types/src/components/MembersContainer.stories.d.ts.map +1 -1
  143. package/dist/types/src/components/MenuFooter.d.ts +2 -2
  144. package/dist/types/src/components/MenuFooter.d.ts.map +1 -1
  145. package/dist/types/src/components/ObjectSettings/AdvancedObjectSettings.d.ts +2 -2
  146. package/dist/types/src/components/ObjectSettings/AdvancedObjectSettings.d.ts.map +1 -1
  147. package/dist/types/src/components/ObjectSettings/BaseObjectSettings.d.ts +2 -2
  148. package/dist/types/src/components/ObjectSettings/BaseObjectSettings.d.ts.map +1 -1
  149. package/dist/types/src/components/ObjectSettings/ForeignKeys.d.ts.map +1 -1
  150. package/dist/types/src/components/ObjectSettings/ObjectSettingsContainer.d.ts +2 -2
  151. package/dist/types/src/components/ObjectSettings/ObjectSettingsContainer.d.ts.map +1 -1
  152. package/dist/types/src/components/PersistenceStatus.d.ts.map +1 -1
  153. package/dist/types/src/components/PopoverRenameObject.d.ts.map +1 -1
  154. package/dist/types/src/components/PopoverRenameSpace.d.ts.map +1 -1
  155. package/dist/types/src/components/SchemaContainer.d.ts.map +1 -1
  156. package/dist/types/src/components/SpacePluginSettings.d.ts.map +1 -1
  157. package/dist/types/src/components/SpacePresence.d.ts.map +1 -1
  158. package/dist/types/src/components/SpacePresence.stories.d.ts.map +1 -1
  159. package/dist/types/src/components/SpaceSettings/SpaceSettingsContainer.d.ts.map +1 -1
  160. package/dist/types/src/components/SyncStatus/InlineSyncStatus.d.ts.map +1 -1
  161. package/dist/types/src/components/SyncStatus/SyncStatus.d.ts.map +1 -1
  162. package/dist/types/src/components/SyncStatus/save-tracker.d.ts.map +1 -1
  163. package/dist/types/src/components/SyncStatus/status.d.ts.map +1 -1
  164. package/dist/types/src/components/index.d.ts +0 -1
  165. package/dist/types/src/components/index.d.ts.map +1 -1
  166. package/dist/types/src/hooks/index.d.ts +1 -0
  167. package/dist/types/src/hooks/index.d.ts.map +1 -1
  168. package/dist/types/src/hooks/useActiveSpace.d.ts +4 -0
  169. package/dist/types/src/hooks/useActiveSpace.d.ts.map +1 -0
  170. package/dist/types/src/hooks/useInputSurfaceLookup.d.ts +2 -2
  171. package/dist/types/src/hooks/useInputSurfaceLookup.d.ts.map +1 -1
  172. package/dist/types/src/hooks/usePath.d.ts +3 -2
  173. package/dist/types/src/hooks/usePath.d.ts.map +1 -1
  174. package/dist/types/src/index.d.ts +3 -2
  175. package/dist/types/src/index.d.ts.map +1 -1
  176. package/dist/types/src/translations.d.ts +2 -263
  177. package/dist/types/src/translations.d.ts.map +1 -1
  178. package/dist/types/src/types/collection.d.ts +9 -8
  179. package/dist/types/src/types/collection.d.ts.map +1 -1
  180. package/dist/types/src/types/index.d.ts +0 -1
  181. package/dist/types/src/types/index.d.ts.map +1 -1
  182. package/dist/types/src/types/types.d.ts +161 -160
  183. package/dist/types/src/types/types.d.ts.map +1 -1
  184. package/dist/types/src/util.d.ts +10 -16
  185. package/dist/types/src/util.d.ts.map +1 -1
  186. package/dist/types/tsconfig.tsbuildinfo +1 -1
  187. package/package.json +54 -48
  188. package/src/SpacePlugin.tsx +8 -7
  189. package/src/capabilities/app-graph-builder.ts +376 -268
  190. package/src/capabilities/app-graph-serializer.ts +4 -4
  191. package/src/capabilities/capabilities.ts +0 -9
  192. package/src/capabilities/identity-created.ts +3 -3
  193. package/src/capabilities/index.ts +2 -2
  194. package/src/capabilities/intent-resolver.ts +22 -29
  195. package/src/capabilities/react-surface.tsx +15 -23
  196. package/src/capabilities/schema-defs.ts +30 -0
  197. package/src/capabilities/schema-tool.test.ts +2 -3
  198. package/src/capabilities/schema-tools.ts +29 -29
  199. package/src/capabilities/spaces-ready.ts +15 -13
  200. package/src/capabilities/state.ts +3 -3
  201. package/src/components/AwaitingObject.tsx +1 -1
  202. package/src/components/CreateDialog/CreateObjectDialog.stories.tsx +2 -2
  203. package/src/components/CreateDialog/CreateObjectDialog.tsx +1 -1
  204. package/src/components/CreateDialog/CreateSpaceDialog.tsx +2 -3
  205. package/src/components/MembersContainer.stories.tsx +1 -5
  206. package/src/components/MenuFooter.tsx +2 -2
  207. package/src/components/ObjectSettings/AdvancedObjectSettings.tsx +4 -4
  208. package/src/components/ObjectSettings/BaseObjectSettings.tsx +2 -2
  209. package/src/components/ObjectSettings/ObjectSettingsContainer.tsx +4 -4
  210. package/src/components/PersistenceStatus.tsx +11 -14
  211. package/src/components/PopoverRenameObject.tsx +1 -1
  212. package/src/components/PopoverRenameSpace.tsx +1 -1
  213. package/src/components/SpacePresence.stories.tsx +1 -1
  214. package/src/components/SpacePresence.tsx +34 -43
  215. package/src/components/SpaceSettings/SpaceSettingsContainer.tsx +5 -3
  216. package/src/components/SyncStatus/InlineSyncStatus.tsx +10 -17
  217. package/src/components/index.ts +0 -1
  218. package/src/hooks/index.ts +1 -0
  219. package/src/hooks/useActiveSpace.ts +20 -0
  220. package/src/hooks/useInputSurfaceLookup.tsx +2 -2
  221. package/src/hooks/usePath.ts +9 -6
  222. package/src/index.ts +3 -2
  223. package/src/translations.ts +1 -2
  224. package/src/types/collection.ts +6 -4
  225. package/src/types/index.ts +0 -1
  226. package/src/types/types.ts +119 -112
  227. package/src/util.tsx +36 -73
  228. package/dist/lib/browser/app-graph-builder-ZWNOWRAX.mjs +0 -369
  229. package/dist/lib/browser/app-graph-builder-ZWNOWRAX.mjs.map +0 -7
  230. package/dist/lib/browser/app-graph-serializer-UUJH7JRN.mjs.map +0 -7
  231. package/dist/lib/browser/chunk-4226DMDP.mjs +0 -1937
  232. package/dist/lib/browser/chunk-4226DMDP.mjs.map +0 -7
  233. package/dist/lib/browser/chunk-DIJ7LMCS.mjs.map +0 -7
  234. package/dist/lib/browser/chunk-JS6ZV4GV.mjs.map +0 -7
  235. package/dist/lib/browser/chunk-O7WGQVLQ.mjs +0 -306
  236. package/dist/lib/browser/chunk-O7WGQVLQ.mjs.map +0 -7
  237. package/dist/lib/browser/identity-created-NRVE4XLL.mjs.map +0 -7
  238. package/dist/lib/browser/intent-resolver-NP55M7C7.mjs.map +0 -7
  239. package/dist/lib/browser/react-surface-2DW2UDRX.mjs.map +0 -7
  240. package/dist/lib/browser/schema-FHTA26SW.mjs +0 -24
  241. package/dist/lib/browser/schema-FHTA26SW.mjs.map +0 -7
  242. package/dist/lib/browser/schema-tools-YAXPRIXP.mjs.map +0 -7
  243. package/dist/lib/browser/spaces-ready-ERNSICUW.mjs.map +0 -7
  244. package/dist/lib/browser/state-CYV6QCTN.mjs.map +0 -7
  245. package/dist/lib/node/app-graph-builder-LLIV422L.cjs +0 -371
  246. package/dist/lib/node/app-graph-builder-LLIV422L.cjs.map +0 -7
  247. package/dist/lib/node/app-graph-serializer-M6Z2OPA4.cjs.map +0 -7
  248. package/dist/lib/node/chunk-EQ5BPSQ7.cjs +0 -334
  249. package/dist/lib/node/chunk-EQ5BPSQ7.cjs.map +0 -7
  250. package/dist/lib/node/chunk-UOCR4G2D.cjs.map +0 -7
  251. package/dist/lib/node/chunk-XADZLQAJ.cjs.map +0 -7
  252. package/dist/lib/node/chunk-ZMQO74LX.cjs +0 -1932
  253. package/dist/lib/node/chunk-ZMQO74LX.cjs.map +0 -7
  254. package/dist/lib/node/identity-created-YDTRMOMX.cjs.map +0 -7
  255. package/dist/lib/node/intent-resolver-3J52ARFL.cjs.map +0 -7
  256. package/dist/lib/node/react-surface-IWSTOZ2E.cjs.map +0 -7
  257. package/dist/lib/node/schema-PPJ5BZ3A.cjs.map +0 -7
  258. package/dist/lib/node/schema-tools-BLIMOZYY.cjs.map +0 -7
  259. package/dist/lib/node/spaces-ready-6EBR4SM4.cjs.map +0 -7
  260. package/dist/lib/node/state-JLN7TGRR.cjs.map +0 -7
  261. package/dist/lib/node-esm/app-graph-builder-HSGLCS76.mjs +0 -370
  262. package/dist/lib/node-esm/app-graph-builder-HSGLCS76.mjs.map +0 -7
  263. package/dist/lib/node-esm/app-graph-serializer-J3B4WSXU.mjs.map +0 -7
  264. package/dist/lib/node-esm/chunk-ABTVMAG5.mjs.map +0 -7
  265. package/dist/lib/node-esm/chunk-FJPCLEKN.mjs +0 -307
  266. package/dist/lib/node-esm/chunk-FJPCLEKN.mjs.map +0 -7
  267. package/dist/lib/node-esm/chunk-OLISVDCF.mjs.map +0 -7
  268. package/dist/lib/node-esm/chunk-PQI4D4SH.mjs +0 -1938
  269. package/dist/lib/node-esm/chunk-PQI4D4SH.mjs.map +0 -7
  270. package/dist/lib/node-esm/identity-created-EC6SVYB5.mjs.map +0 -7
  271. package/dist/lib/node-esm/intent-resolver-MXQIFIRC.mjs.map +0 -7
  272. package/dist/lib/node-esm/react-surface-JCHDAPGM.mjs.map +0 -7
  273. package/dist/lib/node-esm/schema-OUZKVYM5.mjs +0 -25
  274. package/dist/lib/node-esm/schema-OUZKVYM5.mjs.map +0 -7
  275. package/dist/lib/node-esm/schema-tools-IU7EX5A5.mjs.map +0 -7
  276. package/dist/lib/node-esm/spaces-ready-5PXESKHX.mjs.map +0 -7
  277. package/dist/lib/node-esm/state-YZPY5T5A.mjs.map +0 -7
  278. package/dist/types/src/capabilities/schema.d.ts +0 -4
  279. package/dist/types/src/capabilities/schema.d.ts.map +0 -1
  280. package/dist/types/src/components/PopoverAddSpace.d.ts +0 -4
  281. package/dist/types/src/components/PopoverAddSpace.d.ts.map +0 -1
  282. package/dist/types/src/types/thread.d.ts +0 -352
  283. package/dist/types/src/types/thread.d.ts.map +0 -1
  284. package/src/capabilities/schema.ts +0 -27
  285. package/src/components/PopoverAddSpace.tsx +0 -52
  286. package/src/types/thread.ts +0 -24
  287. /package/dist/lib/{node-esm/react-root-ZBCJCEFS.mjs.map → browser/react-root-PVKJE4EZ.mjs.map} +0 -0
  288. /package/dist/lib/browser/{settings-MVT32NP6.mjs.map → settings-2IN2WLUK.mjs.map} +0 -0
  289. /package/dist/lib/node/{settings-JLV7YT6Q.cjs.map → settings-FOH7EB5C.cjs.map} +0 -0
  290. /package/dist/lib/node-esm/{settings-AILIMHTE.mjs.map → settings-Q4XDFSYD.mjs.map} +0 -0
@@ -2,28 +2,28 @@
2
2
  // Copyright 2025 DXOS.org
3
3
  //
4
4
 
5
- import { Capabilities, contributes, createIntent, type PluginsContext } from '@dxos/app-framework';
5
+ import { Rx } from '@effect-rx/rx-react';
6
+ import { Array, Option, pipe } from 'effect';
7
+
8
+ import { Capabilities, contributes, createIntent, type PluginContext } from '@dxos/app-framework';
6
9
  import {
7
10
  Expando,
8
11
  Filter,
9
- FQ_ID_LENGTH,
10
12
  getSpace,
11
13
  isEchoObject,
12
- OBJECT_ID_LENGTH,
13
- type ReactiveEchoObject,
14
- SPACE_ID_LENGTH,
15
14
  SpaceState,
16
15
  type Space,
17
- parseId,
16
+ isSpace,
17
+ type QueryResult,
18
18
  } from '@dxos/client/echo';
19
- import { isDeleted } from '@dxos/live-object';
20
19
  import { log } from '@dxos/log';
21
20
  import { ClientCapabilities } from '@dxos/plugin-client';
22
21
  import { PLANK_COMPANION_TYPE, ATTENDABLE_PATH_SEPARATOR } from '@dxos/plugin-deck/types';
23
- import { createExtension, toSignal, type Node, type InvokeParams } from '@dxos/plugin-graph';
22
+ import { createExtension, rxFromObservable, ROOT_ID, rxFromSignal } from '@dxos/plugin-graph';
24
23
  import { isNonNullable } from '@dxos/util';
25
24
 
26
25
  import { SpaceCapabilities } from './capabilities';
26
+ import { getActiveSpace } from '../hooks';
27
27
  import { SPACE_PLUGIN } from '../meta';
28
28
  import { CollectionType, SPACE_TYPE, SpaceAction, type SpaceSettingsProps } from '../types';
29
29
  import {
@@ -31,14 +31,14 @@ import {
31
31
  constructSpaceActions,
32
32
  constructSpaceNode,
33
33
  createObjectNode,
34
- memoizeQuery,
34
+ rxFromQuery,
35
35
  SHARED,
36
36
  SPACES,
37
37
  } from '../util';
38
38
 
39
- export default (context: PluginsContext) => {
39
+ export default (context: PluginContext) => {
40
40
  const resolve = (typename: string) =>
41
- context.requestCapabilities(Capabilities.Metadata).find(({ id }) => id === typename)?.metadata ?? {};
41
+ context.getCapabilities(Capabilities.Metadata).find(({ id }) => id === typename)?.metadata ?? {};
42
42
 
43
43
  const spacesNode = {
44
44
  id: SPACES,
@@ -53,13 +53,13 @@ export default (context: PluginsContext) => {
53
53
  disabled: true,
54
54
  childrenPersistenceClass: 'echo',
55
55
  onRearrangeChildren: async (nextOrder: Space[]) => {
56
- const { graph } = context.requestCapability(Capabilities.AppGraph);
57
- const client = context.requestCapability(ClientCapabilities.Client);
56
+ const { graph } = context.getCapability(Capabilities.AppGraph);
57
+ const client = context.getCapability(ClientCapabilities.Client);
58
58
 
59
59
  // NOTE: This is needed to ensure order is updated by next animation frame.
60
60
  // TODO(wittjosiah): Is there a better way to do this?
61
61
  // If not, graph should be passed as an argument to the extension.
62
- graph._sortEdges(
62
+ graph.sortEdges(
63
63
  SPACES,
64
64
  'outbound',
65
65
  nextOrder.map(({ id }) => id),
@@ -67,7 +67,7 @@ export default (context: PluginsContext) => {
67
67
 
68
68
  const {
69
69
  objects: [spacesOrder],
70
- } = await client.spaces.default.db.query(Filter.schema(Expando, { key: SHARED })).run();
70
+ } = await client.spaces.default.db.query(Filter.type(Expando, { key: SHARED })).run();
71
71
  if (spacesOrder) {
72
72
  spacesOrder.order = nextOrder.map(({ id }) => id);
73
73
  } else {
@@ -82,297 +82,405 @@ export default (context: PluginsContext) => {
82
82
  createExtension({
83
83
  id: `${SPACE_PLUGIN}/primary-actions`,
84
84
  position: 'hoist',
85
- filter: (node): node is Node<null> => node.id === 'root',
86
- actions: () => [
87
- {
88
- id: SpaceAction.AddSpace._tag,
89
- data: async (params: InvokeParams) => {
90
- const { dispatchPromise: dispatch } = context.requestCapability(Capabilities.IntentDispatcher);
91
- await dispatch(createIntent(SpaceAction.AddSpace));
92
- },
93
- properties: {
94
- label: ['add space label', { ns: SPACE_PLUGIN }],
95
- icon: 'ph--plus--regular',
96
- testId: 'spacePlugin.addSpace',
97
- disposition: 'item',
98
- position: 'fallback',
99
- },
100
- },
101
- {
102
- id: SpaceAction.OpenMembers._tag,
103
- data: async () => {
104
- const { dispatchPromise: dispatch } = context.requestCapability(Capabilities.IntentDispatcher);
105
- const layout = context.requestCapability(Capabilities.Layout);
106
- const client = context.requestCapability(ClientCapabilities.Client);
107
- const { spaceId } = parseId(layout.workspace);
108
- const space = (spaceId && client.spaces.get(spaceId)) ?? client.spaces.default;
109
- await dispatch(createIntent(SpaceAction.OpenMembers, { space }));
110
- },
111
- properties: {
112
- label: ['share space label', { ns: SPACE_PLUGIN }],
113
- icon: 'ph--users--regular',
114
- testId: 'spacePlugin.shareSpace',
115
- keyBinding: {
116
- macos: 'meta+.',
117
- windows: 'alt+.',
118
- },
119
- },
120
- },
121
- {
122
- id: SpaceAction.OpenSettings._tag,
123
- data: async () => {
124
- const { dispatchPromise: dispatch } = context.requestCapability(Capabilities.IntentDispatcher);
125
- const layout = context.requestCapability(Capabilities.Layout);
126
- const client = context.requestCapability(ClientCapabilities.Client);
127
- const { spaceId } = parseId(layout.workspace);
128
- const space = (spaceId && client.spaces.get(spaceId)) ?? client.spaces.default;
129
- await dispatch(createIntent(SpaceAction.OpenSettings, { space }));
130
- },
131
- properties: {
132
- label: ['open current space settings label', { ns: SPACE_PLUGIN }],
133
- icon: 'ph--faders--regular',
134
- keyBinding: {
135
- macos: 'meta+shift+,',
136
- windows: 'ctrl+shift+,',
137
- },
138
- },
139
- },
140
- ],
85
+ actions: (node) =>
86
+ Rx.make((get) =>
87
+ pipe(
88
+ get(node),
89
+ Option.flatMap((node) => (node.id === ROOT_ID ? Option.some(node) : Option.none())),
90
+ Option.map(() => [
91
+ {
92
+ id: SpaceAction.OpenCreateSpace._tag,
93
+ data: async () => {
94
+ const { dispatchPromise: dispatch } = context.getCapability(Capabilities.IntentDispatcher);
95
+ await dispatch(createIntent(SpaceAction.OpenCreateSpace));
96
+ },
97
+ properties: {
98
+ label: ['create space label', { ns: SPACE_PLUGIN }],
99
+ icon: 'ph--plus--regular',
100
+ testId: 'spacePlugin.createSpace',
101
+ disposition: 'menu',
102
+ },
103
+ },
104
+ {
105
+ id: SpaceAction.Join._tag,
106
+ data: async () => {
107
+ const { dispatchPromise: dispatch } = context.getCapability(Capabilities.IntentDispatcher);
108
+ await dispatch(createIntent(SpaceAction.Join));
109
+ },
110
+ properties: {
111
+ label: ['join space label', { ns: SPACE_PLUGIN }],
112
+ icon: 'ph--sign-in--regular',
113
+ testId: 'spacePlugin.joinSpace',
114
+ disposition: 'menu',
115
+ },
116
+ },
117
+ {
118
+ id: SpaceAction.OpenMembers._tag,
119
+ data: async () => {
120
+ const { dispatchPromise: dispatch } = context.getCapability(Capabilities.IntentDispatcher);
121
+ const client = context.getCapability(ClientCapabilities.Client);
122
+ const space = getActiveSpace(context) ?? client.spaces.default;
123
+ await dispatch(createIntent(SpaceAction.OpenMembers, { space }));
124
+ },
125
+ properties: {
126
+ label: ['share space label', { ns: SPACE_PLUGIN }],
127
+ icon: 'ph--users--regular',
128
+ testId: 'spacePlugin.shareSpace',
129
+ keyBinding: {
130
+ macos: 'meta+.',
131
+ windows: 'alt+.',
132
+ },
133
+ },
134
+ },
135
+ {
136
+ id: SpaceAction.OpenSettings._tag,
137
+ data: async () => {
138
+ const { dispatchPromise: dispatch } = context.getCapability(Capabilities.IntentDispatcher);
139
+ const client = context.getCapability(ClientCapabilities.Client);
140
+ const space = getActiveSpace(context) ?? client.spaces.default;
141
+ await dispatch(createIntent(SpaceAction.OpenSettings, { space }));
142
+ },
143
+ properties: {
144
+ label: ['open current space settings label', { ns: SPACE_PLUGIN }],
145
+ icon: 'ph--faders--regular',
146
+ keyBinding: {
147
+ macos: 'meta+shift+,',
148
+ windows: 'ctrl+shift+,',
149
+ },
150
+ },
151
+ },
152
+ ]),
153
+ Option.getOrElse(() => []),
154
+ ),
155
+ ),
141
156
  }),
142
157
 
143
158
  // Create spaces group node.
144
159
  createExtension({
145
160
  id: `${SPACE_PLUGIN}/root`,
146
161
  position: 'hoist',
147
- filter: (node): node is Node<null> => node.id === 'root',
148
- connector: () => [spacesNode],
149
- resolver: ({ id }) => (id === SPACES ? spacesNode : undefined),
162
+ connector: (node) =>
163
+ Rx.make((get) =>
164
+ pipe(
165
+ get(node),
166
+ Option.flatMap((node) => (node.id === ROOT_ID ? Option.some(node) : Option.none())),
167
+ Option.map(() => [spacesNode]),
168
+ Option.getOrElse(() => []),
169
+ ),
170
+ ),
171
+ // resolver: ({ id }) => (id === SPACES ? spacesNode : undefined),
150
172
  }),
151
173
 
152
174
  // Create space nodes.
153
175
  createExtension({
154
176
  id: SPACES,
155
- filter: (node): node is Node<null> => node.id === SPACES,
156
- connector: () => {
157
- const client = context.requestCapability(ClientCapabilities.Client);
158
- const spaces = toSignal(
159
- (onChange) => client.spaces.subscribe(() => onChange()).unsubscribe,
160
- () => client.spaces.get(),
161
- );
162
-
163
- const isReady = toSignal(
164
- (onChange) => client.spaces.isReady.subscribe(() => onChange()).unsubscribe,
165
- () => client.spaces.isReady.get(),
177
+ connector: (node) => {
178
+ let query: QueryResult<Expando> | undefined;
179
+ return Rx.make((get) =>
180
+ pipe(
181
+ get(node),
182
+ Option.flatMap((node) => (node.id === SPACES ? Option.some(node) : Option.none())),
183
+ Option.map(() => {
184
+ const state = context.getCapability(SpaceCapabilities.State);
185
+ const client = context.getCapability(ClientCapabilities.Client);
186
+ const spacesRx = rxFromObservable(client.spaces);
187
+ const isReadyRx = rxFromObservable(client.spaces.isReady);
188
+
189
+ const spaces = get(spacesRx);
190
+ const isReady = get(isReadyRx);
191
+
192
+ if (!spaces || !isReady) {
193
+ return [];
194
+ }
195
+
196
+ const settings = get(context.capabilities(Capabilities.SettingsStore))[0]?.getStore<SpaceSettingsProps>(
197
+ SPACE_PLUGIN,
198
+ )?.value;
199
+
200
+ // TODO(wittjosiah): During client reset, accessing default space throws.
201
+ try {
202
+ if (!query) {
203
+ query = client.spaces.default.db.query(Filter.type(Expando, { key: SHARED }));
204
+ }
205
+ const [spacesOrder] = get(rxFromQuery(query));
206
+ return get(
207
+ rxFromSignal(() => {
208
+ const order: string[] = spacesOrder?.order ?? [];
209
+ const orderMap = new Map(order.map((id, index) => [id, index]));
210
+ return [
211
+ ...spaces
212
+ .filter((space) => orderMap.has(space.id))
213
+ .sort((a, b) => orderMap.get(a.id)! - orderMap.get(b.id)!),
214
+ ...spaces.filter((space) => !orderMap.has(space.id)),
215
+ ]
216
+ .filter((space) =>
217
+ settings?.showHidden ? true : space.state.get() !== SpaceState.SPACE_INACTIVE,
218
+ )
219
+ .map((space) =>
220
+ constructSpaceNode({
221
+ space,
222
+ navigable: state.navigableCollections,
223
+ personal: space === client.spaces.default,
224
+ namesCache: state.spaceNames,
225
+ resolve,
226
+ }),
227
+ );
228
+ }),
229
+ );
230
+ } catch {
231
+ return [];
232
+ }
233
+ }),
234
+ Option.getOrElse(() => []),
235
+ ),
166
236
  );
167
-
168
- if (!spaces || !isReady) {
169
- return;
170
- }
171
-
172
- const state = context.requestCapability(SpaceCapabilities.State);
173
- const settings = context
174
- .requestCapabilities(Capabilities.SettingsStore)[0]
175
- ?.getStore<SpaceSettingsProps>(SPACE_PLUGIN)?.value;
176
-
177
- // TODO(wittjosiah): During client reset, accessing default space throws.
178
- try {
179
- const [spacesOrder] = memoizeQuery(client.spaces.default, Filter.schema(Expando, { key: SHARED }));
180
- const order: string[] = spacesOrder?.order ?? [];
181
- const orderMap = new Map(order.map((id, index) => [id, index]));
182
- return [
183
- ...spaces
184
- .filter((space) => orderMap.has(space.id))
185
- .sort((a, b) => orderMap.get(a.id)! - orderMap.get(b.id)!),
186
- ...spaces.filter((space) => !orderMap.has(space.id)),
187
- ]
188
- .filter((space) => (settings?.showHidden ? true : space.state.get() !== SpaceState.SPACE_INACTIVE))
189
- .map((space) =>
190
- constructSpaceNode({
191
- space,
192
- navigable: state.navigableCollections,
193
- personal: space === client.spaces.default,
194
- namesCache: state.spaceNames,
195
- resolve,
196
- }),
197
- );
198
- } catch {}
199
- },
200
- resolver: ({ id }) => {
201
- if (id.length !== SPACE_ID_LENGTH) {
202
- return;
203
- }
204
-
205
- const client = context.requestCapability(ClientCapabilities.Client);
206
- const spaces = toSignal(
207
- (onChange) => client.spaces.subscribe(() => onChange()).unsubscribe,
208
- () => client.spaces.get(),
209
- );
210
-
211
- const isReady = toSignal(
212
- (onChange) => client.spaces.isReady.subscribe(() => onChange()).unsubscribe,
213
- () => client.spaces.isReady.get(),
214
- );
215
-
216
- if (!spaces || !isReady) {
217
- return;
218
- }
219
-
220
- const space = spaces.find((space) => space.id === id);
221
- if (!space) {
222
- return;
223
- }
224
-
225
- if (space.state.get() === SpaceState.SPACE_INACTIVE) {
226
- return false;
227
- } else if (space.state.get() !== SpaceState.SPACE_READY) {
228
- return undefined;
229
- } else {
230
- const state = context.requestCapability(SpaceCapabilities.State);
231
- return constructSpaceNode({
232
- space,
233
- navigable: state.navigableCollections,
234
- personal: space === client.spaces.default,
235
- namesCache: state.spaceNames,
236
- resolve,
237
- });
238
- }
239
237
  },
238
+ // resolver: ({ id }) => {
239
+ // if (id.length !== SPACE_ID_LENGTH) {
240
+ // return;
241
+ // }
242
+
243
+ // const client = context.requestCapability(ClientCapabilities.Client);
244
+ // const spaces = toSignal(
245
+ // (onChange) => client.spaces.subscribe(() => onChange()).unsubscribe,
246
+ // () => client.spaces.get(),
247
+ // );
248
+
249
+ // const isReady = toSignal(
250
+ // (onChange) => client.spaces.isReady.subscribe(() => onChange()).unsubscribe,
251
+ // () => client.spaces.isReady.get(),
252
+ // );
253
+
254
+ // if (!spaces || !isReady) {
255
+ // return;
256
+ // }
257
+
258
+ // const space = spaces.find((space) => space.id === id);
259
+ // if (!space) {
260
+ // return;
261
+ // }
262
+
263
+ // if (space.state.get() === SpaceState.SPACE_INACTIVE) {
264
+ // return false;
265
+ // } else if (space.state.get() !== SpaceState.SPACE_READY) {
266
+ // return undefined;
267
+ // } else {
268
+ // const state = context.requestCapability(SpaceCapabilities.State);
269
+ // return constructSpaceNode({
270
+ // space,
271
+ // navigable: state.navigableCollections,
272
+ // personal: space === client.spaces.default,
273
+ // namesCache: state.spaceNames,
274
+ // resolve,
275
+ // });
276
+ // }
277
+ // },
240
278
  }),
241
279
 
242
280
  // Create space actions.
243
281
  createExtension({
244
282
  id: `${SPACE_PLUGIN}/actions`,
245
- filter: (node): node is Node<Space> => node.type === SPACE_TYPE,
246
- actions: ({ node }) => {
247
- const space = node.data;
248
- const { dispatchPromise: dispatch } = context.requestCapability(Capabilities.IntentDispatcher);
249
- const client = context.requestCapability(ClientCapabilities.Client);
250
- const state = context.requestCapability(SpaceCapabilities.State);
251
- return constructSpaceActions({
252
- space,
253
- dispatch,
254
- personal: space === client.spaces.default,
255
- migrating: state.sdkMigrationRunning[space.id],
256
- });
257
- },
283
+ actions: (node) =>
284
+ Rx.make((get) =>
285
+ pipe(
286
+ get(node),
287
+ Option.flatMap((node) =>
288
+ node.type === SPACE_TYPE && isSpace(node.data) ? Option.some(node.data) : Option.none(),
289
+ ),
290
+ Option.flatMap((space) => {
291
+ const [dispatcher] = get(context.capabilities(Capabilities.IntentDispatcher));
292
+ const [client] = get(context.capabilities(ClientCapabilities.Client));
293
+ const [state] = get(context.capabilities(SpaceCapabilities.State));
294
+
295
+ if (!dispatcher || !client || !state) {
296
+ return Option.none();
297
+ } else {
298
+ return Option.some({
299
+ space,
300
+ dispatch: dispatcher.dispatchPromise,
301
+ personal: space === client.spaces.default,
302
+ migrating: state.sdkMigrationRunning[space.id],
303
+ });
304
+ }
305
+ }),
306
+ Option.map((params) => constructSpaceActions(params)),
307
+ Option.getOrElse(() => []),
308
+ ),
309
+ ),
258
310
  }),
259
311
 
260
312
  // Create nodes for objects in the root collection of a space.
261
313
  createExtension({
262
314
  id: `${SPACE_PLUGIN}/root-collection`,
263
- filter: (node): node is Node<Space> => node.type === SPACE_TYPE,
264
- connector: ({ node }) => {
265
- const space = node.data;
266
- const spaceState = toSignal(
267
- (onChange) => space.state.subscribe(() => onChange()).unsubscribe,
268
- () => space.state.get(),
269
- space.id,
270
- );
271
- if (spaceState !== SpaceState.SPACE_READY) {
272
- return;
273
- }
274
-
275
- const collection = space.properties[CollectionType.typename]?.target as CollectionType | undefined;
276
- if (!collection) {
277
- return;
278
- }
279
-
280
- const state = context.requestCapability(SpaceCapabilities.State);
281
-
282
- return collection.objects
283
- .map((object) => object.target)
284
- .filter(isNonNullable)
285
- .map((object) => createObjectNode({ object, space, resolve, navigable: state.navigableCollections }))
286
- .filter(isNonNullable);
287
- },
315
+ connector: (node) =>
316
+ Rx.make((get) =>
317
+ pipe(
318
+ get(node),
319
+ Option.flatMap((node) =>
320
+ node.type === SPACE_TYPE && isSpace(node.data) ? Option.some(node.data) : Option.none(),
321
+ ),
322
+ Option.map((space) => {
323
+ const state = context.getCapability(SpaceCapabilities.State);
324
+
325
+ const spaceState = get(rxFromObservable(space.state));
326
+ if (spaceState !== SpaceState.SPACE_READY) {
327
+ return [];
328
+ }
329
+
330
+ const collection = get(
331
+ rxFromSignal(() => space.properties[CollectionType.typename]?.target as CollectionType | undefined),
332
+ );
333
+ if (!collection) {
334
+ return [];
335
+ }
336
+
337
+ return get(
338
+ rxFromSignal(() =>
339
+ pipe(
340
+ collection.objects,
341
+ Array.map((object) => object.target),
342
+ Array.filter(isNonNullable),
343
+ Array.map((object) =>
344
+ createObjectNode({
345
+ object,
346
+ space,
347
+ resolve,
348
+ navigable: state.navigableCollections,
349
+ }),
350
+ ),
351
+ Array.filter(isNonNullable),
352
+ ),
353
+ ),
354
+ );
355
+ }),
356
+ Option.getOrElse(() => []),
357
+ ),
358
+ ),
288
359
  }),
289
360
 
290
361
  // Create nodes for objects in a collection or by its fully qualified id.
291
362
  createExtension({
292
363
  id: `${SPACE_PLUGIN}/objects`,
293
- filter: (node): node is Node<CollectionType> => node.data instanceof CollectionType,
294
- connector: ({ node }) => {
295
- const collection = node.data;
296
- const space = getSpace(collection);
297
- if (!space) {
298
- return;
299
- }
300
-
301
- const state = context.requestCapability(SpaceCapabilities.State);
302
-
303
- return collection.objects
304
- .map((object) => object.target)
305
- .filter(isNonNullable)
306
- .map((object) => createObjectNode({ object, space, resolve, navigable: state.navigableCollections }))
307
- .filter(isNonNullable);
308
- },
309
- resolver: ({ id }) => {
310
- if (id.length !== FQ_ID_LENGTH) {
311
- return;
312
- }
313
-
314
- const [spaceId, objectId] = id.split(':');
315
- if (spaceId.length !== SPACE_ID_LENGTH && objectId.length !== OBJECT_ID_LENGTH) {
316
- return;
317
- }
318
-
319
- const client = context.requestCapability(ClientCapabilities.Client);
320
- const space = client.spaces.get().find((space) => space.id === spaceId);
321
- if (!space) {
322
- return;
323
- }
324
-
325
- const spaceState = toSignal(
326
- (onChange) => space.state.subscribe(() => onChange()).unsubscribe,
327
- () => space.state.get(),
328
- space.id,
329
- );
330
- if (spaceState !== SpaceState.SPACE_READY) {
331
- return;
332
- }
333
-
334
- const [object] = memoizeQuery(space, { id: objectId });
335
- if (!object) {
336
- return;
337
- }
338
-
339
- if (isDeleted(object)) {
340
- return false;
341
- } else {
342
- const state = context.requestCapability(SpaceCapabilities.State);
343
- return createObjectNode({ object, space, resolve, navigable: state.navigableCollections });
344
- }
345
- },
364
+ connector: (node) =>
365
+ Rx.make((get) =>
366
+ pipe(
367
+ get(node),
368
+ Option.flatMap((node) => (node.data instanceof CollectionType ? Option.some(node.data) : Option.none())),
369
+ Option.map((collection) => {
370
+ const state = context.getCapability(SpaceCapabilities.State);
371
+ const space = getSpace(collection);
372
+
373
+ return get(
374
+ rxFromSignal(() =>
375
+ pipe(
376
+ collection.objects,
377
+ Array.map((object) => object.target),
378
+ Array.filter(isNonNullable),
379
+ Array.map(
380
+ (object) =>
381
+ space && createObjectNode({ object, space, resolve, navigable: state.navigableCollections }),
382
+ ),
383
+ Array.filter(isNonNullable),
384
+ ),
385
+ ),
386
+ );
387
+ }),
388
+ Option.getOrElse(() => []),
389
+ ),
390
+ ),
391
+ // resolver: ({ id }) => {
392
+ // if (id.length !== FQ_ID_LENGTH) {
393
+ // return;
394
+ // }
395
+
396
+ // const [spaceId, objectId] = id.split(':');
397
+ // if (spaceId.length !== SPACE_ID_LENGTH && objectId.length !== OBJECT_ID_LENGTH) {
398
+ // return;
399
+ // }
400
+
401
+ // const client = context.requestCapability(ClientCapabilities.Client);
402
+ // const space = client.spaces.get().find((space) => space.id === spaceId);
403
+ // if (!space) {
404
+ // return;
405
+ // }
406
+
407
+ // const spaceState = toSignal(
408
+ // (onChange) => space.state.subscribe(() => onChange()).unsubscribe,
409
+ // () => space.state.get(),
410
+ // space.id,
411
+ // );
412
+ // if (spaceState !== SpaceState.SPACE_READY) {
413
+ // return;
414
+ // }
415
+
416
+ // const [object] = memoizeQuery(space, Query.select(Filter.ids(objectId)));
417
+ // if (!object) {
418
+ // return;
419
+ // }
420
+
421
+ // if (isDeleted(object)) {
422
+ // return false;
423
+ // } else {
424
+ // const state = context.requestCapability(SpaceCapabilities.State);
425
+ // return createObjectNode({ object, space, resolve, navigable: state.navigableCollections });
426
+ // }
427
+ // },
346
428
  }),
347
429
 
348
430
  // Create collection actions and action groups.
349
431
  createExtension({
350
432
  id: `${SPACE_PLUGIN}/object-actions`,
351
- filter: (node): node is Node<ReactiveEchoObject<any>> => isEchoObject(node.data),
352
- actions: ({ node }) => {
353
- const { dispatchPromise: dispatch } = context.requestCapability(Capabilities.IntentDispatcher);
354
- const state = context.requestCapability(SpaceCapabilities.State);
355
- return constructObjectActions({ node, dispatch, navigable: state.navigableCollections });
356
- },
433
+ actions: (node) =>
434
+ Rx.make((get) =>
435
+ pipe(
436
+ get(node),
437
+ Option.flatMap((node) => (isEchoObject(node.data) ? Option.some(node.data) : Option.none())),
438
+ Option.flatMap((object) => {
439
+ const [dispatcher] = get(context.capabilities(Capabilities.IntentDispatcher));
440
+ const [appGraph] = get(context.capabilities(Capabilities.AppGraph));
441
+ const [state] = get(context.capabilities(SpaceCapabilities.State));
442
+
443
+ if (!dispatcher || !appGraph || !state) {
444
+ return Option.none();
445
+ } else {
446
+ return Option.some({
447
+ object,
448
+ graph: appGraph.graph,
449
+ dispatch: dispatcher.dispatchPromise,
450
+ navigable: get(rxFromSignal(() => state.navigableCollections)),
451
+ });
452
+ }
453
+ }),
454
+ Option.map((params) => constructObjectActions(params)),
455
+ Option.getOrElse(() => []),
456
+ ),
457
+ ),
357
458
  }),
358
459
 
359
460
  // Object settings plank companion.
360
461
  createExtension({
361
462
  id: `${SPACE_PLUGIN}/settings`,
362
- filter: (node): node is Node<ReactiveEchoObject<any>> => isEchoObject(node.data),
363
- connector: ({ node }) => [
364
- {
365
- id: [node.id, 'settings'].join(ATTENDABLE_PATH_SEPARATOR),
366
- type: PLANK_COMPANION_TYPE,
367
- data: 'settings',
368
- properties: {
369
- label: ['object settings label', { ns: SPACE_PLUGIN }],
370
- icon: 'ph--sliders--regular',
371
- disposition: 'hidden',
372
- position: 'fallback',
373
- },
374
- },
375
- ],
463
+ connector: (node) =>
464
+ Rx.make((get) =>
465
+ pipe(
466
+ get(node),
467
+ Option.flatMap((node) => (isEchoObject(node.data) ? Option.some(node) : Option.none())),
468
+ Option.map((node) => [
469
+ {
470
+ id: [node.id, 'settings'].join(ATTENDABLE_PATH_SEPARATOR),
471
+ type: PLANK_COMPANION_TYPE,
472
+ data: 'settings',
473
+ properties: {
474
+ label: ['object settings label', { ns: SPACE_PLUGIN }],
475
+ icon: 'ph--sliders--regular',
476
+ disposition: 'hidden',
477
+ position: 'fallback',
478
+ },
479
+ },
480
+ ]),
481
+ Option.getOrElse(() => []),
482
+ ),
483
+ ),
376
484
  }),
377
485
  ]);
378
486
  };