@dxos/plugin-space 0.8.4-main.5ea62a8 → 0.8.4-main.66e292d
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/ObjectDetailsPanel-ACGHWPDX.mjs +141 -0
- package/dist/lib/browser/ObjectDetailsPanel-ACGHWPDX.mjs.map +7 -0
- package/dist/lib/browser/ObjectSettings-U3IH7BMV.mjs +144 -0
- package/dist/lib/browser/ObjectSettings-U3IH7BMV.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-HABMCWAI.mjs +517 -0
- package/dist/lib/browser/app-graph-builder-HABMCWAI.mjs.map +7 -0
- package/dist/lib/browser/{app-graph-serializer-3A6KBYWT.mjs → app-graph-serializer-G3VFEGTN.mjs} +19 -19
- package/dist/lib/browser/app-graph-serializer-G3VFEGTN.mjs.map +7 -0
- package/dist/lib/browser/chunk-6A3NWBB6.mjs +392 -0
- package/dist/lib/browser/chunk-6A3NWBB6.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-DCY3W36E.mjs → chunk-GJOZILGC.mjs} +210 -142
- package/dist/lib/browser/chunk-GJOZILGC.mjs.map +7 -0
- package/dist/lib/browser/{chunk-J6YZG77T.mjs → chunk-KCZ527AM.mjs} +641 -500
- package/dist/lib/browser/chunk-KCZ527AM.mjs.map +7 -0
- package/dist/lib/browser/{chunk-ELJDGQTO.mjs → chunk-P25R3AOK.mjs} +35 -5
- package/dist/lib/browser/chunk-P25R3AOK.mjs.map +7 -0
- package/dist/lib/browser/{chunk-WAXS2ZVX.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/{identity-created-T6ZNVE7S.mjs → identity-created-NAXTPQXE.mjs} +5 -5
- package/dist/lib/browser/identity-created-NAXTPQXE.mjs.map +7 -0
- package/dist/lib/browser/index.mjs +88 -131
- package/dist/lib/browser/index.mjs.map +3 -3
- package/dist/lib/browser/{intent-resolver-7E3IZIJS.mjs → intent-resolver-RZEWNJ2K.mjs} +105 -100
- package/dist/lib/browser/intent-resolver-RZEWNJ2K.mjs.map +7 -0
- package/dist/lib/browser/meta.json +1 -1
- package/dist/lib/browser/react-root-JCRD74GI.mjs +30 -0
- package/dist/lib/browser/react-root-JCRD74GI.mjs.map +7 -0
- package/dist/lib/browser/{react-surface-GL4CE2F4.mjs → react-surface-VOETEAG3.mjs} +91 -111
- package/dist/lib/browser/react-surface-VOETEAG3.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-B6MMHLPS.mjs → settings-TRLI52I5.mjs} +5 -5
- package/dist/lib/browser/{settings-B6MMHLPS.mjs.map → settings-TRLI52I5.mjs.map} +1 -1
- package/dist/lib/browser/{spaces-ready-QVABOCO3.mjs → spaces-ready-OHGCWZHQ.mjs} +22 -15
- package/dist/lib/browser/spaces-ready-OHGCWZHQ.mjs.map +7 -0
- package/dist/lib/browser/{state-2RGW7FQG.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/ObjectDetailsPanel-6OFTT3GG.mjs +142 -0
- package/dist/lib/node-esm/ObjectDetailsPanel-6OFTT3GG.mjs.map +7 -0
- package/dist/lib/node-esm/ObjectSettings-YXPJQMJ5.mjs +145 -0
- package/dist/lib/node-esm/ObjectSettings-YXPJQMJ5.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-T6VJKIOA.mjs +518 -0
- package/dist/lib/node-esm/app-graph-builder-T6VJKIOA.mjs.map +7 -0
- package/dist/lib/node-esm/{app-graph-serializer-M45TH5LR.mjs → app-graph-serializer-2NLWWFUB.mjs} +19 -19
- package/dist/lib/node-esm/app-graph-serializer-2NLWWFUB.mjs.map +7 -0
- package/dist/lib/node-esm/{chunk-Q6AAQLQG.mjs → chunk-7EV4SN47.mjs} +34 -5
- package/dist/lib/node-esm/chunk-7EV4SN47.mjs.map +7 -0
- package/dist/lib/node-esm/{chunk-HYIZVPOA.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-AUQ3SKL2.mjs → chunk-I6FZP42D.mjs} +210 -142
- package/dist/lib/node-esm/chunk-I6FZP42D.mjs.map +7 -0
- package/dist/lib/node-esm/{chunk-ZCEH2VYE.mjs → chunk-JAMGJUFU.mjs} +641 -500
- package/dist/lib/node-esm/chunk-JAMGJUFU.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-X34VDVMY.mjs +393 -0
- package/dist/lib/node-esm/chunk-X34VDVMY.mjs.map +7 -0
- package/dist/lib/node-esm/{identity-created-AL7NNCKH.mjs → identity-created-OXLKCJE3.mjs} +5 -5
- package/dist/lib/node-esm/identity-created-OXLKCJE3.mjs.map +7 -0
- package/dist/lib/node-esm/index.mjs +88 -131
- package/dist/lib/node-esm/index.mjs.map +3 -3
- package/dist/lib/node-esm/{intent-resolver-UVO4MKWX.mjs → intent-resolver-4PHJWDXW.mjs} +105 -100
- package/dist/lib/node-esm/intent-resolver-4PHJWDXW.mjs.map +7 -0
- package/dist/lib/node-esm/meta.json +1 -1
- package/dist/lib/node-esm/{react-root-5EKYI66P.mjs → react-root-O5I5CDJ7.mjs} +13 -12
- package/dist/lib/node-esm/react-root-O5I5CDJ7.mjs.map +7 -0
- package/dist/lib/node-esm/{react-surface-IOC6YSVQ.mjs → react-surface-J3XDMU2D.mjs} +91 -111
- package/dist/lib/node-esm/react-surface-J3XDMU2D.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-IOFU6EAS.mjs → settings-MNQTKHL7.mjs} +5 -5
- package/dist/lib/node-esm/{settings-IOFU6EAS.mjs.map → settings-MNQTKHL7.mjs.map} +1 -1
- package/dist/lib/node-esm/{spaces-ready-MS6GHPFR.mjs → spaces-ready-ZPU24DA2.mjs} +22 -15
- package/dist/lib/node-esm/spaces-ready-ZPU24DA2.mjs.map +7 -0
- package/dist/lib/node-esm/{state-7VBVBGNS.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.map +1 -1
- package/dist/types/src/capabilities/capabilities.d.ts +13 -7
- package/dist/types/src/capabilities/capabilities.d.ts.map +1 -1
- package/dist/types/src/capabilities/index.d.ts +1 -1
- package/dist/types/src/capabilities/index.d.ts.map +1 -1
- package/dist/types/src/capabilities/intent-resolver.d.ts.map +1 -1
- package/dist/types/src/capabilities/react-root.d.ts.map +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/spaces-ready.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 +1 -1
- package/dist/types/src/components/CreateDialog/CreateObjectDialog.d.ts.map +1 -1
- package/dist/types/src/components/CreateDialog/CreateObjectDialog.stories.d.ts +218 -215
- package/dist/types/src/components/CreateDialog/CreateObjectDialog.stories.d.ts.map +1 -1
- package/dist/types/src/components/CreateDialog/CreateObjectPanel.d.ts +16 -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/MembersContainer.d.ts.map +1 -0
- package/dist/types/src/components/MembersContainer/MembersContainer.stories.d.ts +1591 -0
- package/dist/types/src/components/{MembersContainer.stories.d.ts.map → MembersContainer/MembersContainer.stories.d.ts.map} +1 -1
- 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/ObjectDetailsPanel/ObjectDetailsPanel.d.ts +9 -0
- package/dist/types/src/components/ObjectDetailsPanel/ObjectDetailsPanel.d.ts.map +1 -0
- package/dist/types/src/components/ObjectDetailsPanel/ObjectForm.d.ts +10 -0
- package/dist/types/src/components/ObjectDetailsPanel/ObjectForm.d.ts.map +1 -0
- package/dist/types/src/components/ObjectDetailsPanel/index.d.ts +3 -0
- package/dist/types/src/components/ObjectDetailsPanel/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/ObjectSettings/AdvancedObjectSettings.d.ts.map +1 -1
- package/dist/types/src/components/ObjectSettings/BaseObjectSettings.d.ts +2 -2
- package/dist/types/src/components/ObjectSettings/BaseObjectSettings.d.ts.map +1 -1
- package/dist/types/src/components/ObjectSettings/BaseObjectSettings.stories.d.ts +1424 -0
- package/dist/types/src/components/ObjectSettings/BaseObjectSettings.stories.d.ts.map +1 -0
- package/dist/types/src/components/ObjectSettings/ForeignKeys.d.ts +3 -3
- package/dist/types/src/components/ObjectSettings/ForeignKeys.d.ts.map +1 -1
- package/dist/types/src/components/ObjectSettings/ObjectSettingsContainer.d.ts.map +1 -1
- package/dist/types/src/components/ObjectSettings/index.d.ts +2 -1
- package/dist/types/src/components/ObjectSettings/index.d.ts.map +1 -1
- 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/{MembersContainer.stories.d.ts → RecordArticle.stories.d.ts} +219 -216
- 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.stories.d.ts → SpacePresence/SpacePresence.stories.d.ts} +220 -217
- package/dist/types/src/components/{SpacePresence.stories.d.ts.map → SpacePresence/SpacePresence.stories.d.ts.map} +1 -1
- 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.map +1 -1
- package/dist/types/src/components/SpaceSettings/SpaceSettingsContainer.stories.d.ts +218 -215
- 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 +219 -216
- 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 -17
- 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 +8 -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 +1 -1
- 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 +24 -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 +82 -142
- package/dist/types/src/types/types.d.ts.map +1 -1
- package/dist/types/src/util.d.ts +21 -34
- package/dist/types/src/util.d.ts.map +1 -1
- package/dist/types/tsconfig.tsbuildinfo +1 -1
- package/package.json +68 -59
- package/src/SpacePlugin.ts +181 -215
- package/src/capabilities/app-graph-builder.ts +205 -267
- package/src/capabilities/app-graph-serializer.ts +12 -12
- package/src/capabilities/capabilities.ts +26 -16
- package/src/capabilities/identity-created.ts +2 -2
- package/src/capabilities/index.ts +1 -1
- package/src/capabilities/intent-resolver.ts +78 -75
- package/src/capabilities/react-root.tsx +4 -3
- package/src/capabilities/react-surface.tsx +95 -145
- package/src/capabilities/repair.ts +57 -0
- package/src/capabilities/spaces-ready.ts +15 -6
- package/src/capabilities/state.ts +2 -2
- 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 +11 -11
- package/src/components/CreateDialog/CreateObjectDialog.tsx +63 -43
- package/src/components/CreateDialog/CreateObjectPanel.tsx +38 -31
- package/src/components/CreateDialog/CreateSpaceDialog.tsx +30 -11
- package/src/components/{JoinDialog.tsx → JoinDialog/JoinDialog.tsx} +26 -10
- package/src/components/JoinDialog/index.ts +5 -0
- package/src/components/{MembersContainer.stories.tsx → MembersContainer/MembersContainer.stories.tsx} +7 -6
- package/src/components/{MembersContainer.tsx → MembersContainer/MembersContainer.tsx} +16 -14
- package/src/components/MembersContainer/index.ts +5 -0
- package/src/components/MenuFooter.tsx +2 -2
- package/src/components/ObjectDetailsPanel/ObjectDetailsPanel.tsx +51 -0
- package/src/components/ObjectDetailsPanel/ObjectForm.tsx +72 -0
- package/src/components/ObjectDetailsPanel/index.ts +7 -0
- package/src/components/{PopoverRenameObject.tsx → ObjectRenamePopover/ObjectRenamePopover.tsx} +6 -6
- package/src/components/ObjectRenamePopover/index.ts +5 -0
- package/src/components/ObjectSettings/AdvancedObjectSettings.tsx +6 -7
- package/src/components/ObjectSettings/BaseObjectSettings.stories.tsx +63 -0
- package/src/components/ObjectSettings/BaseObjectSettings.tsx +90 -26
- package/src/components/ObjectSettings/ForeignKeys.tsx +8 -8
- package/src/components/ObjectSettings/ObjectSettingsContainer.tsx +4 -3
- package/src/components/ObjectSettings/index.ts +3 -1
- package/src/components/RecordArticle.stories.tsx +115 -0
- package/src/components/RecordArticle.tsx +114 -0
- package/src/components/SchemaContainer.tsx +24 -27
- package/src/components/SpacePluginSettings.tsx +10 -4
- package/src/components/{SpacePresence.stories.tsx → SpacePresence/SpacePresence.stories.tsx} +23 -25
- package/src/components/{SpacePresence.tsx → SpacePresence/SpacePresence.tsx} +16 -11
- 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 +9 -4
- package/src/components/SpaceSettings/SpaceSettingsContainer.tsx +63 -23
- package/src/components/SyncStatus/InlineSyncStatus.tsx +8 -8
- package/src/components/SyncStatus/SyncStatus.stories.tsx +4 -5
- package/src/components/SyncStatus/SyncStatus.tsx +107 -11
- package/src/components/ViewEditor.tsx +57 -23
- package/src/components/index.ts +7 -8
- package/src/events.ts +6 -6
- package/src/helpers/index.ts +5 -0
- package/src/helpers/query.test.ts +24 -0
- package/src/helpers/query.ts +158 -0
- package/src/hooks/index.ts +1 -0
- package/src/hooks/useActiveSpace.ts +2 -1
- package/src/hooks/useInputSurfaceLookup.tsx +8 -3
- package/src/hooks/usePath.ts +1 -1
- package/src/hooks/useTypeOptions.ts +27 -0
- package/src/index.ts +1 -0
- package/src/meta.ts +6 -3
- package/src/translations.ts +68 -58
- package/src/types/form.ts +75 -0
- package/src/types/index.ts +1 -0
- package/src/types/types.ts +44 -50
- package/src/util.tsx +216 -143
- package/dist/lib/browser/CollectionMain-D2B75XBS.mjs.map +0 -7
- package/dist/lib/browser/ObjectDetailsPanel-SY6FYTYC.mjs +0 -88
- package/dist/lib/browser/ObjectDetailsPanel-SY6FYTYC.mjs.map +0 -7
- package/dist/lib/browser/RecordMain-TEBGAVSL.mjs +0 -68
- package/dist/lib/browser/RecordMain-TEBGAVSL.mjs.map +0 -7
- package/dist/lib/browser/app-graph-builder-FLF7XMQO.mjs +0 -516
- package/dist/lib/browser/app-graph-builder-FLF7XMQO.mjs.map +0 -7
- package/dist/lib/browser/app-graph-serializer-3A6KBYWT.mjs.map +0 -7
- package/dist/lib/browser/chunk-CBYL62HG.mjs +0 -19
- package/dist/lib/browser/chunk-CBYL62HG.mjs.map +0 -7
- package/dist/lib/browser/chunk-DCY3W36E.mjs.map +0 -7
- package/dist/lib/browser/chunk-ELJDGQTO.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-J6YZG77T.mjs.map +0 -7
- package/dist/lib/browser/chunk-RQVV4XVF.mjs +0 -343
- package/dist/lib/browser/chunk-RQVV4XVF.mjs.map +0 -7
- package/dist/lib/browser/chunk-TUQZO5P4.mjs +0 -20
- package/dist/lib/browser/chunk-TUQZO5P4.mjs.map +0 -7
- package/dist/lib/browser/chunk-WAXS2ZVX.mjs.map +0 -7
- package/dist/lib/browser/identity-created-T6ZNVE7S.mjs.map +0 -7
- package/dist/lib/browser/intent-resolver-7E3IZIJS.mjs.map +0 -7
- package/dist/lib/browser/react-root-RWMT2RCK.mjs +0 -29
- package/dist/lib/browser/react-root-RWMT2RCK.mjs.map +0 -7
- package/dist/lib/browser/react-surface-GL4CE2F4.mjs.map +0 -7
- package/dist/lib/browser/schema-defs-YDPFZELA.mjs +0 -26
- package/dist/lib/browser/schema-defs-YDPFZELA.mjs.map +0 -7
- package/dist/lib/browser/spaces-ready-QVABOCO3.mjs.map +0 -7
- package/dist/lib/browser/state-2RGW7FQG.mjs.map +0 -7
- package/dist/lib/node-esm/CollectionMain-ZJIFCWKZ.mjs.map +0 -7
- package/dist/lib/node-esm/ObjectDetailsPanel-3MYLTMXN.mjs +0 -89
- package/dist/lib/node-esm/ObjectDetailsPanel-3MYLTMXN.mjs.map +0 -7
- package/dist/lib/node-esm/RecordMain-WLYJMYER.mjs +0 -70
- package/dist/lib/node-esm/RecordMain-WLYJMYER.mjs.map +0 -7
- package/dist/lib/node-esm/app-graph-builder-D5YPOJS5.mjs +0 -517
- package/dist/lib/node-esm/app-graph-builder-D5YPOJS5.mjs.map +0 -7
- package/dist/lib/node-esm/app-graph-serializer-M45TH5LR.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-AUQ3SKL2.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-FJZNSJC4.mjs +0 -20
- package/dist/lib/node-esm/chunk-FJZNSJC4.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-HC677WUJ.mjs +0 -21
- package/dist/lib/node-esm/chunk-HC677WUJ.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-HYIZVPOA.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-Q6AAQLQG.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-WKQTO37U.mjs +0 -344
- package/dist/lib/node-esm/chunk-WKQTO37U.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-ZCEH2VYE.mjs.map +0 -7
- package/dist/lib/node-esm/identity-created-AL7NNCKH.mjs.map +0 -7
- package/dist/lib/node-esm/intent-resolver-UVO4MKWX.mjs.map +0 -7
- package/dist/lib/node-esm/react-root-5EKYI66P.mjs.map +0 -7
- package/dist/lib/node-esm/react-surface-IOC6YSVQ.mjs.map +0 -7
- package/dist/lib/node-esm/schema-defs-OYBCWKAS.mjs +0 -27
- package/dist/lib/node-esm/schema-defs-OYBCWKAS.mjs.map +0 -7
- package/dist/lib/node-esm/spaces-ready-MS6GHPFR.mjs.map +0 -7
- package/dist/lib/node-esm/state-7VBVBGNS.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/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/ObjectDetailsPanel.d.ts +0 -9
- package/dist/types/src/components/ObjectDetailsPanel.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/RecordMain.d.ts +0 -7
- package/dist/types/src/components/RecordMain.d.ts.map +0 -1
- package/dist/types/src/components/SpacePresence.d.ts.map +0 -1
- package/src/capabilities/schema-defs.ts +0 -31
- package/src/components/ObjectDetailsPanel.tsx +0 -77
- package/src/components/PersistenceStatus.tsx +0 -83
- package/src/components/RecordMain.tsx +0 -43
- /package/dist/types/src/components/{MembersContainer.d.ts → MembersContainer/MembersContainer.d.ts} +0 -0
|
@@ -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-SSJ7PULS.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 { type Entity, 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<Entity.Unknown>\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: Entity.Unknown }) => {\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: Entity.Unknown[] = [];\n\n // TODO(burdon): Change Person => Organization to relations.\n if (options.references) {\n const getReferences = (obj: Entity.Unknown): 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: Relation.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,518 @@
|
|
|
1
|
+
import { createRequire } from 'node:module';const require = createRequire(import.meta.url);
|
|
2
|
+
import {
|
|
3
|
+
getActiveSpace
|
|
4
|
+
} from "./chunk-7EV4SN47.mjs";
|
|
5
|
+
import {
|
|
6
|
+
SpaceCapabilities
|
|
7
|
+
} from "./chunk-WWGV5FJM.mjs";
|
|
8
|
+
import {
|
|
9
|
+
SHARED,
|
|
10
|
+
SPACES,
|
|
11
|
+
atomFromQuery,
|
|
12
|
+
constructObjectActions,
|
|
13
|
+
constructSpaceActions,
|
|
14
|
+
constructSpaceNode,
|
|
15
|
+
createObjectNode,
|
|
16
|
+
createStaticSchemaActions,
|
|
17
|
+
createStaticSchemaNode
|
|
18
|
+
} from "./chunk-I6FZP42D.mjs";
|
|
19
|
+
import {
|
|
20
|
+
SPACE_TYPE,
|
|
21
|
+
SpaceAction
|
|
22
|
+
} from "./chunk-X34VDVMY.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, 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, View, ViewAnnotation, 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 DXN.
|
|
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
|
+
resolver: (id) => {
|
|
286
|
+
let query;
|
|
287
|
+
return Atom.make((get) => {
|
|
288
|
+
const client = context.getCapability(ClientCapabilities.Client);
|
|
289
|
+
const dxn = DXN.tryParse(id)?.asEchoDXN();
|
|
290
|
+
if (!dxn || !dxn.spaceId) {
|
|
291
|
+
return null;
|
|
292
|
+
}
|
|
293
|
+
const space = client.spaces.get(dxn.spaceId);
|
|
294
|
+
if (!space) {
|
|
295
|
+
return null;
|
|
296
|
+
}
|
|
297
|
+
if (!query) {
|
|
298
|
+
query = space.db.query(Filter.ids(dxn.echoId));
|
|
299
|
+
}
|
|
300
|
+
const object = get(atomFromQuery(query)).at(0);
|
|
301
|
+
if (!Obj.isObject(object)) {
|
|
302
|
+
return null;
|
|
303
|
+
}
|
|
304
|
+
return createObjectNode({
|
|
305
|
+
object,
|
|
306
|
+
space,
|
|
307
|
+
resolve: resolve(get),
|
|
308
|
+
disposition: "hidden"
|
|
309
|
+
});
|
|
310
|
+
});
|
|
311
|
+
}
|
|
312
|
+
}),
|
|
313
|
+
// Create object nodes for schema-based system collections.
|
|
314
|
+
createExtension({
|
|
315
|
+
id: `${meta.id}/system-collections`,
|
|
316
|
+
connector: (node) => {
|
|
317
|
+
const client = context.getCapability(ClientCapabilities.Client);
|
|
318
|
+
let query;
|
|
319
|
+
return Atom.make((get) => Function.pipe(get(node), Option.flatMap((node2) => Obj.instanceOf(Collection.Managed, node2.data) ? Option.some(node2.data) : Option.none()), Option.flatMap((collection) => {
|
|
320
|
+
const space = getSpace(collection);
|
|
321
|
+
const schema = client.graph.schemaRegistry.schemas.find((schema2) => Type.getTypename(schema2) === collection.key);
|
|
322
|
+
return space && schema ? Option.some({
|
|
323
|
+
space,
|
|
324
|
+
schema
|
|
325
|
+
}) : Option.none();
|
|
326
|
+
}), Option.map(({ space, schema }) => {
|
|
327
|
+
if (!query) {
|
|
328
|
+
query = space.db.query(Filter.type(schema));
|
|
329
|
+
}
|
|
330
|
+
return get(atomFromQuery(query)).map((object) => createObjectNode({
|
|
331
|
+
object,
|
|
332
|
+
space,
|
|
333
|
+
managedCollectionChild: true,
|
|
334
|
+
resolve: resolve(get)
|
|
335
|
+
})).filter(isNonNullable);
|
|
336
|
+
}), Option.getOrElse(() => [])));
|
|
337
|
+
}
|
|
338
|
+
}),
|
|
339
|
+
// Create branch nodes for static schema record types.
|
|
340
|
+
createExtension({
|
|
341
|
+
id: `${meta.id}/static-schemas`,
|
|
342
|
+
connector: (node) => {
|
|
343
|
+
const client = context.getCapability(ClientCapabilities.Client);
|
|
344
|
+
return Atom.make((get) => Function.pipe(get(node), Option.flatMap((node2) => Obj.instanceOf(Collection.Managed, node2.data) && node2.data.key === Type.getTypename(Type.PersistentType) ? Option.some(node2.data) : Option.none()), Option.flatMap((collection) => {
|
|
345
|
+
const space = getSpace(collection);
|
|
346
|
+
return space?.properties.staticRecords ? Option.some(space) : Option.none();
|
|
347
|
+
}), Option.map((space) => {
|
|
348
|
+
return get(atomFromSignal(() => space.properties.staticRecords ?? [])).map((typename) => client.graph.schemaRegistry.schemas.find((schema) => Type.getTypename(schema) === typename)).filter(isNonNullable).map((schema) => createStaticSchemaNode({
|
|
349
|
+
schema,
|
|
350
|
+
space
|
|
351
|
+
}));
|
|
352
|
+
}), Option.getOrElse(() => [])));
|
|
353
|
+
}
|
|
354
|
+
}),
|
|
355
|
+
// Create actions for static schema record types.
|
|
356
|
+
createExtension({
|
|
357
|
+
id: `${meta.id}/static-schema-actions`,
|
|
358
|
+
actions: (node) => {
|
|
359
|
+
let query;
|
|
360
|
+
return Atom.make((get) => {
|
|
361
|
+
const schemas = get(context.capabilities(ClientCapabilities.Schema)).flat().filter((schema) => ViewAnnotation.get(schema).pipe(Option.getOrElse(() => false)));
|
|
362
|
+
const filter2 = Filter.or(...schemas.map((schema) => Filter.type(schema)));
|
|
363
|
+
return Function.pipe(get(node), Option.flatMap((node2) => {
|
|
364
|
+
const space = isSpace(node2.properties.space) ? node2.properties.space : void 0;
|
|
365
|
+
return space && Schema.isSchema(node2.data) ? Option.some({
|
|
366
|
+
space,
|
|
367
|
+
schema: node2.data
|
|
368
|
+
}) : Option.none();
|
|
369
|
+
}), Option.map(({ space, schema }) => {
|
|
370
|
+
if (!query) {
|
|
371
|
+
query = space.db.query(filter2);
|
|
372
|
+
}
|
|
373
|
+
const objects = get(atomFromQuery(query));
|
|
374
|
+
const filteredViews = get(atomFromSignal(() => objects.filter((viewObject) => getTypenameFromQuery(viewObject.view.target?.query.ast) === Type.getTypename(schema))));
|
|
375
|
+
const deletable = filteredViews.length === 0;
|
|
376
|
+
const [dispatcher] = get(context.capabilities(Capabilities.IntentDispatcher));
|
|
377
|
+
if (!dispatcher) {
|
|
378
|
+
return [];
|
|
379
|
+
}
|
|
380
|
+
return createStaticSchemaActions({
|
|
381
|
+
schema,
|
|
382
|
+
space,
|
|
383
|
+
dispatch: dispatcher.dispatchPromise,
|
|
384
|
+
deletable
|
|
385
|
+
});
|
|
386
|
+
}), Option.getOrElse(() => []));
|
|
387
|
+
});
|
|
388
|
+
}
|
|
389
|
+
}),
|
|
390
|
+
// Create nodes for views of record types.
|
|
391
|
+
createExtension({
|
|
392
|
+
id: `${meta.id}/schema-views`,
|
|
393
|
+
connector: (node) => {
|
|
394
|
+
let query;
|
|
395
|
+
return Atom.make((get) => {
|
|
396
|
+
const schemas = get(context.capabilities(ClientCapabilities.Schema)).flat().filter((schema) => ViewAnnotation.get(schema).pipe(Option.getOrElse(() => false)));
|
|
397
|
+
const filter2 = Filter.or(...schemas.map((schema) => Filter.type(schema)));
|
|
398
|
+
return Function.pipe(get(node), Option.flatMap((node2) => {
|
|
399
|
+
const space = getSpace(node2.data) ?? (isSpace(node2.properties.space) ? node2.properties.space : void 0);
|
|
400
|
+
return space && (Obj.instanceOf(Type.PersistentType, node2.data) || Schema.isSchema(node2.data)) ? Option.some({
|
|
401
|
+
space,
|
|
402
|
+
schema: node2.data
|
|
403
|
+
}) : Option.none();
|
|
404
|
+
}), Option.map(({ space, schema }) => {
|
|
405
|
+
if (!query) {
|
|
406
|
+
query = space.db.query(filter2);
|
|
407
|
+
}
|
|
408
|
+
const typename = Schema.isSchema(schema) ? Type.getTypename(schema) : schema.typename;
|
|
409
|
+
return get(atomFromQuery(query)).filter((object) => get(atomFromSignal(() => getTypenameFromQuery(object.view.target?.query.ast) === typename))).map((object) => get(atomFromSignal(() => createObjectNode({
|
|
410
|
+
object,
|
|
411
|
+
space,
|
|
412
|
+
resolve: resolve(get),
|
|
413
|
+
droppable: false
|
|
414
|
+
})))).filter(isNonNullable);
|
|
415
|
+
}), Option.getOrElse(() => []));
|
|
416
|
+
});
|
|
417
|
+
}
|
|
418
|
+
}),
|
|
419
|
+
// Create collection actions and action groups.
|
|
420
|
+
createExtension({
|
|
421
|
+
id: `${meta.id}/object-actions`,
|
|
422
|
+
actions: (node) => {
|
|
423
|
+
let query;
|
|
424
|
+
return Atom.make((get) => {
|
|
425
|
+
const schemas = get(context.capabilities(ClientCapabilities.Schema)).flat().filter((schema) => ViewAnnotation.get(schema).pipe(Option.getOrElse(() => false)));
|
|
426
|
+
const filter2 = Filter.or(...schemas.map((schema) => Filter.type(schema)));
|
|
427
|
+
return Function.pipe(get(node), Option.flatMap((node2) => {
|
|
428
|
+
const space = getSpace(node2.data);
|
|
429
|
+
return space && Obj.isObject(node2.data) && Obj.getTypename(node2.data) === node2.type ? Option.some({
|
|
430
|
+
space,
|
|
431
|
+
object: node2.data
|
|
432
|
+
}) : Option.none();
|
|
433
|
+
}), Option.flatMap(({ space, object }) => {
|
|
434
|
+
const isSchema2 = Obj.instanceOf(Type.PersistentType, object);
|
|
435
|
+
if (!query && isSchema2) {
|
|
436
|
+
query = space.db.query(filter2);
|
|
437
|
+
}
|
|
438
|
+
let deletable = !isSchema2 && // Don't allow system collections to be deleted.
|
|
439
|
+
!Obj.instanceOf(Collection.Managed, object);
|
|
440
|
+
if (isSchema2 && query) {
|
|
441
|
+
const objects = get(atomFromQuery(query));
|
|
442
|
+
const filteredViews = get(atomFromSignal(() => objects.filter((viewObject) => getTypenameFromQuery(viewObject.view.target?.query.ast) === object.typename)));
|
|
443
|
+
deletable = filteredViews.length === 0;
|
|
444
|
+
}
|
|
445
|
+
const [dispatcher] = get(context.capabilities(Capabilities.IntentDispatcher));
|
|
446
|
+
const [appGraph] = get(context.capabilities(Capabilities.AppGraph));
|
|
447
|
+
const [state] = get(context.capabilities(SpaceCapabilities.State));
|
|
448
|
+
if (!dispatcher || !appGraph || !state) {
|
|
449
|
+
return Option.none();
|
|
450
|
+
} else {
|
|
451
|
+
return Option.some({
|
|
452
|
+
object,
|
|
453
|
+
graph: appGraph.graph,
|
|
454
|
+
dispatch: dispatcher.dispatchPromise,
|
|
455
|
+
resolve: resolve(get),
|
|
456
|
+
deletable,
|
|
457
|
+
navigable: get(atomFromSignal(() => state.navigableCollections))
|
|
458
|
+
});
|
|
459
|
+
}
|
|
460
|
+
}), Option.map((params) => constructObjectActions(params)), Option.getOrElse(() => []));
|
|
461
|
+
});
|
|
462
|
+
}
|
|
463
|
+
}),
|
|
464
|
+
// View selected objects.
|
|
465
|
+
createExtension({
|
|
466
|
+
id: `${meta.id}/selected-objects`,
|
|
467
|
+
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) => [
|
|
468
|
+
{
|
|
469
|
+
id: [
|
|
470
|
+
node2.id,
|
|
471
|
+
"selected-objects"
|
|
472
|
+
].join(ATTENDABLE_PATH_SEPARATOR),
|
|
473
|
+
type: PLANK_COMPANION_TYPE,
|
|
474
|
+
data: "selected-objects",
|
|
475
|
+
properties: {
|
|
476
|
+
label: [
|
|
477
|
+
"companion selected objects label",
|
|
478
|
+
{
|
|
479
|
+
ns: meta.id
|
|
480
|
+
}
|
|
481
|
+
],
|
|
482
|
+
icon: "ph--tree-view--regular",
|
|
483
|
+
disposition: "hidden"
|
|
484
|
+
}
|
|
485
|
+
}
|
|
486
|
+
]), Option.getOrElse(() => [])))
|
|
487
|
+
}),
|
|
488
|
+
// Object settings plank companion.
|
|
489
|
+
createExtension({
|
|
490
|
+
id: `${meta.id}/settings`,
|
|
491
|
+
connector: (node) => Atom.make((get) => Function.pipe(get(node), Option.flatMap((node2) => Obj.isObject(node2.data) ? Option.some(node2) : Option.none()), Option.map((node2) => [
|
|
492
|
+
{
|
|
493
|
+
id: [
|
|
494
|
+
node2.id,
|
|
495
|
+
"settings"
|
|
496
|
+
].join(ATTENDABLE_PATH_SEPARATOR),
|
|
497
|
+
type: PLANK_COMPANION_TYPE,
|
|
498
|
+
data: "settings",
|
|
499
|
+
properties: {
|
|
500
|
+
label: [
|
|
501
|
+
"object settings label",
|
|
502
|
+
{
|
|
503
|
+
ns: meta.id
|
|
504
|
+
}
|
|
505
|
+
],
|
|
506
|
+
icon: "ph--sliders--regular",
|
|
507
|
+
disposition: "hidden",
|
|
508
|
+
position: "fallback"
|
|
509
|
+
}
|
|
510
|
+
}
|
|
511
|
+
]), Option.getOrElse(() => [])))
|
|
512
|
+
})
|
|
513
|
+
]);
|
|
514
|
+
});
|
|
515
|
+
export {
|
|
516
|
+
app_graph_builder_default as default
|
|
517
|
+
};
|
|
518
|
+
//# sourceMappingURL=app-graph-builder-T6VJKIOA.mjs.map
|