@dxos/plugin-space 0.8.4-main.b97322e → 0.8.4-main.c4373fc

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 (272) hide show
  1. package/dist/lib/browser/{CollectionMain-D2B75XBS.mjs → CollectionMain-AX7KKXWP.mjs} +4 -4
  2. package/dist/lib/browser/CollectionMain-AX7KKXWP.mjs.map +7 -0
  3. package/dist/lib/browser/{ObjectDetailsPanel-YPTDQKMG.mjs → ObjectDetailsPanel-SJ4XUXXX.mjs} +11 -9
  4. package/dist/lib/browser/ObjectDetailsPanel-SJ4XUXXX.mjs.map +7 -0
  5. package/dist/lib/browser/RecordMain-FHPCS6GM.mjs +68 -0
  6. package/dist/lib/browser/RecordMain-FHPCS6GM.mjs.map +7 -0
  7. package/dist/lib/browser/{app-graph-builder-7CZZJS3S.mjs → app-graph-builder-Y2LBZX2G.mjs} +102 -61
  8. package/dist/lib/browser/app-graph-builder-Y2LBZX2G.mjs.map +7 -0
  9. package/dist/lib/browser/{app-graph-serializer-H6AW7KGS.mjs → app-graph-serializer-425OVRTW.mjs} +14 -14
  10. package/dist/lib/browser/app-graph-serializer-425OVRTW.mjs.map +7 -0
  11. package/dist/lib/browser/{chunk-V7MJSSBQ.mjs → chunk-6KVKMOGQ.mjs} +148 -157
  12. package/dist/lib/browser/chunk-6KVKMOGQ.mjs.map +7 -0
  13. package/dist/lib/browser/{chunk-VLBRSGJ2.mjs → chunk-CVZAZRW4.mjs} +4 -4
  14. package/dist/lib/browser/chunk-CVZAZRW4.mjs.map +7 -0
  15. package/dist/lib/browser/chunk-EIXZABXD.mjs +19 -0
  16. package/dist/lib/browser/chunk-EIXZABXD.mjs.map +7 -0
  17. package/dist/lib/browser/chunk-IRKDREHY.mjs +11 -0
  18. package/dist/lib/browser/chunk-IRKDREHY.mjs.map +7 -0
  19. package/dist/lib/browser/{chunk-SGTQ52SU.mjs → chunk-OYHC63NL.mjs} +16 -10
  20. package/dist/lib/browser/chunk-OYHC63NL.mjs.map +7 -0
  21. package/dist/lib/browser/chunk-PUF3B7XO.mjs +20 -0
  22. package/dist/lib/browser/chunk-PUF3B7XO.mjs.map +7 -0
  23. package/dist/lib/browser/{chunk-XUYKJUU7.mjs → chunk-X6COEDOD.mjs} +99 -44
  24. package/dist/lib/browser/chunk-X6COEDOD.mjs.map +7 -0
  25. package/dist/lib/browser/{chunk-QACNNDOT.mjs → chunk-YZJWWMNB.mjs} +11 -10
  26. package/dist/lib/browser/chunk-YZJWWMNB.mjs.map +7 -0
  27. package/dist/lib/browser/{identity-created-23XJJV2N.mjs → identity-created-PW2BA46S.mjs} +4 -4
  28. package/dist/lib/browser/{identity-created-23XJJV2N.mjs.map → identity-created-PW2BA46S.mjs.map} +3 -3
  29. package/dist/lib/browser/index.mjs +20 -40
  30. package/dist/lib/browser/index.mjs.map +3 -3
  31. package/dist/lib/browser/{intent-resolver-TIXVDYN7.mjs → intent-resolver-2TBYHOBA.mjs} +47 -42
  32. package/dist/lib/browser/intent-resolver-2TBYHOBA.mjs.map +7 -0
  33. package/dist/lib/browser/meta.json +1 -1
  34. package/dist/lib/browser/{react-root-N2J7TDRX.mjs → react-root-KMJXJ5VX.mjs} +11 -11
  35. package/dist/lib/browser/react-root-KMJXJ5VX.mjs.map +7 -0
  36. package/dist/lib/browser/{react-surface-TPNLWJJH.mjs → react-surface-YAJUAMER.mjs} +53 -42
  37. package/dist/lib/browser/react-surface-YAJUAMER.mjs.map +7 -0
  38. package/dist/lib/browser/{schema-defs-Z6FC4AHC.mjs → schema-defs-2OCPV7JF.mjs} +5 -5
  39. package/dist/lib/browser/schema-defs-2OCPV7JF.mjs.map +7 -0
  40. package/dist/lib/browser/{settings-4IMP5RYT.mjs → settings-UYYJ225A.mjs} +5 -5
  41. package/dist/lib/browser/{settings-4IMP5RYT.mjs.map → settings-UYYJ225A.mjs.map} +1 -1
  42. package/dist/lib/browser/{spaces-ready-TOPG6IV4.mjs → spaces-ready-YNZPWXA3.mjs} +18 -16
  43. package/dist/lib/browser/spaces-ready-YNZPWXA3.mjs.map +7 -0
  44. package/dist/lib/browser/{state-QYZAB45H.mjs → state-BPU73TYO.mjs} +7 -7
  45. package/dist/lib/browser/state-BPU73TYO.mjs.map +7 -0
  46. package/dist/lib/browser/types/index.mjs +2 -2
  47. package/dist/lib/node-esm/{CollectionMain-ZJIFCWKZ.mjs → CollectionMain-EU57SRYK.mjs} +4 -4
  48. package/dist/lib/node-esm/CollectionMain-EU57SRYK.mjs.map +7 -0
  49. package/dist/lib/node-esm/{ObjectDetailsPanel-QKZEDSZK.mjs → ObjectDetailsPanel-P7D727OV.mjs} +11 -9
  50. package/dist/lib/node-esm/ObjectDetailsPanel-P7D727OV.mjs.map +7 -0
  51. package/dist/lib/node-esm/RecordMain-V73AEB6N.mjs +70 -0
  52. package/dist/lib/node-esm/RecordMain-V73AEB6N.mjs.map +7 -0
  53. package/dist/lib/node-esm/{app-graph-builder-KGIGWC72.mjs → app-graph-builder-DMNLDT7E.mjs} +102 -61
  54. package/dist/lib/node-esm/app-graph-builder-DMNLDT7E.mjs.map +7 -0
  55. package/dist/lib/node-esm/{app-graph-serializer-2ICUGQQT.mjs → app-graph-serializer-ZEDSY77N.mjs} +14 -14
  56. package/dist/lib/node-esm/app-graph-serializer-ZEDSY77N.mjs.map +7 -0
  57. package/dist/lib/node-esm/chunk-36TAYXV7.mjs +21 -0
  58. package/dist/lib/node-esm/chunk-36TAYXV7.mjs.map +7 -0
  59. package/dist/lib/node-esm/{chunk-P442DOQ3.mjs → chunk-7UIEPBQJ.mjs} +11 -10
  60. package/dist/lib/node-esm/chunk-7UIEPBQJ.mjs.map +7 -0
  61. package/dist/lib/node-esm/{chunk-JH6F4C3I.mjs → chunk-ADEZJQE3.mjs} +16 -10
  62. package/dist/lib/node-esm/chunk-ADEZJQE3.mjs.map +7 -0
  63. package/dist/lib/node-esm/{chunk-SSLBYZEY.mjs → chunk-FLRC6XWU.mjs} +4 -4
  64. package/dist/lib/node-esm/chunk-FLRC6XWU.mjs.map +7 -0
  65. package/dist/lib/node-esm/{chunk-6X5DLJM5.mjs → chunk-L26ZIGHA.mjs} +148 -157
  66. package/dist/lib/node-esm/chunk-L26ZIGHA.mjs.map +7 -0
  67. package/dist/lib/node-esm/{chunk-HWNG4MEU.mjs → chunk-MWNATOXL.mjs} +2 -4
  68. package/dist/lib/node-esm/chunk-MWNATOXL.mjs.map +7 -0
  69. package/dist/lib/node-esm/chunk-SVFKU7EW.mjs +20 -0
  70. package/dist/lib/node-esm/chunk-SVFKU7EW.mjs.map +7 -0
  71. package/dist/lib/node-esm/{chunk-4AOMYKDE.mjs → chunk-ZFCCFELA.mjs} +99 -44
  72. package/dist/lib/node-esm/chunk-ZFCCFELA.mjs.map +7 -0
  73. package/dist/lib/node-esm/{identity-created-IJQO6GCR.mjs → identity-created-MWTLGQRU.mjs} +4 -4
  74. package/dist/lib/node-esm/{identity-created-IJQO6GCR.mjs.map → identity-created-MWTLGQRU.mjs.map} +3 -3
  75. package/dist/lib/node-esm/index.mjs +20 -40
  76. package/dist/lib/node-esm/index.mjs.map +3 -3
  77. package/dist/lib/node-esm/{intent-resolver-MHGHRGDT.mjs → intent-resolver-YOG27WOG.mjs} +47 -42
  78. package/dist/lib/node-esm/intent-resolver-YOG27WOG.mjs.map +7 -0
  79. package/dist/lib/node-esm/meta.json +1 -1
  80. package/dist/lib/node-esm/{react-root-KW3TGJGY.mjs → react-root-27QMJZD2.mjs} +11 -11
  81. package/dist/lib/node-esm/react-root-27QMJZD2.mjs.map +7 -0
  82. package/dist/lib/node-esm/{react-surface-UUIUUD6P.mjs → react-surface-RC73GAN5.mjs} +53 -42
  83. package/dist/lib/node-esm/react-surface-RC73GAN5.mjs.map +7 -0
  84. package/dist/lib/node-esm/{schema-defs-WHJM7UZE.mjs → schema-defs-X2Z7F2EV.mjs} +5 -5
  85. package/dist/lib/node-esm/schema-defs-X2Z7F2EV.mjs.map +7 -0
  86. package/dist/lib/node-esm/{settings-SAOBPND3.mjs → settings-Q736OQRP.mjs} +5 -5
  87. package/dist/lib/node-esm/{settings-SAOBPND3.mjs.map → settings-Q736OQRP.mjs.map} +1 -1
  88. package/dist/lib/node-esm/{spaces-ready-HIUKNDZK.mjs → spaces-ready-XZQD7Q65.mjs} +18 -16
  89. package/dist/lib/node-esm/spaces-ready-XZQD7Q65.mjs.map +7 -0
  90. package/dist/lib/node-esm/{state-ZVEHQ4BJ.mjs → state-BY75TM32.mjs} +7 -7
  91. package/dist/lib/node-esm/state-BY75TM32.mjs.map +7 -0
  92. package/dist/lib/node-esm/types/index.mjs +2 -2
  93. package/dist/types/src/SpacePlugin.d.ts +1 -1
  94. package/dist/types/src/SpacePlugin.d.ts.map +1 -1
  95. package/dist/types/src/capabilities/app-graph-builder.d.ts +1 -1
  96. package/dist/types/src/capabilities/app-graph-builder.d.ts.map +1 -1
  97. package/dist/types/src/capabilities/app-graph-serializer.d.ts +1 -1
  98. package/dist/types/src/capabilities/capabilities.d.ts +4 -4
  99. package/dist/types/src/capabilities/capabilities.d.ts.map +1 -1
  100. package/dist/types/src/capabilities/identity-created.d.ts +1 -1
  101. package/dist/types/src/capabilities/identity-created.d.ts.map +1 -1
  102. package/dist/types/src/capabilities/index.d.ts +11 -12
  103. package/dist/types/src/capabilities/index.d.ts.map +1 -1
  104. package/dist/types/src/capabilities/intent-resolver.d.ts +1 -1
  105. package/dist/types/src/capabilities/intent-resolver.d.ts.map +1 -1
  106. package/dist/types/src/capabilities/react-root.d.ts +2 -2
  107. package/dist/types/src/capabilities/react-root.d.ts.map +1 -1
  108. package/dist/types/src/capabilities/react-surface.d.ts +1 -1
  109. package/dist/types/src/capabilities/react-surface.d.ts.map +1 -1
  110. package/dist/types/src/capabilities/schema-defs.d.ts +1 -1
  111. package/dist/types/src/capabilities/schema-defs.d.ts.map +1 -1
  112. package/dist/types/src/capabilities/settings.d.ts +1 -1
  113. package/dist/types/src/capabilities/spaces-ready.d.ts +1 -1
  114. package/dist/types/src/capabilities/spaces-ready.d.ts.map +1 -1
  115. package/dist/types/src/capabilities/state.d.ts +1 -1
  116. package/dist/types/src/capabilities/state.d.ts.map +1 -1
  117. package/dist/types/src/components/CreateDialog/CreateObjectDialog.d.ts +3 -3
  118. package/dist/types/src/components/CreateDialog/CreateObjectDialog.d.ts.map +1 -1
  119. package/dist/types/src/components/CreateDialog/CreateObjectDialog.stories.d.ts +1584 -4
  120. package/dist/types/src/components/CreateDialog/CreateObjectDialog.stories.d.ts.map +1 -1
  121. package/dist/types/src/components/CreateDialog/CreateObjectPanel.d.ts +5 -3
  122. package/dist/types/src/components/CreateDialog/CreateObjectPanel.d.ts.map +1 -1
  123. package/dist/types/src/components/CreateDialog/CreateSpaceDialog.d.ts +1 -1
  124. package/dist/types/src/components/CreateDialog/CreateSpaceDialog.d.ts.map +1 -1
  125. package/dist/types/src/components/JoinDialog.d.ts +1 -1
  126. package/dist/types/src/components/JoinDialog.d.ts.map +1 -1
  127. package/dist/types/src/components/MembersContainer.d.ts +3 -2
  128. package/dist/types/src/components/MembersContainer.d.ts.map +1 -1
  129. package/dist/types/src/components/MembersContainer.stories.d.ts +1584 -5
  130. package/dist/types/src/components/MembersContainer.stories.d.ts.map +1 -1
  131. package/dist/types/src/components/ObjectDetailsPanel.d.ts.map +1 -1
  132. package/dist/types/src/components/ObjectSettings/AdvancedObjectSettings.d.ts.map +1 -1
  133. package/dist/types/src/components/ObjectSettings/ForeignKeys.d.ts +1 -1
  134. package/dist/types/src/components/ObjectSettings/ForeignKeys.d.ts.map +1 -1
  135. package/dist/types/src/components/ObjectSettings/ObjectSettingsContainer.d.ts.map +1 -1
  136. package/dist/types/src/components/PopoverRenameObject.d.ts +2 -2
  137. package/dist/types/src/components/PopoverRenameObject.d.ts.map +1 -1
  138. package/dist/types/src/components/PopoverRenameSpace.d.ts +1 -1
  139. package/dist/types/src/components/PopoverRenameSpace.d.ts.map +1 -1
  140. package/dist/types/src/components/RecordMain.d.ts +7 -0
  141. package/dist/types/src/components/RecordMain.d.ts.map +1 -0
  142. package/dist/types/src/components/SpacePluginSettings.d.ts.map +1 -1
  143. package/dist/types/src/components/SpacePresence.d.ts.map +1 -1
  144. package/dist/types/src/components/SpacePresence.stories.d.ts +1412 -4
  145. package/dist/types/src/components/SpacePresence.stories.d.ts.map +1 -1
  146. package/dist/types/src/components/SpaceSettings/SpaceSettingsContainer.d.ts.map +1 -1
  147. package/dist/types/src/components/SpaceSettings/SpaceSettingsContainer.stories.d.ts +1417 -4
  148. package/dist/types/src/components/SpaceSettings/SpaceSettingsContainer.stories.d.ts.map +1 -1
  149. package/dist/types/src/components/SyncStatus/SyncStatus.d.ts.map +1 -1
  150. package/dist/types/src/components/SyncStatus/SyncStatus.stories.d.ts +1418 -5
  151. package/dist/types/src/components/SyncStatus/SyncStatus.stories.d.ts.map +1 -1
  152. package/dist/types/src/components/ViewEditor.d.ts +1 -1
  153. package/dist/types/src/components/ViewEditor.d.ts.map +1 -1
  154. package/dist/types/src/components/index.d.ts +8 -2
  155. package/dist/types/src/components/index.d.ts.map +1 -1
  156. package/dist/types/src/events.d.ts.map +1 -1
  157. package/dist/types/src/hooks/useActiveSpace.d.ts.map +1 -1
  158. package/dist/types/src/hooks/useInputSurfaceLookup.d.ts +1 -1
  159. package/dist/types/src/hooks/useInputSurfaceLookup.d.ts.map +1 -1
  160. package/dist/types/src/hooks/usePath.d.ts +1 -1
  161. package/dist/types/src/hooks/usePath.d.ts.map +1 -1
  162. package/dist/types/src/meta.d.ts +0 -1
  163. package/dist/types/src/meta.d.ts.map +1 -1
  164. package/dist/types/src/translations.d.ts +1216 -26
  165. package/dist/types/src/translations.d.ts.map +1 -1
  166. package/dist/types/src/types/types.d.ts +76 -96
  167. package/dist/types/src/types/types.d.ts.map +1 -1
  168. package/dist/types/src/util.d.ts +10 -7
  169. package/dist/types/src/util.d.ts.map +1 -1
  170. package/dist/types/tsconfig.tsbuildinfo +1 -1
  171. package/package.json +60 -58
  172. package/src/SpacePlugin.ts +204 -219
  173. package/src/capabilities/app-graph-builder.ts +127 -69
  174. package/src/capabilities/app-graph-serializer.ts +7 -7
  175. package/src/capabilities/capabilities.ts +12 -11
  176. package/src/capabilities/identity-created.ts +1 -1
  177. package/src/capabilities/index.ts +0 -1
  178. package/src/capabilities/intent-resolver.ts +37 -25
  179. package/src/capabilities/react-root.tsx +4 -3
  180. package/src/capabilities/react-surface.tsx +52 -38
  181. package/src/capabilities/schema-defs.ts +3 -2
  182. package/src/capabilities/spaces-ready.ts +11 -8
  183. package/src/capabilities/state.ts +5 -4
  184. package/src/components/AwaitingObject.tsx +3 -3
  185. package/src/components/CollectionMain.tsx +2 -2
  186. package/src/components/CollectionSection.tsx +2 -2
  187. package/src/components/CreateDialog/CreateObjectDialog.stories.tsx +11 -10
  188. package/src/components/CreateDialog/CreateObjectDialog.tsx +24 -13
  189. package/src/components/CreateDialog/CreateObjectPanel.tsx +22 -11
  190. package/src/components/CreateDialog/CreateSpaceDialog.tsx +6 -5
  191. package/src/components/JoinDialog.tsx +7 -7
  192. package/src/components/MembersContainer.stories.tsx +36 -10
  193. package/src/components/MembersContainer.tsx +13 -14
  194. package/src/components/MenuFooter.tsx +2 -2
  195. package/src/components/ObjectDetailsPanel.tsx +7 -5
  196. package/src/components/ObjectSettings/AdvancedObjectSettings.tsx +4 -3
  197. package/src/components/ObjectSettings/ForeignKeys.tsx +3 -3
  198. package/src/components/ObjectSettings/ObjectSettingsContainer.tsx +3 -2
  199. package/src/components/PersistenceStatus.tsx +2 -2
  200. package/src/components/PopoverRenameObject.tsx +9 -15
  201. package/src/components/PopoverRenameSpace.tsx +4 -4
  202. package/src/components/RecordMain.tsx +43 -0
  203. package/src/components/SchemaContainer.tsx +5 -5
  204. package/src/components/SpacePluginSettings.tsx +8 -9
  205. package/src/components/SpacePresence.stories.tsx +23 -22
  206. package/src/components/SpacePresence.tsx +10 -10
  207. package/src/components/SpaceSettings/SpaceSettingsContainer.stories.tsx +17 -9
  208. package/src/components/SpaceSettings/SpaceSettingsContainer.tsx +19 -18
  209. package/src/components/SyncStatus/InlineSyncStatus.tsx +3 -3
  210. package/src/components/SyncStatus/SyncStatus.stories.tsx +6 -7
  211. package/src/components/SyncStatus/SyncStatus.tsx +4 -3
  212. package/src/components/ViewEditor.tsx +13 -18
  213. package/src/components/index.ts +1 -0
  214. package/src/events.ts +7 -7
  215. package/src/hooks/useActiveSpace.ts +2 -2
  216. package/src/hooks/useInputSurfaceLookup.tsx +2 -2
  217. package/src/hooks/usePath.ts +1 -1
  218. package/src/meta.ts +1 -3
  219. package/src/translations.ts +9 -8
  220. package/src/types/types.ts +17 -13
  221. package/src/util.tsx +97 -40
  222. package/dist/lib/browser/CollectionMain-D2B75XBS.mjs.map +0 -7
  223. package/dist/lib/browser/ObjectDetailsPanel-YPTDQKMG.mjs.map +0 -7
  224. package/dist/lib/browser/app-graph-builder-7CZZJS3S.mjs.map +0 -7
  225. package/dist/lib/browser/app-graph-serializer-H6AW7KGS.mjs.map +0 -7
  226. package/dist/lib/browser/chunk-CEFHNVU7.mjs +0 -20
  227. package/dist/lib/browser/chunk-CEFHNVU7.mjs.map +0 -7
  228. package/dist/lib/browser/chunk-FBCGT5YY.mjs +0 -13
  229. package/dist/lib/browser/chunk-FBCGT5YY.mjs.map +0 -7
  230. package/dist/lib/browser/chunk-JS3MMC42.mjs +0 -19
  231. package/dist/lib/browser/chunk-JS3MMC42.mjs.map +0 -7
  232. package/dist/lib/browser/chunk-QACNNDOT.mjs.map +0 -7
  233. package/dist/lib/browser/chunk-SGTQ52SU.mjs.map +0 -7
  234. package/dist/lib/browser/chunk-V7MJSSBQ.mjs.map +0 -7
  235. package/dist/lib/browser/chunk-VLBRSGJ2.mjs.map +0 -7
  236. package/dist/lib/browser/chunk-XUYKJUU7.mjs.map +0 -7
  237. package/dist/lib/browser/intent-resolver-TIXVDYN7.mjs.map +0 -7
  238. package/dist/lib/browser/react-root-N2J7TDRX.mjs.map +0 -7
  239. package/dist/lib/browser/react-surface-TPNLWJJH.mjs.map +0 -7
  240. package/dist/lib/browser/schema-defs-Z6FC4AHC.mjs.map +0 -7
  241. package/dist/lib/browser/schema-tools-BNP4JTD7.mjs +0 -124
  242. package/dist/lib/browser/schema-tools-BNP4JTD7.mjs.map +0 -7
  243. package/dist/lib/browser/spaces-ready-TOPG6IV4.mjs.map +0 -7
  244. package/dist/lib/browser/state-QYZAB45H.mjs.map +0 -7
  245. package/dist/lib/node-esm/CollectionMain-ZJIFCWKZ.mjs.map +0 -7
  246. package/dist/lib/node-esm/ObjectDetailsPanel-QKZEDSZK.mjs.map +0 -7
  247. package/dist/lib/node-esm/app-graph-builder-KGIGWC72.mjs.map +0 -7
  248. package/dist/lib/node-esm/app-graph-serializer-2ICUGQQT.mjs.map +0 -7
  249. package/dist/lib/node-esm/chunk-4AOMYKDE.mjs.map +0 -7
  250. package/dist/lib/node-esm/chunk-5HHYE264.mjs +0 -20
  251. package/dist/lib/node-esm/chunk-5HHYE264.mjs.map +0 -7
  252. package/dist/lib/node-esm/chunk-5T3ZH23B.mjs +0 -21
  253. package/dist/lib/node-esm/chunk-5T3ZH23B.mjs.map +0 -7
  254. package/dist/lib/node-esm/chunk-6X5DLJM5.mjs.map +0 -7
  255. package/dist/lib/node-esm/chunk-HWNG4MEU.mjs.map +0 -7
  256. package/dist/lib/node-esm/chunk-JH6F4C3I.mjs.map +0 -7
  257. package/dist/lib/node-esm/chunk-P442DOQ3.mjs.map +0 -7
  258. package/dist/lib/node-esm/chunk-SSLBYZEY.mjs.map +0 -7
  259. package/dist/lib/node-esm/intent-resolver-MHGHRGDT.mjs.map +0 -7
  260. package/dist/lib/node-esm/react-root-KW3TGJGY.mjs.map +0 -7
  261. package/dist/lib/node-esm/react-surface-UUIUUD6P.mjs.map +0 -7
  262. package/dist/lib/node-esm/schema-defs-WHJM7UZE.mjs.map +0 -7
  263. package/dist/lib/node-esm/schema-tools-KWW5PTML.mjs +0 -126
  264. package/dist/lib/node-esm/schema-tools-KWW5PTML.mjs.map +0 -7
  265. package/dist/lib/node-esm/spaces-ready-HIUKNDZK.mjs.map +0 -7
  266. package/dist/lib/node-esm/state-ZVEHQ4BJ.mjs.map +0 -7
  267. package/dist/types/src/capabilities/schema-tool.test.d.ts +0 -2
  268. package/dist/types/src/capabilities/schema-tool.test.d.ts.map +0 -1
  269. package/dist/types/src/capabilities/schema-tools.d.ts +0 -13
  270. package/dist/types/src/capabilities/schema-tools.d.ts.map +0 -1
  271. package/src/capabilities/schema-tool.test.ts +0 -44
  272. package/src/capabilities/schema-tools.ts +0 -125
@@ -1,6 +1,6 @@
1
1
  import {
2
- SPACE_PLUGIN
3
- } from "./chunk-FBCGT5YY.mjs";
2
+ meta
3
+ } from "./chunk-IRKDREHY.mjs";
4
4
 
5
5
  // src/components/CollectionMain.tsx
6
6
  import { useSignals as _useSignals } from "@preact-signals/safe-react/tracking";
@@ -10,7 +10,7 @@ import { baseSurface, descriptionMessage, mx } from "@dxos/react-ui-theme";
10
10
  var CollectionMain = ({ collection }) => {
11
11
  var _effect = _useSignals();
12
12
  try {
13
- const { t } = useTranslation(SPACE_PLUGIN);
13
+ const { t } = useTranslation(meta.id);
14
14
  return /* @__PURE__ */ React.createElement("div", {
15
15
  role: "none",
16
16
  className: mx(baseSurface, "min-bs-screen is-full flex items-center justify-center p-8"),
@@ -28,4 +28,4 @@ export {
28
28
  CollectionMain,
29
29
  CollectionMain_default as default
30
30
  };
31
- //# sourceMappingURL=CollectionMain-D2B75XBS.mjs.map
31
+ //# sourceMappingURL=CollectionMain-AX7KKXWP.mjs.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/components/CollectionMain.tsx"],
4
+ "sourcesContent": ["//\n// Copyright 2023 DXOS.org\n//\n\nimport React from 'react';\n\nimport { useTranslation } from '@dxos/react-ui';\nimport { baseSurface, descriptionMessage, mx } from '@dxos/react-ui-theme';\nimport { type DataType } from '@dxos/schema';\n\nimport { meta } from '../meta';\n\nexport const CollectionMain = ({ collection }: { collection: DataType.Collection }) => {\n const { t } = useTranslation(meta.id);\n\n return (\n <div\n role='none'\n className={mx(baseSurface, 'min-bs-screen is-full flex items-center justify-center p-8')}\n data-testid='composer.firstRunMessage'\n >\n <p\n role='alert'\n className={mx(descriptionMessage, 'rounded-md p-8 font-normal text-lg max-is-[24rem] break-words')}\n >\n {collection.name ?? t('unnamed collection label')}\n </p>\n </div>\n );\n};\n\nexport default CollectionMain;\n"],
5
+ "mappings": ";;;;;;AAIA,OAAOA,WAAW;AAElB,SAASC,sBAAsB;AAC/B,SAASC,aAAaC,oBAAoBC,UAAU;AAK7C,IAAMC,iBAAiB,CAAC,EAAEC,WAAU,MAAuC;;;AAChF,UAAM,EAAEC,EAAC,IAAKC,eAAeC,KAAKC,EAAE;AAEpC,WACE,sBAAA,cAACC,OAAAA;MACCC,MAAK;MACLC,WAAWC,GAAGC,aAAa,4DAAA;MAC3BC,eAAY;OAEZ,sBAAA,cAACC,KAAAA;MACCL,MAAK;MACLC,WAAWC,GAAGI,oBAAoB,+DAAA;OAEjCZ,WAAWa,QAAQZ,EAAE,0BAAA,CAAA,CAAA;;;;AAI9B;AAEA,IAAA,yBAAeF;",
6
+ "names": ["React", "useTranslation", "baseSurface", "descriptionMessage", "mx", "CollectionMain", "collection", "t", "useTranslation", "meta", "id", "div", "role", "className", "mx", "baseSurface", "data-testid", "p", "descriptionMessage", "name"]
7
+ }
@@ -1,26 +1,28 @@
1
1
  import {
2
- SPACE_PLUGIN
3
- } from "./chunk-FBCGT5YY.mjs";
2
+ meta
3
+ } from "./chunk-IRKDREHY.mjs";
4
4
 
5
5
  // src/components/ObjectDetailsPanel.tsx
6
6
  import { useSignals as _useSignals } from "@preact-signals/safe-react/tracking";
7
7
  import React, { useCallback } from "react";
8
- import { setValue } from "@dxos/echo-schema";
8
+ import { setValue } from "@dxos/echo/internal";
9
9
  import { invariant } from "@dxos/invariant";
10
10
  import { useClient } from "@dxos/react-client";
11
- import { getSpace, Filter, useQuery, useSchema } from "@dxos/react-client/echo";
11
+ import { Filter, getSpace, useQuery, useSchema } from "@dxos/react-client/echo";
12
12
  import { Callout, useTranslation } from "@dxos/react-ui";
13
13
  import { useSelected } from "@dxos/react-ui-attention";
14
14
  import { Form, useRefQueryLookupHandler } from "@dxos/react-ui-form";
15
+ import { getTypenameFromQuery } from "@dxos/schema";
15
16
  import { isNonNullable } from "@dxos/util";
16
17
  var __dxlog_file = "/__w/dxos/dxos/packages/plugins/plugin-space/src/components/ObjectDetailsPanel.tsx";
17
18
  var ObjectDetailsPanel = ({ objectId, view }) => {
18
19
  var _effect = _useSignals();
19
20
  try {
20
- const { t } = useTranslation(SPACE_PLUGIN);
21
+ const { t } = useTranslation(meta.id);
21
22
  const client = useClient();
22
23
  const space = getSpace(view);
23
- const schema = useSchema(client, space, view.query?.typename);
24
+ const typename = view.query ? getTypenameFromQuery(view.query.ast) : void 0;
25
+ const schema = useSchema(client, space, typename);
24
26
  const queriedObjects = useQuery(space, schema ? Filter.type(schema) : Filter.nothing());
25
27
  const selectedRows = useSelected(objectId, "multi");
26
28
  const selectedObjects = selectedRows.map((id) => queriedObjects.find((obj) => obj.id === id)).filter(isNonNullable);
@@ -31,7 +33,7 @@ var ObjectDetailsPanel = ({ objectId, view }) => {
31
33
  const id = values.id;
32
34
  invariant(typeof id === "string", void 0, {
33
35
  F: __dxlog_file,
34
- L: 36,
36
+ L: 38,
35
37
  S: void 0,
36
38
  A: [
37
39
  "typeof id === 'string'",
@@ -41,7 +43,7 @@ var ObjectDetailsPanel = ({ objectId, view }) => {
41
43
  const object = queriedObjects.find((obj) => obj.id === id);
42
44
  invariant(object, void 0, {
43
45
  F: __dxlog_file,
44
- L: 38,
46
+ L: 40,
45
47
  S: void 0,
46
48
  A: [
47
49
  "object",
@@ -85,4 +87,4 @@ var ObjectDetailsPanel_default = ObjectDetailsPanel;
85
87
  export {
86
88
  ObjectDetailsPanel_default as default
87
89
  };
88
- //# sourceMappingURL=ObjectDetailsPanel-YPTDQKMG.mjs.map
90
+ //# sourceMappingURL=ObjectDetailsPanel-SJ4XUXXX.mjs.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/components/ObjectDetailsPanel.tsx"],
4
+ "sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport React, { useCallback } from 'react';\n\nimport { type JsonPath, setValue } from '@dxos/echo/internal';\nimport { invariant } from '@dxos/invariant';\nimport { useClient } from '@dxos/react-client';\nimport { Filter, getSpace, useQuery, useSchema } from '@dxos/react-client/echo';\nimport { Callout, useTranslation } from '@dxos/react-ui';\nimport { useSelected } from '@dxos/react-ui-attention';\nimport { Form, useRefQueryLookupHandler } from '@dxos/react-ui-form';\nimport { type DataType } from '@dxos/schema';\nimport { getTypenameFromQuery } from '@dxos/schema';\nimport { isNonNullable } from '@dxos/util';\n\nimport { meta } from '../meta';\n\ntype RowDetailsPanelProps = { objectId: string; view: DataType.View };\n\nconst ObjectDetailsPanel = ({ objectId, view }: RowDetailsPanelProps) => {\n const { t } = useTranslation(meta.id);\n const client = useClient();\n const space = getSpace(view);\n const typename = view.query ? getTypenameFromQuery(view.query.ast) : undefined;\n const schema = useSchema(client, space, typename);\n\n const queriedObjects = useQuery(space, schema ? Filter.type(schema) : Filter.nothing());\n const selectedRows = useSelected(objectId, 'multi');\n const selectedObjects = selectedRows.map((id) => queriedObjects.find((obj) => obj.id === id)).filter(isNonNullable);\n\n const handleRefQueryLookup = useRefQueryLookupHandler({ space });\n\n const handleSave = useCallback(\n (values: any, { changed }: { changed: Record<JsonPath, boolean> }) => {\n const id = values.id;\n invariant(typeof id === 'string');\n const object = queriedObjects.find((obj) => obj.id === id);\n invariant(object);\n\n const changedPaths = Object.keys(changed).filter((path) => changed[path as JsonPath]) as JsonPath[];\n for (const path of changedPaths) {\n const value = values[path];\n setValue(object, path, value);\n }\n },\n [queriedObjects],\n );\n\n if (selectedObjects.length === 0) {\n return (\n <div role='none' className='plb-cardSpacingBlock pli-cardSpacingInline'>\n <Callout.Root classNames='is-full'>\n <Callout.Title>{t('row details no selection label')}</Callout.Title>\n </Callout.Root>\n </div>\n );\n }\n\n return (\n <div role='none' className='bs-full is-full flex flex-col p-2 gap-1 overflow-y-auto'>\n {schema &&\n selectedObjects.map((object) => (\n <div key={object.id} className='border border-separator rounded'>\n <Form\n autoSave\n schema={schema}\n values={object}\n onSave={handleSave}\n onQueryRefOptions={handleRefQueryLookup}\n />\n </div>\n ))}\n </div>\n );\n};\n\nexport default ObjectDetailsPanel;\n"],
5
+ "mappings": ";;;;;;AAIA,OAAOA,SAASC,mBAAmB;AAEnC,SAAwBC,gBAAgB;AACxC,SAASC,iBAAiB;AAC1B,SAASC,iBAAiB;AAC1B,SAASC,QAAQC,UAAUC,UAAUC,iBAAiB;AACtD,SAASC,SAASC,sBAAsB;AACxC,SAASC,mBAAmB;AAC5B,SAASC,MAAMC,gCAAgC;AAE/C,SAASC,4BAA4B;AACrC,SAASC,qBAAqB;;AAM9B,IAAMC,qBAAqB,CAAC,EAAEC,UAAUC,KAAI,MAAwB;;;AAClE,UAAM,EAAEC,EAAC,IAAKC,eAAeC,KAAKC,EAAE;AACpC,UAAMC,SAASC,UAAAA;AACf,UAAMC,QAAQC,SAASR,IAAAA;AACvB,UAAMS,WAAWT,KAAKU,QAAQC,qBAAqBX,KAAKU,MAAME,GAAG,IAAIC;AACrE,UAAMC,SAASC,UAAUV,QAAQE,OAAOE,QAAAA;AAExC,UAAMO,iBAAiBC,SAASV,OAAOO,SAASI,OAAOC,KAAKL,MAAAA,IAAUI,OAAOE,QAAO,CAAA;AACpF,UAAMC,eAAeC,YAAYvB,UAAU,OAAA;AAC3C,UAAMwB,kBAAkBF,aAAaG,IAAI,CAACpB,OAAOY,eAAeS,KAAK,CAACC,QAAQA,IAAItB,OAAOA,EAAAA,CAAAA,EAAKuB,OAAOC,aAAAA;AAErG,UAAMC,uBAAuBC,yBAAyB;MAAEvB;IAAM,CAAA;AAE9D,UAAMwB,aAAaC,YACjB,CAACC,QAAa,EAAEC,QAAO,MAA0C;AAC/D,YAAM9B,KAAK6B,OAAO7B;AAClB+B,gBAAU,OAAO/B,OAAO,UAAA,QAAA;;;;;;;;;AACxB,YAAMgC,SAASpB,eAAeS,KAAK,CAACC,QAAQA,IAAItB,OAAOA,EAAAA;AACvD+B,gBAAUC,QAAAA,QAAAA;;;;;;;;;AAEV,YAAMC,eAAeC,OAAOC,KAAKL,OAAAA,EAASP,OAAO,CAACa,SAASN,QAAQM,IAAAA,CAAiB;AACpF,iBAAWA,QAAQH,cAAc;AAC/B,cAAMI,QAAQR,OAAOO,IAAAA;AACrBE,iBAASN,QAAQI,MAAMC,KAAAA;MACzB;IACF,GACA;MAACzB;KAAe;AAGlB,QAAIO,gBAAgBoB,WAAW,GAAG;AAChC,aACE,sBAAA,cAACC,OAAAA;QAAIC,MAAK;QAAOC,WAAU;SACzB,sBAAA,cAACC,QAAQC,MAAI;QAACC,YAAW;SACvB,sBAAA,cAACF,QAAQG,OAAK,MAAEjD,EAAE,gCAAA,CAAA,CAAA,CAAA;IAI1B;AAEA,WACE,sBAAA,cAAC2C,OAAAA;MAAIC,MAAK;MAAOC,WAAU;OACxBhC,UACCS,gBAAgBC,IAAI,CAACY,WACnB,sBAAA,cAACQ,OAAAA;MAAIO,KAAKf,OAAOhC;MAAI0C,WAAU;OAC7B,sBAAA,cAACM,MAAAA;MACCC,UAAAA;MACAvC;MACAmB,QAAQG;MACRkB,QAAQvB;MACRwB,mBAAmB1B;;;;;AAMjC;AAEA,IAAA,6BAAe/B;",
6
+ "names": ["React", "useCallback", "setValue", "invariant", "useClient", "Filter", "getSpace", "useQuery", "useSchema", "Callout", "useTranslation", "useSelected", "Form", "useRefQueryLookupHandler", "getTypenameFromQuery", "isNonNullable", "ObjectDetailsPanel", "objectId", "view", "t", "useTranslation", "meta", "id", "client", "useClient", "space", "getSpace", "typename", "query", "getTypenameFromQuery", "ast", "undefined", "schema", "useSchema", "queriedObjects", "useQuery", "Filter", "type", "nothing", "selectedRows", "useSelected", "selectedObjects", "map", "find", "obj", "filter", "isNonNullable", "handleRefQueryLookup", "useRefQueryLookupHandler", "handleSave", "useCallback", "values", "changed", "invariant", "object", "changedPaths", "Object", "keys", "path", "value", "setValue", "length", "div", "role", "className", "Callout", "Root", "classNames", "Title", "key", "Form", "autoSave", "onSave", "onQueryRefOptions"]
7
+ }
@@ -0,0 +1,68 @@
1
+ // src/components/RecordMain.tsx
2
+ import { useSignals as _useSignals } from "@preact-signals/safe-react/tracking";
3
+ import React, { useCallback } from "react";
4
+ import { Obj } from "@dxos/echo";
5
+ import { setValue } from "@dxos/echo/internal";
6
+ import { invariant } from "@dxos/invariant";
7
+ import { getSpace } from "@dxos/react-client/echo";
8
+ import { Form, useRefQueryLookupHandler } from "@dxos/react-ui-form";
9
+ var __dxlog_file = "/__w/dxos/dxos/packages/plugins/plugin-space/src/components/RecordMain.tsx";
10
+ var RecordMain = ({ record }) => {
11
+ var _effect = _useSignals();
12
+ try {
13
+ const space = getSpace(record);
14
+ const schema = Obj.getSchema(record);
15
+ invariant(schema, "Record has no schema.", {
16
+ F: __dxlog_file,
17
+ L: 16,
18
+ S: void 0,
19
+ A: [
20
+ "schema",
21
+ "'Record has no schema.'"
22
+ ]
23
+ });
24
+ const handleRefQueryLookup = useRefQueryLookupHandler({
25
+ space
26
+ });
27
+ const handleSave = useCallback((values, { changed }) => {
28
+ const id = values.id;
29
+ invariant(typeof id === "string", void 0, {
30
+ F: __dxlog_file,
31
+ L: 23,
32
+ S: void 0,
33
+ A: [
34
+ "typeof id === 'string'",
35
+ ""
36
+ ]
37
+ });
38
+ const changedPaths = Object.keys(changed).filter((path) => changed[path]);
39
+ for (const path of changedPaths) {
40
+ const value = values[path];
41
+ setValue(record, path, value);
42
+ }
43
+ }, [
44
+ record
45
+ ]);
46
+ return /* @__PURE__ */ React.createElement("div", {
47
+ role: "none",
48
+ className: "container-max-width flex flex-col p-2 gap-1 overflow-y-auto"
49
+ }, /* @__PURE__ */ React.createElement("div", {
50
+ key: record.id,
51
+ className: "border border-separator rounded"
52
+ }, /* @__PURE__ */ React.createElement(Form, {
53
+ autoSave: true,
54
+ schema,
55
+ values: record,
56
+ onSave: handleSave,
57
+ onQueryRefOptions: handleRefQueryLookup
58
+ })));
59
+ } finally {
60
+ _effect.f();
61
+ }
62
+ };
63
+ var RecordMain_default = RecordMain;
64
+ export {
65
+ RecordMain,
66
+ RecordMain_default as default
67
+ };
68
+ //# sourceMappingURL=RecordMain-FHPCS6GM.mjs.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/components/RecordMain.tsx"],
4
+ "sourcesContent": ["//\n// Copyright 2023 DXOS.org\n//\n\nimport React, { useCallback } from 'react';\n\nimport { Obj } from '@dxos/echo';\nimport { type JsonPath, setValue } from '@dxos/echo/internal';\nimport { invariant } from '@dxos/invariant';\nimport { getSpace } from '@dxos/react-client/echo';\nimport { Form, useRefQueryLookupHandler } from '@dxos/react-ui-form';\n\nexport const RecordMain = ({ record }: { record: Obj.Any }) => {\n const space = getSpace(record);\n const schema = Obj.getSchema(record);\n invariant(schema, 'Record has no schema.');\n\n const handleRefQueryLookup = useRefQueryLookupHandler({ space });\n\n const handleSave = useCallback(\n (values: any, { changed }: { changed: Record<JsonPath, boolean> }) => {\n const id = values.id;\n invariant(typeof id === 'string');\n\n const changedPaths = Object.keys(changed).filter((path) => changed[path as JsonPath]) as JsonPath[];\n for (const path of changedPaths) {\n const value = values[path];\n setValue(record, path, value);\n }\n },\n [record],\n );\n\n return (\n <div role='none' className='container-max-width flex flex-col p-2 gap-1 overflow-y-auto'>\n <div key={record.id} className='border border-separator rounded'>\n <Form autoSave schema={schema} values={record} onSave={handleSave} onQueryRefOptions={handleRefQueryLookup} />\n </div>\n </div>\n );\n};\n\nexport default RecordMain;\n"],
5
+ "mappings": ";;AAIA,OAAOA,SAASC,mBAAmB;AAEnC,SAASC,WAAW;AACpB,SAAwBC,gBAAgB;AACxC,SAASC,iBAAiB;AAC1B,SAASC,gBAAgB;AACzB,SAASC,MAAMC,gCAAgC;;AAExC,IAAMC,aAAa,CAAC,EAAEC,OAAM,MAAuB;;;AACxD,UAAMC,QAAQL,SAASI,MAAAA;AACvB,UAAME,SAAST,IAAIU,UAAUH,MAAAA;AAC7BL,cAAUO,QAAQ,yBAAA;;;;;;;;;AAElB,UAAME,uBAAuBN,yBAAyB;MAAEG;IAAM,CAAA;AAE9D,UAAMI,aAAab,YACjB,CAACc,QAAa,EAAEC,QAAO,MAA0C;AAC/D,YAAMC,KAAKF,OAAOE;AAClBb,gBAAU,OAAOa,OAAO,UAAA,QAAA;;;;;;;;;AAExB,YAAMC,eAAeC,OAAOC,KAAKJ,OAAAA,EAASK,OAAO,CAACC,SAASN,QAAQM,IAAAA,CAAiB;AACpF,iBAAWA,QAAQJ,cAAc;AAC/B,cAAMK,QAAQR,OAAOO,IAAAA;AACrBnB,iBAASM,QAAQa,MAAMC,KAAAA;MACzB;IACF,GACA;MAACd;KAAO;AAGV,WACE,sBAAA,cAACe,OAAAA;MAAIC,MAAK;MAAOC,WAAU;OACzB,sBAAA,cAACF,OAAAA;MAAIG,KAAKlB,OAAOQ;MAAIS,WAAU;OAC7B,sBAAA,cAACpB,MAAAA;MAAKsB,UAAAA;MAASjB;MAAgBI,QAAQN;MAAQoB,QAAQf;MAAYgB,mBAAmBjB;;;;;AAI9F;AAEA,IAAA,qBAAeL;",
6
+ "names": ["React", "useCallback", "Obj", "setValue", "invariant", "getSpace", "Form", "useRefQueryLookupHandler", "RecordMain", "record", "space", "schema", "getSchema", "handleRefQueryLookup", "handleSave", "values", "changed", "id", "changedPaths", "Object", "keys", "filter", "path", "value", "div", "role", "className", "key", "autoSave", "onSave", "onQueryRefOptions"]
7
+ }
@@ -1,9 +1,9 @@
1
1
  import {
2
2
  getActiveSpace
3
- } from "./chunk-VLBRSGJ2.mjs";
3
+ } from "./chunk-CVZAZRW4.mjs";
4
4
  import {
5
5
  SpaceCapabilities
6
- } from "./chunk-CEFHNVU7.mjs";
6
+ } from "./chunk-PUF3B7XO.mjs";
7
7
  import {
8
8
  SHARED,
9
9
  SPACES,
@@ -14,29 +14,32 @@ import {
14
14
  createStaticSchemaActions,
15
15
  createStaticSchemaNode,
16
16
  rxFromQuery
17
- } from "./chunk-XUYKJUU7.mjs";
17
+ } from "./chunk-X6COEDOD.mjs";
18
18
  import {
19
19
  SPACE_TYPE,
20
20
  SpaceAction
21
- } from "./chunk-SGTQ52SU.mjs";
21
+ } from "./chunk-OYHC63NL.mjs";
22
22
  import {
23
- SPACE_PLUGIN
24
- } from "./chunk-FBCGT5YY.mjs";
23
+ meta
24
+ } from "./chunk-IRKDREHY.mjs";
25
25
 
26
26
  // src/capabilities/app-graph-builder.ts
27
27
  import { Rx } from "@effect-rx/rx-react";
28
- import { Array, Option, pipe, Schema } from "effect";
28
+ import * as Array from "effect/Array";
29
+ import * as Function from "effect/Function";
30
+ import * as Option from "effect/Option";
31
+ import * as Schema from "effect/Schema";
29
32
  import { Capabilities, contributes, createIntent } from "@dxos/app-framework";
30
- import { getSpace, SpaceState, isSpace } from "@dxos/client/echo";
33
+ import { SpaceState, getSpace, isSpace, parseId } from "@dxos/client/echo";
31
34
  import { Filter, Obj, Query, Type } from "@dxos/echo";
32
35
  import { log } from "@dxos/log";
33
36
  import { ClientCapabilities } from "@dxos/plugin-client";
34
- import { PLANK_COMPANION_TYPE, ATTENDABLE_PATH_SEPARATOR } from "@dxos/plugin-deck/types";
35
- import { createExtension, rxFromObservable, ROOT_ID, rxFromSignal } from "@dxos/plugin-graph";
36
- import { DataType } from "@dxos/schema";
37
+ import { ATTENDABLE_PATH_SEPARATOR, PLANK_COMPANION_TYPE } from "@dxos/plugin-deck/types";
38
+ import { ROOT_ID, createExtension, rxFromObservable, rxFromSignal } from "@dxos/plugin-graph";
39
+ import { DataType, getTypenameFromQuery } from "@dxos/schema";
37
40
  import { isNonNullable } from "@dxos/util";
38
41
  var __dxlog_file = "/__w/dxos/dxos/packages/plugins/plugin-space/src/capabilities/app-graph-builder.ts";
39
- var app_graph_builder_default = (context) => {
42
+ var app_graph_builder_default = ((context) => {
40
43
  const resolve = (typename) => context.getCapabilities(Capabilities.Metadata).find(({ id }) => id === typename)?.metadata ?? {};
41
44
  const spacesNode = {
42
45
  id: SPACES,
@@ -49,7 +52,7 @@ var app_graph_builder_default = (context) => {
49
52
  label: [
50
53
  "spaces label",
51
54
  {
52
- ns: SPACE_PLUGIN
55
+ ns: meta.id
53
56
  }
54
57
  ],
55
58
  icon: "ph--planet--regular",
@@ -70,7 +73,7 @@ var app_graph_builder_default = (context) => {
70
73
  } else {
71
74
  log.warn("spaces order object not found", void 0, {
72
75
  F: __dxlog_file,
73
- L: 70,
76
+ L: 74,
74
77
  S: void 0,
75
78
  C: (f, a) => f(...a)
76
79
  });
@@ -81,9 +84,9 @@ var app_graph_builder_default = (context) => {
81
84
  return contributes(Capabilities.AppGraphBuilder, [
82
85
  // Primary actions.
83
86
  createExtension({
84
- id: `${SPACE_PLUGIN}/primary-actions`,
87
+ id: `${meta.id}/primary-actions`,
85
88
  position: "hoist",
86
- actions: (node) => Rx.make((get) => pipe(get(node), Option.flatMap((node2) => node2.id === ROOT_ID ? Option.some(node2) : Option.none()), Option.map(() => [
89
+ actions: (node) => Rx.make((get) => Function.pipe(get(node), Option.flatMap((node2) => node2.id === ROOT_ID ? Option.some(node2) : Option.none()), Option.map(() => [
87
90
  {
88
91
  id: SpaceAction.OpenCreateSpace._tag,
89
92
  data: async () => {
@@ -94,7 +97,7 @@ var app_graph_builder_default = (context) => {
94
97
  label: [
95
98
  "create space label",
96
99
  {
97
- ns: SPACE_PLUGIN
100
+ ns: meta.id
98
101
  }
99
102
  ],
100
103
  icon: "ph--plus--regular",
@@ -112,7 +115,7 @@ var app_graph_builder_default = (context) => {
112
115
  label: [
113
116
  "join space label",
114
117
  {
115
- ns: SPACE_PLUGIN
118
+ ns: meta.id
116
119
  }
117
120
  ],
118
121
  icon: "ph--sign-in--regular",
@@ -134,7 +137,7 @@ var app_graph_builder_default = (context) => {
134
137
  label: [
135
138
  "share space label",
136
139
  {
137
- ns: SPACE_PLUGIN
140
+ ns: meta.id
138
141
  }
139
142
  ],
140
143
  icon: "ph--users--regular",
@@ -159,7 +162,7 @@ var app_graph_builder_default = (context) => {
159
162
  label: [
160
163
  "open current space settings label",
161
164
  {
162
- ns: SPACE_PLUGIN
165
+ ns: meta.id
163
166
  }
164
167
  ],
165
168
  icon: "ph--faders--regular",
@@ -173,9 +176,9 @@ var app_graph_builder_default = (context) => {
173
176
  }),
174
177
  // Create spaces group node.
175
178
  createExtension({
176
- id: `${SPACE_PLUGIN}/root`,
179
+ id: `${meta.id}/root`,
177
180
  position: "hoist",
178
- connector: (node) => Rx.make((get) => pipe(get(node), Option.flatMap((node2) => node2.id === ROOT_ID ? Option.some(node2) : Option.none()), Option.map(() => [
181
+ connector: (node) => Rx.make((get) => Function.pipe(get(node), Option.flatMap((node2) => node2.id === ROOT_ID ? Option.some(node2) : Option.none()), Option.map(() => [
179
182
  spacesNode
180
183
  ]), Option.getOrElse(() => [])))
181
184
  }),
@@ -184,7 +187,7 @@ var app_graph_builder_default = (context) => {
184
187
  id: SPACES,
185
188
  connector: (node) => {
186
189
  let query;
187
- return Rx.make((get) => pipe(get(node), Option.flatMap((node2) => node2.id === SPACES ? Option.some(node2) : Option.none()), Option.map(() => {
190
+ return Rx.make((get) => Function.pipe(get(node), Option.flatMap((node2) => node2.id === SPACES ? Option.some(node2) : Option.none()), Option.map(() => {
188
191
  const state = context.getCapability(SpaceCapabilities.State);
189
192
  const client = context.getCapability(ClientCapabilities.Client);
190
193
  const spacesRx = rxFromObservable(client.spaces);
@@ -194,7 +197,7 @@ var app_graph_builder_default = (context) => {
194
197
  if (!spaces || !isReady) {
195
198
  return [];
196
199
  }
197
- const settings = get(context.capabilities(Capabilities.SettingsStore))[0]?.getStore(SPACE_PLUGIN)?.value;
200
+ const settings = get(context.capabilities(Capabilities.SettingsStore))[0]?.getStore(meta.id)?.value;
198
201
  try {
199
202
  if (!query) {
200
203
  query = client.spaces.default.db.query(Filter.type(Type.Expando, {
@@ -227,8 +230,8 @@ var app_graph_builder_default = (context) => {
227
230
  }),
228
231
  // Create space actions.
229
232
  createExtension({
230
- id: `${SPACE_PLUGIN}/actions`,
231
- actions: (node) => Rx.make((get) => pipe(get(node), Option.flatMap((node2) => node2.type === SPACE_TYPE && isSpace(node2.data) ? Option.some(node2.data) : Option.none()), Option.flatMap((space) => {
233
+ id: `${meta.id}/actions`,
234
+ actions: (node) => Rx.make((get) => Function.pipe(get(node), Option.flatMap((node2) => node2.type === SPACE_TYPE && isSpace(node2.data) ? Option.some(node2.data) : Option.none()), Option.flatMap((space) => {
232
235
  const [dispatcher] = get(context.capabilities(Capabilities.IntentDispatcher));
233
236
  const [client] = get(context.capabilities(ClientCapabilities.Client));
234
237
  const [state] = get(context.capabilities(SpaceCapabilities.State));
@@ -246,8 +249,8 @@ var app_graph_builder_default = (context) => {
246
249
  }),
247
250
  // Create nodes for objects in the root collection of a space.
248
251
  createExtension({
249
- id: `${SPACE_PLUGIN}/root-collection`,
250
- connector: (node) => Rx.make((get) => pipe(get(node), Option.flatMap((node2) => node2.type === SPACE_TYPE && isSpace(node2.data) ? Option.some(node2.data) : Option.none()), Option.map((space) => {
252
+ id: `${meta.id}/root-collection`,
253
+ connector: (node) => Rx.make((get) => Function.pipe(get(node), Option.flatMap((node2) => node2.type === SPACE_TYPE && isSpace(node2.data) ? Option.some(node2.data) : Option.none()), Option.map((space) => {
251
254
  const state = context.getCapability(SpaceCapabilities.State);
252
255
  const spaceState = get(rxFromObservable(space.state));
253
256
  if (spaceState !== SpaceState.SPACE_READY) {
@@ -257,7 +260,7 @@ var app_graph_builder_default = (context) => {
257
260
  if (!collection) {
258
261
  return [];
259
262
  }
260
- return get(rxFromSignal(() => pipe(collection.objects, Array.map((object) => object.target), Array.filter(isNonNullable), Array.map((object) => createObjectNode({
263
+ return get(rxFromSignal(() => Function.pipe(collection.objects, Array.map((object) => object.target), Array.filter(isNonNullable), Array.map((object) => createObjectNode({
261
264
  space,
262
265
  object,
263
266
  resolve,
@@ -267,11 +270,11 @@ var app_graph_builder_default = (context) => {
267
270
  }),
268
271
  // Create nodes for objects in a collection or by its fully qualified id.
269
272
  createExtension({
270
- id: `${SPACE_PLUGIN}/objects`,
271
- connector: (node) => Rx.make((get) => pipe(get(node), Option.flatMap((node2) => Obj.instanceOf(DataType.Collection, node2.data) ? Option.some(node2.data) : Option.none()), Option.map((collection) => {
273
+ id: `${meta.id}/objects`,
274
+ connector: (node) => Rx.make((get) => Function.pipe(get(node), Option.flatMap((node2) => Obj.instanceOf(DataType.Collection, node2.data) ? Option.some(node2.data) : Option.none()), Option.map((collection) => {
272
275
  const state = context.getCapability(SpaceCapabilities.State);
273
276
  const space = getSpace(collection);
274
- return get(rxFromSignal(() => pipe(collection.objects, Array.map((object) => object.target), Array.filter(isNonNullable), Array.map((object) => space && createObjectNode({
277
+ return get(rxFromSignal(() => Function.pipe(collection.objects, Array.map((object) => object.target), Array.filter(isNonNullable), Array.map((object) => space && createObjectNode({
275
278
  object,
276
279
  space,
277
280
  resolve,
@@ -281,13 +284,14 @@ var app_graph_builder_default = (context) => {
281
284
  }),
282
285
  // Create nodes for objects in a query collection.
283
286
  createExtension({
284
- id: `${SPACE_PLUGIN}/query-collection-objects`,
287
+ id: `${meta.id}/query-collection-objects`,
285
288
  connector: (node) => {
286
289
  let query;
287
- return Rx.make((get) => pipe(get(node), Option.flatMap((node2) => Obj.instanceOf(DataType.QueryCollection, node2.data) ? Option.some(node2.data) : Option.none()), Option.flatMap((collection) => {
290
+ return Rx.make((get) => Function.pipe(get(node), Option.flatMap((node2) => Obj.instanceOf(DataType.QueryCollection, node2.data) ? Option.some(node2.data) : Option.none()), Option.flatMap((collection) => {
288
291
  const space = getSpace(collection);
289
- return collection.query.typename && space ? Option.some({
290
- typename: collection.query.typename,
292
+ const typename = getTypenameFromQuery(collection.query);
293
+ return typename && space ? Option.some({
294
+ typename,
291
295
  space
292
296
  }) : Option.none();
293
297
  }), Option.map(({ typename, space }) => {
@@ -301,7 +305,7 @@ var app_graph_builder_default = (context) => {
301
305
  Query.select(Filter.typename(typename)).referencedBy(DataType.Collection, "objects").reference("objects")
302
306
  ));
303
307
  }
304
- return get(rxFromQuery(query)).map((object) => get(rxFromSignal(() => createObjectNode({
308
+ return get(rxFromQuery(query)).toSorted((a, b) => a.id.localeCompare(b.id)).map((object) => get(rxFromSignal(() => createObjectNode({
305
309
  object,
306
310
  space,
307
311
  resolve,
@@ -313,10 +317,10 @@ var app_graph_builder_default = (context) => {
313
317
  }),
314
318
  // Static schema records.
315
319
  createExtension({
316
- id: `${SPACE_PLUGIN}/static-schemas`,
320
+ id: `${meta.id}/static-schemas`,
317
321
  connector: (node) => {
318
322
  const client = context.getCapability(ClientCapabilities.Client);
319
- return Rx.make((get) => pipe(get(node), Option.flatMap((node2) => Obj.instanceOf(DataType.QueryCollection, node2.data) && node2.data.query.typename === DataType.StoredSchema.typename ? Option.some(node2.data) : Option.none()), Option.flatMap((collection) => {
323
+ return Rx.make((get) => Function.pipe(get(node), Option.flatMap((node2) => Obj.instanceOf(DataType.QueryCollection, node2.data) && getTypenameFromQuery(node2.data.query) === DataType.StoredSchema.typename ? Option.some(node2.data) : Option.none()), Option.flatMap((collection) => {
320
324
  const space = getSpace(collection);
321
325
  return space?.properties.staticRecords ? Option.some(space) : Option.none();
322
326
  }), Option.map((space) => {
@@ -329,10 +333,10 @@ var app_graph_builder_default = (context) => {
329
333
  }),
330
334
  // Create static schema actions.
331
335
  createExtension({
332
- id: `${SPACE_PLUGIN}/static-schema-actions`,
336
+ id: `${meta.id}/static-schema-actions`,
333
337
  actions: (node) => {
334
338
  let query;
335
- return Rx.make((get) => pipe(get(node), Option.flatMap((node2) => {
339
+ return Rx.make((get) => Function.pipe(get(node), Option.flatMap((node2) => {
336
340
  const space = isSpace(node2.properties.space) ? node2.properties.space : void 0;
337
341
  return space && Schema.isSchema(node2.data) ? Option.some({
338
342
  space,
@@ -345,12 +349,17 @@ var app_graph_builder_default = (context) => {
345
349
  const views = get(rxFromQuery(query));
346
350
  const filteredViews = get(rxFromSignal(() => (
347
351
  // TODO(wittjosiah): Remove cast.
348
- views.filter((view) => view.query.typename === Type.getTypename(schema))
352
+ views.filter((view) => getTypenameFromQuery(view.query.ast) === Type.getTypename(schema))
349
353
  )));
350
354
  const deletable = filteredViews.length === 0;
355
+ const [dispatcher] = get(context.capabilities(Capabilities.IntentDispatcher));
356
+ if (!dispatcher) {
357
+ return [];
358
+ }
351
359
  return createStaticSchemaActions({
352
360
  schema,
353
361
  space,
362
+ dispatch: dispatcher.dispatchPromise,
354
363
  deletable
355
364
  });
356
365
  }), Option.getOrElse(() => [])));
@@ -358,10 +367,10 @@ var app_graph_builder_default = (context) => {
358
367
  }),
359
368
  // Create nodes for schema views.
360
369
  createExtension({
361
- id: `${SPACE_PLUGIN}/schema-views`,
370
+ id: `${meta.id}/schema-views`,
362
371
  connector: (node) => {
363
372
  let query;
364
- return Rx.make((get) => pipe(get(node), Option.flatMap((node2) => {
373
+ return Rx.make((get) => Function.pipe(get(node), Option.flatMap((node2) => {
365
374
  const space = getSpace(node2.data) ?? (isSpace(node2.properties.space) ? node2.properties.space : void 0);
366
375
  return space && (Obj.instanceOf(DataType.StoredSchema, node2.data) || Schema.isSchema(node2.data)) ? Option.some({
367
376
  space,
@@ -372,7 +381,7 @@ var app_graph_builder_default = (context) => {
372
381
  query = space.db.query(Filter.type(DataType.View));
373
382
  }
374
383
  const typename = Schema.isSchema(schema) ? Type.getTypename(schema) : schema.typename;
375
- return get(rxFromQuery(query)).filter((view) => view.query.typename === typename).map((view) => get(rxFromSignal(() => createObjectNode({
384
+ return get(rxFromQuery(query)).filter((view) => getTypenameFromQuery(view.query.ast) === typename).map((view) => get(rxFromSignal(() => createObjectNode({
376
385
  object: view,
377
386
  space,
378
387
  resolve,
@@ -381,26 +390,58 @@ var app_graph_builder_default = (context) => {
381
390
  }), Option.getOrElse(() => [])));
382
391
  }
383
392
  }),
393
+ // Create record nodes.
394
+ createExtension({
395
+ id: `${meta.id}/records`,
396
+ resolver: (id) => {
397
+ let query;
398
+ return Rx.make((get) => {
399
+ const client = context.getCapability(ClientCapabilities.Client);
400
+ const { spaceId, objectId } = parseId(id);
401
+ if (!spaceId || !objectId) {
402
+ return null;
403
+ }
404
+ const space = client.spaces.get(spaceId);
405
+ if (!space) {
406
+ return null;
407
+ }
408
+ if (!query) {
409
+ query = space.db.query(Filter.ids(objectId));
410
+ }
411
+ const object = get(rxFromQuery(query)).at(0);
412
+ if (!object) {
413
+ return null;
414
+ }
415
+ return createObjectNode({
416
+ object,
417
+ space,
418
+ resolve,
419
+ disposition: "hidden"
420
+ });
421
+ });
422
+ }
423
+ }),
384
424
  // Create collection actions and action groups.
385
425
  createExtension({
386
- id: `${SPACE_PLUGIN}/object-actions`,
426
+ id: `${meta.id}/object-actions`,
387
427
  actions: (node) => {
388
428
  let query;
389
- return Rx.make((get) => pipe(get(node), Option.flatMap((node2) => {
429
+ return Rx.make((get) => Function.pipe(get(node), Option.flatMap((node2) => {
390
430
  const space = getSpace(node2.data);
391
- return space && Obj.isObject(node2.data) ? Option.some({
431
+ return space && Obj.isObject(node2.data) && Obj.getTypename(node2.data) === node2.type ? Option.some({
392
432
  space,
393
433
  object: node2.data
394
434
  }) : Option.none();
395
435
  }), Option.flatMap(({ space, object }) => {
396
- const isSchema = Obj.instanceOf(DataType.StoredSchema, object);
397
- if (!query && isSchema) {
436
+ const isSchema2 = Obj.instanceOf(DataType.StoredSchema, object);
437
+ if (!query && isSchema2) {
398
438
  query = space.db.query(Filter.type(DataType.View));
399
439
  }
400
- let deletable = !isSchema;
401
- if (isSchema && query) {
440
+ let deletable = !isSchema2 && // Don't allow the Records smart collection to be deleted.
441
+ !(Obj.instanceOf(DataType.QueryCollection, object) && getTypenameFromQuery(object.query) === DataType.StoredSchema.typename);
442
+ if (isSchema2 && query) {
402
443
  const views = get(rxFromQuery(query));
403
- const filteredViews = get(rxFromSignal(() => views.filter((view) => view.query.typename === object.typename)));
444
+ const filteredViews = get(rxFromSignal(() => views.filter((view) => getTypenameFromQuery(view.query.ast) === object.typename)));
404
445
  deletable = filteredViews.length === 0;
405
446
  }
406
447
  const [dispatcher] = get(context.capabilities(Capabilities.IntentDispatcher));
@@ -424,8 +465,8 @@ var app_graph_builder_default = (context) => {
424
465
  }),
425
466
  // View selected objects.
426
467
  createExtension({
427
- id: `${SPACE_PLUGIN}/selected-objects`,
428
- connector: (node) => Rx.make((get) => pipe(get(node), Option.flatMap((node2) => Obj.instanceOf(DataType.View, node2.data) ? Option.some(node2) : Option.none()), Option.map((node2) => [
468
+ id: `${meta.id}/selected-objects`,
469
+ connector: (node) => Rx.make((get) => Function.pipe(get(node), Option.flatMap((node2) => Obj.instanceOf(DataType.View, node2.data) ? Option.some(node2) : Option.none()), Option.map((node2) => [
429
470
  {
430
471
  id: [
431
472
  node2.id,
@@ -437,7 +478,7 @@ var app_graph_builder_default = (context) => {
437
478
  label: [
438
479
  "companion selected objects label",
439
480
  {
440
- ns: SPACE_PLUGIN
481
+ ns: meta.id
441
482
  }
442
483
  ],
443
484
  icon: "ph--tree-view--regular",
@@ -448,8 +489,8 @@ var app_graph_builder_default = (context) => {
448
489
  }),
449
490
  // Object settings plank companion.
450
491
  createExtension({
451
- id: `${SPACE_PLUGIN}/settings`,
452
- connector: (node) => Rx.make((get) => pipe(get(node), Option.flatMap((node2) => Obj.isObject(node2.data) ? Option.some(node2) : Option.none()), Option.map((node2) => [
492
+ id: `${meta.id}/settings`,
493
+ connector: (node) => Rx.make((get) => Function.pipe(get(node), Option.flatMap((node2) => Obj.isObject(node2.data) ? Option.some(node2) : Option.none()), Option.map((node2) => [
453
494
  {
454
495
  id: [
455
496
  node2.id,
@@ -461,7 +502,7 @@ var app_graph_builder_default = (context) => {
461
502
  label: [
462
503
  "object settings label",
463
504
  {
464
- ns: SPACE_PLUGIN
505
+ ns: meta.id
465
506
  }
466
507
  ],
467
508
  icon: "ph--sliders--regular",
@@ -472,8 +513,8 @@ var app_graph_builder_default = (context) => {
472
513
  ]), Option.getOrElse(() => [])))
473
514
  })
474
515
  ]);
475
- };
516
+ });
476
517
  export {
477
518
  app_graph_builder_default as default
478
519
  };
479
- //# sourceMappingURL=app-graph-builder-7CZZJS3S.mjs.map
520
+ //# sourceMappingURL=app-graph-builder-Y2LBZX2G.mjs.map