@dxos/plugin-space 0.8.4-main.2e9d522 → 0.8.4-main.3c1ae3b
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.
- package/dist/lib/browser/{CollectionMain-D2B75XBS.mjs → CollectionArticle-WTHWY4YS.mjs} +10 -10
- package/dist/lib/browser/CollectionArticle-WTHWY4YS.mjs.map +7 -0
- package/dist/lib/browser/ObjectCardStack-TE7AWPMH.mjs +144 -0
- package/dist/lib/browser/ObjectCardStack-TE7AWPMH.mjs.map +7 -0
- package/dist/lib/browser/ObjectDetails-666IBRHE.mjs +144 -0
- package/dist/lib/browser/ObjectDetails-666IBRHE.mjs.map +7 -0
- package/dist/lib/browser/RecordArticle-2PFEBPXY.mjs +116 -0
- package/dist/lib/browser/RecordArticle-2PFEBPXY.mjs.map +7 -0
- package/dist/lib/browser/app-graph-builder-USKWFIDK.mjs +551 -0
- package/dist/lib/browser/app-graph-builder-USKWFIDK.mjs.map +7 -0
- package/dist/lib/browser/{app-graph-serializer-H6AW7KGS.mjs → app-graph-serializer-SXIQ425K.mjs} +19 -19
- package/dist/lib/browser/app-graph-serializer-SXIQ425K.mjs.map +7 -0
- package/dist/lib/browser/{chunk-VLBRSGJ2.mjs → chunk-5CSSKOWR.mjs} +42 -16
- package/dist/lib/browser/chunk-5CSSKOWR.mjs.map +7 -0
- package/dist/lib/browser/chunk-C6DAPIFF.mjs +20 -0
- package/dist/lib/browser/chunk-C6DAPIFF.mjs.map +7 -0
- package/dist/lib/browser/chunk-E4BEMEZ3.mjs +399 -0
- package/dist/lib/browser/chunk-E4BEMEZ3.mjs.map +7 -0
- package/dist/lib/browser/{chunk-XUYKJUU7.mjs → chunk-IJCMB5B5.mjs} +269 -145
- package/dist/lib/browser/chunk-IJCMB5B5.mjs.map +7 -0
- package/dist/lib/browser/{chunk-QACNNDOT.mjs → chunk-POFUXISV.mjs} +69 -62
- package/dist/lib/browser/chunk-POFUXISV.mjs.map +7 -0
- package/dist/lib/browser/chunk-VZBIIYFM.mjs +16 -0
- package/dist/lib/browser/chunk-VZBIIYFM.mjs.map +7 -0
- package/dist/lib/browser/chunk-WJXU4GKV.mjs +19 -0
- package/dist/lib/browser/chunk-WJXU4GKV.mjs.map +7 -0
- package/dist/lib/browser/{chunk-V7MJSSBQ.mjs → chunk-XKQCDLXX.mjs} +734 -615
- package/dist/lib/browser/chunk-XKQCDLXX.mjs.map +7 -0
- package/dist/lib/browser/{identity-created-23XJJV2N.mjs → identity-created-NAXTPQXE.mjs} +6 -6
- package/dist/lib/browser/identity-created-NAXTPQXE.mjs.map +7 -0
- package/dist/lib/browser/index.mjs +92 -139
- package/dist/lib/browser/index.mjs.map +3 -3
- package/dist/lib/browser/{intent-resolver-TIXVDYN7.mjs → intent-resolver-QEIM7NQT.mjs} +118 -109
- package/dist/lib/browser/intent-resolver-QEIM7NQT.mjs.map +7 -0
- package/dist/lib/browser/meta.json +1 -1
- package/dist/lib/browser/react-root-T6ZETLD2.mjs +30 -0
- package/dist/lib/browser/react-root-T6ZETLD2.mjs.map +7 -0
- package/dist/lib/browser/{react-surface-TPNLWJJH.mjs → react-surface-MLN5BZ2G.mjs} +120 -120
- package/dist/lib/browser/react-surface-MLN5BZ2G.mjs.map +7 -0
- package/dist/lib/browser/repair-CNLE35NF.mjs +44 -0
- package/dist/lib/browser/repair-CNLE35NF.mjs.map +7 -0
- package/dist/lib/browser/{settings-4IMP5RYT.mjs → settings-EGTCHS7U.mjs} +5 -5
- package/dist/lib/browser/{settings-4IMP5RYT.mjs.map → settings-EGTCHS7U.mjs.map} +1 -1
- package/dist/lib/browser/{spaces-ready-TOPG6IV4.mjs → spaces-ready-YS4BBZXW.mjs} +29 -20
- package/dist/lib/browser/spaces-ready-YS4BBZXW.mjs.map +7 -0
- package/dist/lib/browser/{state-QYZAB45H.mjs → state-C7N6EDDZ.mjs} +7 -7
- package/dist/lib/browser/state-C7N6EDDZ.mjs.map +7 -0
- package/dist/lib/browser/types/index.mjs +10 -4
- package/dist/lib/node-esm/{CollectionMain-ZJIFCWKZ.mjs → CollectionArticle-KHXYT3SH.mjs} +10 -10
- package/dist/lib/node-esm/CollectionArticle-KHXYT3SH.mjs.map +7 -0
- package/dist/lib/node-esm/ObjectCardStack-AAKMAQ6T.mjs +145 -0
- package/dist/lib/node-esm/ObjectCardStack-AAKMAQ6T.mjs.map +7 -0
- package/dist/lib/node-esm/ObjectDetails-TZ5YKXGN.mjs +145 -0
- package/dist/lib/node-esm/ObjectDetails-TZ5YKXGN.mjs.map +7 -0
- package/dist/lib/node-esm/RecordArticle-SSJ7PULS.mjs +117 -0
- package/dist/lib/node-esm/RecordArticle-SSJ7PULS.mjs.map +7 -0
- package/dist/lib/node-esm/app-graph-builder-QRQ5EQLB.mjs +552 -0
- package/dist/lib/node-esm/app-graph-builder-QRQ5EQLB.mjs.map +7 -0
- package/dist/lib/node-esm/{app-graph-serializer-2ICUGQQT.mjs → app-graph-serializer-P2X4W7LI.mjs} +19 -19
- package/dist/lib/node-esm/app-graph-serializer-P2X4W7LI.mjs.map +7 -0
- package/dist/lib/node-esm/{chunk-4AOMYKDE.mjs → chunk-3D4NGZPW.mjs} +269 -145
- package/dist/lib/node-esm/chunk-3D4NGZPW.mjs.map +7 -0
- package/dist/lib/node-esm/{chunk-P442DOQ3.mjs → chunk-AX3UGL5D.mjs} +69 -62
- package/dist/lib/node-esm/chunk-AX3UGL5D.mjs.map +7 -0
- package/dist/lib/node-esm/chunk-BDEFTL6K.mjs +18 -0
- package/dist/lib/node-esm/chunk-BDEFTL6K.mjs.map +7 -0
- package/dist/lib/node-esm/chunk-H4JILUJK.mjs +20 -0
- package/dist/lib/node-esm/chunk-H4JILUJK.mjs.map +7 -0
- package/dist/lib/node-esm/chunk-QQQE2ZCX.mjs +400 -0
- package/dist/lib/node-esm/chunk-QQQE2ZCX.mjs.map +7 -0
- package/dist/lib/node-esm/{chunk-SSLBYZEY.mjs → chunk-UMZ7G6G4.mjs} +41 -16
- package/dist/lib/node-esm/chunk-UMZ7G6G4.mjs.map +7 -0
- package/dist/lib/node-esm/chunk-WWGV5FJM.mjs +21 -0
- package/dist/lib/node-esm/chunk-WWGV5FJM.mjs.map +7 -0
- package/dist/lib/node-esm/{chunk-6X5DLJM5.mjs → chunk-XD532BVR.mjs} +734 -615
- package/dist/lib/node-esm/chunk-XD532BVR.mjs.map +7 -0
- package/dist/lib/node-esm/{identity-created-IJQO6GCR.mjs → identity-created-OXLKCJE3.mjs} +6 -6
- package/dist/lib/node-esm/identity-created-OXLKCJE3.mjs.map +7 -0
- package/dist/lib/node-esm/index.mjs +92 -139
- package/dist/lib/node-esm/index.mjs.map +3 -3
- package/dist/lib/node-esm/{intent-resolver-MHGHRGDT.mjs → intent-resolver-ZWCBVABN.mjs} +118 -109
- package/dist/lib/node-esm/intent-resolver-ZWCBVABN.mjs.map +7 -0
- package/dist/lib/node-esm/meta.json +1 -1
- package/dist/lib/node-esm/{react-root-KW3TGJGY.mjs → react-root-SKB4UJ4K.mjs} +13 -12
- package/dist/lib/node-esm/react-root-SKB4UJ4K.mjs.map +7 -0
- package/dist/lib/node-esm/{react-surface-UUIUUD6P.mjs → react-surface-BVZGNSBB.mjs} +120 -120
- package/dist/lib/node-esm/react-surface-BVZGNSBB.mjs.map +7 -0
- package/dist/lib/node-esm/repair-EHZS6MFY.mjs +45 -0
- package/dist/lib/node-esm/repair-EHZS6MFY.mjs.map +7 -0
- package/dist/lib/node-esm/{settings-SAOBPND3.mjs → settings-N3F6JCIR.mjs} +5 -5
- package/dist/lib/node-esm/{settings-SAOBPND3.mjs.map → settings-N3F6JCIR.mjs.map} +1 -1
- package/dist/lib/node-esm/{spaces-ready-HIUKNDZK.mjs → spaces-ready-U2K5P4LB.mjs} +29 -20
- package/dist/lib/node-esm/spaces-ready-U2K5P4LB.mjs.map +7 -0
- package/dist/lib/node-esm/{state-ZVEHQ4BJ.mjs → state-45TXZQJ6.mjs} +7 -7
- package/dist/lib/node-esm/state-45TXZQJ6.mjs.map +7 -0
- package/dist/lib/node-esm/types/index.mjs +10 -4
- package/dist/types/src/SpacePlugin.d.ts +1 -1
- package/dist/types/src/SpacePlugin.d.ts.map +1 -1
- package/dist/types/src/capabilities/app-graph-builder.d.ts +1 -1
- package/dist/types/src/capabilities/app-graph-builder.d.ts.map +1 -1
- package/dist/types/src/capabilities/app-graph-serializer.d.ts +1 -1
- package/dist/types/src/capabilities/capabilities.d.ts +14 -8
- package/dist/types/src/capabilities/capabilities.d.ts.map +1 -1
- package/dist/types/src/capabilities/identity-created.d.ts +1 -1
- package/dist/types/src/capabilities/identity-created.d.ts.map +1 -1
- package/dist/types/src/capabilities/index.d.ts +11 -12
- package/dist/types/src/capabilities/index.d.ts.map +1 -1
- package/dist/types/src/capabilities/intent-resolver.d.ts +1 -1
- package/dist/types/src/capabilities/intent-resolver.d.ts.map +1 -1
- package/dist/types/src/capabilities/react-root.d.ts +2 -2
- package/dist/types/src/capabilities/react-root.d.ts.map +1 -1
- package/dist/types/src/capabilities/react-surface.d.ts +1 -1
- package/dist/types/src/capabilities/react-surface.d.ts.map +1 -1
- package/dist/types/src/capabilities/repair.d.ts +4 -0
- package/dist/types/src/capabilities/repair.d.ts.map +1 -0
- package/dist/types/src/capabilities/settings.d.ts +1 -1
- package/dist/types/src/capabilities/spaces-ready.d.ts +1 -1
- package/dist/types/src/capabilities/spaces-ready.d.ts.map +1 -1
- package/dist/types/src/capabilities/state.d.ts +1 -1
- package/dist/types/src/capabilities/state.d.ts.map +1 -1
- package/dist/types/src/components/AwaitingObject.d.ts.map +1 -1
- package/dist/types/src/components/CollectionArticle.d.ts +6 -0
- package/dist/types/src/components/CollectionArticle.d.ts.map +1 -0
- package/dist/types/src/components/CollectionSection.d.ts +3 -4
- package/dist/types/src/components/CollectionSection.d.ts.map +1 -1
- package/dist/types/src/components/CreateDialog/CreateObjectDialog.d.ts +3 -3
- package/dist/types/src/components/CreateDialog/CreateObjectDialog.d.ts.map +1 -1
- package/dist/types/src/components/CreateDialog/CreateObjectDialog.stories.d.ts +1588 -4
- package/dist/types/src/components/CreateDialog/CreateObjectDialog.stories.d.ts.map +1 -1
- package/dist/types/src/components/CreateDialog/CreateObjectPanel.d.ts +18 -9
- package/dist/types/src/components/CreateDialog/CreateObjectPanel.d.ts.map +1 -1
- package/dist/types/src/components/CreateDialog/CreateSpaceDialog.d.ts +1 -1
- package/dist/types/src/components/CreateDialog/CreateSpaceDialog.d.ts.map +1 -1
- package/dist/types/src/components/{JoinDialog.d.ts → JoinDialog/JoinDialog.d.ts} +1 -1
- package/dist/types/src/components/JoinDialog/JoinDialog.d.ts.map +1 -0
- package/dist/types/src/components/JoinDialog/index.d.ts +2 -0
- package/dist/types/src/components/JoinDialog/index.d.ts.map +1 -0
- package/dist/types/src/components/{MembersContainer.d.ts → MembersContainer/MembersContainer.d.ts} +3 -2
- package/dist/types/src/components/MembersContainer/MembersContainer.d.ts.map +1 -0
- package/dist/types/src/components/MembersContainer/MembersContainer.stories.d.ts +1591 -0
- package/dist/types/src/components/MembersContainer/MembersContainer.stories.d.ts.map +1 -0
- package/dist/types/src/components/MembersContainer/index.d.ts +2 -0
- package/dist/types/src/components/MembersContainer/index.d.ts.map +1 -0
- package/dist/types/src/components/ObjectCardStack/ObjectCardStack.d.ts +8 -0
- package/dist/types/src/components/ObjectCardStack/ObjectCardStack.d.ts.map +1 -0
- package/dist/types/src/components/ObjectCardStack/ObjectForm.d.ts +9 -0
- package/dist/types/src/components/ObjectCardStack/ObjectForm.d.ts.map +1 -0
- package/dist/types/src/components/ObjectCardStack/index.d.ts +3 -0
- package/dist/types/src/components/ObjectCardStack/index.d.ts.map +1 -0
- package/dist/types/src/components/{ObjectSettings → ObjectDetails}/BaseObjectSettings.d.ts +2 -2
- package/dist/types/src/components/ObjectDetails/BaseObjectSettings.d.ts.map +1 -0
- package/dist/types/src/components/ObjectDetails/BaseObjectSettings.stories.d.ts +1424 -0
- package/dist/types/src/components/ObjectDetails/BaseObjectSettings.stories.d.ts.map +1 -0
- package/dist/types/src/components/ObjectDetails/ForeignKeys.d.ts +8 -0
- package/dist/types/src/components/ObjectDetails/ForeignKeys.d.ts.map +1 -0
- package/dist/types/src/components/ObjectDetails/ObjectDetails.d.ts +8 -0
- package/dist/types/src/components/ObjectDetails/ObjectDetails.d.ts.map +1 -0
- package/dist/types/src/components/ObjectDetails/index.d.ts +3 -0
- package/dist/types/src/components/ObjectDetails/index.d.ts.map +1 -0
- package/dist/types/src/components/ObjectRenamePopover/ObjectRenamePopover.d.ts +7 -0
- package/dist/types/src/components/ObjectRenamePopover/ObjectRenamePopover.d.ts.map +1 -0
- package/dist/types/src/components/ObjectRenamePopover/index.d.ts +2 -0
- package/dist/types/src/components/ObjectRenamePopover/index.d.ts.map +1 -0
- package/dist/types/src/components/RecordArticle.d.ts +5 -0
- package/dist/types/src/components/RecordArticle.d.ts.map +1 -0
- package/dist/types/src/components/RecordArticle.stories.d.ts +1591 -0
- package/dist/types/src/components/RecordArticle.stories.d.ts.map +1 -0
- package/dist/types/src/components/SchemaContainer.d.ts +2 -2
- package/dist/types/src/components/SchemaContainer.d.ts.map +1 -1
- package/dist/types/src/components/SpacePluginSettings.d.ts.map +1 -1
- package/dist/types/src/components/{SpacePresence.d.ts → SpacePresence/SpacePresence.d.ts} +6 -5
- package/dist/types/src/components/SpacePresence/SpacePresence.d.ts.map +1 -0
- package/dist/types/src/components/SpacePresence/SpacePresence.stories.d.ts +1421 -0
- package/dist/types/src/components/SpacePresence/SpacePresence.stories.d.ts.map +1 -0
- package/dist/types/src/components/SpacePresence/index.d.ts +2 -0
- package/dist/types/src/components/SpacePresence/index.d.ts.map +1 -0
- package/dist/types/src/components/SpaceRenamePopover/SpaceRenamePopover.d.ts +7 -0
- package/dist/types/src/components/SpaceRenamePopover/SpaceRenamePopover.d.ts.map +1 -0
- package/dist/types/src/components/SpaceRenamePopover/index.d.ts +2 -0
- package/dist/types/src/components/SpaceRenamePopover/index.d.ts.map +1 -0
- package/dist/types/src/components/SpaceSettings/SpaceSettingsContainer.d.ts +1 -1
- package/dist/types/src/components/SpaceSettings/SpaceSettingsContainer.d.ts.map +1 -1
- package/dist/types/src/components/SpaceSettings/SpaceSettingsContainer.stories.d.ts +1421 -4
- package/dist/types/src/components/SpaceSettings/SpaceSettingsContainer.stories.d.ts.map +1 -1
- package/dist/types/src/components/SyncStatus/SyncStatus.d.ts.map +1 -1
- package/dist/types/src/components/SyncStatus/SyncStatus.stories.d.ts +1422 -5
- package/dist/types/src/components/SyncStatus/SyncStatus.stories.d.ts.map +1 -1
- package/dist/types/src/components/ViewEditor.d.ts +3 -4
- package/dist/types/src/components/ViewEditor.d.ts.map +1 -1
- package/dist/types/src/components/index.d.ts +10 -12
- package/dist/types/src/components/index.d.ts.map +1 -1
- package/dist/types/src/events.d.ts.map +1 -1
- package/dist/types/src/helpers/index.d.ts +2 -0
- package/dist/types/src/helpers/index.d.ts.map +1 -0
- package/dist/types/src/helpers/query.d.ts +7 -0
- package/dist/types/src/helpers/query.d.ts.map +1 -0
- package/dist/types/src/helpers/query.test.d.ts +2 -0
- package/dist/types/src/helpers/query.test.d.ts.map +1 -0
- package/dist/types/src/hooks/index.d.ts +1 -0
- package/dist/types/src/hooks/index.d.ts.map +1 -1
- package/dist/types/src/hooks/useActiveSpace.d.ts.map +1 -1
- package/dist/types/src/hooks/useInputSurfaceLookup.d.ts +2 -8
- package/dist/types/src/hooks/useInputSurfaceLookup.d.ts.map +1 -1
- package/dist/types/src/hooks/usePath.d.ts +1 -1
- package/dist/types/src/hooks/usePath.d.ts.map +1 -1
- package/dist/types/src/hooks/useTypeOptions.d.ts +10 -0
- package/dist/types/src/hooks/useTypeOptions.d.ts.map +1 -0
- package/dist/types/src/index.d.ts +1 -0
- package/dist/types/src/index.d.ts.map +1 -1
- package/dist/types/src/meta.d.ts +0 -1
- package/dist/types/src/meta.d.ts.map +1 -1
- package/dist/types/src/translations.d.ts +1261 -67
- package/dist/types/src/translations.d.ts.map +1 -1
- package/dist/types/src/types/form.d.ts +22 -0
- package/dist/types/src/types/form.d.ts.map +1 -0
- package/dist/types/src/types/index.d.ts +1 -0
- package/dist/types/src/types/index.d.ts.map +1 -1
- package/dist/types/src/types/types.d.ts +96 -157
- package/dist/types/src/types/types.d.ts.map +1 -1
- package/dist/types/src/util.d.ts +25 -36
- package/dist/types/src/util.d.ts.map +1 -1
- package/dist/types/tsconfig.tsbuildinfo +1 -1
- package/package.json +70 -59
- package/src/SpacePlugin.ts +182 -222
- package/src/capabilities/app-graph-builder.ts +271 -246
- package/src/capabilities/app-graph-serializer.ts +12 -12
- package/src/capabilities/capabilities.ts +28 -17
- package/src/capabilities/identity-created.ts +3 -3
- package/src/capabilities/index.ts +1 -2
- package/src/capabilities/intent-resolver.ts +92 -81
- package/src/capabilities/react-root.tsx +6 -4
- package/src/capabilities/react-surface.tsx +127 -155
- package/src/capabilities/repair.ts +57 -0
- package/src/capabilities/spaces-ready.ts +38 -17
- package/src/capabilities/state.ts +5 -4
- package/src/components/AwaitingObject.tsx +12 -14
- package/src/components/{CollectionMain.tsx → CollectionArticle.tsx} +7 -6
- package/src/components/CollectionSection.tsx +8 -6
- package/src/components/CreateDialog/CreateObjectDialog.stories.tsx +17 -16
- package/src/components/CreateDialog/CreateObjectDialog.tsx +74 -46
- package/src/components/CreateDialog/CreateObjectPanel.tsx +65 -43
- package/src/components/CreateDialog/CreateSpaceDialog.tsx +45 -22
- package/src/components/{JoinDialog.tsx → JoinDialog/JoinDialog.tsx} +26 -10
- package/src/components/JoinDialog/index.ts +5 -0
- package/src/components/MembersContainer/MembersContainer.stories.tsx +56 -0
- package/src/components/{MembersContainer.tsx → MembersContainer/MembersContainer.tsx} +22 -21
- package/src/components/MembersContainer/index.ts +5 -0
- package/src/components/MenuFooter.tsx +2 -2
- package/src/components/ObjectCardStack/ObjectCardStack.tsx +64 -0
- package/src/components/ObjectCardStack/ObjectForm.tsx +90 -0
- package/src/components/ObjectCardStack/index.ts +7 -0
- package/src/components/ObjectDetails/BaseObjectSettings.stories.tsx +63 -0
- package/src/components/ObjectDetails/BaseObjectSettings.tsx +118 -0
- package/src/components/{ObjectSettings → ObjectDetails}/ForeignKeys.tsx +8 -8
- package/src/components/ObjectDetails/ObjectDetails.tsx +35 -0
- package/src/components/ObjectDetails/index.ts +7 -0
- package/src/components/{PopoverRenameObject.tsx → ObjectRenamePopover/ObjectRenamePopover.tsx} +10 -16
- package/src/components/ObjectRenamePopover/index.ts +5 -0
- package/src/components/RecordArticle.stories.tsx +115 -0
- package/src/components/RecordArticle.tsx +114 -0
- package/src/components/SchemaContainer.tsx +26 -29
- package/src/components/SpacePluginSettings.tsx +16 -11
- package/src/components/{SpacePresence.stories.tsx → SpacePresence/SpacePresence.stories.tsx} +24 -23
- package/src/components/{SpacePresence.tsx → SpacePresence/SpacePresence.tsx} +22 -17
- package/src/components/SpacePresence/index.ts +5 -0
- package/src/components/{PopoverRenameSpace.tsx → SpaceRenamePopover/SpaceRenamePopover.tsx} +7 -6
- package/src/components/SpaceRenamePopover/index.ts +5 -0
- package/src/components/SpaceSettings/SpaceSettingsContainer.stories.tsx +17 -9
- package/src/components/SpaceSettings/SpaceSettingsContainer.tsx +190 -155
- package/src/components/SyncStatus/InlineSyncStatus.tsx +8 -8
- package/src/components/SyncStatus/SyncStatus.stories.tsx +9 -9
- package/src/components/SyncStatus/SyncStatus.tsx +109 -12
- package/src/components/ViewEditor.tsx +56 -23
- package/src/components/index.ts +7 -7
- package/src/events.ts +7 -7
- package/src/helpers/index.ts +5 -0
- package/src/helpers/query.test.ts +24 -0
- package/src/helpers/query.ts +152 -0
- package/src/hooks/index.ts +1 -0
- package/src/hooks/useActiveSpace.ts +3 -2
- package/src/hooks/useInputSurfaceLookup.tsx +9 -13
- package/src/hooks/usePath.ts +1 -1
- package/src/hooks/useTypeOptions.ts +25 -0
- package/src/index.ts +1 -0
- package/src/meta.ts +6 -3
- package/src/translations.ts +68 -58
- package/src/types/form.ts +69 -0
- package/src/types/index.ts +1 -0
- package/src/types/types.ts +51 -52
- package/src/util.tsx +269 -147
- package/dist/lib/browser/CollectionMain-D2B75XBS.mjs.map +0 -7
- package/dist/lib/browser/ObjectDetailsPanel-YPTDQKMG.mjs +0 -88
- package/dist/lib/browser/ObjectDetailsPanel-YPTDQKMG.mjs.map +0 -7
- package/dist/lib/browser/app-graph-builder-7CZZJS3S.mjs +0 -479
- package/dist/lib/browser/app-graph-builder-7CZZJS3S.mjs.map +0 -7
- package/dist/lib/browser/app-graph-serializer-H6AW7KGS.mjs.map +0 -7
- package/dist/lib/browser/chunk-CEFHNVU7.mjs +0 -20
- package/dist/lib/browser/chunk-CEFHNVU7.mjs.map +0 -7
- package/dist/lib/browser/chunk-FBCGT5YY.mjs +0 -13
- package/dist/lib/browser/chunk-FBCGT5YY.mjs.map +0 -7
- package/dist/lib/browser/chunk-JS3MMC42.mjs +0 -19
- package/dist/lib/browser/chunk-JS3MMC42.mjs.map +0 -7
- package/dist/lib/browser/chunk-QACNNDOT.mjs.map +0 -7
- package/dist/lib/browser/chunk-SGTQ52SU.mjs +0 -338
- package/dist/lib/browser/chunk-SGTQ52SU.mjs.map +0 -7
- package/dist/lib/browser/chunk-V7MJSSBQ.mjs.map +0 -7
- package/dist/lib/browser/chunk-VLBRSGJ2.mjs.map +0 -7
- package/dist/lib/browser/chunk-XUYKJUU7.mjs.map +0 -7
- package/dist/lib/browser/identity-created-23XJJV2N.mjs.map +0 -7
- package/dist/lib/browser/intent-resolver-TIXVDYN7.mjs.map +0 -7
- package/dist/lib/browser/react-root-N2J7TDRX.mjs +0 -29
- package/dist/lib/browser/react-root-N2J7TDRX.mjs.map +0 -7
- package/dist/lib/browser/react-surface-TPNLWJJH.mjs.map +0 -7
- package/dist/lib/browser/schema-defs-Z6FC4AHC.mjs +0 -26
- package/dist/lib/browser/schema-defs-Z6FC4AHC.mjs.map +0 -7
- package/dist/lib/browser/schema-tools-BNP4JTD7.mjs +0 -124
- package/dist/lib/browser/schema-tools-BNP4JTD7.mjs.map +0 -7
- package/dist/lib/browser/spaces-ready-TOPG6IV4.mjs.map +0 -7
- package/dist/lib/browser/state-QYZAB45H.mjs.map +0 -7
- package/dist/lib/node-esm/CollectionMain-ZJIFCWKZ.mjs.map +0 -7
- package/dist/lib/node-esm/ObjectDetailsPanel-QKZEDSZK.mjs +0 -89
- package/dist/lib/node-esm/ObjectDetailsPanel-QKZEDSZK.mjs.map +0 -7
- package/dist/lib/node-esm/app-graph-builder-KGIGWC72.mjs +0 -480
- package/dist/lib/node-esm/app-graph-builder-KGIGWC72.mjs.map +0 -7
- package/dist/lib/node-esm/app-graph-serializer-2ICUGQQT.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-4AOMYKDE.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-5HHYE264.mjs +0 -20
- package/dist/lib/node-esm/chunk-5HHYE264.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-5T3ZH23B.mjs +0 -21
- package/dist/lib/node-esm/chunk-5T3ZH23B.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-6X5DLJM5.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-HWNG4MEU.mjs +0 -15
- package/dist/lib/node-esm/chunk-HWNG4MEU.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-JH6F4C3I.mjs +0 -339
- package/dist/lib/node-esm/chunk-JH6F4C3I.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-P442DOQ3.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-SSLBYZEY.mjs.map +0 -7
- package/dist/lib/node-esm/identity-created-IJQO6GCR.mjs.map +0 -7
- package/dist/lib/node-esm/intent-resolver-MHGHRGDT.mjs.map +0 -7
- package/dist/lib/node-esm/react-root-KW3TGJGY.mjs.map +0 -7
- package/dist/lib/node-esm/react-surface-UUIUUD6P.mjs.map +0 -7
- package/dist/lib/node-esm/schema-defs-WHJM7UZE.mjs +0 -27
- package/dist/lib/node-esm/schema-defs-WHJM7UZE.mjs.map +0 -7
- package/dist/lib/node-esm/schema-tools-KWW5PTML.mjs +0 -126
- package/dist/lib/node-esm/schema-tools-KWW5PTML.mjs.map +0 -7
- package/dist/lib/node-esm/spaces-ready-HIUKNDZK.mjs.map +0 -7
- package/dist/lib/node-esm/state-ZVEHQ4BJ.mjs.map +0 -7
- package/dist/types/src/capabilities/schema-defs.d.ts +0 -4
- package/dist/types/src/capabilities/schema-defs.d.ts.map +0 -1
- package/dist/types/src/capabilities/schema-tool.test.d.ts +0 -2
- package/dist/types/src/capabilities/schema-tool.test.d.ts.map +0 -1
- package/dist/types/src/capabilities/schema-tools.d.ts +0 -13
- package/dist/types/src/capabilities/schema-tools.d.ts.map +0 -1
- package/dist/types/src/components/CollectionMain.d.ts +0 -7
- package/dist/types/src/components/CollectionMain.d.ts.map +0 -1
- package/dist/types/src/components/JoinDialog.d.ts.map +0 -1
- package/dist/types/src/components/MembersContainer.d.ts.map +0 -1
- package/dist/types/src/components/MembersContainer.stories.d.ts +0 -8
- package/dist/types/src/components/MembersContainer.stories.d.ts.map +0 -1
- package/dist/types/src/components/ObjectDetailsPanel.d.ts +0 -9
- package/dist/types/src/components/ObjectDetailsPanel.d.ts.map +0 -1
- package/dist/types/src/components/ObjectSettings/AdvancedObjectSettings.d.ts +0 -7
- package/dist/types/src/components/ObjectSettings/AdvancedObjectSettings.d.ts.map +0 -1
- package/dist/types/src/components/ObjectSettings/BaseObjectSettings.d.ts.map +0 -1
- package/dist/types/src/components/ObjectSettings/ForeignKeys.d.ts +0 -8
- package/dist/types/src/components/ObjectSettings/ForeignKeys.d.ts.map +0 -1
- package/dist/types/src/components/ObjectSettings/ObjectSettingsContainer.d.ts +0 -8
- package/dist/types/src/components/ObjectSettings/ObjectSettingsContainer.d.ts.map +0 -1
- package/dist/types/src/components/ObjectSettings/index.d.ts +0 -2
- package/dist/types/src/components/ObjectSettings/index.d.ts.map +0 -1
- package/dist/types/src/components/PersistenceStatus.d.ts +0 -6
- package/dist/types/src/components/PersistenceStatus.d.ts.map +0 -1
- package/dist/types/src/components/PopoverRenameObject.d.ts +0 -7
- package/dist/types/src/components/PopoverRenameObject.d.ts.map +0 -1
- package/dist/types/src/components/PopoverRenameSpace.d.ts +0 -7
- package/dist/types/src/components/PopoverRenameSpace.d.ts.map +0 -1
- package/dist/types/src/components/SpacePresence.d.ts.map +0 -1
- package/dist/types/src/components/SpacePresence.stories.d.ts +0 -9
- package/dist/types/src/components/SpacePresence.stories.d.ts.map +0 -1
- package/src/capabilities/schema-defs.ts +0 -30
- package/src/capabilities/schema-tool.test.ts +0 -44
- package/src/capabilities/schema-tools.ts +0 -125
- package/src/components/MembersContainer.stories.tsx +0 -30
- package/src/components/ObjectDetailsPanel.tsx +0 -77
- package/src/components/ObjectSettings/AdvancedObjectSettings.tsx +0 -80
- package/src/components/ObjectSettings/BaseObjectSettings.tsx +0 -47
- package/src/components/ObjectSettings/ObjectSettingsContainer.tsx +0 -36
- package/src/components/ObjectSettings/index.ts +0 -5
- package/src/components/PersistenceStatus.tsx +0 -83
|
@@ -4,15 +4,15 @@
|
|
|
4
4
|
|
|
5
5
|
import { Capabilities, type PluginContext, contributes, createIntent } from '@dxos/app-framework';
|
|
6
6
|
import { isSpace } from '@dxos/client/echo';
|
|
7
|
-
import { Obj
|
|
8
|
-
import {
|
|
7
|
+
import { Obj } from '@dxos/echo';
|
|
8
|
+
import { Collection } from '@dxos/schema';
|
|
9
9
|
|
|
10
|
-
import {
|
|
10
|
+
import { meta } from '../meta';
|
|
11
11
|
import { translations } from '../translations';
|
|
12
12
|
import { SPACE_TYPE, SpaceAction } from '../types';
|
|
13
13
|
import { SPACES } from '../util';
|
|
14
14
|
|
|
15
|
-
const COLLECTION_TYPE =
|
|
15
|
+
const COLLECTION_TYPE = Collection.Collection.typename;
|
|
16
16
|
|
|
17
17
|
// https://stackoverflow.com/a/19016910
|
|
18
18
|
const DIRECTORY_TYPE = 'text/directory';
|
|
@@ -23,8 +23,8 @@ export default (context: PluginContext) =>
|
|
|
23
23
|
inputType: SPACES,
|
|
24
24
|
outputType: DIRECTORY_TYPE,
|
|
25
25
|
serialize: (node) => ({
|
|
26
|
-
name: translations[0]['en-US'][
|
|
27
|
-
data: translations[0]['en-US'][
|
|
26
|
+
name: translations[0]['en-US'][meta.id]['spaces label'] ?? 'Spaces',
|
|
27
|
+
data: translations[0]['en-US'][meta.id]['spaces label'] ?? 'Spaces',
|
|
28
28
|
type: DIRECTORY_TYPE,
|
|
29
29
|
}),
|
|
30
30
|
deserialize: () => {
|
|
@@ -35,8 +35,8 @@ export default (context: PluginContext) =>
|
|
|
35
35
|
inputType: SPACE_TYPE,
|
|
36
36
|
outputType: DIRECTORY_TYPE,
|
|
37
37
|
serialize: (node) => ({
|
|
38
|
-
name: node.data.properties.name ?? translations[0]['en-US'][
|
|
39
|
-
data: node.data.properties.name ?? translations[0]['en-US'][
|
|
38
|
+
name: node.data.properties.name ?? translations[0]['en-US'][meta.id]['unnamed space label'],
|
|
39
|
+
data: node.data.properties.name ?? translations[0]['en-US'][meta.id]['unnamed space label'],
|
|
40
40
|
type: DIRECTORY_TYPE,
|
|
41
41
|
}),
|
|
42
42
|
deserialize: async (data) => {
|
|
@@ -49,14 +49,14 @@ export default (context: PluginContext) =>
|
|
|
49
49
|
inputType: COLLECTION_TYPE,
|
|
50
50
|
outputType: DIRECTORY_TYPE,
|
|
51
51
|
serialize: (node) => ({
|
|
52
|
-
name: node.data.name ?? translations[0]['en-US'][
|
|
53
|
-
data: node.data.name ?? translations[0]['en-US'][
|
|
52
|
+
name: node.data.name ?? translations[0]['en-US'][meta.id]['object name placeholder'],
|
|
53
|
+
data: node.data.name ?? translations[0]['en-US'][meta.id]['object name placeholder'],
|
|
54
54
|
type: DIRECTORY_TYPE,
|
|
55
55
|
}),
|
|
56
56
|
deserialize: async (data, ancestors) => {
|
|
57
57
|
const space = ancestors.find(isSpace);
|
|
58
58
|
const collection =
|
|
59
|
-
ancestors.findLast((ancestor) => Obj.instanceOf(
|
|
59
|
+
ancestors.findLast((ancestor) => Obj.instanceOf(Collection.Collection, ancestor)) ??
|
|
60
60
|
space?.properties[COLLECTION_TYPE]?.target;
|
|
61
61
|
if (!space || !collection) {
|
|
62
62
|
return;
|
|
@@ -66,7 +66,7 @@ export default (context: PluginContext) =>
|
|
|
66
66
|
const result = await dispatch(
|
|
67
67
|
createIntent(SpaceAction.AddObject, {
|
|
68
68
|
target: collection,
|
|
69
|
-
object: Obj.make(
|
|
69
|
+
object: Obj.make(Collection.Collection, { name: data.name, objects: [] }),
|
|
70
70
|
}),
|
|
71
71
|
);
|
|
72
72
|
|
|
@@ -2,28 +2,39 @@
|
|
|
2
2
|
// Copyright 2025 DXOS.org
|
|
3
3
|
//
|
|
4
4
|
|
|
5
|
-
import
|
|
5
|
+
import type * as Schema from 'effect/Schema';
|
|
6
6
|
|
|
7
|
-
import { type AnyIntentChain,
|
|
7
|
+
import { type AnyIntentChain, type Label, defineCapability } from '@dxos/app-framework';
|
|
8
8
|
import { type Space } from '@dxos/react-client/echo';
|
|
9
|
-
import { type
|
|
10
|
-
import { type
|
|
9
|
+
import { type Collection } from '@dxos/schema';
|
|
10
|
+
import { type DeepReadonly, type Position } from '@dxos/util';
|
|
11
11
|
|
|
12
|
-
import {
|
|
13
|
-
import { type
|
|
12
|
+
import { meta } from '../meta';
|
|
13
|
+
import { type PluginState } from '../types';
|
|
14
14
|
|
|
15
15
|
export namespace SpaceCapabilities {
|
|
16
|
-
export const State = defineCapability<DeepReadonly<PluginState>>(`${
|
|
17
|
-
export const MutableState = defineCapability<PluginState>(`${
|
|
16
|
+
export const State = defineCapability<DeepReadonly<PluginState>>(`${meta.id}/capability/state`);
|
|
17
|
+
export const MutableState = defineCapability<PluginState>(`${meta.id}/capability/state`);
|
|
18
18
|
|
|
19
19
|
export type SettingsSection = { id: string; label: Label; position?: Position };
|
|
20
|
-
export const SettingsSection = defineCapability<SettingsSection>(`${
|
|
21
|
-
|
|
22
|
-
export type
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
20
|
+
export const SettingsSection = defineCapability<SettingsSection>(`${meta.id}/capability/settings-section`);
|
|
21
|
+
|
|
22
|
+
export type OnCreateSpace = (params: {
|
|
23
|
+
space: Space;
|
|
24
|
+
isDefault: boolean;
|
|
25
|
+
rootCollection: Collection.Collection;
|
|
26
|
+
}) => AnyIntentChain;
|
|
27
|
+
export const OnCreateSpace = defineCapability<OnCreateSpace>(`${meta.id}/capability/on-space-created`);
|
|
28
|
+
|
|
29
|
+
export type OnSchemaAdded = (params: {
|
|
30
|
+
space: Space;
|
|
31
|
+
schema: Schema.Schema.AnyNoContext;
|
|
32
|
+
// TODO(wittjosiah): This is leaky.
|
|
33
|
+
show?: boolean;
|
|
34
|
+
}) => AnyIntentChain;
|
|
35
|
+
export const OnSchemaAdded = defineCapability<OnSchemaAdded>(`${meta.id}/capability/on-schema-added`);
|
|
36
|
+
|
|
37
|
+
// TODO(wittjosiah): Replace with migrations, this is not a sustainable solution.
|
|
38
|
+
export type HandleRepair = (params: { space: Space; isDefault: boolean }) => Promise<void>;
|
|
39
|
+
export const Repair = defineCapability<HandleRepair>(`${meta.id}/capability/repair`);
|
|
29
40
|
}
|
|
@@ -2,11 +2,11 @@
|
|
|
2
2
|
// Copyright 2025 DXOS.org
|
|
3
3
|
//
|
|
4
4
|
|
|
5
|
-
import {
|
|
5
|
+
import { Capabilities, type PluginContext, contributes } from '@dxos/app-framework';
|
|
6
6
|
import { Obj, Ref } from '@dxos/echo';
|
|
7
7
|
import { Migrations } from '@dxos/migrations';
|
|
8
8
|
import { ClientCapabilities } from '@dxos/plugin-client';
|
|
9
|
-
import {
|
|
9
|
+
import { Collection } from '@dxos/schema';
|
|
10
10
|
|
|
11
11
|
export default async (context: PluginContext) => {
|
|
12
12
|
const client = context.getCapability(ClientCapabilities.Client);
|
|
@@ -16,7 +16,7 @@ export default async (context: PluginContext) => {
|
|
|
16
16
|
await defaultSpace.waitUntilReady();
|
|
17
17
|
|
|
18
18
|
// Create root collection structure.
|
|
19
|
-
defaultSpace.properties[
|
|
19
|
+
defaultSpace.properties[Collection.Collection.typename] = Ref.make(Obj.make(Collection.Collection, { objects: [] }));
|
|
20
20
|
if (Migrations.versionProperty) {
|
|
21
21
|
defaultSpace.properties[Migrations.versionProperty] = Migrations.targetVersion;
|
|
22
22
|
}
|
|
@@ -10,8 +10,7 @@ export const IdentityCreated = lazy(() => import('./identity-created'));
|
|
|
10
10
|
export const IntentResolver = lazy(() => import('./intent-resolver'));
|
|
11
11
|
export const ReactRoot = lazy(() => import('./react-root'));
|
|
12
12
|
export const ReactSurface = lazy(() => import('./react-surface'));
|
|
13
|
-
export const
|
|
14
|
-
export const SchemaTools = lazy(() => import('./schema-tools'));
|
|
13
|
+
export const Repair = lazy(() => import('./repair'));
|
|
15
14
|
export const SpaceSettings = lazy(() => import('./settings'));
|
|
16
15
|
export const SpaceState = lazy(() => import('./state'));
|
|
17
16
|
export const SpacesReady = lazy(() => import('./spaces-ready'));
|
|
@@ -2,44 +2,50 @@
|
|
|
2
2
|
// Copyright 2025 DXOS.org
|
|
3
3
|
//
|
|
4
4
|
|
|
5
|
-
import
|
|
5
|
+
import * as Effect from 'effect/Effect';
|
|
6
6
|
|
|
7
7
|
import {
|
|
8
8
|
Capabilities,
|
|
9
|
+
type Label,
|
|
9
10
|
LayoutAction,
|
|
10
11
|
type PluginContext,
|
|
11
12
|
contributes,
|
|
12
13
|
createIntent,
|
|
13
14
|
createResolver,
|
|
14
15
|
} from '@dxos/app-framework';
|
|
15
|
-
import { Obj, Ref, Relation, Type } from '@dxos/echo';
|
|
16
|
+
import { Obj, Query, Ref, Relation, Type } from '@dxos/echo';
|
|
17
|
+
import { Database } from '@dxos/echo';
|
|
18
|
+
import { Serializer } from '@dxos/echo-db';
|
|
16
19
|
import { invariant } from '@dxos/invariant';
|
|
17
20
|
import { Migrations } from '@dxos/migrations';
|
|
18
21
|
import { ClientCapabilities } from '@dxos/plugin-client';
|
|
19
22
|
import { ObservabilityAction } from '@dxos/plugin-observability/types';
|
|
20
23
|
import { EdgeReplicationSetting } from '@dxos/protocols/proto/dxos/echo/metadata';
|
|
21
|
-
import {
|
|
24
|
+
import { SpaceState, getSpace, isSpace } from '@dxos/react-client/echo';
|
|
22
25
|
import { Invitation, InvitationEncoder } from '@dxos/react-client/invitations';
|
|
23
26
|
import { ATTENDABLE_PATH_SEPARATOR } from '@dxos/react-ui-attention';
|
|
24
|
-
import {
|
|
27
|
+
import { iconValues } from '@dxos/react-ui-pickers';
|
|
28
|
+
import { hues } from '@dxos/react-ui-theme';
|
|
29
|
+
import { Collection, ProjectionModel, getTypenameFromQuery } from '@dxos/schema';
|
|
25
30
|
|
|
26
|
-
import { SpaceCapabilities } from './capabilities';
|
|
27
31
|
import {
|
|
28
32
|
CREATE_OBJECT_DIALOG,
|
|
29
33
|
CREATE_SPACE_DIALOG,
|
|
30
|
-
JOIN_DIALOG,
|
|
31
|
-
POPOVER_RENAME_OBJECT,
|
|
32
|
-
POPOVER_RENAME_SPACE,
|
|
33
34
|
type CreateObjectDialogProps,
|
|
35
|
+
JOIN_DIALOG,
|
|
34
36
|
type JoinDialogProps,
|
|
37
|
+
OBJECT_RENAME_POPOVER,
|
|
38
|
+
SPACE_RENAME_POPOVER,
|
|
35
39
|
} from '../components';
|
|
36
40
|
import { SpaceEvents } from '../events';
|
|
37
|
-
import {
|
|
41
|
+
import { meta } from '../meta';
|
|
38
42
|
import { CollectionAction, SpaceAction } from '../types';
|
|
39
|
-
import {
|
|
43
|
+
import { COMPOSER_SPACE_LOCK, cloneObject, getNestedObjects } from '../util';
|
|
44
|
+
|
|
45
|
+
import { SpaceCapabilities } from './capabilities';
|
|
40
46
|
|
|
41
47
|
// TODO(wittjosiah): Remove.
|
|
42
|
-
const SPACE_MAX_OBJECTS =
|
|
48
|
+
const SPACE_MAX_OBJECTS = 750;
|
|
43
49
|
|
|
44
50
|
type IntentResolverOptions = {
|
|
45
51
|
context: PluginContext;
|
|
@@ -68,8 +74,10 @@ export default ({ context, observability, createInvitationUrl }: IntentResolverO
|
|
|
68
74
|
}),
|
|
69
75
|
createResolver({
|
|
70
76
|
intent: SpaceAction.Create,
|
|
71
|
-
resolve: async ({ name, hue, icon, edgeReplication }) => {
|
|
77
|
+
resolve: async ({ name, hue: hue_, icon: icon_, edgeReplication }) => {
|
|
72
78
|
const client = context.getCapability(ClientCapabilities.Client);
|
|
79
|
+
const hue = hue_ ?? hues[Math.floor(Math.random() * hues.length)];
|
|
80
|
+
const icon = icon_ ?? iconValues[Math.floor(Math.random() * iconValues.length)];
|
|
73
81
|
const space = await client.spaces.create({ name, hue, icon });
|
|
74
82
|
if (edgeReplication) {
|
|
75
83
|
await space.internal.setEdgeReplicationPreference(EdgeReplicationSetting.ENABLED);
|
|
@@ -77,8 +85,8 @@ export default ({ context, observability, createInvitationUrl }: IntentResolverO
|
|
|
77
85
|
await space.waitUntilReady();
|
|
78
86
|
|
|
79
87
|
// Create root collection.
|
|
80
|
-
const collection = Obj.make(
|
|
81
|
-
space.properties[
|
|
88
|
+
const collection = Obj.make(Collection.Collection, { objects: [] });
|
|
89
|
+
space.properties[Collection.Collection.typename] = Ref.make(collection);
|
|
82
90
|
|
|
83
91
|
// Set current migration version.
|
|
84
92
|
if (Migrations.versionProperty) {
|
|
@@ -86,16 +94,13 @@ export default ({ context, observability, createInvitationUrl }: IntentResolverO
|
|
|
86
94
|
}
|
|
87
95
|
|
|
88
96
|
// Create records smart collection.
|
|
89
|
-
|
|
90
|
-
query: { typename: DataType.StoredSchema.typename },
|
|
91
|
-
});
|
|
92
|
-
collection.objects.push(Ref.make(records));
|
|
97
|
+
collection.objects.push(Ref.make(Collection.makeManaged({ key: Type.getTypename(Type.PersistentType) })));
|
|
93
98
|
|
|
94
99
|
// Allow other plugins to add default content.
|
|
95
100
|
await context.activatePromise(SpaceEvents.SpaceCreated);
|
|
96
|
-
const
|
|
97
|
-
const spaceCreatedIntents =
|
|
98
|
-
|
|
101
|
+
const onCreateSpaceCallbacks = context.getCapabilities(SpaceCapabilities.OnCreateSpace);
|
|
102
|
+
const spaceCreatedIntents = onCreateSpaceCallbacks.map((onCreateSpace) =>
|
|
103
|
+
onCreateSpace({ space, isDefault: false, rootCollection: collection }),
|
|
99
104
|
);
|
|
100
105
|
|
|
101
106
|
return {
|
|
@@ -253,7 +258,7 @@ export default ({ context, observability, createInvitationUrl }: IntentResolverO
|
|
|
253
258
|
intents: [
|
|
254
259
|
createIntent(LayoutAction.UpdatePopover, {
|
|
255
260
|
part: 'popover',
|
|
256
|
-
subject:
|
|
261
|
+
subject: SPACE_RENAME_POPOVER,
|
|
257
262
|
options: {
|
|
258
263
|
anchorId: `dxos.org/ui/${caller}/${space.id}`,
|
|
259
264
|
props: space,
|
|
@@ -320,12 +325,22 @@ export default ({ context, observability, createInvitationUrl }: IntentResolverO
|
|
|
320
325
|
};
|
|
321
326
|
},
|
|
322
327
|
}),
|
|
328
|
+
createResolver({
|
|
329
|
+
intent: SpaceAction.Snapshot,
|
|
330
|
+
resolve: async ({ space, query }) => {
|
|
331
|
+
const backup = await new Serializer().export(space.db, query && Query.fromAst(query));
|
|
332
|
+
return {
|
|
333
|
+
data: {
|
|
334
|
+
snapshot: new Blob([JSON.stringify(backup, null, 2)], { type: 'application/json' }),
|
|
335
|
+
},
|
|
336
|
+
};
|
|
337
|
+
},
|
|
338
|
+
}),
|
|
323
339
|
createResolver({
|
|
324
340
|
intent: SpaceAction.UseStaticSchema,
|
|
325
|
-
resolve: async ({ space, typename }) => {
|
|
341
|
+
resolve: async ({ space, typename, show }) => {
|
|
326
342
|
const client = context.getCapability(ClientCapabilities.Client);
|
|
327
|
-
const schema = client.graph.schemaRegistry.
|
|
328
|
-
invariant(schema, `Schema not found: ${typename}`);
|
|
343
|
+
const schema = await client.graph.schemaRegistry.query({ typename, location: ['runtime'] }).first();
|
|
329
344
|
|
|
330
345
|
if (!space.properties.staticRecords) {
|
|
331
346
|
space.properties.staticRecords = [];
|
|
@@ -337,7 +352,7 @@ export default ({ context, observability, createInvitationUrl }: IntentResolverO
|
|
|
337
352
|
|
|
338
353
|
await context.activatePromise(SpaceEvents.SchemaAdded);
|
|
339
354
|
const onSchemaAdded = context.getCapabilities(SpaceCapabilities.OnSchemaAdded);
|
|
340
|
-
const schemaAddedIntents = onSchemaAdded.map((onSchemaAdded) => onSchemaAdded({ space, schema }));
|
|
355
|
+
const schemaAddedIntents = onSchemaAdded.map((onSchemaAdded) => onSchemaAdded({ space, schema, show }));
|
|
341
356
|
|
|
342
357
|
return {
|
|
343
358
|
data: {},
|
|
@@ -360,15 +375,21 @@ export default ({ context, observability, createInvitationUrl }: IntentResolverO
|
|
|
360
375
|
}),
|
|
361
376
|
createResolver({
|
|
362
377
|
intent: SpaceAction.AddSchema,
|
|
363
|
-
resolve: async ({ space, name, schema: schemaInput }) => {
|
|
378
|
+
resolve: async ({ space, name, typename, version, schema: schemaInput, show }) => {
|
|
364
379
|
const [schema] = await space.db.schemaRegistry.register([schemaInput]);
|
|
365
380
|
if (name) {
|
|
366
381
|
schema.storedSchema.name = name;
|
|
367
382
|
}
|
|
383
|
+
if (typename) {
|
|
384
|
+
schema.storedSchema.typename = typename;
|
|
385
|
+
}
|
|
386
|
+
if (version) {
|
|
387
|
+
schema.storedSchema.version = version;
|
|
388
|
+
}
|
|
368
389
|
|
|
369
390
|
await context.activatePromise(SpaceEvents.SchemaAdded);
|
|
370
391
|
const onSchemaAdded = context.getCapabilities(SpaceCapabilities.OnSchemaAdded);
|
|
371
|
-
const schemaAddedIntents = onSchemaAdded.map((onSchemaAdded) => onSchemaAdded({ space, schema }));
|
|
392
|
+
const schemaAddedIntents = onSchemaAdded.map((onSchemaAdded) => onSchemaAdded({ space, schema, show }));
|
|
372
393
|
|
|
373
394
|
return {
|
|
374
395
|
data: {
|
|
@@ -399,15 +420,16 @@ export default ({ context, observability, createInvitationUrl }: IntentResolverO
|
|
|
399
420
|
resolve: async ({ view, fieldId, deletionData }, undo) => {
|
|
400
421
|
const space = getSpace(view);
|
|
401
422
|
invariant(space);
|
|
402
|
-
|
|
403
|
-
|
|
423
|
+
const typename = getTypenameFromQuery(view.query.ast);
|
|
424
|
+
invariant(typename);
|
|
425
|
+
const schema = await space.db.schemaRegistry.query({ typename }).firstOrUndefined();
|
|
404
426
|
invariant(schema);
|
|
405
427
|
const projection = new ProjectionModel(schema.jsonSchema, view.projection);
|
|
406
428
|
if (!undo) {
|
|
407
429
|
const { deleted, index } = projection.deleteFieldProjection(fieldId);
|
|
408
430
|
return {
|
|
409
431
|
undoable: {
|
|
410
|
-
message: ['field deleted label', { ns:
|
|
432
|
+
message: ['field deleted label', { ns: meta.id }],
|
|
411
433
|
data: { deletionData: { ...deleted, index } },
|
|
412
434
|
},
|
|
413
435
|
};
|
|
@@ -419,7 +441,7 @@ export default ({ context, observability, createInvitationUrl }: IntentResolverO
|
|
|
419
441
|
}),
|
|
420
442
|
createResolver({
|
|
421
443
|
intent: SpaceAction.OpenCreateObject,
|
|
422
|
-
resolve: ({ target, typename, navigable = true, onCreateObject }) => {
|
|
444
|
+
resolve: ({ target, views, typename, initialFormValues, navigable = true, onCreateObject }) => {
|
|
423
445
|
const state = context.getCapability(SpaceCapabilities.State);
|
|
424
446
|
|
|
425
447
|
return {
|
|
@@ -431,13 +453,15 @@ export default ({ context, observability, createInvitationUrl }: IntentResolverO
|
|
|
431
453
|
blockAlign: 'start',
|
|
432
454
|
props: {
|
|
433
455
|
target,
|
|
456
|
+
views,
|
|
434
457
|
typename,
|
|
458
|
+
initialFormValues,
|
|
435
459
|
onCreateObject,
|
|
436
460
|
shouldNavigate: navigable
|
|
437
461
|
? (object: Obj.Any) => {
|
|
438
|
-
const isCollection = Obj.instanceOf(
|
|
439
|
-
const
|
|
440
|
-
return (!isCollection && !
|
|
462
|
+
const isCollection = Obj.instanceOf(Collection.Collection, object);
|
|
463
|
+
const isSystemCollection = Obj.instanceOf(Collection.Managed, object);
|
|
464
|
+
return (!isCollection && !isSystemCollection) || state.navigableCollections;
|
|
441
465
|
}
|
|
442
466
|
: () => false,
|
|
443
467
|
} satisfies Partial<CreateObjectDialogProps>,
|
|
@@ -460,13 +484,13 @@ export default ({ context, observability, createInvitationUrl }: IntentResolverO
|
|
|
460
484
|
createIntent(LayoutAction.AddToast, {
|
|
461
485
|
part: 'toast',
|
|
462
486
|
subject: {
|
|
463
|
-
id: `${
|
|
464
|
-
title: ['space limit label', { ns:
|
|
465
|
-
description: ['space limit description', { ns:
|
|
487
|
+
id: `${meta.id}/space-limit`,
|
|
488
|
+
title: ['space limit label', { ns: meta.id }],
|
|
489
|
+
description: ['space limit description', { ns: meta.id }],
|
|
466
490
|
duration: 5_000,
|
|
467
491
|
icon: 'ph--warning--regular',
|
|
468
|
-
actionLabel: ['remove deleted objects label', { ns:
|
|
469
|
-
actionAlt: ['remove deleted objects alt', { ns:
|
|
492
|
+
actionLabel: ['remove deleted objects label', { ns: meta.id }],
|
|
493
|
+
actionAlt: ['remove deleted objects alt', { ns: meta.id }],
|
|
470
494
|
closeLabel: ['close label', { ns: 'os' }],
|
|
471
495
|
onAction: () => space.db.coreDatabase.unlinkDeletedObjects(),
|
|
472
496
|
},
|
|
@@ -485,25 +509,18 @@ export default ({ context, observability, createInvitationUrl }: IntentResolverO
|
|
|
485
509
|
};
|
|
486
510
|
}
|
|
487
511
|
|
|
488
|
-
|
|
489
|
-
|
|
490
|
-
|
|
491
|
-
|
|
492
|
-
|
|
493
|
-
|
|
494
|
-
|
|
495
|
-
collection.objects.push(Ref.make(object));
|
|
496
|
-
} else {
|
|
497
|
-
// TODO(wittjosiah): Can't add non-echo objects by including in a collection because of types.
|
|
498
|
-
const collection = Obj.make(DataType.Collection, { objects: [Ref.make(object)] });
|
|
499
|
-
space.properties[DataType.Collection.typename] = Ref.make(collection);
|
|
500
|
-
}
|
|
501
|
-
}
|
|
512
|
+
await Effect.gen(function* () {
|
|
513
|
+
yield* Collection.add({
|
|
514
|
+
object,
|
|
515
|
+
target: isSpace(target) ? undefined : target,
|
|
516
|
+
hidden,
|
|
517
|
+
});
|
|
518
|
+
}).pipe(Effect.provide(Database.Service.layer(space.db)), Effect.runPromise);
|
|
502
519
|
|
|
503
520
|
return {
|
|
504
521
|
data: {
|
|
505
|
-
id:
|
|
506
|
-
subject: [
|
|
522
|
+
id: Obj.getDXN(object).toString(),
|
|
523
|
+
subject: [Obj.getDXN(object).toString()],
|
|
507
524
|
object,
|
|
508
525
|
},
|
|
509
526
|
intents: [
|
|
@@ -552,26 +569,26 @@ export default ({ context, observability, createInvitationUrl }: IntentResolverO
|
|
|
552
569
|
const openObjectIds = new Set<string>(layout.active);
|
|
553
570
|
|
|
554
571
|
if (!undo) {
|
|
555
|
-
const parentCollection:
|
|
556
|
-
target ?? space.properties[
|
|
572
|
+
const parentCollection: Collection.Collection =
|
|
573
|
+
target ?? space.properties[Collection.Collection.typename]?.target;
|
|
557
574
|
const nestedObjectsList = await Promise.all(objects.map((obj) => getNestedObjects(obj, resolve)));
|
|
558
575
|
|
|
559
576
|
const deletionData = {
|
|
560
577
|
objects,
|
|
561
578
|
parentCollection,
|
|
562
579
|
indices: objects.map((obj) =>
|
|
563
|
-
Obj.instanceOf(
|
|
580
|
+
Obj.instanceOf(Collection.Collection, parentCollection)
|
|
564
581
|
? parentCollection.objects.findIndex((object) => object.target === obj)
|
|
565
582
|
: -1,
|
|
566
583
|
),
|
|
567
584
|
nestedObjectsList,
|
|
568
585
|
wasActive: objects
|
|
569
586
|
.flatMap((obj, i) => [obj, ...nestedObjectsList[i]])
|
|
570
|
-
.map((obj) =>
|
|
587
|
+
.map((obj) => Obj.getDXN(obj).toString())
|
|
571
588
|
.filter((id) => openObjectIds.has(id)),
|
|
572
589
|
} satisfies SpaceAction.DeletionData;
|
|
573
590
|
|
|
574
|
-
if (Obj.instanceOf(
|
|
591
|
+
if (Obj.instanceOf(Collection.Collection, deletionData.parentCollection)) {
|
|
575
592
|
[...deletionData.indices]
|
|
576
593
|
.sort((a, b) => b - a)
|
|
577
594
|
.forEach((index: number) => {
|
|
@@ -586,16 +603,17 @@ export default ({ context, observability, createInvitationUrl }: IntentResolverO
|
|
|
586
603
|
});
|
|
587
604
|
objects.forEach((obj) => space.db.remove(obj));
|
|
588
605
|
|
|
589
|
-
|
|
590
|
-
|
|
591
|
-
|
|
592
|
-
|
|
593
|
-
|
|
606
|
+
// TODO(wittjosiah): Once we can compose translations outside of react, use count instead.
|
|
607
|
+
// ['deleted label', { ns: meta.id, typename: ['typename label', { ns: typename, count: objects.length }] }]
|
|
608
|
+
const undoMessageLabel: Label =
|
|
609
|
+
objects.length === 1
|
|
610
|
+
? ['object deleted label', { ns: Obj.getTypename(objects[0]) ?? meta.id, defaultValue: 'Object deleted' }]
|
|
611
|
+
: ['objects deleted label', { ns: meta.id }];
|
|
594
612
|
|
|
595
613
|
return {
|
|
596
614
|
undoable: {
|
|
597
615
|
// TODO(ZaymonFC): Pluralize if more than one object.
|
|
598
|
-
message:
|
|
616
|
+
message: undoMessageLabel,
|
|
599
617
|
data: { deletionData },
|
|
600
618
|
},
|
|
601
619
|
intents:
|
|
@@ -613,19 +631,19 @@ export default ({ context, observability, createInvitationUrl }: IntentResolverO
|
|
|
613
631
|
if (
|
|
614
632
|
deletionData?.objects?.length &&
|
|
615
633
|
deletionData.objects.every(Obj.isObject) &&
|
|
616
|
-
Obj.instanceOf(
|
|
634
|
+
Obj.instanceOf(Collection.Collection, deletionData.parentCollection)
|
|
617
635
|
) {
|
|
618
636
|
// Restore the object to the space.
|
|
619
|
-
const restoredObjects = deletionData.objects.map((obj:
|
|
637
|
+
const restoredObjects = deletionData.objects.map((obj: Obj.Any) => space.db.add(obj));
|
|
620
638
|
|
|
621
639
|
// Restore nested objects to the space.
|
|
622
|
-
deletionData.nestedObjectsList.flat().forEach((obj:
|
|
640
|
+
deletionData.nestedObjectsList.flat().forEach((obj: Obj.Any) => {
|
|
623
641
|
space.db.add(obj);
|
|
624
642
|
});
|
|
625
643
|
|
|
626
644
|
deletionData.indices.forEach((index: number, i: number) => {
|
|
627
645
|
if (index !== -1) {
|
|
628
|
-
deletionData.parentCollection.objects.splice(index, 0, Ref.make(restoredObjects[i] as
|
|
646
|
+
deletionData.parentCollection.objects.splice(index, 0, Ref.make(restoredObjects[i] as Obj.Any));
|
|
629
647
|
}
|
|
630
648
|
});
|
|
631
649
|
|
|
@@ -650,9 +668,9 @@ export default ({ context, observability, createInvitationUrl }: IntentResolverO
|
|
|
650
668
|
intents: [
|
|
651
669
|
createIntent(LayoutAction.UpdatePopover, {
|
|
652
670
|
part: 'popover',
|
|
653
|
-
subject:
|
|
671
|
+
subject: OBJECT_RENAME_POPOVER,
|
|
654
672
|
options: {
|
|
655
|
-
anchorId: `dxos.org/ui/${caller}/${
|
|
673
|
+
anchorId: `dxos.org/ui/${caller}/${Obj.getDXN(object).toString()}`,
|
|
656
674
|
props: object,
|
|
657
675
|
},
|
|
658
676
|
}),
|
|
@@ -664,7 +682,6 @@ export default ({ context, observability, createInvitationUrl }: IntentResolverO
|
|
|
664
682
|
resolve: async ({ object, target }) => {
|
|
665
683
|
const space = isSpace(target) ? target : getSpace(target);
|
|
666
684
|
invariant(space, 'Space not found.');
|
|
667
|
-
|
|
668
685
|
const newObject = await cloneObject(object, resolve, space);
|
|
669
686
|
return {
|
|
670
687
|
intents: [createIntent(SpaceAction.AddObject, { object: newObject, target })],
|
|
@@ -681,13 +698,7 @@ export default ({ context, observability, createInvitationUrl }: IntentResolverO
|
|
|
681
698
|
createResolver({
|
|
682
699
|
intent: CollectionAction.Create,
|
|
683
700
|
resolve: async ({ name }) => ({
|
|
684
|
-
data: { object: Obj.make(
|
|
685
|
-
}),
|
|
686
|
-
}),
|
|
687
|
-
createResolver({
|
|
688
|
-
intent: CollectionAction.CreateQueryCollection,
|
|
689
|
-
resolve: async ({ name, typename }) => ({
|
|
690
|
-
data: { object: Obj.make(DataType.QueryCollection, { name, query: { typename } }) },
|
|
701
|
+
data: { object: Obj.make(Collection.Collection, { name, objects: [] }) },
|
|
691
702
|
}),
|
|
692
703
|
}),
|
|
693
704
|
]);
|
|
@@ -4,15 +4,17 @@
|
|
|
4
4
|
|
|
5
5
|
import React from 'react';
|
|
6
6
|
|
|
7
|
-
import { Capabilities, contributes
|
|
7
|
+
import { Capabilities, contributes } from '@dxos/app-framework';
|
|
8
|
+
import { useCapability } from '@dxos/app-framework/react';
|
|
8
9
|
|
|
9
|
-
import { SpaceCapabilities } from './capabilities';
|
|
10
10
|
import { AwaitingObject } from '../components';
|
|
11
|
-
import {
|
|
11
|
+
import { meta } from '../meta';
|
|
12
|
+
|
|
13
|
+
import { SpaceCapabilities } from './capabilities';
|
|
12
14
|
|
|
13
15
|
export default () =>
|
|
14
16
|
contributes(Capabilities.ReactRoot, {
|
|
15
|
-
id:
|
|
17
|
+
id: meta.id,
|
|
16
18
|
root: () => {
|
|
17
19
|
const state = useCapability(SpaceCapabilities.State);
|
|
18
20
|
return state.awaiting ? <AwaitingObject id={state.awaiting} /> : null;
|