@dxos/plugin-space 0.8.4-main.f9ba587 → 0.8.4-main.fffef41

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 (361) hide show
  1. package/dist/lib/browser/CollectionArticle-WTHWY4YS.mjs +31 -0
  2. package/dist/lib/browser/CollectionArticle-WTHWY4YS.mjs.map +7 -0
  3. package/dist/lib/browser/ObjectDetailsPanel-2BRUBHP6.mjs +141 -0
  4. package/dist/lib/browser/ObjectDetailsPanel-2BRUBHP6.mjs.map +7 -0
  5. package/dist/lib/browser/ObjectSettings-5LLWCVEK.mjs +144 -0
  6. package/dist/lib/browser/ObjectSettings-5LLWCVEK.mjs.map +7 -0
  7. package/dist/lib/browser/RecordArticle-SXDRWTTU.mjs +116 -0
  8. package/dist/lib/browser/RecordArticle-SXDRWTTU.mjs.map +7 -0
  9. package/dist/lib/browser/app-graph-builder-DTM7BJ6D.mjs +528 -0
  10. package/dist/lib/browser/app-graph-builder-DTM7BJ6D.mjs.map +7 -0
  11. package/dist/lib/browser/{app-graph-serializer-UKYMBX4O.mjs → app-graph-serializer-TIKXF43P.mjs} +19 -19
  12. package/dist/lib/browser/app-graph-serializer-TIKXF43P.mjs.map +7 -0
  13. package/dist/lib/browser/chunk-AFUOMLX6.mjs +167 -0
  14. package/dist/lib/browser/chunk-AFUOMLX6.mjs.map +7 -0
  15. package/dist/lib/browser/{chunk-GVTXQCIW.mjs → chunk-CKACGS7T.mjs} +714 -571
  16. package/dist/lib/browser/chunk-CKACGS7T.mjs.map +7 -0
  17. package/dist/lib/browser/chunk-K5J7ZB5P.mjs +20 -0
  18. package/dist/lib/browser/chunk-K5J7ZB5P.mjs.map +7 -0
  19. package/dist/lib/browser/{chunk-WBSEOLEM.mjs → chunk-KFUMADZF.mjs} +301 -73
  20. package/dist/lib/browser/chunk-KFUMADZF.mjs.map +7 -0
  21. package/dist/lib/browser/{chunk-6VLSHG4A.mjs → chunk-VGKOXAPE.mjs} +87 -12
  22. package/dist/lib/browser/chunk-VGKOXAPE.mjs.map +7 -0
  23. package/dist/lib/browser/chunk-VZBIIYFM.mjs +16 -0
  24. package/dist/lib/browser/chunk-VZBIIYFM.mjs.map +7 -0
  25. package/dist/lib/browser/chunk-WJXU4GKV.mjs +19 -0
  26. package/dist/lib/browser/chunk-WJXU4GKV.mjs.map +7 -0
  27. package/dist/lib/browser/{chunk-S6NY637J.mjs → chunk-ZQMSGD5J.mjs} +95 -19
  28. package/dist/lib/browser/chunk-ZQMSGD5J.mjs.map +7 -0
  29. package/dist/lib/browser/{identity-created-23XJJV2N.mjs → identity-created-NAXTPQXE.mjs} +6 -6
  30. package/dist/lib/browser/identity-created-NAXTPQXE.mjs.map +7 -0
  31. package/dist/lib/browser/index.mjs +148 -59
  32. package/dist/lib/browser/index.mjs.map +3 -3
  33. package/dist/lib/browser/{intent-resolver-WK5WYFH3.mjs → intent-resolver-3FNTO3VW.mjs} +236 -68
  34. package/dist/lib/browser/intent-resolver-3FNTO3VW.mjs.map +7 -0
  35. package/dist/lib/browser/meta.json +1 -1
  36. package/dist/lib/browser/react-root-Q7VBWBES.mjs +30 -0
  37. package/dist/lib/browser/react-root-Q7VBWBES.mjs.map +7 -0
  38. package/dist/lib/browser/{react-surface-6C3YJNDK.mjs → react-surface-TTHS332A.mjs} +98 -100
  39. package/dist/lib/browser/react-surface-TTHS332A.mjs.map +7 -0
  40. package/dist/lib/browser/{schema-defs-K3B3OAH4.mjs → schema-defs-QPI2JU3X.mjs} +6 -6
  41. package/dist/lib/browser/schema-defs-QPI2JU3X.mjs.map +7 -0
  42. package/dist/lib/browser/{settings-XNWYRWNM.mjs → settings-45PGPO2V.mjs} +5 -5
  43. package/dist/lib/browser/{settings-XNWYRWNM.mjs.map → settings-45PGPO2V.mjs.map} +1 -1
  44. package/dist/lib/browser/{spaces-ready-K7NSNBHM.mjs → spaces-ready-QCND4DVY.mjs} +21 -18
  45. package/dist/lib/browser/spaces-ready-QCND4DVY.mjs.map +7 -0
  46. package/dist/lib/browser/{state-522XTUR4.mjs → state-Q7YRE5KG.mjs} +7 -7
  47. package/dist/lib/browser/state-Q7YRE5KG.mjs.map +7 -0
  48. package/dist/lib/browser/types/index.mjs +2 -2
  49. package/dist/lib/node-esm/CollectionArticle-KHXYT3SH.mjs +32 -0
  50. package/dist/lib/node-esm/CollectionArticle-KHXYT3SH.mjs.map +7 -0
  51. package/dist/lib/node-esm/ObjectDetailsPanel-6PZQIQG3.mjs +142 -0
  52. package/dist/lib/node-esm/ObjectDetailsPanel-6PZQIQG3.mjs.map +7 -0
  53. package/dist/lib/node-esm/ObjectSettings-OQSBOH7K.mjs +145 -0
  54. package/dist/lib/node-esm/ObjectSettings-OQSBOH7K.mjs.map +7 -0
  55. package/dist/lib/node-esm/RecordArticle-NACBH42P.mjs +117 -0
  56. package/dist/lib/node-esm/RecordArticle-NACBH42P.mjs.map +7 -0
  57. package/dist/lib/node-esm/app-graph-builder-FBJFWI4H.mjs +529 -0
  58. package/dist/lib/node-esm/app-graph-builder-FBJFWI4H.mjs.map +7 -0
  59. package/dist/lib/node-esm/{app-graph-serializer-LA3IZDXJ.mjs → app-graph-serializer-BESQZAYU.mjs} +19 -19
  60. package/dist/lib/node-esm/app-graph-serializer-BESQZAYU.mjs.map +7 -0
  61. package/dist/lib/node-esm/{chunk-2THX6G4C.mjs → chunk-6VEONPNZ.mjs} +95 -19
  62. package/dist/lib/node-esm/chunk-6VEONPNZ.mjs.map +7 -0
  63. package/dist/lib/node-esm/chunk-6ZQGZBEP.mjs +168 -0
  64. package/dist/lib/node-esm/chunk-6ZQGZBEP.mjs.map +7 -0
  65. package/dist/lib/node-esm/chunk-BDEFTL6K.mjs +18 -0
  66. package/dist/lib/node-esm/chunk-BDEFTL6K.mjs.map +7 -0
  67. package/dist/lib/node-esm/chunk-H4JILUJK.mjs +20 -0
  68. package/dist/lib/node-esm/chunk-H4JILUJK.mjs.map +7 -0
  69. package/dist/lib/node-esm/{chunk-HJJHLWKY.mjs → chunk-OK2L7N2F.mjs} +301 -73
  70. package/dist/lib/node-esm/chunk-OK2L7N2F.mjs.map +7 -0
  71. package/dist/lib/node-esm/{chunk-SXD6T2N4.mjs → chunk-QBRPYAEL.mjs} +87 -12
  72. package/dist/lib/node-esm/chunk-QBRPYAEL.mjs.map +7 -0
  73. package/dist/lib/node-esm/{chunk-OUBADVJE.mjs → chunk-XGAMJC5C.mjs} +714 -571
  74. package/dist/lib/node-esm/chunk-XGAMJC5C.mjs.map +7 -0
  75. package/dist/lib/node-esm/chunk-Z7BB6HC2.mjs +21 -0
  76. package/dist/lib/node-esm/chunk-Z7BB6HC2.mjs.map +7 -0
  77. package/dist/lib/node-esm/{identity-created-IJQO6GCR.mjs → identity-created-OXLKCJE3.mjs} +6 -6
  78. package/dist/lib/node-esm/identity-created-OXLKCJE3.mjs.map +7 -0
  79. package/dist/lib/node-esm/index.mjs +148 -59
  80. package/dist/lib/node-esm/index.mjs.map +3 -3
  81. package/dist/lib/node-esm/{intent-resolver-HSR27ME4.mjs → intent-resolver-6O5FSB7Z.mjs} +236 -68
  82. package/dist/lib/node-esm/intent-resolver-6O5FSB7Z.mjs.map +7 -0
  83. package/dist/lib/node-esm/meta.json +1 -1
  84. package/dist/lib/node-esm/{react-root-HUK3ANLV.mjs → react-root-K66W3FMA.mjs} +13 -12
  85. package/dist/lib/node-esm/react-root-K66W3FMA.mjs.map +7 -0
  86. package/dist/lib/node-esm/{react-surface-AGAWX7DD.mjs → react-surface-Y7FTEIDF.mjs} +98 -100
  87. package/dist/lib/node-esm/react-surface-Y7FTEIDF.mjs.map +7 -0
  88. package/dist/lib/node-esm/{schema-defs-4MCDG4DV.mjs → schema-defs-ZS2D47XW.mjs} +6 -6
  89. package/dist/lib/node-esm/schema-defs-ZS2D47XW.mjs.map +7 -0
  90. package/dist/lib/node-esm/{settings-YGKHGFPH.mjs → settings-6FO65BA6.mjs} +5 -5
  91. package/dist/lib/node-esm/{settings-YGKHGFPH.mjs.map → settings-6FO65BA6.mjs.map} +1 -1
  92. package/dist/lib/node-esm/{spaces-ready-UM2P3DCR.mjs → spaces-ready-P7CKVXBE.mjs} +21 -18
  93. package/dist/lib/node-esm/spaces-ready-P7CKVXBE.mjs.map +7 -0
  94. package/dist/lib/node-esm/{state-C4IOXPZP.mjs → state-362I5BMK.mjs} +7 -7
  95. package/dist/lib/node-esm/state-362I5BMK.mjs.map +7 -0
  96. package/dist/lib/node-esm/types/index.mjs +2 -2
  97. package/dist/types/src/SpacePlugin.d.ts +1 -1
  98. package/dist/types/src/SpacePlugin.d.ts.map +1 -1
  99. package/dist/types/src/capabilities/app-graph-builder.d.ts +1 -1
  100. package/dist/types/src/capabilities/app-graph-builder.d.ts.map +1 -1
  101. package/dist/types/src/capabilities/app-graph-serializer.d.ts +1 -1
  102. package/dist/types/src/capabilities/capabilities.d.ts +14 -7
  103. package/dist/types/src/capabilities/capabilities.d.ts.map +1 -1
  104. package/dist/types/src/capabilities/identity-created.d.ts +1 -1
  105. package/dist/types/src/capabilities/identity-created.d.ts.map +1 -1
  106. package/dist/types/src/capabilities/index.d.ts +11 -12
  107. package/dist/types/src/capabilities/index.d.ts.map +1 -1
  108. package/dist/types/src/capabilities/intent-resolver.d.ts +1 -1
  109. package/dist/types/src/capabilities/intent-resolver.d.ts.map +1 -1
  110. package/dist/types/src/capabilities/react-root.d.ts +2 -2
  111. package/dist/types/src/capabilities/react-root.d.ts.map +1 -1
  112. package/dist/types/src/capabilities/react-surface.d.ts +1 -1
  113. package/dist/types/src/capabilities/react-surface.d.ts.map +1 -1
  114. package/dist/types/src/capabilities/schema-defs.d.ts +1 -1
  115. package/dist/types/src/capabilities/schema-defs.d.ts.map +1 -1
  116. package/dist/types/src/capabilities/settings.d.ts +1 -1
  117. package/dist/types/src/capabilities/spaces-ready.d.ts +1 -1
  118. package/dist/types/src/capabilities/spaces-ready.d.ts.map +1 -1
  119. package/dist/types/src/capabilities/state.d.ts +1 -1
  120. package/dist/types/src/capabilities/state.d.ts.map +1 -1
  121. package/dist/types/src/components/AwaitingObject.d.ts.map +1 -1
  122. package/dist/types/src/components/CollectionArticle.d.ts +6 -0
  123. package/dist/types/src/components/CollectionArticle.d.ts.map +1 -0
  124. package/dist/types/src/components/CollectionSection.d.ts +3 -4
  125. package/dist/types/src/components/CollectionSection.d.ts.map +1 -1
  126. package/dist/types/src/components/CreateDialog/CreateObjectDialog.d.ts +5 -4
  127. package/dist/types/src/components/CreateDialog/CreateObjectDialog.d.ts.map +1 -1
  128. package/dist/types/src/components/CreateDialog/CreateObjectDialog.stories.d.ts +1704 -4
  129. package/dist/types/src/components/CreateDialog/CreateObjectDialog.stories.d.ts.map +1 -1
  130. package/dist/types/src/components/CreateDialog/CreateObjectPanel.d.ts +7 -5
  131. package/dist/types/src/components/CreateDialog/CreateObjectPanel.d.ts.map +1 -1
  132. package/dist/types/src/components/CreateDialog/CreateSpaceDialog.d.ts +1 -1
  133. package/dist/types/src/components/CreateDialog/CreateSpaceDialog.d.ts.map +1 -1
  134. package/dist/types/src/components/{JoinDialog.d.ts → JoinDialog/JoinDialog.d.ts} +1 -1
  135. package/dist/types/src/components/JoinDialog/JoinDialog.d.ts.map +1 -0
  136. package/dist/types/src/components/JoinDialog/index.d.ts +2 -0
  137. package/dist/types/src/components/JoinDialog/index.d.ts.map +1 -0
  138. package/dist/types/src/components/{MembersContainer.d.ts → MembersContainer/MembersContainer.d.ts} +3 -2
  139. package/dist/types/src/components/MembersContainer/MembersContainer.d.ts.map +1 -0
  140. package/dist/types/src/components/MembersContainer/MembersContainer.stories.d.ts +1707 -0
  141. package/dist/types/src/components/MembersContainer/MembersContainer.stories.d.ts.map +1 -0
  142. package/dist/types/src/components/MembersContainer/index.d.ts +2 -0
  143. package/dist/types/src/components/MembersContainer/index.d.ts.map +1 -0
  144. package/dist/types/src/components/MenuFooter.d.ts.map +1 -1
  145. package/dist/types/src/components/ObjectDetailsPanel/ObjectDetailsPanel.d.ts +9 -0
  146. package/dist/types/src/components/ObjectDetailsPanel/ObjectDetailsPanel.d.ts.map +1 -0
  147. package/dist/types/src/components/ObjectDetailsPanel/ObjectForm.d.ts +10 -0
  148. package/dist/types/src/components/ObjectDetailsPanel/ObjectForm.d.ts.map +1 -0
  149. package/dist/types/src/components/ObjectDetailsPanel/index.d.ts +3 -0
  150. package/dist/types/src/components/ObjectDetailsPanel/index.d.ts.map +1 -0
  151. package/dist/types/src/components/ObjectRenamePopover/ObjectRenamePopover.d.ts +7 -0
  152. package/dist/types/src/components/ObjectRenamePopover/ObjectRenamePopover.d.ts.map +1 -0
  153. package/dist/types/src/components/ObjectRenamePopover/index.d.ts +2 -0
  154. package/dist/types/src/components/ObjectRenamePopover/index.d.ts.map +1 -0
  155. package/dist/types/src/components/ObjectSettings/AdvancedObjectSettings.d.ts.map +1 -1
  156. package/dist/types/src/components/ObjectSettings/BaseObjectSettings.d.ts +2 -2
  157. package/dist/types/src/components/ObjectSettings/BaseObjectSettings.d.ts.map +1 -1
  158. package/dist/types/src/components/ObjectSettings/BaseObjectSettings.stories.d.ts +1540 -0
  159. package/dist/types/src/components/ObjectSettings/BaseObjectSettings.stories.d.ts.map +1 -0
  160. package/dist/types/src/components/ObjectSettings/ForeignKeys.d.ts +1 -1
  161. package/dist/types/src/components/ObjectSettings/ForeignKeys.d.ts.map +1 -1
  162. package/dist/types/src/components/ObjectSettings/ObjectSettingsContainer.d.ts.map +1 -1
  163. package/dist/types/src/components/ObjectSettings/index.d.ts +2 -1
  164. package/dist/types/src/components/ObjectSettings/index.d.ts.map +1 -1
  165. package/dist/types/src/components/RecordArticle.d.ts +5 -0
  166. package/dist/types/src/components/RecordArticle.d.ts.map +1 -0
  167. package/dist/types/src/components/RecordArticle.stories.d.ts +1707 -0
  168. package/dist/types/src/components/RecordArticle.stories.d.ts.map +1 -0
  169. package/dist/types/src/components/SchemaContainer.d.ts +1 -1
  170. package/dist/types/src/components/SchemaContainer.d.ts.map +1 -1
  171. package/dist/types/src/components/SpacePluginSettings.d.ts.map +1 -1
  172. package/dist/types/src/components/{SpacePresence.d.ts → SpacePresence/SpacePresence.d.ts} +4 -3
  173. package/dist/types/src/components/SpacePresence/SpacePresence.d.ts.map +1 -0
  174. package/dist/types/src/components/SpacePresence/SpacePresence.stories.d.ts +1537 -0
  175. package/dist/types/src/components/SpacePresence/SpacePresence.stories.d.ts.map +1 -0
  176. package/dist/types/src/components/SpacePresence/index.d.ts +2 -0
  177. package/dist/types/src/components/SpacePresence/index.d.ts.map +1 -0
  178. package/dist/types/src/components/SpaceRenamePopover/SpaceRenamePopover.d.ts +7 -0
  179. package/dist/types/src/components/SpaceRenamePopover/SpaceRenamePopover.d.ts.map +1 -0
  180. package/dist/types/src/components/SpaceRenamePopover/index.d.ts +2 -0
  181. package/dist/types/src/components/SpaceRenamePopover/index.d.ts.map +1 -0
  182. package/dist/types/src/components/SpaceSettings/SpaceSettingsContainer.d.ts.map +1 -1
  183. package/dist/types/src/components/SpaceSettings/SpaceSettingsContainer.stories.d.ts +1537 -4
  184. package/dist/types/src/components/SpaceSettings/SpaceSettingsContainer.stories.d.ts.map +1 -1
  185. package/dist/types/src/components/SyncStatus/SyncStatus.d.ts +1 -1
  186. package/dist/types/src/components/SyncStatus/SyncStatus.d.ts.map +1 -1
  187. package/dist/types/src/components/SyncStatus/SyncStatus.stories.d.ts +1538 -5
  188. package/dist/types/src/components/SyncStatus/SyncStatus.stories.d.ts.map +1 -1
  189. package/dist/types/src/components/SyncStatus/status.d.ts +5 -5
  190. package/dist/types/src/components/ViewEditor.d.ts +7 -0
  191. package/dist/types/src/components/ViewEditor.d.ts.map +1 -0
  192. package/dist/types/src/components/index.d.ts +11 -5
  193. package/dist/types/src/components/index.d.ts.map +1 -1
  194. package/dist/types/src/events.d.ts +1 -0
  195. package/dist/types/src/events.d.ts.map +1 -1
  196. package/dist/types/src/helpers/index.d.ts +2 -0
  197. package/dist/types/src/helpers/index.d.ts.map +1 -0
  198. package/dist/types/src/helpers/query.d.ts +8 -0
  199. package/dist/types/src/helpers/query.d.ts.map +1 -0
  200. package/dist/types/src/helpers/query.test.d.ts +2 -0
  201. package/dist/types/src/helpers/query.test.d.ts.map +1 -0
  202. package/dist/types/src/hooks/index.d.ts +1 -0
  203. package/dist/types/src/hooks/index.d.ts.map +1 -1
  204. package/dist/types/src/hooks/useActiveSpace.d.ts.map +1 -1
  205. package/dist/types/src/hooks/useInputSurfaceLookup.d.ts +1 -1
  206. package/dist/types/src/hooks/useInputSurfaceLookup.d.ts.map +1 -1
  207. package/dist/types/src/hooks/usePath.d.ts +1 -1
  208. package/dist/types/src/hooks/usePath.d.ts.map +1 -1
  209. package/dist/types/src/hooks/useTypeOptions.d.ts +10 -0
  210. package/dist/types/src/hooks/useTypeOptions.d.ts.map +1 -0
  211. package/dist/types/src/index.d.ts +1 -0
  212. package/dist/types/src/index.d.ts.map +1 -1
  213. package/dist/types/src/meta.d.ts +0 -1
  214. package/dist/types/src/meta.d.ts.map +1 -1
  215. package/dist/types/src/translations.d.ts +1382 -11
  216. package/dist/types/src/translations.d.ts.map +1 -1
  217. package/dist/types/src/types/types.d.ts +141 -66
  218. package/dist/types/src/types/types.d.ts.map +1 -1
  219. package/dist/types/src/util.d.ts +40 -10
  220. package/dist/types/src/util.d.ts.map +1 -1
  221. package/dist/types/tsconfig.tsbuildinfo +1 -1
  222. package/package.json +67 -61
  223. package/src/SpacePlugin.ts +232 -139
  224. package/src/capabilities/app-graph-builder.ts +335 -88
  225. package/src/capabilities/app-graph-serializer.ts +12 -12
  226. package/src/capabilities/capabilities.ts +21 -10
  227. package/src/capabilities/identity-created.ts +3 -3
  228. package/src/capabilities/index.ts +0 -1
  229. package/src/capabilities/intent-resolver.ts +191 -54
  230. package/src/capabilities/react-root.tsx +6 -4
  231. package/src/capabilities/react-surface.tsx +94 -119
  232. package/src/capabilities/schema-defs.ts +4 -3
  233. package/src/capabilities/spaces-ready.ts +16 -10
  234. package/src/capabilities/state.ts +5 -4
  235. package/src/components/AwaitingObject.tsx +16 -20
  236. package/src/components/{CollectionMain.tsx → CollectionArticle.tsx} +8 -5
  237. package/src/components/CollectionSection.tsx +8 -6
  238. package/src/components/CreateDialog/CreateObjectDialog.stories.tsx +17 -16
  239. package/src/components/CreateDialog/CreateObjectDialog.tsx +76 -54
  240. package/src/components/CreateDialog/CreateObjectPanel.tsx +24 -13
  241. package/src/components/CreateDialog/CreateSpaceDialog.tsx +30 -11
  242. package/src/components/{JoinDialog.tsx → JoinDialog/JoinDialog.tsx} +26 -10
  243. package/src/components/JoinDialog/index.ts +5 -0
  244. package/src/components/MembersContainer/MembersContainer.stories.tsx +56 -0
  245. package/src/components/{MembersContainer.tsx → MembersContainer/MembersContainer.tsx} +27 -24
  246. package/src/components/MembersContainer/index.ts +5 -0
  247. package/src/components/MenuFooter.tsx +4 -5
  248. package/src/components/ObjectDetailsPanel/ObjectDetailsPanel.tsx +51 -0
  249. package/src/components/ObjectDetailsPanel/ObjectForm.tsx +72 -0
  250. package/src/components/ObjectDetailsPanel/index.ts +7 -0
  251. package/src/components/{PopoverRenameObject.tsx → ObjectRenamePopover/ObjectRenamePopover.tsx} +11 -17
  252. package/src/components/ObjectRenamePopover/index.ts +5 -0
  253. package/src/components/ObjectSettings/AdvancedObjectSettings.tsx +4 -3
  254. package/src/components/ObjectSettings/BaseObjectSettings.stories.tsx +63 -0
  255. package/src/components/ObjectSettings/BaseObjectSettings.tsx +90 -26
  256. package/src/components/ObjectSettings/ForeignKeys.tsx +4 -4
  257. package/src/components/ObjectSettings/ObjectSettingsContainer.tsx +4 -3
  258. package/src/components/ObjectSettings/index.ts +3 -1
  259. package/src/components/RecordArticle.stories.tsx +115 -0
  260. package/src/components/RecordArticle.tsx +114 -0
  261. package/src/components/SchemaContainer.tsx +25 -28
  262. package/src/components/SpacePluginSettings.tsx +16 -11
  263. package/src/components/{SpacePresence.stories.tsx → SpacePresence/SpacePresence.stories.tsx} +24 -23
  264. package/src/components/{SpacePresence.tsx → SpacePresence/SpacePresence.tsx} +22 -17
  265. package/src/components/SpacePresence/index.ts +5 -0
  266. package/src/components/{PopoverRenameSpace.tsx → SpaceRenamePopover/SpaceRenamePopover.tsx} +7 -6
  267. package/src/components/SpaceRenamePopover/index.ts +5 -0
  268. package/src/components/SpaceSettings/SpaceSettingsContainer.stories.tsx +17 -9
  269. package/src/components/SpaceSettings/SpaceSettingsContainer.tsx +49 -28
  270. package/src/components/SyncStatus/InlineSyncStatus.tsx +8 -8
  271. package/src/components/SyncStatus/SyncStatus.stories.tsx +9 -9
  272. package/src/components/SyncStatus/SyncStatus.tsx +110 -13
  273. package/src/components/SyncStatus/status.ts +4 -4
  274. package/src/components/ViewEditor.tsx +92 -0
  275. package/src/components/index.ts +10 -5
  276. package/src/events.ts +7 -6
  277. package/src/helpers/index.ts +5 -0
  278. package/src/helpers/query.test.ts +24 -0
  279. package/src/helpers/query.ts +158 -0
  280. package/src/hooks/index.ts +1 -0
  281. package/src/hooks/useActiveSpace.ts +3 -2
  282. package/src/hooks/useInputSurfaceLookup.tsx +8 -3
  283. package/src/hooks/usePath.ts +1 -1
  284. package/src/hooks/useTypeOptions.ts +59 -0
  285. package/src/index.ts +1 -0
  286. package/src/meta.ts +6 -3
  287. package/src/translations.ts +85 -7
  288. package/src/types/types.ts +94 -22
  289. package/src/util.tsx +297 -75
  290. package/dist/lib/browser/app-graph-builder-PMDF6PJV.mjs +0 -363
  291. package/dist/lib/browser/app-graph-builder-PMDF6PJV.mjs.map +0 -7
  292. package/dist/lib/browser/app-graph-serializer-UKYMBX4O.mjs.map +0 -7
  293. package/dist/lib/browser/chunk-6VLSHG4A.mjs.map +0 -7
  294. package/dist/lib/browser/chunk-C7KGJTAL.mjs +0 -18
  295. package/dist/lib/browser/chunk-C7KGJTAL.mjs.map +0 -7
  296. package/dist/lib/browser/chunk-FBCGT5YY.mjs +0 -13
  297. package/dist/lib/browser/chunk-FBCGT5YY.mjs.map +0 -7
  298. package/dist/lib/browser/chunk-GVTXQCIW.mjs.map +0 -7
  299. package/dist/lib/browser/chunk-S6NY637J.mjs.map +0 -7
  300. package/dist/lib/browser/chunk-VLBRSGJ2.mjs +0 -94
  301. package/dist/lib/browser/chunk-VLBRSGJ2.mjs.map +0 -7
  302. package/dist/lib/browser/chunk-WBSEOLEM.mjs.map +0 -7
  303. package/dist/lib/browser/chunk-XXIPJLJF.mjs +0 -19
  304. package/dist/lib/browser/chunk-XXIPJLJF.mjs.map +0 -7
  305. package/dist/lib/browser/identity-created-23XJJV2N.mjs.map +0 -7
  306. package/dist/lib/browser/intent-resolver-WK5WYFH3.mjs.map +0 -7
  307. package/dist/lib/browser/react-root-7S6FIC5G.mjs +0 -29
  308. package/dist/lib/browser/react-root-7S6FIC5G.mjs.map +0 -7
  309. package/dist/lib/browser/react-surface-6C3YJNDK.mjs.map +0 -7
  310. package/dist/lib/browser/schema-defs-K3B3OAH4.mjs.map +0 -7
  311. package/dist/lib/browser/schema-tools-BNP4JTD7.mjs +0 -124
  312. package/dist/lib/browser/schema-tools-BNP4JTD7.mjs.map +0 -7
  313. package/dist/lib/browser/spaces-ready-K7NSNBHM.mjs.map +0 -7
  314. package/dist/lib/browser/state-522XTUR4.mjs.map +0 -7
  315. package/dist/lib/node-esm/app-graph-builder-TO72W6MI.mjs +0 -364
  316. package/dist/lib/node-esm/app-graph-builder-TO72W6MI.mjs.map +0 -7
  317. package/dist/lib/node-esm/app-graph-serializer-LA3IZDXJ.mjs.map +0 -7
  318. package/dist/lib/node-esm/chunk-2THX6G4C.mjs.map +0 -7
  319. package/dist/lib/node-esm/chunk-72QMMRKC.mjs +0 -19
  320. package/dist/lib/node-esm/chunk-72QMMRKC.mjs.map +0 -7
  321. package/dist/lib/node-esm/chunk-AT7LGFER.mjs +0 -20
  322. package/dist/lib/node-esm/chunk-AT7LGFER.mjs.map +0 -7
  323. package/dist/lib/node-esm/chunk-HJJHLWKY.mjs.map +0 -7
  324. package/dist/lib/node-esm/chunk-HWNG4MEU.mjs +0 -15
  325. package/dist/lib/node-esm/chunk-HWNG4MEU.mjs.map +0 -7
  326. package/dist/lib/node-esm/chunk-OUBADVJE.mjs.map +0 -7
  327. package/dist/lib/node-esm/chunk-SSLBYZEY.mjs +0 -96
  328. package/dist/lib/node-esm/chunk-SSLBYZEY.mjs.map +0 -7
  329. package/dist/lib/node-esm/chunk-SXD6T2N4.mjs.map +0 -7
  330. package/dist/lib/node-esm/identity-created-IJQO6GCR.mjs.map +0 -7
  331. package/dist/lib/node-esm/intent-resolver-HSR27ME4.mjs.map +0 -7
  332. package/dist/lib/node-esm/react-root-HUK3ANLV.mjs.map +0 -7
  333. package/dist/lib/node-esm/react-surface-AGAWX7DD.mjs.map +0 -7
  334. package/dist/lib/node-esm/schema-defs-4MCDG4DV.mjs.map +0 -7
  335. package/dist/lib/node-esm/schema-tools-KWW5PTML.mjs +0 -126
  336. package/dist/lib/node-esm/schema-tools-KWW5PTML.mjs.map +0 -7
  337. package/dist/lib/node-esm/spaces-ready-UM2P3DCR.mjs.map +0 -7
  338. package/dist/lib/node-esm/state-C4IOXPZP.mjs.map +0 -7
  339. package/dist/types/src/capabilities/schema-tool.test.d.ts +0 -2
  340. package/dist/types/src/capabilities/schema-tool.test.d.ts.map +0 -1
  341. package/dist/types/src/capabilities/schema-tools.d.ts +0 -13
  342. package/dist/types/src/capabilities/schema-tools.d.ts.map +0 -1
  343. package/dist/types/src/components/CollectionMain.d.ts +0 -6
  344. package/dist/types/src/components/CollectionMain.d.ts.map +0 -1
  345. package/dist/types/src/components/JoinDialog.d.ts.map +0 -1
  346. package/dist/types/src/components/MembersContainer.d.ts.map +0 -1
  347. package/dist/types/src/components/MembersContainer.stories.d.ts +0 -8
  348. package/dist/types/src/components/MembersContainer.stories.d.ts.map +0 -1
  349. package/dist/types/src/components/PersistenceStatus.d.ts +0 -6
  350. package/dist/types/src/components/PersistenceStatus.d.ts.map +0 -1
  351. package/dist/types/src/components/PopoverRenameObject.d.ts +0 -7
  352. package/dist/types/src/components/PopoverRenameObject.d.ts.map +0 -1
  353. package/dist/types/src/components/PopoverRenameSpace.d.ts +0 -7
  354. package/dist/types/src/components/PopoverRenameSpace.d.ts.map +0 -1
  355. package/dist/types/src/components/SpacePresence.d.ts.map +0 -1
  356. package/dist/types/src/components/SpacePresence.stories.d.ts +0 -9
  357. package/dist/types/src/components/SpacePresence.stories.d.ts.map +0 -1
  358. package/src/capabilities/schema-tool.test.ts +0 -44
  359. package/src/capabilities/schema-tools.ts +0 -125
  360. package/src/components/MembersContainer.stories.tsx +0 -30
  361. package/src/components/PersistenceStatus.tsx +0 -84
@@ -0,0 +1,117 @@
1
+ import { createRequire } from 'node:module';const require = createRequire(import.meta.url);
2
+ import {
3
+ meta
4
+ } from "./chunk-BDEFTL6K.mjs";
5
+
6
+ // src/components/RecordArticle.tsx
7
+ import { useSignals as _useSignals } from "@preact-signals/safe-react/tracking";
8
+ import React, { useMemo } from "react";
9
+ import { Surface } from "@dxos/app-framework/react";
10
+ import { Filter, Ref, Relation } from "@dxos/echo";
11
+ import { getSpace, useQuery } from "@dxos/react-client/echo";
12
+ import { useTranslation } from "@dxos/react-ui";
13
+ import { Masonry } from "@dxos/react-ui-masonry";
14
+ import { StackItem } from "@dxos/react-ui-stack";
15
+ import { mx } from "@dxos/react-ui-theme";
16
+ import { isNonNullable } from "@dxos/util";
17
+ var RecordArticle = ({ subject }) => {
18
+ var _effect = _useSignals();
19
+ try {
20
+ const { t } = useTranslation(meta.id);
21
+ const space = getSpace(subject);
22
+ const data = useMemo(() => ({
23
+ subject
24
+ }), [
25
+ subject
26
+ ]);
27
+ const related = useRelatedObjects(space, subject, {
28
+ references: true,
29
+ relations: true
30
+ });
31
+ const singleColumn = related.length === 1;
32
+ return /* @__PURE__ */ React.createElement(StackItem.Content, null, /* @__PURE__ */ React.createElement("div", {
33
+ role: "none",
34
+ className: mx("flex flex-col gap-4 p-4 is-full overflow-y-auto")
35
+ }, /* @__PURE__ */ React.createElement("div", {
36
+ role: "none",
37
+ className: mx("flex is-full card-max-width")
38
+ }, /* @__PURE__ */ React.createElement(Surface, {
39
+ role: "section",
40
+ data,
41
+ limit: 1
42
+ })), related.length > 0 && /* @__PURE__ */ React.createElement("div", {
43
+ role: "none",
44
+ className: mx("flex flex-col gap-1", singleColumn ? "card-max-width" : "is-full")
45
+ }, /* @__PURE__ */ React.createElement("label", {
46
+ className: "mbs-2 text-sm text-description"
47
+ }, t("related objects label")), /* @__PURE__ */ React.createElement(Masonry.Root, {
48
+ items: related,
49
+ render: Card,
50
+ columnCount: singleColumn ? 1 : void 0,
51
+ intrinsicHeight: true
52
+ }))));
53
+ } finally {
54
+ _effect.f();
55
+ }
56
+ };
57
+ var Card = ({ data: subject }) => {
58
+ var _effect = _useSignals();
59
+ try {
60
+ const data = useMemo(() => ({
61
+ subject
62
+ }), [
63
+ subject
64
+ ]);
65
+ return /* @__PURE__ */ React.createElement(Surface, {
66
+ role: "card",
67
+ data,
68
+ limit: 1
69
+ });
70
+ } finally {
71
+ _effect.f();
72
+ }
73
+ };
74
+ var useRelatedObjects = (space, record, options = {}) => {
75
+ const objects = useQuery(space, Filter.everything());
76
+ return useMemo(() => {
77
+ if (!record) {
78
+ return [];
79
+ }
80
+ const related = [];
81
+ if (options.references) {
82
+ const getReferences = (obj) => {
83
+ return Object.getOwnPropertyNames(obj).map((name) => obj[name]).filter((value) => Ref.isRef(value));
84
+ };
85
+ const references = getReferences(record);
86
+ const referenceTargets = references.map((ref) => ref.target).filter(isNonNullable);
87
+ const referenceSources = objects.filter((obj) => {
88
+ const refs = getReferences(obj);
89
+ return refs.some((ref) => ref.target === record);
90
+ });
91
+ related.push(...referenceTargets, ...referenceSources);
92
+ }
93
+ if (options.relations) {
94
+ const isValidRelation = (obj) => {
95
+ try {
96
+ return Relation.isRelation(obj) && Relation.getSource(obj) && Relation.getTarget(obj);
97
+ } catch {
98
+ return false;
99
+ }
100
+ };
101
+ const relations = objects.filter((obj) => Relation.isRelation(obj)).filter((obj) => isValidRelation(obj));
102
+ const targetObjects = relations.filter((relation) => Relation.getTarget(relation) === record).map((relation) => Relation.getSource(relation));
103
+ const sourceObjects = relations.filter((relation) => Relation.getSource(relation) === record).map((relation) => Relation.getTarget(relation));
104
+ related.push(...targetObjects, ...sourceObjects);
105
+ }
106
+ return related;
107
+ }, [
108
+ record,
109
+ objects
110
+ ]);
111
+ };
112
+ var RecordArticle_default = RecordArticle;
113
+ export {
114
+ RecordArticle,
115
+ RecordArticle_default as default
116
+ };
117
+ //# sourceMappingURL=RecordArticle-NACBH42P.mjs.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/components/RecordArticle.tsx"],
4
+ "sourcesContent": ["//\n// Copyright 2023 DXOS.org\n//\n\nimport React, { useMemo } from 'react';\n\nimport { Surface } from '@dxos/app-framework/react';\nimport { type SurfaceComponentProps } from '@dxos/app-framework/react';\nimport { Filter, type Obj, Ref, Relation } from '@dxos/echo';\nimport { type Space, getSpace, useQuery } from '@dxos/react-client/echo';\nimport { useTranslation } from '@dxos/react-ui';\nimport { Masonry } from '@dxos/react-ui-masonry';\nimport { StackItem } from '@dxos/react-ui-stack';\nimport { mx } from '@dxos/react-ui-theme';\nimport { isNonNullable } from '@dxos/util';\n\nimport { meta } from '../meta';\n\nexport const RecordArticle = ({ subject }: SurfaceComponentProps) => {\n const { t } = useTranslation(meta.id);\n const space = getSpace(subject);\n const data = useMemo(() => ({ subject }), [subject]);\n const related = useRelatedObjects(space, subject, {\n references: true,\n relations: true,\n });\n const singleColumn = related.length === 1;\n\n return (\n <StackItem.Content>\n <div role='none' className={mx('flex flex-col gap-4 p-4 is-full overflow-y-auto')}>\n <div role='none' className={mx('flex is-full card-max-width')}>\n <Surface role='section' data={data} limit={1} />\n </div>\n\n {related.length > 0 && (\n <div role='none' className={mx('flex flex-col gap-1', singleColumn ? 'card-max-width' : 'is-full')}>\n <label className='mbs-2 text-sm text-description'>{t('related objects label')}</label>\n <Masonry.Root<Obj.Any>\n items={related}\n render={Card}\n columnCount={singleColumn ? 1 : undefined}\n intrinsicHeight\n />\n </div>\n )}\n </div>\n </StackItem.Content>\n );\n};\n\nconst Card = ({ data: subject }: { data: Obj.Any }) => {\n const data = useMemo(() => ({ subject }), [subject]);\n return <Surface role='card' data={data} limit={1} />;\n};\n\n// TODO(wittjosiah): This is a hack. ECHO needs to have a back reference index to easily query for related objects.\nconst useRelatedObjects = (\n space?: Space,\n record?: Obj.Any,\n options: { references?: boolean; relations?: boolean } = {},\n) => {\n const objects = useQuery(space, Filter.everything());\n return useMemo(() => {\n if (!record) {\n return [];\n }\n\n const related: Obj.Any[] = [];\n\n // TODO(burdon): Change Person => Organization to relations.\n if (options.references) {\n const getReferences = (obj: Obj.Any): Ref.Any[] => {\n return Object.getOwnPropertyNames(obj)\n .map((name) => obj[name as keyof Obj.Any])\n .filter((value) => Ref.isRef(value)) as Ref.Any[];\n };\n\n const references = getReferences(record);\n const referenceTargets = references.map((ref) => ref.target).filter(isNonNullable);\n const referenceSources = objects.filter((obj) => {\n const refs = getReferences(obj);\n return refs.some((ref) => ref.target === record);\n });\n\n related.push(...referenceTargets, ...referenceSources);\n }\n\n if (options.relations) {\n // TODO(dmaretskyi): Workaround until https://github.com/dxos/dxos/pull/10100 lands.\n const isValidRelation = (obj: Obj.Any) => {\n try {\n return Relation.isRelation(obj) && Relation.getSource(obj) && Relation.getTarget(obj);\n } catch {\n return false;\n }\n };\n\n const relations = objects.filter((obj) => Relation.isRelation(obj)).filter((obj) => isValidRelation(obj));\n const targetObjects = relations\n .filter((relation) => Relation.getTarget(relation) === record)\n .map((relation) => Relation.getSource(relation));\n const sourceObjects = relations\n .filter((relation) => Relation.getSource(relation) === record)\n .map((relation) => Relation.getTarget(relation));\n\n related.push(...targetObjects, ...sourceObjects);\n }\n\n return related;\n }, [record, objects]);\n};\n\nexport default RecordArticle;\n"],
5
+ "mappings": "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",
6
+ "names": ["React", "useMemo", "Surface", "Filter", "Ref", "Relation", "getSpace", "useQuery", "useTranslation", "Masonry", "StackItem", "mx", "isNonNullable", "RecordArticle", "subject", "t", "useTranslation", "meta", "id", "space", "getSpace", "data", "useMemo", "related", "useRelatedObjects", "references", "relations", "singleColumn", "length", "StackItem", "Content", "div", "role", "className", "mx", "Surface", "limit", "label", "Masonry", "Root", "items", "render", "Card", "columnCount", "undefined", "intrinsicHeight", "record", "options", "objects", "useQuery", "Filter", "everything", "getReferences", "obj", "Object", "getOwnPropertyNames", "map", "name", "filter", "value", "Ref", "isRef", "referenceTargets", "ref", "target", "isNonNullable", "referenceSources", "refs", "some", "push", "isValidRelation", "Relation", "isRelation", "getSource", "getTarget", "targetObjects", "relation", "sourceObjects"]
7
+ }
@@ -0,0 +1,529 @@
1
+ import { createRequire } from 'node:module';const require = createRequire(import.meta.url);
2
+ import {
3
+ getActiveSpace
4
+ } from "./chunk-6ZQGZBEP.mjs";
5
+ import {
6
+ SpaceCapabilities
7
+ } from "./chunk-Z7BB6HC2.mjs";
8
+ import {
9
+ SHARED,
10
+ SPACES,
11
+ atomFromQuery,
12
+ constructObjectActions,
13
+ constructSpaceActions,
14
+ constructSpaceNode,
15
+ createObjectNode,
16
+ createStaticSchemaActions,
17
+ createStaticSchemaNode
18
+ } from "./chunk-OK2L7N2F.mjs";
19
+ import {
20
+ SPACE_TYPE,
21
+ SpaceAction
22
+ } from "./chunk-6VEONPNZ.mjs";
23
+ import {
24
+ meta
25
+ } from "./chunk-BDEFTL6K.mjs";
26
+
27
+ // src/capabilities/app-graph-builder.ts
28
+ import { Atom } from "@effect-atom/atom-react";
29
+ import * as Array from "effect/Array";
30
+ import * as Function from "effect/Function";
31
+ import * as Option from "effect/Option";
32
+ import * as Schema from "effect/Schema";
33
+ import { Capabilities, contributes, createIntent } from "@dxos/app-framework";
34
+ import { SpaceState, getSpace, isSpace } from "@dxos/client/echo";
35
+ import { DXN, Filter, Obj, Query, Type } from "@dxos/echo";
36
+ import { log } from "@dxos/log";
37
+ import { ClientCapabilities } from "@dxos/plugin-client";
38
+ import { ATTENDABLE_PATH_SEPARATOR, PLANK_COMPANION_TYPE } from "@dxos/plugin-deck/types";
39
+ import { ROOT_ID, atomFromObservable, atomFromSignal, createExtension } from "@dxos/plugin-graph";
40
+ import { Collection, StoredSchema, View, getTypenameFromQuery } from "@dxos/schema";
41
+ import { isNonNullable } from "@dxos/util";
42
+ var __dxlog_file = "/__w/dxos/dxos/packages/plugins/plugin-space/src/capabilities/app-graph-builder.ts";
43
+ var app_graph_builder_default = ((context) => {
44
+ const resolve = (get) => (typename) => context.getCapabilities(Capabilities.Metadata).find(({ id }) => id === typename)?.metadata ?? {};
45
+ const spacesNode = {
46
+ id: SPACES,
47
+ type: SPACES,
48
+ cacheable: [
49
+ "label",
50
+ "role"
51
+ ],
52
+ properties: {
53
+ label: [
54
+ "spaces label",
55
+ {
56
+ ns: meta.id
57
+ }
58
+ ],
59
+ icon: "ph--planet--regular",
60
+ testId: "spacePlugin.spaces",
61
+ role: "branch",
62
+ disposition: "collection",
63
+ disabled: true,
64
+ childrenPersistenceClass: "echo",
65
+ onRearrangeChildren: async (nextOrder) => {
66
+ const { graph } = context.getCapability(Capabilities.AppGraph);
67
+ const client = context.getCapability(ClientCapabilities.Client);
68
+ graph.sortEdges(SPACES, "outbound", nextOrder.map(({ id }) => id));
69
+ const { objects: [spacesOrder] } = await client.spaces.default.db.query(Filter.type(Type.Expando, {
70
+ key: SHARED
71
+ })).run();
72
+ if (spacesOrder) {
73
+ spacesOrder.order = nextOrder.map(({ id }) => id);
74
+ } else {
75
+ log.warn("spaces order object not found", void 0, {
76
+ F: __dxlog_file,
77
+ L: 74,
78
+ S: void 0,
79
+ C: (f, a) => f(...a)
80
+ });
81
+ }
82
+ }
83
+ }
84
+ };
85
+ return contributes(Capabilities.AppGraphBuilder, [
86
+ // Primary actions.
87
+ createExtension({
88
+ id: `${meta.id}/primary-actions`,
89
+ position: "hoist",
90
+ actions: (node) => Atom.make((get) => Function.pipe(get(node), Option.flatMap((node2) => node2.id === ROOT_ID ? Option.some(node2) : Option.none()), 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: [
99
+ "create space label",
100
+ {
101
+ ns: meta.id
102
+ }
103
+ ],
104
+ icon: "ph--plus--regular",
105
+ testId: "spacePlugin.createSpace",
106
+ disposition: "menu"
107
+ }
108
+ },
109
+ {
110
+ id: SpaceAction.Join._tag,
111
+ data: async () => {
112
+ const { dispatchPromise: dispatch } = context.getCapability(Capabilities.IntentDispatcher);
113
+ await dispatch(createIntent(SpaceAction.Join));
114
+ },
115
+ properties: {
116
+ label: [
117
+ "join space label",
118
+ {
119
+ ns: meta.id
120
+ }
121
+ ],
122
+ icon: "ph--sign-in--regular",
123
+ testId: "spacePlugin.joinSpace",
124
+ disposition: "menu"
125
+ }
126
+ },
127
+ {
128
+ id: SpaceAction.OpenMembers._tag,
129
+ data: async () => {
130
+ const { dispatchPromise: dispatch } = context.getCapability(Capabilities.IntentDispatcher);
131
+ const client = context.getCapability(ClientCapabilities.Client);
132
+ const space = getActiveSpace(context) ?? client.spaces.default;
133
+ await dispatch(createIntent(SpaceAction.OpenMembers, {
134
+ space
135
+ }));
136
+ },
137
+ properties: {
138
+ label: [
139
+ "share space label",
140
+ {
141
+ ns: meta.id
142
+ }
143
+ ],
144
+ icon: "ph--users--regular",
145
+ testId: "spacePlugin.shareSpace",
146
+ keyBinding: {
147
+ macos: "meta+.",
148
+ windows: "alt+."
149
+ }
150
+ }
151
+ },
152
+ {
153
+ id: SpaceAction.OpenSettings._tag,
154
+ data: async () => {
155
+ const { dispatchPromise: dispatch } = context.getCapability(Capabilities.IntentDispatcher);
156
+ const client = context.getCapability(ClientCapabilities.Client);
157
+ const space = getActiveSpace(context) ?? client.spaces.default;
158
+ await dispatch(createIntent(SpaceAction.OpenSettings, {
159
+ space
160
+ }));
161
+ },
162
+ properties: {
163
+ label: [
164
+ "open current space settings label",
165
+ {
166
+ ns: meta.id
167
+ }
168
+ ],
169
+ icon: "ph--faders--regular",
170
+ keyBinding: {
171
+ macos: "meta+shift+,",
172
+ windows: "ctrl+shift+,"
173
+ }
174
+ }
175
+ }
176
+ ]), Option.getOrElse(() => [])))
177
+ }),
178
+ // Create spaces group node.
179
+ createExtension({
180
+ id: `${meta.id}/root`,
181
+ position: "hoist",
182
+ connector: (node) => Atom.make((get) => Function.pipe(get(node), Option.flatMap((node2) => node2.id === ROOT_ID ? Option.some(node2) : Option.none()), Option.map(() => [
183
+ spacesNode
184
+ ]), Option.getOrElse(() => [])))
185
+ }),
186
+ // Create space nodes.
187
+ createExtension({
188
+ id: SPACES,
189
+ connector: (node) => {
190
+ let query;
191
+ return Atom.make((get) => Function.pipe(get(node), Option.flatMap((node2) => node2.id === SPACES ? Option.some(node2) : Option.none()), Option.map(() => {
192
+ const state = context.getCapability(SpaceCapabilities.State);
193
+ const client = context.getCapability(ClientCapabilities.Client);
194
+ const spacesAtom = atomFromObservable(client.spaces);
195
+ const isReadyAtom = atomFromObservable(client.spaces.isReady);
196
+ const spaces = get(spacesAtom);
197
+ const isReady = get(isReadyAtom);
198
+ if (!spaces || !isReady) {
199
+ return [];
200
+ }
201
+ const settings = get(context.capabilities(Capabilities.SettingsStore))[0]?.getStore(meta.id)?.value;
202
+ try {
203
+ if (!query) {
204
+ query = client.spaces.default.db.query(Filter.type(Type.Expando, {
205
+ key: SHARED
206
+ }));
207
+ }
208
+ const [spacesOrder] = get(atomFromQuery(query));
209
+ return get(atomFromSignal(() => {
210
+ const order = spacesOrder?.order ?? [];
211
+ const orderMap = new Map(order.map((id, index) => [
212
+ id,
213
+ index
214
+ ]));
215
+ return [
216
+ ...spaces.filter((space) => orderMap.has(space.id)).sort((a, b) => orderMap.get(a.id) - orderMap.get(b.id)),
217
+ ...spaces.filter((space) => !orderMap.has(space.id))
218
+ ].filter((space) => settings?.showHidden ? true : space.state.get() !== SpaceState.SPACE_INACTIVE).map((space) => constructSpaceNode({
219
+ space,
220
+ navigable: state.navigableCollections,
221
+ personal: space === client.spaces.default,
222
+ namesCache: state.spaceNames,
223
+ resolve: resolve(get)
224
+ }));
225
+ }));
226
+ } catch {
227
+ return [];
228
+ }
229
+ }), Option.getOrElse(() => [])));
230
+ }
231
+ }),
232
+ // Create space actions.
233
+ createExtension({
234
+ id: `${meta.id}/actions`,
235
+ actions: (node) => Atom.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) => {
236
+ const [dispatcher] = get(context.capabilities(Capabilities.IntentDispatcher));
237
+ const [client] = get(context.capabilities(ClientCapabilities.Client));
238
+ const [state] = get(context.capabilities(SpaceCapabilities.State));
239
+ if (!dispatcher || !client || !state) {
240
+ return Option.none();
241
+ } else {
242
+ return Option.some({
243
+ space,
244
+ dispatch: dispatcher.dispatchPromise,
245
+ personal: space === client.spaces.default,
246
+ migrating: state.sdkMigrationRunning[space.id]
247
+ });
248
+ }
249
+ }), Option.map((params) => constructSpaceActions(params)), Option.getOrElse(() => [])))
250
+ }),
251
+ // Create nodes for objects in the root collection of a space.
252
+ createExtension({
253
+ id: `${meta.id}/root-collection`,
254
+ connector: (node) => Atom.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) => {
255
+ const state = context.getCapability(SpaceCapabilities.State);
256
+ const spaceState = get(atomFromObservable(space.state));
257
+ if (spaceState !== SpaceState.SPACE_READY) {
258
+ return [];
259
+ }
260
+ const collection = get(atomFromSignal(() => space.properties[Collection.Collection.typename]?.target));
261
+ if (!collection) {
262
+ return [];
263
+ }
264
+ return get(atomFromSignal(() => Function.pipe(collection.objects, Array.map((object) => object.target), Array.filter(isNonNullable), Array.map((object) => createObjectNode({
265
+ space,
266
+ object,
267
+ resolve: resolve(get),
268
+ navigable: state.navigableCollections
269
+ })), Array.filter(isNonNullable))));
270
+ }), Option.getOrElse(() => [])))
271
+ }),
272
+ // Create nodes for objects in a collection or by its fully qualified id.
273
+ createExtension({
274
+ id: `${meta.id}/objects`,
275
+ connector: (node) => Atom.make((get) => Function.pipe(get(node), Option.flatMap((node2) => Obj.instanceOf(Collection.Collection, node2.data) ? Option.some(node2.data) : Option.none()), Option.map((collection) => {
276
+ const state = context.getCapability(SpaceCapabilities.State);
277
+ const space = getSpace(collection);
278
+ return get(atomFromSignal(() => Function.pipe(collection.objects, Array.map((object) => object.target), Array.filter(isNonNullable), Array.map((object) => space && createObjectNode({
279
+ object,
280
+ space,
281
+ resolve: resolve(get),
282
+ navigable: state.navigableCollections
283
+ })), Array.filter(isNonNullable))));
284
+ }), Option.getOrElse(() => [])))
285
+ }),
286
+ // Create nodes for objects in a query collection.
287
+ createExtension({
288
+ id: `${meta.id}/query-collection-objects`,
289
+ connector: (node) => {
290
+ let query;
291
+ return Atom.make((get) => Function.pipe(get(node), Option.flatMap((node2) => Obj.instanceOf(Collection.QueryCollection, node2.data) ? Option.some(node2.data) : Option.none()), Option.flatMap((collection) => {
292
+ const space = getSpace(collection);
293
+ const typename = getTypenameFromQuery(collection.query);
294
+ return typename && space ? Option.some({
295
+ typename,
296
+ space
297
+ }) : Option.none();
298
+ }), Option.map(({ typename, space }) => {
299
+ const state = context.getCapability(SpaceCapabilities.State);
300
+ if (!query) {
301
+ query = space.db.query(Query.without(
302
+ Query.select(Filter.typename(typename)),
303
+ // TODO(wittjosiah): This query is broader than it should be.
304
+ // It will return all objects in the collection, not just the ones of the given type.
305
+ // However this works fine for now because this query is only used for exclusions.
306
+ Query.select(Filter.typename(typename)).referencedBy(Collection.Collection, "objects").reference("objects")
307
+ ));
308
+ }
309
+ return get(atomFromQuery(query)).toSorted((a, b) => a.id.localeCompare(b.id)).map((object) => get(atomFromSignal(() => createObjectNode({
310
+ object,
311
+ space,
312
+ resolve: resolve(get),
313
+ droppable: false,
314
+ navigable: state.navigableCollections
315
+ })))).filter(isNonNullable);
316
+ }), Option.getOrElse(() => [])));
317
+ }
318
+ }),
319
+ // Static schema records.
320
+ createExtension({
321
+ id: `${meta.id}/static-schemas`,
322
+ connector: (node) => {
323
+ const client = context.getCapability(ClientCapabilities.Client);
324
+ return Atom.make((get) => Function.pipe(get(node), Option.flatMap((node2) => Obj.instanceOf(Collection.QueryCollection, node2.data) && getTypenameFromQuery(node2.data.query) === StoredSchema.typename ? Option.some(node2.data) : Option.none()), Option.flatMap((collection) => {
325
+ const space = getSpace(collection);
326
+ return space?.properties.staticRecords ? Option.some(space) : Option.none();
327
+ }), Option.map((space) => {
328
+ return get(atomFromSignal(() => space.properties.staticRecords ?? [])).map((typename) => client.graph.schemaRegistry.schemas.find((schema) => Type.getTypename(schema) === typename)).filter(isNonNullable).map((schema) => createStaticSchemaNode({
329
+ schema,
330
+ space
331
+ }));
332
+ }), Option.getOrElse(() => [])));
333
+ }
334
+ }),
335
+ // Create static schema actions.
336
+ createExtension({
337
+ id: `${meta.id}/static-schema-actions`,
338
+ actions: (node) => {
339
+ let query;
340
+ return Atom.make((get) => Function.pipe(get(node), Option.flatMap((node2) => {
341
+ const space = isSpace(node2.properties.space) ? node2.properties.space : void 0;
342
+ return space && Schema.isSchema(node2.data) ? Option.some({
343
+ space,
344
+ schema: node2.data
345
+ }) : Option.none();
346
+ }), Option.map(({ space, schema }) => {
347
+ if (!query) {
348
+ query = space.db.query(Filter.type(View.View));
349
+ }
350
+ const views = get(atomFromQuery(query));
351
+ const filteredViews = get(atomFromSignal(() => (
352
+ // TODO(wittjosiah): Remove cast.
353
+ views.filter((view) => getTypenameFromQuery(view.query.ast) === Type.getTypename(schema))
354
+ )));
355
+ const deletable = filteredViews.length === 0;
356
+ const [dispatcher] = get(context.capabilities(Capabilities.IntentDispatcher));
357
+ if (!dispatcher) {
358
+ return [];
359
+ }
360
+ return createStaticSchemaActions({
361
+ schema,
362
+ space,
363
+ dispatch: dispatcher.dispatchPromise,
364
+ deletable
365
+ });
366
+ }), Option.getOrElse(() => [])));
367
+ }
368
+ }),
369
+ // Create nodes for schema views.
370
+ createExtension({
371
+ id: `${meta.id}/schema-views`,
372
+ connector: (node) => {
373
+ let query;
374
+ return Atom.make((get) => Function.pipe(get(node), Option.flatMap((node2) => {
375
+ const space = getSpace(node2.data) ?? (isSpace(node2.properties.space) ? node2.properties.space : void 0);
376
+ return space && (Obj.instanceOf(StoredSchema, node2.data) || Schema.isSchema(node2.data)) ? Option.some({
377
+ space,
378
+ schema: node2.data
379
+ }) : Option.none();
380
+ }), Option.map(({ space, schema }) => {
381
+ if (!query) {
382
+ query = space.db.query(Filter.type(View.View));
383
+ }
384
+ const typename = Schema.isSchema(schema) ? Type.getTypename(schema) : schema.typename;
385
+ return get(atomFromQuery(query)).filter((view) => getTypenameFromQuery(view.query.ast) === typename).filter((view) => get(atomFromSignal(() => {
386
+ const presentation = view.presentation.target;
387
+ if (presentation) {
388
+ const typename2 = Obj.getTypename(presentation);
389
+ return typename2 !== Collection.Collection.typename;
390
+ } else {
391
+ return false;
392
+ }
393
+ }))).map((view) => get(atomFromSignal(() => createObjectNode({
394
+ object: view,
395
+ space,
396
+ resolve: resolve(get),
397
+ droppable: false
398
+ })))).filter(isNonNullable);
399
+ }), Option.getOrElse(() => [])));
400
+ }
401
+ }),
402
+ // Create record nodes.
403
+ createExtension({
404
+ id: `${meta.id}/records`,
405
+ resolver: (id) => {
406
+ let query;
407
+ return Atom.make((get) => {
408
+ const client = context.getCapability(ClientCapabilities.Client);
409
+ const dxn = DXN.tryParse(id)?.asEchoDXN();
410
+ if (!dxn || !dxn.spaceId) {
411
+ return null;
412
+ }
413
+ const space = client.spaces.get(dxn.spaceId);
414
+ if (!space) {
415
+ return null;
416
+ }
417
+ if (!query) {
418
+ query = space.db.query(Filter.ids(dxn.echoId));
419
+ }
420
+ const object = get(atomFromQuery(query)).at(0);
421
+ if (!object) {
422
+ return null;
423
+ }
424
+ return createObjectNode({
425
+ object,
426
+ space,
427
+ resolve: resolve(get),
428
+ disposition: "hidden"
429
+ });
430
+ });
431
+ }
432
+ }),
433
+ // Create collection actions and action groups.
434
+ createExtension({
435
+ id: `${meta.id}/object-actions`,
436
+ actions: (node) => {
437
+ let query;
438
+ return Atom.make((get) => Function.pipe(get(node), Option.flatMap((node2) => {
439
+ const space = getSpace(node2.data);
440
+ return space && Obj.isObject(node2.data) && Obj.getTypename(node2.data) === node2.type ? Option.some({
441
+ space,
442
+ object: node2.data
443
+ }) : Option.none();
444
+ }), Option.flatMap(({ space, object }) => {
445
+ const isSchema2 = Obj.instanceOf(StoredSchema, object);
446
+ if (!query && isSchema2) {
447
+ query = space.db.query(Filter.type(View.View));
448
+ }
449
+ let deletable = !isSchema2 && // Don't allow the Records smart collection to be deleted.
450
+ !(Obj.instanceOf(Collection.QueryCollection, object) && getTypenameFromQuery(object.query) === StoredSchema.typename);
451
+ if (isSchema2 && query) {
452
+ const views = get(atomFromQuery(query));
453
+ const filteredViews = get(atomFromSignal(() => views.filter((view) => getTypenameFromQuery(view.query.ast) === object.typename)));
454
+ deletable = filteredViews.length === 0;
455
+ }
456
+ const [dispatcher] = get(context.capabilities(Capabilities.IntentDispatcher));
457
+ const [appGraph] = get(context.capabilities(Capabilities.AppGraph));
458
+ const [state] = get(context.capabilities(SpaceCapabilities.State));
459
+ const objectForms = get(context.capabilities(SpaceCapabilities.ObjectForm));
460
+ if (!dispatcher || !appGraph || !state) {
461
+ return Option.none();
462
+ } else {
463
+ return Option.some({
464
+ object,
465
+ graph: appGraph.graph,
466
+ dispatch: dispatcher.dispatchPromise,
467
+ objectForms,
468
+ deletable,
469
+ navigable: get(atomFromSignal(() => state.navigableCollections))
470
+ });
471
+ }
472
+ }), Option.map((params) => constructObjectActions(params)), Option.getOrElse(() => [])));
473
+ }
474
+ }),
475
+ // View selected objects.
476
+ createExtension({
477
+ id: `${meta.id}/selected-objects`,
478
+ connector: (node) => Atom.make((get) => Function.pipe(get(node), Option.flatMap((node2) => Obj.instanceOf(View.View, node2.data) ? Option.some(node2) : Option.none()), Option.map((node2) => [
479
+ {
480
+ id: [
481
+ node2.id,
482
+ "selected-objects"
483
+ ].join(ATTENDABLE_PATH_SEPARATOR),
484
+ type: PLANK_COMPANION_TYPE,
485
+ data: "selected-objects",
486
+ properties: {
487
+ label: [
488
+ "companion selected objects label",
489
+ {
490
+ ns: meta.id
491
+ }
492
+ ],
493
+ icon: "ph--tree-view--regular",
494
+ disposition: "hidden"
495
+ }
496
+ }
497
+ ]), Option.getOrElse(() => [])))
498
+ }),
499
+ // Object settings plank companion.
500
+ createExtension({
501
+ id: `${meta.id}/settings`,
502
+ connector: (node) => Atom.make((get) => Function.pipe(get(node), Option.flatMap((node2) => Obj.isObject(node2.data) ? Option.some(node2) : Option.none()), Option.map((node2) => [
503
+ {
504
+ id: [
505
+ node2.id,
506
+ "settings"
507
+ ].join(ATTENDABLE_PATH_SEPARATOR),
508
+ type: PLANK_COMPANION_TYPE,
509
+ data: "settings",
510
+ properties: {
511
+ label: [
512
+ "object settings label",
513
+ {
514
+ ns: meta.id
515
+ }
516
+ ],
517
+ icon: "ph--sliders--regular",
518
+ disposition: "hidden",
519
+ position: "fallback"
520
+ }
521
+ }
522
+ ]), Option.getOrElse(() => [])))
523
+ })
524
+ ]);
525
+ });
526
+ export {
527
+ app_graph_builder_default as default
528
+ };
529
+ //# sourceMappingURL=app-graph-builder-FBJFWI4H.mjs.map