@dxos/plugin-space 0.8.2-staging.7ac8446 → 0.8.2

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 (341) 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-DSF2U3A5.mjs → app-graph-serializer-MLU7XI2P.mjs} +10 -10
  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-LO5UL6RU.mjs → chunk-N5QMRLKI.mjs} +78 -173
  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-5BDV575R.mjs → chunk-VEBKN45O.mjs} +21 -10
  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-JR7BNXFH.mjs → identity-created-O63SIYOF.mjs} +5 -5
  18. package/dist/lib/browser/identity-created-O63SIYOF.mjs.map +7 -0
  19. package/dist/lib/browser/index.mjs +34 -54
  20. package/dist/lib/browser/index.mjs.map +3 -3
  21. package/dist/lib/browser/{intent-resolver-RKYILWWQ.mjs → intent-resolver-KBF3YU6I.mjs} +116 -108
  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-6H7NX2M2.mjs → react-root-PVKJE4EZ.mjs} +6 -5
  25. package/dist/lib/browser/{react-surface-7AGLOVMK.mjs → react-surface-252P4NCK.mjs} +121 -54
  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-PJPTJUPE.mjs → settings-2IN2WLUK.mjs} +4 -4
  32. package/dist/lib/browser/settings-2IN2WLUK.mjs.map +7 -0
  33. package/dist/lib/browser/{spaces-ready-BSSP7HHG.mjs → spaces-ready-L4QAGTDE.mjs} +20 -19
  34. package/dist/lib/browser/spaces-ready-L4QAGTDE.mjs.map +7 -0
  35. package/dist/lib/browser/{state-X7VLCC6E.mjs → state-6HOSHLIN.mjs} +3 -5
  36. package/dist/lib/browser/state-6HOSHLIN.mjs.map +7 -0
  37. package/dist/lib/browser/types/index.mjs +7 -7
  38. package/dist/lib/node/app-graph-builder-WC445X77.cjs +328 -0
  39. package/dist/lib/node/app-graph-builder-WC445X77.cjs.map +7 -0
  40. package/dist/lib/node/{app-graph-serializer-JELGJUAY.cjs → app-graph-serializer-UPQOQVMJ.cjs} +22 -22
  41. package/dist/lib/node/app-graph-serializer-UPQOQVMJ.cjs.map +7 -0
  42. package/dist/lib/node/chunk-5WLAXYE3.cjs +125 -0
  43. package/dist/lib/node/chunk-5WLAXYE3.cjs.map +7 -0
  44. package/dist/lib/node/{chunk-IKIDS6XF.cjs → chunk-7GQGM4ZF.cjs} +7 -13
  45. package/dist/lib/node/{chunk-IKIDS6XF.cjs.map → chunk-7GQGM4ZF.cjs.map} +3 -3
  46. package/dist/lib/node/{chunk-TUZWEPGX.cjs → chunk-COQYISES.cjs} +100 -198
  47. package/dist/lib/node/chunk-COQYISES.cjs.map +7 -0
  48. package/dist/lib/node/{chunk-PU2EYH4E.cjs → chunk-DXL5TDFP.cjs} +25 -14
  49. package/dist/lib/node/chunk-DXL5TDFP.cjs.map +7 -0
  50. package/dist/lib/node/chunk-FXHI7JNY.cjs +315 -0
  51. package/dist/lib/node/chunk-FXHI7JNY.cjs.map +7 -0
  52. package/dist/lib/node/chunk-Q3YZEYZT.cjs +1904 -0
  53. package/dist/lib/node/chunk-Q3YZEYZT.cjs.map +7 -0
  54. package/dist/lib/node/{identity-created-XU4HFV2T.cjs → identity-created-UXEAUGC7.cjs} +7 -7
  55. package/dist/lib/node/identity-created-UXEAUGC7.cjs.map +7 -0
  56. package/dist/lib/node/index.cjs +83 -105
  57. package/dist/lib/node/index.cjs.map +3 -3
  58. package/dist/lib/node/{intent-resolver-VJ7YV74L.cjs → intent-resolver-SVFJKUH7.cjs} +161 -152
  59. package/dist/lib/node/intent-resolver-SVFJKUH7.cjs.map +7 -0
  60. package/dist/lib/node/meta.json +1 -1
  61. package/dist/lib/node/{react-root-TEL5RW3N.cjs → react-root-DDPDUMCG.cjs} +11 -10
  62. package/dist/lib/node/{react-root-TEL5RW3N.cjs.map → react-root-DDPDUMCG.cjs.map} +1 -1
  63. package/dist/lib/node/{react-surface-2H3S5TY5.cjs → react-surface-JUIU37BX.cjs} +144 -77
  64. package/dist/lib/node/react-surface-JUIU37BX.cjs.map +7 -0
  65. package/dist/lib/node/{schema-PPJ5BZ3A.cjs → schema-defs-XLFBG3XK.cjs} +14 -12
  66. package/dist/lib/node/schema-defs-XLFBG3XK.cjs.map +7 -0
  67. package/dist/lib/node/{schema-tools-BLIMOZYY.cjs → schema-tools-ZG6Z2QRC.cjs} +32 -32
  68. package/dist/lib/node/schema-tools-ZG6Z2QRC.cjs.map +7 -0
  69. package/dist/lib/node/{settings-WVFP2UEP.cjs → settings-FOH7EB5C.cjs} +7 -7
  70. package/dist/lib/node/settings-FOH7EB5C.cjs.map +7 -0
  71. package/dist/lib/node/{spaces-ready-7DNZSUOG.cjs → spaces-ready-VXQYCBII.cjs} +27 -26
  72. package/dist/lib/node/spaces-ready-VXQYCBII.cjs.map +7 -0
  73. package/dist/lib/node/{state-5KX6WBJH.cjs → state-ZT3MTZXB.cjs} +7 -9
  74. package/dist/lib/node/state-ZT3MTZXB.cjs.map +7 -0
  75. package/dist/lib/node/types/index.cjs +15 -15
  76. package/dist/lib/node/types/index.cjs.map +1 -1
  77. package/dist/lib/node-esm/app-graph-builder-E7CCGPQJ.mjs +329 -0
  78. package/dist/lib/node-esm/app-graph-builder-E7CCGPQJ.mjs.map +7 -0
  79. package/dist/lib/node-esm/{app-graph-serializer-FXONFKOE.mjs → app-graph-serializer-UCMSLPIA.mjs} +10 -10
  80. package/dist/lib/node-esm/app-graph-serializer-UCMSLPIA.mjs.map +7 -0
  81. package/dist/lib/node-esm/{chunk-PIYAWT5N.mjs → chunk-4X4Y63ND.mjs} +3 -8
  82. package/dist/lib/{browser/chunk-KVRYWFZU.mjs.map → node-esm/chunk-4X4Y63ND.mjs.map} +3 -3
  83. package/dist/lib/node-esm/chunk-FTELJGEG.mjs +289 -0
  84. package/dist/lib/node-esm/chunk-FTELJGEG.mjs.map +7 -0
  85. package/dist/lib/node-esm/chunk-GH2FGJXH.mjs +96 -0
  86. package/dist/lib/node-esm/chunk-GH2FGJXH.mjs.map +7 -0
  87. package/dist/lib/node-esm/chunk-HL2Z2GNW.mjs +1901 -0
  88. package/dist/lib/node-esm/chunk-HL2Z2GNW.mjs.map +7 -0
  89. package/dist/lib/node-esm/{chunk-3ZOUV4DF.mjs → chunk-OSPEGYX3.mjs} +21 -10
  90. package/dist/lib/node-esm/chunk-OSPEGYX3.mjs.map +7 -0
  91. package/dist/lib/node-esm/{chunk-ZGLK25WQ.mjs → chunk-XAZNQ3QN.mjs} +78 -173
  92. package/dist/lib/node-esm/chunk-XAZNQ3QN.mjs.map +7 -0
  93. package/dist/lib/node-esm/{identity-created-WJKAS2PV.mjs → identity-created-ZECO4NH3.mjs} +5 -5
  94. package/dist/lib/node-esm/identity-created-ZECO4NH3.mjs.map +7 -0
  95. package/dist/lib/node-esm/index.mjs +34 -54
  96. package/dist/lib/node-esm/index.mjs.map +3 -3
  97. package/dist/lib/node-esm/{intent-resolver-ZFNSA4CM.mjs → intent-resolver-K2UDBF2R.mjs} +116 -108
  98. package/dist/lib/node-esm/intent-resolver-K2UDBF2R.mjs.map +7 -0
  99. package/dist/lib/node-esm/meta.json +1 -1
  100. package/dist/lib/node-esm/{react-root-PRBJMWLQ.mjs → react-root-6F7B3OVO.mjs} +6 -5
  101. package/dist/lib/{browser/react-root-6H7NX2M2.mjs.map → node-esm/react-root-6F7B3OVO.mjs.map} +1 -1
  102. package/dist/lib/node-esm/{react-surface-RCZG2PNF.mjs → react-surface-NP3Y6BNZ.mjs} +121 -54
  103. package/dist/lib/node-esm/react-surface-NP3Y6BNZ.mjs.map +7 -0
  104. package/dist/lib/node-esm/schema-defs-QZJS6UXN.mjs +27 -0
  105. package/dist/lib/node-esm/schema-defs-QZJS6UXN.mjs.map +7 -0
  106. package/dist/lib/node-esm/{schema-tools-IU7EX5A5.mjs → schema-tools-2Y4D42PD.mjs} +26 -26
  107. package/dist/lib/node-esm/schema-tools-2Y4D42PD.mjs.map +7 -0
  108. package/dist/lib/node-esm/{settings-FJZPC2TV.mjs → settings-Q4XDFSYD.mjs} +4 -4
  109. package/dist/lib/node-esm/settings-Q4XDFSYD.mjs.map +7 -0
  110. package/dist/lib/node-esm/{spaces-ready-7X5PGB2V.mjs → spaces-ready-JHKPD4PH.mjs} +20 -19
  111. package/dist/lib/node-esm/spaces-ready-JHKPD4PH.mjs.map +7 -0
  112. package/dist/lib/node-esm/{state-Z6E2YTNC.mjs → state-4ATRHSKA.mjs} +3 -5
  113. package/dist/lib/node-esm/state-4ATRHSKA.mjs.map +7 -0
  114. package/dist/lib/node-esm/types/index.mjs +7 -7
  115. package/dist/types/src/SpacePlugin.d.ts.map +1 -1
  116. package/dist/types/src/capabilities/app-graph-builder.d.ts +2 -179
  117. package/dist/types/src/capabilities/app-graph-builder.d.ts.map +1 -1
  118. package/dist/types/src/capabilities/app-graph-serializer.d.ts +2 -2
  119. package/dist/types/src/capabilities/app-graph-serializer.d.ts.map +1 -1
  120. package/dist/types/src/capabilities/capabilities.d.ts +0 -8
  121. package/dist/types/src/capabilities/capabilities.d.ts.map +1 -1
  122. package/dist/types/src/capabilities/identity-created.d.ts +2 -2
  123. package/dist/types/src/capabilities/identity-created.d.ts.map +1 -1
  124. package/dist/types/src/capabilities/index.d.ts +9 -184
  125. package/dist/types/src/capabilities/index.d.ts.map +1 -1
  126. package/dist/types/src/capabilities/intent-resolver.d.ts +4 -3
  127. package/dist/types/src/capabilities/intent-resolver.d.ts.map +1 -1
  128. package/dist/types/src/capabilities/react-surface.d.ts.map +1 -1
  129. package/dist/types/src/capabilities/schema-defs.d.ts +4 -0
  130. package/dist/types/src/capabilities/schema-defs.d.ts.map +1 -0
  131. package/dist/types/src/capabilities/schema-tools.d.ts +3 -3
  132. package/dist/types/src/capabilities/schema-tools.d.ts.map +1 -1
  133. package/dist/types/src/capabilities/spaces-ready.d.ts +2 -2
  134. package/dist/types/src/capabilities/spaces-ready.d.ts.map +1 -1
  135. package/dist/types/src/capabilities/state.d.ts +2 -2
  136. package/dist/types/src/capabilities/state.d.ts.map +1 -1
  137. package/dist/types/src/components/AwaitingObject.d.ts.map +1 -1
  138. package/dist/types/src/components/CollectionMain.d.ts.map +1 -1
  139. package/dist/types/src/components/CollectionSection.d.ts.map +1 -1
  140. package/dist/types/src/components/CreateDialog/CreateObjectDialog.d.ts +2 -2
  141. package/dist/types/src/components/CreateDialog/CreateObjectDialog.d.ts.map +1 -1
  142. package/dist/types/src/components/CreateDialog/CreateObjectPanel.d.ts.map +1 -1
  143. package/dist/types/src/components/CreateDialog/CreateSpaceDialog.d.ts.map +1 -1
  144. package/dist/types/src/components/JoinDialog.d.ts.map +1 -1
  145. package/dist/types/src/components/MembersContainer.d.ts.map +1 -1
  146. package/dist/types/src/components/MembersContainer.stories.d.ts.map +1 -1
  147. package/dist/types/src/components/MenuFooter.d.ts +2 -2
  148. package/dist/types/src/components/MenuFooter.d.ts.map +1 -1
  149. package/dist/types/src/components/{ObjectSettingsContainer → ObjectSettings}/AdvancedObjectSettings.d.ts +2 -2
  150. package/dist/types/src/components/ObjectSettings/AdvancedObjectSettings.d.ts.map +1 -0
  151. package/dist/types/src/components/{ObjectSettingsContainer → ObjectSettings}/BaseObjectSettings.d.ts +2 -2
  152. package/dist/types/src/components/ObjectSettings/BaseObjectSettings.d.ts.map +1 -0
  153. package/dist/types/src/components/ObjectSettings/ForeignKeys.d.ts.map +1 -0
  154. package/dist/types/src/components/{ObjectSettingsContainer → ObjectSettings}/ObjectSettingsContainer.d.ts +2 -2
  155. package/dist/types/src/components/ObjectSettings/ObjectSettingsContainer.d.ts.map +1 -0
  156. package/dist/types/src/components/ObjectSettings/index.d.ts.map +1 -0
  157. package/dist/types/src/components/PersistenceStatus.d.ts.map +1 -1
  158. package/dist/types/src/components/PopoverRenameObject.d.ts +2 -2
  159. package/dist/types/src/components/PopoverRenameObject.d.ts.map +1 -1
  160. package/dist/types/src/components/PopoverRenameSpace.d.ts.map +1 -1
  161. package/dist/types/src/components/SchemaContainer.d.ts +13 -0
  162. package/dist/types/src/components/SchemaContainer.d.ts.map +1 -0
  163. package/dist/types/src/components/SpacePluginSettings.d.ts.map +1 -1
  164. package/dist/types/src/components/SpacePresence.d.ts.map +1 -1
  165. package/dist/types/src/components/SpacePresence.stories.d.ts.map +1 -1
  166. package/dist/types/src/components/SpaceSettings/SpaceSettingsContainer.d.ts +0 -2
  167. package/dist/types/src/components/SpaceSettings/SpaceSettingsContainer.d.ts.map +1 -1
  168. package/dist/types/src/components/SpaceSettings/SpaceSettingsContainer.stories.d.ts +7 -0
  169. package/dist/types/src/components/SpaceSettings/SpaceSettingsContainer.stories.d.ts.map +1 -0
  170. package/dist/types/src/components/SpaceSettings/index.d.ts +0 -1
  171. package/dist/types/src/components/SpaceSettings/index.d.ts.map +1 -1
  172. package/dist/types/src/components/SyncStatus/InlineSyncStatus.d.ts.map +1 -1
  173. package/dist/types/src/components/SyncStatus/SyncStatus.d.ts +1 -8
  174. package/dist/types/src/components/SyncStatus/SyncStatus.d.ts.map +1 -1
  175. package/dist/types/src/components/SyncStatus/save-tracker.d.ts.map +1 -1
  176. package/dist/types/src/components/SyncStatus/status.d.ts.map +1 -1
  177. package/dist/types/src/components/index.d.ts +2 -3
  178. package/dist/types/src/components/index.d.ts.map +1 -1
  179. package/dist/types/src/hooks/index.d.ts +2 -0
  180. package/dist/types/src/hooks/index.d.ts.map +1 -1
  181. package/dist/types/src/hooks/useActiveSpace.d.ts +4 -0
  182. package/dist/types/src/hooks/useActiveSpace.d.ts.map +1 -0
  183. package/dist/types/src/hooks/useInputSurfaceLookup.d.ts +14 -0
  184. package/dist/types/src/hooks/useInputSurfaceLookup.d.ts.map +1 -0
  185. package/dist/types/src/hooks/usePath.d.ts +3 -2
  186. package/dist/types/src/hooks/usePath.d.ts.map +1 -1
  187. package/dist/types/src/index.d.ts +3 -2
  188. package/dist/types/src/index.d.ts.map +1 -1
  189. package/dist/types/src/translations.d.ts +17 -242
  190. package/dist/types/src/translations.d.ts.map +1 -1
  191. package/dist/types/src/types/collection.d.ts +9 -8
  192. package/dist/types/src/types/collection.d.ts.map +1 -1
  193. package/dist/types/src/types/index.d.ts +0 -1
  194. package/dist/types/src/types/index.d.ts.map +1 -1
  195. package/dist/types/src/types/types.d.ts +173 -146
  196. package/dist/types/src/types/types.d.ts.map +1 -1
  197. package/dist/types/src/util.d.ts +36 -20
  198. package/dist/types/src/util.d.ts.map +1 -1
  199. package/dist/types/tsconfig.tsbuildinfo +1 -1
  200. package/package.json +54 -47
  201. package/src/SpacePlugin.tsx +11 -20
  202. package/src/capabilities/app-graph-builder.ts +377 -230
  203. package/src/capabilities/app-graph-serializer.ts +8 -8
  204. package/src/capabilities/capabilities.ts +0 -9
  205. package/src/capabilities/identity-created.ts +5 -5
  206. package/src/capabilities/index.ts +2 -2
  207. package/src/capabilities/intent-resolver.ts +107 -111
  208. package/src/capabilities/react-surface.tsx +111 -50
  209. package/src/capabilities/schema-defs.ts +30 -0
  210. package/src/capabilities/schema-tool.test.ts +2 -3
  211. package/src/capabilities/schema-tools.ts +29 -29
  212. package/src/capabilities/settings.ts +2 -2
  213. package/src/capabilities/spaces-ready.ts +17 -15
  214. package/src/capabilities/state.ts +3 -5
  215. package/src/components/AwaitingObject.tsx +1 -1
  216. package/src/components/CollectionMain.tsx +2 -5
  217. package/src/components/CreateDialog/CreateObjectDialog.stories.tsx +4 -4
  218. package/src/components/CreateDialog/CreateObjectDialog.tsx +4 -4
  219. package/src/components/CreateDialog/CreateObjectPanel.tsx +3 -25
  220. package/src/components/CreateDialog/CreateSpaceDialog.tsx +6 -3
  221. package/src/components/MembersContainer.stories.tsx +1 -5
  222. package/src/components/MembersContainer.tsx +80 -54
  223. package/src/components/MenuFooter.tsx +2 -2
  224. package/src/components/{ObjectSettingsContainer → ObjectSettings}/AdvancedObjectSettings.tsx +4 -4
  225. package/src/components/{ObjectSettingsContainer → ObjectSettings}/BaseObjectSettings.tsx +2 -2
  226. package/src/components/{ObjectSettingsContainer → ObjectSettings}/ObjectSettingsContainer.tsx +4 -4
  227. package/src/components/PersistenceStatus.tsx +11 -14
  228. package/src/components/PopoverRenameObject.tsx +15 -9
  229. package/src/components/PopoverRenameSpace.tsx +9 -1
  230. package/src/components/SchemaContainer.tsx +59 -0
  231. package/src/components/SpacePluginSettings.tsx +27 -2
  232. package/src/components/SpacePresence.stories.tsx +1 -1
  233. package/src/components/SpacePresence.tsx +60 -65
  234. package/src/components/SpaceSettings/{SpacePropertiesForm.stories.tsx → SpaceSettingsContainer.stories.tsx} +6 -6
  235. package/src/components/SpaceSettings/SpaceSettingsContainer.tsx +159 -39
  236. package/src/components/SpaceSettings/index.ts +0 -1
  237. package/src/components/SyncStatus/InlineSyncStatus.tsx +15 -24
  238. package/src/components/SyncStatus/SyncStatus.tsx +6 -69
  239. package/src/components/index.ts +2 -3
  240. package/src/hooks/index.ts +2 -0
  241. package/src/hooks/useActiveSpace.ts +20 -0
  242. package/src/hooks/useInputSurfaceLookup.tsx +31 -0
  243. package/src/hooks/usePath.ts +9 -6
  244. package/src/index.ts +3 -2
  245. package/src/translations.ts +19 -7
  246. package/src/types/collection.ts +6 -4
  247. package/src/types/index.ts +0 -1
  248. package/src/types/types.ts +130 -101
  249. package/src/util.tsx +75 -172
  250. package/dist/lib/browser/app-graph-builder-GMFCSOLG.mjs +0 -315
  251. package/dist/lib/browser/app-graph-builder-GMFCSOLG.mjs.map +0 -7
  252. package/dist/lib/browser/app-graph-serializer-DSF2U3A5.mjs.map +0 -7
  253. package/dist/lib/browser/chunk-5BDV575R.mjs.map +0 -7
  254. package/dist/lib/browser/chunk-AYW4IDRT.mjs +0 -275
  255. package/dist/lib/browser/chunk-AYW4IDRT.mjs.map +0 -7
  256. package/dist/lib/browser/chunk-JZXWPMLA.mjs +0 -2081
  257. package/dist/lib/browser/chunk-JZXWPMLA.mjs.map +0 -7
  258. package/dist/lib/browser/chunk-LO5UL6RU.mjs.map +0 -7
  259. package/dist/lib/browser/identity-created-JR7BNXFH.mjs.map +0 -7
  260. package/dist/lib/browser/intent-resolver-RKYILWWQ.mjs.map +0 -7
  261. package/dist/lib/browser/react-surface-7AGLOVMK.mjs.map +0 -7
  262. package/dist/lib/browser/schema-FHTA26SW.mjs +0 -24
  263. package/dist/lib/browser/schema-FHTA26SW.mjs.map +0 -7
  264. package/dist/lib/browser/schema-tools-YAXPRIXP.mjs.map +0 -7
  265. package/dist/lib/browser/settings-PJPTJUPE.mjs.map +0 -7
  266. package/dist/lib/browser/spaces-ready-BSSP7HHG.mjs.map +0 -7
  267. package/dist/lib/browser/state-X7VLCC6E.mjs.map +0 -7
  268. package/dist/lib/node/app-graph-builder-DPY7AUZE.cjs +0 -318
  269. package/dist/lib/node/app-graph-builder-DPY7AUZE.cjs.map +0 -7
  270. package/dist/lib/node/app-graph-serializer-JELGJUAY.cjs.map +0 -7
  271. package/dist/lib/node/chunk-3GKCNADA.cjs +0 -2074
  272. package/dist/lib/node/chunk-3GKCNADA.cjs.map +0 -7
  273. package/dist/lib/node/chunk-PU2EYH4E.cjs.map +0 -7
  274. package/dist/lib/node/chunk-TUZWEPGX.cjs.map +0 -7
  275. package/dist/lib/node/chunk-WDEIFDTX.cjs +0 -300
  276. package/dist/lib/node/chunk-WDEIFDTX.cjs.map +0 -7
  277. package/dist/lib/node/identity-created-XU4HFV2T.cjs.map +0 -7
  278. package/dist/lib/node/intent-resolver-VJ7YV74L.cjs.map +0 -7
  279. package/dist/lib/node/react-surface-2H3S5TY5.cjs.map +0 -7
  280. package/dist/lib/node/schema-PPJ5BZ3A.cjs.map +0 -7
  281. package/dist/lib/node/schema-tools-BLIMOZYY.cjs.map +0 -7
  282. package/dist/lib/node/settings-WVFP2UEP.cjs.map +0 -7
  283. package/dist/lib/node/spaces-ready-7DNZSUOG.cjs.map +0 -7
  284. package/dist/lib/node/state-5KX6WBJH.cjs.map +0 -7
  285. package/dist/lib/node-esm/app-graph-builder-42IGWRPL.mjs +0 -316
  286. package/dist/lib/node-esm/app-graph-builder-42IGWRPL.mjs.map +0 -7
  287. package/dist/lib/node-esm/app-graph-serializer-FXONFKOE.mjs.map +0 -7
  288. package/dist/lib/node-esm/chunk-3ZOUV4DF.mjs.map +0 -7
  289. package/dist/lib/node-esm/chunk-BEWBZ4Q4.mjs +0 -2082
  290. package/dist/lib/node-esm/chunk-BEWBZ4Q4.mjs.map +0 -7
  291. package/dist/lib/node-esm/chunk-FC4UHDPL.mjs +0 -276
  292. package/dist/lib/node-esm/chunk-FC4UHDPL.mjs.map +0 -7
  293. package/dist/lib/node-esm/chunk-ZGLK25WQ.mjs.map +0 -7
  294. package/dist/lib/node-esm/identity-created-WJKAS2PV.mjs.map +0 -7
  295. package/dist/lib/node-esm/intent-resolver-ZFNSA4CM.mjs.map +0 -7
  296. package/dist/lib/node-esm/react-surface-RCZG2PNF.mjs.map +0 -7
  297. package/dist/lib/node-esm/schema-OUZKVYM5.mjs +0 -25
  298. package/dist/lib/node-esm/schema-OUZKVYM5.mjs.map +0 -7
  299. package/dist/lib/node-esm/schema-tools-IU7EX5A5.mjs.map +0 -7
  300. package/dist/lib/node-esm/settings-FJZPC2TV.mjs.map +0 -7
  301. package/dist/lib/node-esm/spaces-ready-7X5PGB2V.mjs.map +0 -7
  302. package/dist/lib/node-esm/state-Z6E2YTNC.mjs.map +0 -7
  303. package/dist/types/src/capabilities/schema.d.ts +0 -4
  304. package/dist/types/src/capabilities/schema.d.ts.map +0 -1
  305. package/dist/types/src/components/ObjectSettingsContainer/AdvancedObjectSettings.d.ts.map +0 -1
  306. package/dist/types/src/components/ObjectSettingsContainer/BaseObjectSettings.d.ts.map +0 -1
  307. package/dist/types/src/components/ObjectSettingsContainer/ForeignKeys.d.ts.map +0 -1
  308. package/dist/types/src/components/ObjectSettingsContainer/ObjectSettingsContainer.d.ts.map +0 -1
  309. package/dist/types/src/components/ObjectSettingsContainer/index.d.ts.map +0 -1
  310. package/dist/types/src/components/PopoverAddSpace.d.ts +0 -4
  311. package/dist/types/src/components/PopoverAddSpace.d.ts.map +0 -1
  312. package/dist/types/src/components/ShareSpaceButton.d.ts +0 -9
  313. package/dist/types/src/components/ShareSpaceButton.d.ts.map +0 -1
  314. package/dist/types/src/components/ShareSpaceButton.stories.d.ts +0 -10
  315. package/dist/types/src/components/ShareSpaceButton.stories.d.ts.map +0 -1
  316. package/dist/types/src/components/SpaceSettings/SpacePropertiesForm.d.ts +0 -7
  317. package/dist/types/src/components/SpaceSettings/SpacePropertiesForm.d.ts.map +0 -1
  318. package/dist/types/src/components/SpaceSettings/SpacePropertiesForm.stories.d.ts +0 -7
  319. package/dist/types/src/components/SpaceSettings/SpacePropertiesForm.stories.d.ts.map +0 -1
  320. package/dist/types/src/components/SyncStatus/Space.d.ts +0 -13
  321. package/dist/types/src/components/SyncStatus/Space.d.ts.map +0 -1
  322. package/dist/types/src/components/SyncStatus/SyncStatusDetail.stories.d.ts +0 -9
  323. package/dist/types/src/components/SyncStatus/SyncStatusDetail.stories.d.ts.map +0 -1
  324. package/dist/types/src/components/SyncStatus/sync-state.d.ts +0 -18
  325. package/dist/types/src/components/SyncStatus/sync-state.d.ts.map +0 -1
  326. package/dist/types/src/types/thread.d.ts +0 -128
  327. package/dist/types/src/types/thread.d.ts.map +0 -1
  328. package/src/capabilities/schema.ts +0 -27
  329. package/src/components/PopoverAddSpace.tsx +0 -46
  330. package/src/components/ShareSpaceButton.stories.tsx +0 -27
  331. package/src/components/ShareSpaceButton.tsx +0 -32
  332. package/src/components/SpaceSettings/SpacePropertiesForm.tsx +0 -136
  333. package/src/components/SyncStatus/Space.tsx +0 -133
  334. package/src/components/SyncStatus/SyncStatusDetail.stories.tsx +0 -89
  335. package/src/components/SyncStatus/sync-state.ts +0 -101
  336. package/src/types/thread.ts +0 -24
  337. /package/dist/lib/{node-esm/react-root-PRBJMWLQ.mjs.map → browser/react-root-PVKJE4EZ.mjs.map} +0 -0
  338. /package/dist/types/src/components/{ObjectSettingsContainer → ObjectSettings}/ForeignKeys.d.ts +0 -0
  339. /package/dist/types/src/components/{ObjectSettingsContainer → ObjectSettings}/index.d.ts +0 -0
  340. /package/src/components/{ObjectSettingsContainer → ObjectSettings}/ForeignKeys.tsx +0 -0
  341. /package/src/components/{ObjectSettingsContainer → ObjectSettings}/index.ts +0 -0
@@ -2,43 +2,43 @@
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
- isSpace,
13
- OBJECT_ID_LENGTH,
14
- type ReactiveEchoObject,
15
- SPACE_ID_LENGTH,
16
14
  SpaceState,
17
15
  type Space,
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
- import { CollectionType, SpaceAction, type SpaceSettingsProps } from '../types';
28
+ import { CollectionType, SPACE_TYPE, SpaceAction, type SpaceSettingsProps } from '../types';
29
29
  import {
30
30
  constructObjectActions,
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,258 +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
- ],
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
+ ),
102
156
  }),
103
157
 
104
158
  // Create spaces group node.
105
159
  createExtension({
106
160
  id: `${SPACE_PLUGIN}/root`,
107
161
  position: 'hoist',
108
- filter: (node): node is Node<null> => node.id === 'root',
109
- connector: () => [spacesNode],
110
- 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),
111
172
  }),
112
173
 
113
174
  // Create space nodes.
114
175
  createExtension({
115
176
  id: SPACES,
116
- filter: (node): node is Node<null> => node.id === SPACES,
117
- connector: () => {
118
- const client = context.requestCapability(ClientCapabilities.Client);
119
- const spaces = toSignal(
120
- (onChange) => client.spaces.subscribe(() => onChange()).unsubscribe,
121
- () => client.spaces.get(),
122
- );
123
-
124
- const isReady = toSignal(
125
- (onChange) => client.spaces.isReady.subscribe(() => onChange()).unsubscribe,
126
- () => client.spaces.isReady.get(),
127
- );
128
-
129
- if (!spaces || !isReady) {
130
- return;
131
- }
132
-
133
- const state = context.requestCapability(SpaceCapabilities.State);
134
- const settings = context
135
- .requestCapabilities(Capabilities.SettingsStore)[0]
136
- ?.getStore<SpaceSettingsProps>(SPACE_PLUGIN)?.value;
137
-
138
- // TODO(wittjosiah): During client reset, accessing default space throws.
139
- try {
140
- const [spacesOrder] = memoizeQuery(client.spaces.default, Filter.schema(Expando, { key: SHARED }));
141
- const order: string[] = spacesOrder?.order ?? [];
142
- const orderMap = new Map(order.map((id, index) => [id, index]));
143
- return [
144
- ...spaces
145
- .filter((space) => orderMap.has(space.id))
146
- .sort((a, b) => orderMap.get(a.id)! - orderMap.get(b.id)!),
147
- ...spaces.filter((space) => !orderMap.has(space.id)),
148
- ]
149
- .filter((space) => (settings?.showHidden ? true : space.state.get() !== SpaceState.SPACE_INACTIVE))
150
- .map((space) =>
151
- constructSpaceNode({
152
- space,
153
- navigable: state.navigableCollections,
154
- personal: space === client.spaces.default,
155
- namesCache: state.spaceNames,
156
- resolve,
157
- }),
158
- );
159
- } catch {}
160
- },
161
- resolver: ({ id }) => {
162
- if (id.length !== SPACE_ID_LENGTH) {
163
- return;
164
- }
165
-
166
- const client = context.requestCapability(ClientCapabilities.Client);
167
- const spaces = toSignal(
168
- (onChange) => client.spaces.subscribe(() => onChange()).unsubscribe,
169
- () => client.spaces.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
+ ),
170
236
  );
171
-
172
- const isReady = toSignal(
173
- (onChange) => client.spaces.isReady.subscribe(() => onChange()).unsubscribe,
174
- () => client.spaces.isReady.get(),
175
- );
176
-
177
- if (!spaces || !isReady) {
178
- return;
179
- }
180
-
181
- const space = spaces.find((space) => space.id === id);
182
- if (!space) {
183
- return;
184
- }
185
-
186
- if (space.state.get() === SpaceState.SPACE_INACTIVE) {
187
- return false;
188
- } else if (space.state.get() !== SpaceState.SPACE_READY) {
189
- return undefined;
190
- } else {
191
- const state = context.requestCapability(SpaceCapabilities.State);
192
- return constructSpaceNode({
193
- space,
194
- navigable: state.navigableCollections,
195
- personal: space === client.spaces.default,
196
- namesCache: state.spaceNames,
197
- resolve,
198
- });
199
- }
200
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
+ // },
201
278
  }),
202
279
 
203
280
  // Create space actions.
204
281
  createExtension({
205
282
  id: `${SPACE_PLUGIN}/actions`,
206
- filter: (node): node is Node<Space> => isSpace(node.data),
207
- actions: ({ node }) => {
208
- const space = node.data;
209
- const { dispatchPromise: dispatch } = context.requestCapability(Capabilities.IntentDispatcher);
210
- const client = context.requestCapability(ClientCapabilities.Client);
211
- const state = context.requestCapability(SpaceCapabilities.State);
212
- return constructSpaceActions({
213
- space,
214
- dispatch,
215
- personal: space === client.spaces.default,
216
- migrating: state.sdkMigrationRunning[space.id],
217
- });
218
- },
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
+ ),
219
310
  }),
220
311
 
221
312
  // Create nodes for objects in the root collection of a space.
222
313
  createExtension({
223
314
  id: `${SPACE_PLUGIN}/root-collection`,
224
- filter: (node): node is Node<Space> => isSpace(node.data),
225
- connector: ({ node }) => {
226
- const space = node.data;
227
- const spaceState = toSignal(
228
- (onChange) => space.state.subscribe(() => onChange()).unsubscribe,
229
- () => space.state.get(),
230
- space.id,
231
- );
232
- if (spaceState !== SpaceState.SPACE_READY) {
233
- return;
234
- }
235
-
236
- const collection = space.properties[CollectionType.typename]?.target as CollectionType | undefined;
237
- if (!collection) {
238
- return;
239
- }
240
-
241
- const state = context.requestCapability(SpaceCapabilities.State);
242
-
243
- return collection.objects
244
- .map((object) => object.target)
245
- .filter(isNonNullable)
246
- .map((object) => createObjectNode({ object, space, resolve, navigable: state.navigableCollections }))
247
- .filter(isNonNullable);
248
- },
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
+ ),
249
359
  }),
250
360
 
251
361
  // Create nodes for objects in a collection or by its fully qualified id.
252
362
  createExtension({
253
363
  id: `${SPACE_PLUGIN}/objects`,
254
- filter: (node): node is Node<CollectionType> => node.data instanceof CollectionType,
255
- connector: ({ node }) => {
256
- const collection = node.data;
257
- const space = getSpace(collection);
258
- if (!space) {
259
- return;
260
- }
261
-
262
- const state = context.requestCapability(SpaceCapabilities.State);
263
-
264
- return collection.objects
265
- .map((object) => object.target)
266
- .filter(isNonNullable)
267
- .map((object) => createObjectNode({ object, space, resolve, navigable: state.navigableCollections }))
268
- .filter(isNonNullable);
269
- },
270
- resolver: ({ id }) => {
271
- if (id.length !== FQ_ID_LENGTH) {
272
- return;
273
- }
274
-
275
- const [spaceId, objectId] = id.split(':');
276
- if (spaceId.length !== SPACE_ID_LENGTH && objectId.length !== OBJECT_ID_LENGTH) {
277
- return;
278
- }
279
-
280
- const client = context.requestCapability(ClientCapabilities.Client);
281
- const space = client.spaces.get().find((space) => space.id === spaceId);
282
- if (!space) {
283
- return;
284
- }
285
-
286
- const spaceState = toSignal(
287
- (onChange) => space.state.subscribe(() => onChange()).unsubscribe,
288
- () => space.state.get(),
289
- space.id,
290
- );
291
- if (spaceState !== SpaceState.SPACE_READY) {
292
- return;
293
- }
294
-
295
- const [object] = memoizeQuery(space, { id: objectId });
296
- if (!object) {
297
- return;
298
- }
299
-
300
- if (isDeleted(object)) {
301
- return false;
302
- } else {
303
- const state = context.requestCapability(SpaceCapabilities.State);
304
- return createObjectNode({ object, space, resolve, navigable: state.navigableCollections });
305
- }
306
- },
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
+ // },
307
428
  }),
308
429
 
309
430
  // Create collection actions and action groups.
310
431
  createExtension({
311
432
  id: `${SPACE_PLUGIN}/object-actions`,
312
- filter: (node): node is Node<ReactiveEchoObject<any>> => isEchoObject(node.data),
313
- actions: ({ node }) => {
314
- const { dispatchPromise: dispatch } = context.requestCapability(Capabilities.IntentDispatcher);
315
- const state = context.requestCapability(SpaceCapabilities.State);
316
- return constructObjectActions({ node, dispatch, navigable: state.navigableCollections });
317
- },
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
+ ),
318
458
  }),
319
459
 
320
460
  // Object settings plank companion.
321
461
  createExtension({
322
462
  id: `${SPACE_PLUGIN}/settings`,
323
- filter: (node): node is Node<ReactiveEchoObject<any>> => isEchoObject(node.data),
324
- connector: ({ node }) => [
325
- {
326
- id: [node.id, 'settings'].join(ATTENDABLE_PATH_SEPARATOR),
327
- type: PLANK_COMPANION_TYPE,
328
- data: 'settings',
329
- properties: {
330
- label: ['object settings label', { ns: SPACE_PLUGIN }],
331
- icon: 'ph--sliders--regular',
332
- disposition: 'hidden',
333
- position: 'hoist',
334
- },
335
- },
336
- ],
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
+ ),
337
484
  }),
338
485
  ]);
339
486
  };