@dxos/plugin-space 0.8.4-main.e098934 → 0.8.4-main.e8ec1fe
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-2BRUBHP6.mjs +141 -0
- package/dist/lib/browser/ObjectDetailsPanel-2BRUBHP6.mjs.map +7 -0
- package/dist/lib/browser/ObjectSettings-5LLWCVEK.mjs +144 -0
- package/dist/lib/browser/ObjectSettings-5LLWCVEK.mjs.map +7 -0
- package/dist/lib/browser/RecordArticle-SXDRWTTU.mjs +116 -0
- package/dist/lib/browser/RecordArticle-SXDRWTTU.mjs.map +7 -0
- package/dist/lib/browser/{app-graph-builder-AFC6PNAB.mjs → app-graph-builder-DTM7BJ6D.mjs} +107 -96
- package/dist/lib/browser/app-graph-builder-DTM7BJ6D.mjs.map +7 -0
- package/dist/lib/browser/{app-graph-serializer-Q7QG4EKW.mjs → app-graph-serializer-TIKXF43P.mjs} +19 -19
- package/dist/lib/browser/app-graph-serializer-TIKXF43P.mjs.map +7 -0
- package/dist/lib/browser/chunk-AFUOMLX6.mjs +167 -0
- package/dist/lib/browser/chunk-AFUOMLX6.mjs.map +7 -0
- package/dist/lib/browser/{chunk-6GRF7NEF.mjs → chunk-CKACGS7T.mjs} +553 -475
- package/dist/lib/browser/chunk-CKACGS7T.mjs.map +7 -0
- package/dist/lib/browser/chunk-K5J7ZB5P.mjs +20 -0
- package/dist/lib/browser/chunk-K5J7ZB5P.mjs.map +7 -0
- package/dist/lib/browser/{chunk-S33AYKSS.mjs → chunk-KFUMADZF.mjs} +135 -62
- package/dist/lib/browser/chunk-KFUMADZF.mjs.map +7 -0
- package/dist/lib/browser/{chunk-WZYRDFW7.mjs → chunk-VGKOXAPE.mjs} +26 -13
- package/dist/lib/browser/chunk-VGKOXAPE.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-URST7EEN.mjs → chunk-ZQMSGD5J.mjs} +35 -19
- package/dist/lib/browser/chunk-ZQMSGD5J.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 -70
- package/dist/lib/browser/index.mjs.map +3 -3
- package/dist/lib/browser/{intent-resolver-CO262Q44.mjs → intent-resolver-3FNTO3VW.mjs} +89 -76
- package/dist/lib/browser/intent-resolver-3FNTO3VW.mjs.map +7 -0
- package/dist/lib/browser/meta.json +1 -1
- package/dist/lib/browser/react-root-Q7VBWBES.mjs +30 -0
- package/dist/lib/browser/react-root-Q7VBWBES.mjs.map +7 -0
- package/dist/lib/browser/{react-surface-TPUOK2LC.mjs → react-surface-TTHS332A.mjs} +71 -105
- package/dist/lib/browser/react-surface-TTHS332A.mjs.map +7 -0
- package/dist/lib/browser/{schema-defs-YDPFZELA.mjs → schema-defs-QPI2JU3X.mjs} +6 -6
- package/dist/lib/browser/schema-defs-QPI2JU3X.mjs.map +7 -0
- package/dist/lib/browser/{settings-ZYH2JWNI.mjs → settings-45PGPO2V.mjs} +5 -5
- package/dist/lib/browser/{settings-ZYH2JWNI.mjs.map → settings-45PGPO2V.mjs.map} +1 -1
- package/dist/lib/browser/{spaces-ready-3I5LISH4.mjs → spaces-ready-QCND4DVY.mjs} +15 -14
- package/dist/lib/browser/spaces-ready-QCND4DVY.mjs.map +7 -0
- package/dist/lib/browser/{state-2RGW7FQG.mjs → state-Q7YRE5KG.mjs} +7 -7
- package/dist/lib/browser/state-Q7YRE5KG.mjs.map +7 -0
- package/dist/lib/browser/types/index.mjs +2 -2
- 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-6PZQIQG3.mjs +142 -0
- package/dist/lib/node-esm/ObjectDetailsPanel-6PZQIQG3.mjs.map +7 -0
- package/dist/lib/node-esm/ObjectSettings-OQSBOH7K.mjs +145 -0
- package/dist/lib/node-esm/ObjectSettings-OQSBOH7K.mjs.map +7 -0
- package/dist/lib/node-esm/RecordArticle-NACBH42P.mjs +117 -0
- package/dist/lib/node-esm/RecordArticle-NACBH42P.mjs.map +7 -0
- package/dist/lib/node-esm/{app-graph-builder-OW2EBYRI.mjs → app-graph-builder-FBJFWI4H.mjs} +107 -96
- package/dist/lib/node-esm/app-graph-builder-FBJFWI4H.mjs.map +7 -0
- package/dist/lib/node-esm/{app-graph-serializer-6PGC5WR5.mjs → app-graph-serializer-BESQZAYU.mjs} +19 -19
- package/dist/lib/node-esm/app-graph-serializer-BESQZAYU.mjs.map +7 -0
- package/dist/lib/node-esm/{chunk-RXDT5LA5.mjs → chunk-6VEONPNZ.mjs} +35 -19
- package/dist/lib/node-esm/chunk-6VEONPNZ.mjs.map +7 -0
- package/dist/lib/node-esm/chunk-6ZQGZBEP.mjs +168 -0
- package/dist/lib/node-esm/chunk-6ZQGZBEP.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-TEUN2E4F.mjs → chunk-OK2L7N2F.mjs} +135 -62
- package/dist/lib/node-esm/chunk-OK2L7N2F.mjs.map +7 -0
- package/dist/lib/node-esm/{chunk-LGNPMOXU.mjs → chunk-QBRPYAEL.mjs} +26 -13
- package/dist/lib/node-esm/chunk-QBRPYAEL.mjs.map +7 -0
- package/dist/lib/node-esm/{chunk-NMCD2PSG.mjs → chunk-XGAMJC5C.mjs} +553 -475
- package/dist/lib/node-esm/chunk-XGAMJC5C.mjs.map +7 -0
- package/dist/lib/node-esm/chunk-Z7BB6HC2.mjs +21 -0
- package/dist/lib/node-esm/chunk-Z7BB6HC2.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 -70
- package/dist/lib/node-esm/index.mjs.map +3 -3
- package/dist/lib/node-esm/{intent-resolver-EXPK4B76.mjs → intent-resolver-6O5FSB7Z.mjs} +89 -76
- package/dist/lib/node-esm/intent-resolver-6O5FSB7Z.mjs.map +7 -0
- package/dist/lib/node-esm/meta.json +1 -1
- package/dist/lib/node-esm/{react-root-4OQ7MPGW.mjs → react-root-K66W3FMA.mjs} +13 -12
- package/dist/lib/node-esm/react-root-K66W3FMA.mjs.map +7 -0
- package/dist/lib/node-esm/{react-surface-WXEXIDB7.mjs → react-surface-Y7FTEIDF.mjs} +71 -105
- package/dist/lib/node-esm/react-surface-Y7FTEIDF.mjs.map +7 -0
- package/dist/lib/node-esm/{schema-defs-OYBCWKAS.mjs → schema-defs-ZS2D47XW.mjs} +6 -6
- package/dist/lib/node-esm/schema-defs-ZS2D47XW.mjs.map +7 -0
- package/dist/lib/node-esm/{settings-2RYFMMTP.mjs → settings-6FO65BA6.mjs} +5 -5
- package/dist/lib/node-esm/{settings-2RYFMMTP.mjs.map → settings-6FO65BA6.mjs.map} +1 -1
- package/dist/lib/node-esm/{spaces-ready-JAP22P57.mjs → spaces-ready-P7CKVXBE.mjs} +15 -14
- package/dist/lib/node-esm/spaces-ready-P7CKVXBE.mjs.map +7 -0
- package/dist/lib/node-esm/{state-7VBVBGNS.mjs → state-362I5BMK.mjs} +7 -7
- package/dist/lib/node-esm/state-362I5BMK.mjs.map +7 -0
- package/dist/lib/node-esm/types/index.mjs +2 -2
- 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 +6 -5
- package/dist/types/src/capabilities/capabilities.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/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 +120 -1
- package/dist/types/src/components/CreateDialog/CreateObjectDialog.stories.d.ts.map +1 -1
- package/dist/types/src/components/CreateDialog/CreateObjectPanel.d.ts +3 -3
- 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 +1707 -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/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 +1540 -0
- package/dist/types/src/components/ObjectSettings/BaseObjectSettings.stories.d.ts.map +1 -0
- package/dist/types/src/components/ObjectSettings/ForeignKeys.d.ts +1 -1
- package/dist/types/src/components/ObjectSettings/ForeignKeys.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} +121 -2
- package/dist/types/src/components/RecordArticle.stories.d.ts.map +1 -0
- package/dist/types/src/components/SchemaContainer.d.ts +1 -1
- 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} +4 -3
- 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} +122 -3
- 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 +120 -1
- 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 +121 -2
- 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 +120 -0
- package/dist/types/src/translations.d.ts.map +1 -1
- package/dist/types/src/types/types.d.ts +70 -55
- package/dist/types/src/types/types.d.ts.map +1 -1
- package/dist/types/src/util.d.ts +10 -7
- package/dist/types/src/util.d.ts.map +1 -1
- package/dist/types/tsconfig.tsbuildinfo +1 -1
- package/package.json +65 -60
- package/src/SpacePlugin.ts +228 -200
- package/src/capabilities/app-graph-builder.ts +157 -121
- package/src/capabilities/app-graph-serializer.ts +12 -12
- package/src/capabilities/capabilities.ts +16 -11
- package/src/capabilities/identity-created.ts +2 -2
- package/src/capabilities/intent-resolver.ts +75 -59
- package/src/capabilities/react-root.tsx +4 -3
- package/src/capabilities/react-surface.tsx +65 -141
- package/src/capabilities/schema-defs.ts +1 -1
- package/src/capabilities/spaces-ready.ts +8 -5
- 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 +36 -28
- package/src/components/CreateDialog/CreateObjectPanel.tsx +8 -8
- 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 +3 -3
- package/src/components/ObjectSettings/BaseObjectSettings.stories.tsx +63 -0
- package/src/components/ObjectSettings/BaseObjectSettings.tsx +90 -26
- package/src/components/ObjectSettings/ForeignKeys.tsx +4 -4
- package/src/components/ObjectSettings/ObjectSettingsContainer.tsx +1 -1
- 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 +23 -26
- 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 +44 -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 +51 -18
- 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 +59 -0
- package/src/index.ts +1 -0
- package/src/meta.ts +6 -3
- package/src/translations.ts +25 -10
- package/src/types/types.ts +33 -18
- package/src/util.tsx +141 -63
- package/dist/lib/browser/CollectionMain-D2B75XBS.mjs.map +0 -7
- package/dist/lib/browser/ObjectDetailsPanel-J7KGPJJK.mjs +0 -90
- package/dist/lib/browser/ObjectDetailsPanel-J7KGPJJK.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-AFC6PNAB.mjs.map +0 -7
- package/dist/lib/browser/app-graph-serializer-Q7QG4EKW.mjs.map +0 -7
- package/dist/lib/browser/chunk-6GRF7NEF.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-ELJDGQTO.mjs +0 -94
- 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-S33AYKSS.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-URST7EEN.mjs.map +0 -7
- package/dist/lib/browser/chunk-WZYRDFW7.mjs.map +0 -7
- package/dist/lib/browser/identity-created-T6ZNVE7S.mjs.map +0 -7
- package/dist/lib/browser/intent-resolver-CO262Q44.mjs.map +0 -7
- package/dist/lib/browser/react-root-K4IVLFYZ.mjs +0 -29
- package/dist/lib/browser/react-root-K4IVLFYZ.mjs.map +0 -7
- package/dist/lib/browser/react-surface-TPUOK2LC.mjs.map +0 -7
- package/dist/lib/browser/schema-defs-YDPFZELA.mjs.map +0 -7
- package/dist/lib/browser/spaces-ready-3I5LISH4.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-7ADOXZ5W.mjs +0 -91
- package/dist/lib/node-esm/ObjectDetailsPanel-7ADOXZ5W.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-OW2EBYRI.mjs.map +0 -7
- package/dist/lib/node-esm/app-graph-serializer-6PGC5WR5.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-LGNPMOXU.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-NMCD2PSG.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-Q6AAQLQG.mjs +0 -96
- package/dist/lib/node-esm/chunk-Q6AAQLQG.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-RXDT5LA5.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-TEUN2E4F.mjs.map +0 -7
- package/dist/lib/node-esm/identity-created-AL7NNCKH.mjs.map +0 -7
- package/dist/lib/node-esm/intent-resolver-EXPK4B76.mjs.map +0 -7
- package/dist/lib/node-esm/react-root-4OQ7MPGW.mjs.map +0 -7
- package/dist/lib/node-esm/react-surface-WXEXIDB7.mjs.map +0 -7
- package/dist/lib/node-esm/schema-defs-OYBCWKAS.mjs.map +0 -7
- package/dist/lib/node-esm/spaces-ready-JAP22P57.mjs.map +0 -7
- package/dist/lib/node-esm/state-7VBVBGNS.mjs.map +0 -7
- 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/components/ObjectDetailsPanel.tsx +0 -79
- 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
|
@@ -2,34 +2,28 @@
|
|
|
2
2
|
// Copyright 2024 DXOS.org
|
|
3
3
|
//
|
|
4
4
|
|
|
5
|
-
import
|
|
5
|
+
import * as Effect from 'effect/Effect';
|
|
6
|
+
import * as Function from 'effect/Function';
|
|
6
7
|
import React, { useCallback, useRef, useState } from 'react';
|
|
7
8
|
|
|
8
|
-
import {
|
|
9
|
-
|
|
10
|
-
LayoutAction,
|
|
11
|
-
chain,
|
|
12
|
-
createIntent,
|
|
13
|
-
useCapabilities,
|
|
14
|
-
useIntentDispatcher,
|
|
15
|
-
usePluginManager,
|
|
16
|
-
} from '@dxos/app-framework';
|
|
9
|
+
import { Capabilities, LayoutAction, chain, createIntent } from '@dxos/app-framework';
|
|
10
|
+
import { useCapabilities, useIntentDispatcher, usePluginManager } from '@dxos/app-framework/react';
|
|
17
11
|
import { Obj, Query, Type } from '@dxos/echo';
|
|
18
12
|
import { invariant } from '@dxos/invariant';
|
|
19
13
|
import { useClient } from '@dxos/react-client';
|
|
20
14
|
import { type Space, getSpace, isLiveObject, isSpace, useQuery, useSpaces } from '@dxos/react-client/echo';
|
|
21
|
-
import {
|
|
15
|
+
import { Dialog, IconButton, useTranslation } from '@dxos/react-ui';
|
|
22
16
|
import { cardDialogContent, cardDialogHeader } from '@dxos/react-ui-stack';
|
|
23
|
-
import {
|
|
17
|
+
import { Collection, StoredSchema, getTypenameFromQuery } from '@dxos/schema';
|
|
24
18
|
import { isNonNullable } from '@dxos/util';
|
|
25
19
|
|
|
26
20
|
import { SpaceCapabilities } from '../../capabilities';
|
|
27
|
-
import {
|
|
21
|
+
import { meta } from '../../meta';
|
|
28
22
|
import { SpaceAction } from '../../types';
|
|
29
23
|
|
|
30
24
|
import { CreateObjectPanel, type CreateObjectPanelProps } from './CreateObjectPanel';
|
|
31
25
|
|
|
32
|
-
export const CREATE_OBJECT_DIALOG = `${
|
|
26
|
+
export const CREATE_OBJECT_DIALOG = `${meta.id}/CreateObjectDialog`;
|
|
33
27
|
|
|
34
28
|
export type CreateObjectDialogProps = Pick<
|
|
35
29
|
CreateObjectPanelProps,
|
|
@@ -47,20 +41,20 @@ export const CreateObjectDialog = ({
|
|
|
47
41
|
onCreateObject,
|
|
48
42
|
shouldNavigate: _shouldNavigate,
|
|
49
43
|
}: CreateObjectDialogProps) => {
|
|
50
|
-
const closeRef = useRef<HTMLButtonElement | null>(null);
|
|
51
44
|
const manager = usePluginManager();
|
|
52
|
-
const { t } = useTranslation(
|
|
53
|
-
const client = useClient();
|
|
54
|
-
const spaces = useSpaces();
|
|
45
|
+
const { t } = useTranslation(meta.id);
|
|
55
46
|
const { dispatch } = useIntentDispatcher();
|
|
56
47
|
const forms = useCapabilities(SpaceCapabilities.ObjectForm);
|
|
57
|
-
const [target, setTarget] = useState<Space |
|
|
48
|
+
const [target, setTarget] = useState<Space | Collection.Collection | undefined>(initialTarget);
|
|
58
49
|
const [typename, setTypename] = useState<string | undefined>(initialTypename);
|
|
50
|
+
const client = useClient();
|
|
51
|
+
const spaces = useSpaces();
|
|
59
52
|
const space = isSpace(target) ? target : getSpace(target);
|
|
60
|
-
const queryCollections = useQuery(space, Query.type(
|
|
53
|
+
const queryCollections = useQuery(space, Query.type(Collection.QueryCollection));
|
|
61
54
|
const hiddenTypenames = queryCollections
|
|
62
|
-
.map((collection) =>
|
|
55
|
+
.map((collection) => getTypenameFromQuery(collection.query))
|
|
63
56
|
.filter(isNonNullable);
|
|
57
|
+
const closeRef = useRef<HTMLButtonElement | null>(null);
|
|
64
58
|
|
|
65
59
|
const resolve = useCallback<NonNullable<CreateObjectPanelProps['resolve']>>(
|
|
66
60
|
(typename) =>
|
|
@@ -82,13 +76,17 @@ export const CreateObjectDialog = ({
|
|
|
82
76
|
const space = isSpace(target) ? target : getSpace(target);
|
|
83
77
|
invariant(space, 'Missing space');
|
|
84
78
|
const { object } = yield* dispatch(form.getIntent(data, { space }));
|
|
85
|
-
if (isLiveObject(object) && !Obj.instanceOf(
|
|
79
|
+
if (isLiveObject(object) && !Obj.instanceOf(StoredSchema, object)) {
|
|
86
80
|
// TODO(wittjosiah): Selection in navtree isn't working as expected when hidden typenames evals to true.
|
|
87
81
|
const hidden = form.hidden || hiddenTypenames.includes(Type.getTypename(form.objectSchema));
|
|
88
|
-
const addObjectIntent = createIntent(SpaceAction.AddObject, {
|
|
82
|
+
const addObjectIntent = createIntent(SpaceAction.AddObject, {
|
|
83
|
+
target,
|
|
84
|
+
object,
|
|
85
|
+
hidden,
|
|
86
|
+
});
|
|
89
87
|
const shouldNavigate = _shouldNavigate ?? (() => true);
|
|
90
88
|
if (shouldNavigate(object)) {
|
|
91
|
-
yield* dispatch(pipe(addObjectIntent, chain(LayoutAction.Open, { part: 'main' })));
|
|
89
|
+
yield* dispatch(Function.pipe(addObjectIntent, chain(LayoutAction.Open, { part: 'main' })));
|
|
92
90
|
} else {
|
|
93
91
|
yield* dispatch(addObjectIntent);
|
|
94
92
|
}
|
|
@@ -106,13 +104,23 @@ export const CreateObjectDialog = ({
|
|
|
106
104
|
<div role='none' className={cardDialogHeader}>
|
|
107
105
|
<Dialog.Title>
|
|
108
106
|
{t('create object dialog title', {
|
|
109
|
-
object: t('typename label', {
|
|
107
|
+
object: t('typename label', {
|
|
108
|
+
ns: typename,
|
|
109
|
+
defaultValue: views ? 'View' : 'Item',
|
|
110
|
+
}),
|
|
110
111
|
})}
|
|
111
112
|
</Dialog.Title>
|
|
112
113
|
<Dialog.Close asChild>
|
|
113
|
-
<
|
|
114
|
-
|
|
115
|
-
|
|
114
|
+
<IconButton
|
|
115
|
+
ref={closeRef}
|
|
116
|
+
icon='ph--x--regular'
|
|
117
|
+
size={4}
|
|
118
|
+
label='Close'
|
|
119
|
+
iconOnly
|
|
120
|
+
density='fine'
|
|
121
|
+
variant='ghost'
|
|
122
|
+
autoFocus
|
|
123
|
+
/>
|
|
116
124
|
</Dialog.Close>
|
|
117
125
|
</div>
|
|
118
126
|
|
|
@@ -2,21 +2,21 @@
|
|
|
2
2
|
// Copyright 2024 DXOS.org
|
|
3
3
|
//
|
|
4
4
|
|
|
5
|
-
import
|
|
5
|
+
import * as Option from 'effect/Option';
|
|
6
6
|
import React, { useCallback } from 'react';
|
|
7
7
|
|
|
8
8
|
import { Type } from '@dxos/echo';
|
|
9
|
-
import { type BaseObject, type TypeAnnotation, ViewAnnotation, getTypeAnnotation } from '@dxos/echo
|
|
9
|
+
import { type BaseObject, type TypeAnnotation, ViewAnnotation, getTypeAnnotation } from '@dxos/echo/internal';
|
|
10
10
|
import { type Space, type SpaceId } from '@dxos/react-client/echo';
|
|
11
11
|
import { Icon, toLocalizedString, useDefaultValue, useTranslation } from '@dxos/react-ui';
|
|
12
12
|
import { Form } from '@dxos/react-ui-form';
|
|
13
13
|
import { SearchList } from '@dxos/react-ui-searchlist';
|
|
14
14
|
import { cardDialogOverflow, cardDialogPaddedOverflow, cardDialogSearchListRoot } from '@dxos/react-ui-stack';
|
|
15
|
-
import { type
|
|
15
|
+
import { type Collection } from '@dxos/schema';
|
|
16
16
|
import { type MaybePromise, isNonNullable } from '@dxos/util';
|
|
17
17
|
|
|
18
18
|
import { useInputSurfaceLookup } from '../../hooks';
|
|
19
|
-
import {
|
|
19
|
+
import { meta } from '../../meta';
|
|
20
20
|
import { type ObjectForm } from '../../types';
|
|
21
21
|
import { getSpaceDisplayName } from '../../util';
|
|
22
22
|
|
|
@@ -24,7 +24,7 @@ export type CreateObjectPanelProps = {
|
|
|
24
24
|
forms: ObjectForm[];
|
|
25
25
|
spaces: Space[];
|
|
26
26
|
typename?: string;
|
|
27
|
-
target?: Space |
|
|
27
|
+
target?: Space | Collection.Collection;
|
|
28
28
|
views?: boolean;
|
|
29
29
|
initialFormValues?: Partial<BaseObject>;
|
|
30
30
|
defaultSpaceId?: SpaceId;
|
|
@@ -47,7 +47,7 @@ export const CreateObjectPanel = ({
|
|
|
47
47
|
onTypenameChange,
|
|
48
48
|
onCreateObject,
|
|
49
49
|
}: CreateObjectPanelProps) => {
|
|
50
|
-
const { t } = useTranslation(
|
|
50
|
+
const { t } = useTranslation(meta.id);
|
|
51
51
|
const initialFormValues = useDefaultValue(_initialFormValues, () => ({}));
|
|
52
52
|
const form = forms.find((form) => Type.getTypename(form.objectSchema) === typename);
|
|
53
53
|
const options: TypeAnnotation[] = forms
|
|
@@ -115,7 +115,7 @@ const SelectSpace = ({
|
|
|
115
115
|
defaultSpaceId,
|
|
116
116
|
onChange,
|
|
117
117
|
}: { onChange?: (space: Space) => void } & Pick<CreateObjectPanelProps, 'spaces' | 'defaultSpaceId'>) => {
|
|
118
|
-
const { t } = useTranslation(
|
|
118
|
+
const { t } = useTranslation(meta.id);
|
|
119
119
|
|
|
120
120
|
return (
|
|
121
121
|
<SearchList.Root label={t('space input label')} classNames={cardDialogSearchListRoot}>
|
|
@@ -156,7 +156,7 @@ const SelectSchema = ({
|
|
|
156
156
|
options: TypeAnnotation[];
|
|
157
157
|
onChange: (type: string) => void;
|
|
158
158
|
} & Pick<CreateObjectPanelProps, 'resolve'>) => {
|
|
159
|
-
const { t } = useTranslation(
|
|
159
|
+
const { t } = useTranslation(meta.id);
|
|
160
160
|
|
|
161
161
|
return (
|
|
162
162
|
<SearchList.Root label={t('schema input label')} classNames={cardDialogSearchListRoot}>
|
|
@@ -2,26 +2,28 @@
|
|
|
2
2
|
// Copyright 2024 DXOS.org
|
|
3
3
|
//
|
|
4
4
|
|
|
5
|
-
import
|
|
5
|
+
import * as Effect from 'effect/Effect';
|
|
6
|
+
import type * as Schema from 'effect/Schema';
|
|
6
7
|
import React, { useCallback, useRef } from 'react';
|
|
7
8
|
|
|
8
|
-
import { LayoutAction, createIntent
|
|
9
|
-
import {
|
|
9
|
+
import { LayoutAction, createIntent } from '@dxos/app-framework';
|
|
10
|
+
import { useIntentDispatcher } from '@dxos/app-framework/react';
|
|
11
|
+
import { Dialog, IconButton, useTranslation } from '@dxos/react-ui';
|
|
10
12
|
import { Form } from '@dxos/react-ui-form';
|
|
11
13
|
import { cardDialogContent, cardDialogHeader } from '@dxos/react-ui-stack';
|
|
12
14
|
|
|
13
15
|
import { useInputSurfaceLookup } from '../../hooks';
|
|
14
|
-
import {
|
|
16
|
+
import { meta } from '../../meta';
|
|
15
17
|
import { SpaceAction, SpaceForm } from '../../types';
|
|
16
18
|
|
|
17
|
-
export const CREATE_SPACE_DIALOG = `${
|
|
19
|
+
export const CREATE_SPACE_DIALOG = `${meta.id}/CreateSpaceDialog`;
|
|
18
20
|
|
|
19
21
|
type FormValues = Schema.Schema.Type<typeof SpaceForm>;
|
|
20
22
|
const initialValues: FormValues = { edgeReplication: true };
|
|
21
23
|
|
|
22
24
|
export const CreateSpaceDialog = () => {
|
|
23
25
|
const closeRef = useRef<HTMLButtonElement | null>(null);
|
|
24
|
-
const { t } = useTranslation(
|
|
26
|
+
const { t } = useTranslation(meta.id);
|
|
25
27
|
const { dispatch } = useIntentDispatcher();
|
|
26
28
|
|
|
27
29
|
const inputSurfaceLookup = useInputSurfaceLookup();
|
|
@@ -30,8 +32,18 @@ export const CreateSpaceDialog = () => {
|
|
|
30
32
|
async (data: FormValues) => {
|
|
31
33
|
const program = Effect.gen(function* () {
|
|
32
34
|
const { space } = yield* dispatch(createIntent(SpaceAction.Create, data));
|
|
33
|
-
yield* dispatch(
|
|
34
|
-
|
|
35
|
+
yield* dispatch(
|
|
36
|
+
createIntent(LayoutAction.SwitchWorkspace, {
|
|
37
|
+
part: 'workspace',
|
|
38
|
+
subject: space.id,
|
|
39
|
+
}),
|
|
40
|
+
);
|
|
41
|
+
yield* dispatch(
|
|
42
|
+
createIntent(LayoutAction.UpdateDialog, {
|
|
43
|
+
part: 'dialog',
|
|
44
|
+
options: { state: false },
|
|
45
|
+
}),
|
|
46
|
+
);
|
|
35
47
|
});
|
|
36
48
|
await Effect.runPromise(program);
|
|
37
49
|
},
|
|
@@ -45,9 +57,16 @@ export const CreateSpaceDialog = () => {
|
|
|
45
57
|
<div role='none' className={cardDialogHeader}>
|
|
46
58
|
<Dialog.Title>{t('create space dialog title')}</Dialog.Title>
|
|
47
59
|
<Dialog.Close asChild>
|
|
48
|
-
<
|
|
49
|
-
|
|
50
|
-
|
|
60
|
+
<IconButton
|
|
61
|
+
ref={closeRef}
|
|
62
|
+
icon='ph--x--regular'
|
|
63
|
+
size={4}
|
|
64
|
+
label='Close'
|
|
65
|
+
iconOnly
|
|
66
|
+
density='fine'
|
|
67
|
+
variant='ghost'
|
|
68
|
+
autoFocus
|
|
69
|
+
/>
|
|
51
70
|
</Dialog.Close>
|
|
52
71
|
</div>
|
|
53
72
|
<div role='none' className='contents'>
|
|
@@ -4,7 +4,8 @@
|
|
|
4
4
|
|
|
5
5
|
import React, { useCallback } from 'react';
|
|
6
6
|
|
|
7
|
-
import { LayoutAction, createIntent
|
|
7
|
+
import { LayoutAction, createIntent } from '@dxos/app-framework';
|
|
8
|
+
import { useAppGraph, useIntentDispatcher } from '@dxos/app-framework/react';
|
|
8
9
|
import { Trigger } from '@dxos/async';
|
|
9
10
|
import { ObservabilityAction } from '@dxos/plugin-observability/types';
|
|
10
11
|
import { useClient } from '@dxos/react-client';
|
|
@@ -13,9 +14,9 @@ import { type InvitationResult } from '@dxos/react-client/invitations';
|
|
|
13
14
|
import { Dialog, useTranslation } from '@dxos/react-ui';
|
|
14
15
|
import { JoinPanel, type JoinPanelProps } from '@dxos/shell/react';
|
|
15
16
|
|
|
16
|
-
import {
|
|
17
|
+
import { meta } from '../../meta';
|
|
17
18
|
|
|
18
|
-
export const JOIN_DIALOG = `${
|
|
19
|
+
export const JOIN_DIALOG = `${meta.id}/JoinDialog`;
|
|
19
20
|
|
|
20
21
|
export type JoinDialogProps = JoinPanelProps & {
|
|
21
22
|
navigableCollections?: boolean;
|
|
@@ -25,7 +26,7 @@ export const JoinDialog = ({ navigableCollections, onDone, ...props }: JoinDialo
|
|
|
25
26
|
const { dispatchPromise: dispatch } = useIntentDispatcher();
|
|
26
27
|
const client = useClient();
|
|
27
28
|
const { graph } = useAppGraph();
|
|
28
|
-
const { t } = useTranslation(
|
|
29
|
+
const { t } = useTranslation(meta.id);
|
|
29
30
|
|
|
30
31
|
const handleDone = useCallback(
|
|
31
32
|
async (result: InvitationResult | null) => {
|
|
@@ -39,10 +40,10 @@ export const JoinDialog = ({ navigableCollections, onDone, ...props }: JoinDialo
|
|
|
39
40
|
createIntent(LayoutAction.AddToast, {
|
|
40
41
|
part: 'toast',
|
|
41
42
|
subject: {
|
|
42
|
-
id: `${
|
|
43
|
+
id: `${meta.id}/join-success`,
|
|
43
44
|
duration: 5_000,
|
|
44
|
-
title: ['join success label', { ns:
|
|
45
|
-
closeLabel: ['dismiss label', { ns:
|
|
45
|
+
title: ['join success label', { ns: meta.id }],
|
|
46
|
+
closeLabel: ['dismiss label', { ns: meta.id }],
|
|
46
47
|
},
|
|
47
48
|
}),
|
|
48
49
|
),
|
|
@@ -69,7 +70,12 @@ export const JoinDialog = ({ navigableCollections, onDone, ...props }: JoinDialo
|
|
|
69
70
|
space = await trigger.wait();
|
|
70
71
|
}
|
|
71
72
|
|
|
72
|
-
await dispatch(
|
|
73
|
+
await dispatch(
|
|
74
|
+
createIntent(LayoutAction.SwitchWorkspace, {
|
|
75
|
+
part: 'workspace',
|
|
76
|
+
subject: space.id,
|
|
77
|
+
}),
|
|
78
|
+
);
|
|
73
79
|
|
|
74
80
|
// TODO(wittjosiah): If navigableCollections is false and there's no target,
|
|
75
81
|
// should try to navigate to the first object of the space replicates.
|
|
@@ -80,8 +86,18 @@ export const JoinDialog = ({ navigableCollections, onDone, ...props }: JoinDialo
|
|
|
80
86
|
// If the target has not yet replicated, this will trigger a loading toast.
|
|
81
87
|
await graph.waitForPath({ target }).catch(() => {});
|
|
82
88
|
await Promise.all([
|
|
83
|
-
dispatch(
|
|
84
|
-
|
|
89
|
+
dispatch(
|
|
90
|
+
createIntent(LayoutAction.Open, {
|
|
91
|
+
part: 'main',
|
|
92
|
+
subject: [target],
|
|
93
|
+
}),
|
|
94
|
+
),
|
|
95
|
+
dispatch(
|
|
96
|
+
createIntent(LayoutAction.Expose, {
|
|
97
|
+
part: 'navigation',
|
|
98
|
+
subject: target,
|
|
99
|
+
}),
|
|
100
|
+
),
|
|
85
101
|
]);
|
|
86
102
|
}
|
|
87
103
|
|
|
@@ -2,17 +2,18 @@
|
|
|
2
2
|
// Copyright 2023 DXOS.org
|
|
3
3
|
//
|
|
4
4
|
|
|
5
|
-
import '@dxos-theme';
|
|
6
|
-
|
|
7
5
|
import { type Meta, type StoryObj } from '@storybook/react-vite';
|
|
8
6
|
import React from 'react';
|
|
9
7
|
|
|
8
|
+
import { IntentPlugin } from '@dxos/app-framework';
|
|
9
|
+
import { withPluginManager } from '@dxos/app-framework/testing';
|
|
10
10
|
import { useSpace } from '@dxos/react-client/echo';
|
|
11
11
|
import { withClientProvider } from '@dxos/react-client/testing';
|
|
12
|
+
import { withTheme } from '@dxos/react-ui/testing';
|
|
12
13
|
import { translations as shellTranslations } from '@dxos/shell/react';
|
|
13
|
-
import { render
|
|
14
|
+
import { render } from '@dxos/storybook-utils';
|
|
14
15
|
|
|
15
|
-
import { translations } from '
|
|
16
|
+
import { translations } from '../../translations';
|
|
16
17
|
|
|
17
18
|
import { MembersContainer } from './MembersContainer';
|
|
18
19
|
|
|
@@ -35,12 +36,12 @@ const meta = {
|
|
|
35
36
|
component: MembersContainer as any,
|
|
36
37
|
render: render(DefaultStory),
|
|
37
38
|
decorators: [
|
|
39
|
+
withTheme, // TODO(wittjosiah): Try to write story which does not depend on plugin manager.
|
|
40
|
+
withPluginManager({ plugins: [IntentPlugin()] }),
|
|
38
41
|
withClientProvider({
|
|
39
42
|
createIdentity: true,
|
|
40
43
|
createSpace: true,
|
|
41
44
|
}),
|
|
42
|
-
withTheme,
|
|
43
|
-
withLayout(),
|
|
44
45
|
],
|
|
45
46
|
parameters: {
|
|
46
47
|
layout: 'fullscreen',
|
|
@@ -5,15 +5,17 @@
|
|
|
5
5
|
import React, { type Dispatch, type SetStateAction, useCallback, useMemo, useState } from 'react';
|
|
6
6
|
import { QR } from 'react-qr-rounded';
|
|
7
7
|
|
|
8
|
-
import { createIntent
|
|
8
|
+
import { createIntent } from '@dxos/app-framework';
|
|
9
|
+
import { useIntentDispatcher } from '@dxos/app-framework/react';
|
|
10
|
+
import { Obj } from '@dxos/echo';
|
|
9
11
|
import { log } from '@dxos/log';
|
|
10
12
|
import { useConfig } from '@dxos/react-client';
|
|
11
|
-
import { type Space,
|
|
13
|
+
import { type Space, useSpaceInvitations } from '@dxos/react-client/echo';
|
|
12
14
|
import { type CancellableInvitationObservable, Invitation, InvitationEncoder } from '@dxos/react-client/invitations';
|
|
13
15
|
import { Button, Clipboard, Icon, Input, useId, useTranslation } from '@dxos/react-ui';
|
|
14
16
|
import { ControlFrame, ControlFrameItem, ControlItemInput, ControlPage, ControlSection } from '@dxos/react-ui-form';
|
|
15
17
|
import { StackItem } from '@dxos/react-ui-stack';
|
|
16
|
-
import {
|
|
18
|
+
import { Collection } from '@dxos/schema';
|
|
17
19
|
import {
|
|
18
20
|
type ActionMenuItem,
|
|
19
21
|
AuthCode,
|
|
@@ -26,9 +28,9 @@ import {
|
|
|
26
28
|
} from '@dxos/shell/react';
|
|
27
29
|
import { hexToEmoji } from '@dxos/util';
|
|
28
30
|
|
|
29
|
-
import {
|
|
30
|
-
import { SpaceAction } from '
|
|
31
|
-
import { COMPOSER_SPACE_LOCK } from '
|
|
31
|
+
import { meta } from '../../meta';
|
|
32
|
+
import { SpaceAction } from '../../types';
|
|
33
|
+
import { COMPOSER_SPACE_LOCK } from '../../util';
|
|
32
34
|
|
|
33
35
|
// TODO(wittjosiah): Copied from Shell.
|
|
34
36
|
const activeActionKey = 'dxos:react-shell/space-manager/active-action';
|
|
@@ -47,7 +49,7 @@ export type MembersContainerProps = {
|
|
|
47
49
|
};
|
|
48
50
|
|
|
49
51
|
export const MembersContainer = ({ space, createInvitationUrl }: MembersContainerProps) => {
|
|
50
|
-
const { t } = useTranslation(
|
|
52
|
+
const { t } = useTranslation(meta.id);
|
|
51
53
|
const config = useConfig();
|
|
52
54
|
const { dispatchPromise: dispatch } = useIntentDispatcher();
|
|
53
55
|
const invitations = useSpaceInvitations(space.key);
|
|
@@ -63,7 +65,7 @@ export const MembersContainer = ({ space, createInvitationUrl }: MembersContaine
|
|
|
63
65
|
};
|
|
64
66
|
|
|
65
67
|
// TODO(wittjosiah): Track which was the most recently viewed object.
|
|
66
|
-
const target = space.properties[
|
|
68
|
+
const target = space.properties[Collection.Collection.typename]?.target?.objects[0]?.target;
|
|
67
69
|
|
|
68
70
|
const locked = space.properties[COMPOSER_SPACE_LOCK];
|
|
69
71
|
const handleChangeLocked = useCallback(() => {
|
|
@@ -75,7 +77,7 @@ export const MembersContainer = ({ space, createInvitationUrl }: MembersContaine
|
|
|
75
77
|
inviteOne: {
|
|
76
78
|
label: t('invite one label', { ns: 'os' }),
|
|
77
79
|
description: t('invite one description', { ns: 'os' }),
|
|
78
|
-
icon:
|
|
80
|
+
icon: 'ph--user-plus--regular',
|
|
79
81
|
testId: 'membersContainer.inviteOne',
|
|
80
82
|
onClick: async () => {
|
|
81
83
|
const { data: invitation } = await dispatch(
|
|
@@ -84,7 +86,7 @@ export const MembersContainer = ({ space, createInvitationUrl }: MembersContaine
|
|
|
84
86
|
type: Invitation.Type.INTERACTIVE,
|
|
85
87
|
authMethod: Invitation.AuthMethod.SHARED_SECRET,
|
|
86
88
|
multiUse: false,
|
|
87
|
-
target: target &&
|
|
89
|
+
target: target && Obj.getDXN(target).toString(),
|
|
88
90
|
}),
|
|
89
91
|
);
|
|
90
92
|
if (invitation && config.values.runtime?.app?.env?.DX_ENVIRONMENT !== 'production') {
|
|
@@ -97,7 +99,7 @@ export const MembersContainer = ({ space, createInvitationUrl }: MembersContaine
|
|
|
97
99
|
inviteMany: {
|
|
98
100
|
label: t('invite many label', { ns: 'os' }),
|
|
99
101
|
description: t('invite many description', { ns: 'os' }),
|
|
100
|
-
icon:
|
|
102
|
+
icon: 'ph--users-three--regular',
|
|
101
103
|
testId: 'membersContainer.inviteMany',
|
|
102
104
|
onClick: async () => {
|
|
103
105
|
const { data: invitation } = await dispatch(
|
|
@@ -106,7 +108,7 @@ export const MembersContainer = ({ space, createInvitationUrl }: MembersContaine
|
|
|
106
108
|
type: Invitation.Type.DELEGATED,
|
|
107
109
|
authMethod: Invitation.AuthMethod.KNOWN_PUBLIC_KEY,
|
|
108
110
|
multiUse: true,
|
|
109
|
-
target: target &&
|
|
111
|
+
target: target && Obj.getDXN(target).toString(),
|
|
110
112
|
}),
|
|
111
113
|
);
|
|
112
114
|
if (invitation && config.values.runtime?.app?.env?.DX_ENVIRONMENT !== 'production') {
|
|
@@ -130,7 +132,7 @@ export const MembersContainer = ({ space, createInvitationUrl }: MembersContaine
|
|
|
130
132
|
|
|
131
133
|
return (
|
|
132
134
|
<Clipboard.Provider>
|
|
133
|
-
<StackItem.Content
|
|
135
|
+
<StackItem.Content scrollable>
|
|
134
136
|
<ControlPage>
|
|
135
137
|
<ControlSection title={t('members verbose label')} description={t('members description')}>
|
|
136
138
|
<ControlFrame>
|
|
@@ -230,7 +232,7 @@ const InvitationQR = ({ id, url, onCancel }: { id: string; url: string; onCancel
|
|
|
230
232
|
const emoji = hexToEmoji(id);
|
|
231
233
|
return (
|
|
232
234
|
<>
|
|
233
|
-
<p className='text-description'>{t('qr code description', { ns:
|
|
235
|
+
<p className='text-description'>{t('qr code description', { ns: meta.id })}</p>
|
|
234
236
|
<div role='group' className='grid grid-cols-[1fr_min-content] mlb-2 gap-2'>
|
|
235
237
|
<div role='none' className='is-full aspect-square relative text-description'>
|
|
236
238
|
<QR
|
|
@@ -9,11 +9,11 @@ import { type Obj } from '@dxos/echo';
|
|
|
9
9
|
import { useClient } from '@dxos/react-client';
|
|
10
10
|
import { DropdownMenu, Icon, toLocalizedString, useTranslation } from '@dxos/react-ui';
|
|
11
11
|
|
|
12
|
-
import {
|
|
12
|
+
import { meta } from '../meta';
|
|
13
13
|
import { getSpaceDisplayName } from '../util';
|
|
14
14
|
|
|
15
15
|
export const MenuFooter = ({ object }: { object: Obj.Any }) => {
|
|
16
|
-
const { t } = useTranslation(
|
|
16
|
+
const { t } = useTranslation(meta.id);
|
|
17
17
|
const client = useClient();
|
|
18
18
|
const space = getSpace(object);
|
|
19
19
|
const spaceName = space ? getSpaceDisplayName(space, { personal: client.spaces.default === space }) : '';
|
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
//
|
|
2
|
+
// Copyright 2025 DXOS.org
|
|
3
|
+
//
|
|
4
|
+
|
|
5
|
+
import React from 'react';
|
|
6
|
+
|
|
7
|
+
import { useClient } from '@dxos/react-client';
|
|
8
|
+
import { Filter, getSpace, useQuery, useSchema } from '@dxos/react-client/echo';
|
|
9
|
+
import { Callout, useTranslation } from '@dxos/react-ui';
|
|
10
|
+
import { useSelected } from '@dxos/react-ui-attention';
|
|
11
|
+
import { type View, getTypenameFromQuery } from '@dxos/schema';
|
|
12
|
+
import { isNonNullable } from '@dxos/util';
|
|
13
|
+
|
|
14
|
+
import { meta } from '../../meta';
|
|
15
|
+
|
|
16
|
+
import { ObjectForm } from './ObjectForm';
|
|
17
|
+
|
|
18
|
+
type RowDetailsPanelProps = { objectId: string; view: View.View };
|
|
19
|
+
|
|
20
|
+
export const ObjectDetailsPanel = ({ objectId, view }: RowDetailsPanelProps) => {
|
|
21
|
+
const { t } = useTranslation(meta.id);
|
|
22
|
+
const client = useClient();
|
|
23
|
+
const space = getSpace(view);
|
|
24
|
+
const typename = view.query ? getTypenameFromQuery(view.query.ast) : undefined;
|
|
25
|
+
const schema = useSchema(client, space, typename);
|
|
26
|
+
|
|
27
|
+
const queriedObjects = useQuery(space, schema ? Filter.type(schema) : Filter.nothing());
|
|
28
|
+
const selectedRows = useSelected(objectId, 'multi');
|
|
29
|
+
const selectedObjects = selectedRows.map((id) => queriedObjects.find((obj) => obj.id === id)).filter(isNonNullable);
|
|
30
|
+
|
|
31
|
+
if (selectedObjects.length === 0) {
|
|
32
|
+
return (
|
|
33
|
+
<div role='none' className='plb-cardSpacingBlock pli-cardSpacingInline'>
|
|
34
|
+
<Callout.Root classNames='is-full'>
|
|
35
|
+
<Callout.Title>{t('row details no selection label')}</Callout.Title>
|
|
36
|
+
</Callout.Root>
|
|
37
|
+
</div>
|
|
38
|
+
);
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
return (
|
|
42
|
+
<div role='none' className='bs-full is-full flex flex-col p-2 gap-1 overflow-y-auto'>
|
|
43
|
+
{schema &&
|
|
44
|
+
selectedObjects.map((object) => (
|
|
45
|
+
<div key={object.id} className='border border-separator rounded'>
|
|
46
|
+
<ObjectForm object={object} schema={schema} />
|
|
47
|
+
</div>
|
|
48
|
+
))}
|
|
49
|
+
</div>
|
|
50
|
+
);
|
|
51
|
+
};
|
|
@@ -0,0 +1,72 @@
|
|
|
1
|
+
//
|
|
2
|
+
// Copyright 2025 DXOS.org
|
|
3
|
+
//
|
|
4
|
+
|
|
5
|
+
import * as Schema from 'effect/Schema';
|
|
6
|
+
import React, { useCallback, useMemo } from 'react';
|
|
7
|
+
|
|
8
|
+
import { DXN, Obj, type Ref, Tag, Type } from '@dxos/echo';
|
|
9
|
+
import { type JsonPath, setValue } from '@dxos/echo/internal';
|
|
10
|
+
import { invariant } from '@dxos/invariant';
|
|
11
|
+
import { getSpace } from '@dxos/react-client/echo';
|
|
12
|
+
import { Form, useRefQueryLookupHandler } from '@dxos/react-ui-form';
|
|
13
|
+
import { isNonNullable } from '@dxos/util';
|
|
14
|
+
|
|
15
|
+
import { meta as pluginMeta } from '../../meta';
|
|
16
|
+
|
|
17
|
+
const TagSchema = Tag.Tag.pipe(Schema.omit('id'));
|
|
18
|
+
|
|
19
|
+
type ObjectFormProps = { object: Obj.Any; schema: Schema.Schema.AnyNoContext };
|
|
20
|
+
|
|
21
|
+
export const ObjectForm = ({ object, schema }: ObjectFormProps) => {
|
|
22
|
+
const space = getSpace(object);
|
|
23
|
+
const handleRefQueryLookup = useRefQueryLookupHandler({ space });
|
|
24
|
+
|
|
25
|
+
const formSchema = useMemo(
|
|
26
|
+
() => Schema.Struct({ tags: Schema.Array(Type.Ref(Tag.Tag)).pipe(Schema.optional) }).pipe(Schema.extend(schema)),
|
|
27
|
+
[schema],
|
|
28
|
+
);
|
|
29
|
+
|
|
30
|
+
const meta = Obj.getMeta(object);
|
|
31
|
+
const tags = (meta.tags ?? []).map((tag) => space?.db.ref(DXN.parse(tag))).filter(isNonNullable);
|
|
32
|
+
const values = useMemo(() => ({ tags, ...object }), [object, tags]);
|
|
33
|
+
|
|
34
|
+
const handleCreateTag = useCallback((values: Schema.Schema.Type<typeof TagSchema>) => {
|
|
35
|
+
invariant(space);
|
|
36
|
+
const tag = space.db.add(Tag.make(values));
|
|
37
|
+
const meta = Obj.getMeta(object);
|
|
38
|
+
meta.tags = [...(meta.tags ?? []), Obj.getDXN(tag).toString()];
|
|
39
|
+
}, []);
|
|
40
|
+
|
|
41
|
+
const handleSave = useCallback(
|
|
42
|
+
({ tags, ...values }: any, { changed }: { changed: Record<JsonPath, boolean> }) => {
|
|
43
|
+
const changedPaths = Object.keys(changed).filter((path) => changed[path as JsonPath]) as JsonPath[];
|
|
44
|
+
for (const path of changedPaths) {
|
|
45
|
+
if (path === 'tags') {
|
|
46
|
+
const meta = Obj.getMeta(object);
|
|
47
|
+
meta.tags = tags?.map((tag: Ref.Ref<Tag.Tag>) => tag.dxn.toString()) ?? [];
|
|
48
|
+
continue;
|
|
49
|
+
}
|
|
50
|
+
|
|
51
|
+
const value = values[path];
|
|
52
|
+
setValue(object, path, value);
|
|
53
|
+
}
|
|
54
|
+
},
|
|
55
|
+
[object],
|
|
56
|
+
);
|
|
57
|
+
|
|
58
|
+
return (
|
|
59
|
+
<Form
|
|
60
|
+
autoSave
|
|
61
|
+
schema={formSchema}
|
|
62
|
+
values={values}
|
|
63
|
+
createSchema={TagSchema}
|
|
64
|
+
createOptionIcon='ph--plus--regular'
|
|
65
|
+
createOptionLabel={['add tag label', { ns: pluginMeta.id }]}
|
|
66
|
+
createInitialValuePath='label'
|
|
67
|
+
onCreate={handleCreateTag}
|
|
68
|
+
onSave={handleSave}
|
|
69
|
+
onQueryRefOptions={handleRefQueryLookup}
|
|
70
|
+
/>
|
|
71
|
+
);
|
|
72
|
+
};
|