@dxos/plugin-space 0.8.4-staging.60fe92afc8 → 0.9.1-main.c7dcc2e112
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/neutral/{CollectionArticle-S3OF5KJ7.mjs → CollectionArticle-BMH7SZ7Q.mjs} +9 -12
- package/dist/lib/neutral/CollectionArticle-BMH7SZ7Q.mjs.map +7 -0
- package/dist/lib/neutral/{CollectionSection-A5WRHE5Z.mjs → CollectionSection-BLYTGOKH.mjs} +2 -2
- package/dist/lib/neutral/{CollectionSection-A5WRHE5Z.mjs.map → CollectionSection-BLYTGOKH.mjs.map} +3 -3
- package/dist/lib/neutral/{CreateObjectDialog-66R3K6I3.mjs → CreateObjectDialog-4VMOUKM7.mjs} +10 -10
- package/dist/lib/neutral/CreateObjectDialog-4VMOUKM7.mjs.map +7 -0
- package/dist/lib/neutral/{CreateSpaceDialog-CDGSEIJB.mjs → CreateSpaceDialog-WWNUTLVK.mjs} +6 -6
- package/dist/lib/neutral/CreateSpaceDialog-WWNUTLVK.mjs.map +7 -0
- package/dist/lib/neutral/{ImportSpaceDialog-7GKV4OTF.mjs → ImportSpaceDialog-CSSRTFAO.mjs} +4 -4
- package/dist/lib/neutral/ImportSpaceDialog-CSSRTFAO.mjs.map +7 -0
- package/dist/lib/neutral/{InlineSyncStatus-TBJKZCH7.mjs → InlineSyncStatus-UOUTAPCU.mjs} +4 -4
- package/dist/lib/neutral/InlineSyncStatus-UOUTAPCU.mjs.map +7 -0
- package/dist/lib/neutral/{JoinDialog-SSFKRFTJ.mjs → JoinDialog-QZGNRJ4P.mjs} +16 -9
- package/dist/lib/neutral/JoinDialog-QZGNRJ4P.mjs.map +7 -0
- package/dist/lib/neutral/{MembersContainer-KMCQDWCS.mjs → MembersContainer-OWCAMBKS.mjs} +5 -5
- package/dist/lib/neutral/MembersContainer-OWCAMBKS.mjs.map +7 -0
- package/dist/lib/neutral/{MenuFooter-5JT7V5FZ.mjs → MenuFooter-QCNFUIAO.mjs} +6 -6
- package/dist/lib/neutral/MenuFooter-QCNFUIAO.mjs.map +7 -0
- package/dist/lib/neutral/{ObjectCardStack-IXNU3HEN.mjs → ObjectCardStack-DHVDRNRK.mjs} +4 -4
- package/dist/lib/neutral/ObjectCardStack-DHVDRNRK.mjs.map +7 -0
- package/dist/lib/neutral/RecordArticle-JSORXRAA.mjs +102 -0
- package/dist/lib/neutral/RecordArticle-JSORXRAA.mjs.map +7 -0
- package/dist/lib/neutral/{RelatedArticle-YDNGUDAJ.mjs → RelatedArticle-YRCRBIYU.mjs} +11 -9
- package/dist/lib/neutral/RelatedArticle-YRCRBIYU.mjs.map +7 -0
- package/dist/lib/neutral/RenamePopover-XBZAKNM7.mjs +96 -0
- package/dist/lib/neutral/RenamePopover-XBZAKNM7.mjs.map +7 -0
- package/dist/lib/neutral/{SchemaContainer-Q4BP6X2M.mjs → SchemaContainer-2NK5YB5O.mjs} +2 -2
- package/dist/lib/neutral/SchemaContainer-2NK5YB5O.mjs.map +7 -0
- package/dist/lib/neutral/{SmallPresenceLive-GUF4WLUC.mjs → SmallPresenceLive-L4H7WJOA.mjs} +2 -2
- package/dist/lib/neutral/SpaceHomeArticle-ZV7EERLS.mjs +78 -0
- package/dist/lib/neutral/SpaceHomeArticle-ZV7EERLS.mjs.map +7 -0
- package/dist/lib/neutral/SpaceHomeRecent-ZR4LIIUD.mjs +83 -0
- package/dist/lib/neutral/SpaceHomeRecent-ZR4LIIUD.mjs.map +7 -0
- package/dist/lib/neutral/SpacePlugin.mjs +1 -1
- package/dist/lib/neutral/SpacePlugin.node.mjs +4 -4
- package/dist/lib/neutral/SpacePlugin.node.mjs.map +3 -3
- package/dist/lib/neutral/{SpacePresence-ACEXUS3N.mjs → SpacePresence-PDTEDHDE.mjs} +2 -2
- package/dist/lib/neutral/{SpaceSettings-YAHBOY5T.mjs → SpaceSettings-IVTCSLNT.mjs} +6 -6
- package/dist/lib/neutral/SpaceSettings-IVTCSLNT.mjs.map +7 -0
- package/dist/lib/neutral/{SpaceSettingsContainer-IB34TEOB.mjs → SpaceSettingsContainer-QAFQ4LWC.mjs} +8 -8
- package/dist/lib/neutral/SpaceSettingsContainer-QAFQ4LWC.mjs.map +7 -0
- package/dist/lib/neutral/{SyncStatus-CWOXWDDZ.mjs → SyncStatus-J7CHLO5O.mjs} +3 -3
- package/dist/lib/neutral/SyncStatus-J7CHLO5O.mjs.map +7 -0
- package/dist/lib/neutral/{add-object-QYOMCBJA.mjs → add-object-S64XELC3.mjs} +10 -10
- package/dist/lib/neutral/add-object-S64XELC3.mjs.map +7 -0
- package/dist/lib/neutral/{add-relation-HV3VCMJG.mjs → add-relation-GWSE42BU.mjs} +3 -3
- package/dist/lib/neutral/{add-type-CZVKSEIW.mjs → add-type-C3KYE6PI.mjs} +3 -3
- package/dist/lib/neutral/{app-graph-builder-SQGCUCDO.mjs → app-graph-builder-TMAD2ZTH.mjs} +128 -71
- package/dist/lib/neutral/app-graph-builder-TMAD2ZTH.mjs.map +7 -0
- package/dist/lib/neutral/capabilities/index.mjs +13 -15
- package/dist/lib/neutral/capabilities/index.mjs.map +3 -3
- package/dist/lib/neutral/capabilities/node.mjs +2 -2
- package/dist/lib/neutral/{chunk-EEXRKYOD.mjs → chunk-2LTGSUGQ.mjs} +2 -2
- package/dist/lib/neutral/{chunk-EEXRKYOD.mjs.map → chunk-2LTGSUGQ.mjs.map} +2 -2
- package/dist/lib/neutral/chunk-2RPQHHD7.mjs +17 -0
- package/dist/lib/neutral/chunk-2RPQHHD7.mjs.map +7 -0
- package/dist/lib/neutral/chunk-5ZZS3KMK.mjs +46 -0
- package/dist/lib/neutral/chunk-5ZZS3KMK.mjs.map +7 -0
- package/dist/lib/neutral/{chunk-K34BPPQE.mjs → chunk-DSYEB2UN.mjs} +29 -17
- package/dist/lib/neutral/chunk-DSYEB2UN.mjs.map +7 -0
- package/dist/lib/neutral/{chunk-YY62663T.mjs → chunk-F2VJ6VBV.mjs} +3 -3
- package/dist/lib/neutral/chunk-F2VJ6VBV.mjs.map +7 -0
- package/dist/lib/neutral/{chunk-JHZGRYGS.mjs → chunk-G2KHP7FX.mjs} +2 -2
- package/dist/lib/neutral/{chunk-JHZGRYGS.mjs.map → chunk-G2KHP7FX.mjs.map} +2 -2
- package/dist/lib/neutral/chunk-I5JXVBXX.mjs +8 -0
- package/dist/lib/neutral/{chunk-BBQR23DW.mjs → chunk-LY6XK5MV.mjs} +105 -128
- package/dist/lib/neutral/chunk-LY6XK5MV.mjs.map +7 -0
- package/dist/lib/neutral/{chunk-7WUJENBF.mjs → chunk-PSCIOT7Q.mjs} +4 -4
- package/dist/lib/neutral/chunk-PSCIOT7Q.mjs.map +7 -0
- package/dist/lib/neutral/{close-FGQN37PK.mjs → close-YZHFYPUN.mjs} +3 -3
- package/dist/lib/neutral/components/index.mjs +7 -7
- package/dist/lib/neutral/components/index.mjs.map +3 -3
- package/dist/lib/neutral/containers/index.mjs +23 -21
- package/dist/lib/neutral/containers/index.mjs.map +3 -3
- package/dist/lib/neutral/{create-EPIFSRJA.mjs → create-XKU2W6QC.mjs} +6 -6
- package/dist/lib/neutral/create-XKU2W6QC.mjs.map +7 -0
- package/dist/lib/neutral/{delete-LIA5M3WI.mjs → delete-EFM7CAVO.mjs} +3 -3
- package/dist/lib/neutral/{delete-field-ZIGFXFHY.mjs → delete-field-ONAPFFO5.mjs} +3 -3
- package/dist/lib/neutral/{duplicate-object-X37FM6PW.mjs → duplicate-object-OJRPFV5I.mjs} +3 -3
- package/dist/lib/neutral/{export-space-VWJHVXWF.mjs → export-space-M5RNVUQX.mjs} +3 -3
- package/dist/lib/neutral/{get-share-link-3LEA5FSK.mjs → get-share-link-FUQBJPSQ.mjs} +4 -4
- package/dist/lib/neutral/hooks/index.mjs +16 -4
- package/dist/lib/neutral/hooks/index.mjs.map +3 -3
- package/dist/lib/neutral/{identity-created-57RML5XT.mjs → identity-created-QMV4DANW.mjs} +4 -4
- package/dist/lib/neutral/identity-created-QMV4DANW.mjs.map +7 -0
- package/dist/lib/neutral/{import-space-Y5L3QE3C.mjs → import-space-L3AUIARM.mjs} +3 -3
- package/dist/lib/neutral/index.mjs +12 -6
- package/dist/lib/neutral/{join-Z5K4OAIG.mjs → join-VY3QYBU7.mjs} +4 -4
- package/dist/lib/neutral/meta.json +1 -1
- package/dist/lib/neutral/meta.mjs +1 -1
- package/dist/lib/neutral/{migrate-G7I52UKD.mjs → migrate-WPUISBC4.mjs} +3 -3
- package/dist/lib/neutral/{navigation-handler-QQJYEMAS.mjs → navigation-handler-IKXZGMII.mjs} +4 -4
- package/dist/lib/neutral/{navigation-resolver-IFVQRCGU.mjs → navigation-resolver-VBPGMFCE.mjs} +7 -7
- package/dist/lib/neutral/navigation-resolver-VBPGMFCE.mjs.map +7 -0
- package/dist/lib/neutral/{open-CPWVZSI4.mjs → open-RRYULTSY.mjs} +3 -3
- package/dist/lib/neutral/{open-create-object-4LN4PR6N.mjs → open-create-object-BRUVFZSY.mjs} +4 -4
- package/dist/lib/neutral/{open-create-space-VPAW3F2T.mjs → open-create-space-ARLQWW65.mjs} +4 -4
- package/dist/lib/neutral/{open-import-space-VLQ5V55H.mjs → open-import-space-65H57JXX.mjs} +4 -4
- package/dist/lib/neutral/{open-members-BEXOSSBS.mjs → open-members-677P6KD3.mjs} +6 -6
- package/dist/lib/neutral/open-members-677P6KD3.mjs.map +7 -0
- package/dist/lib/neutral/{open-settings-RHDBW2K5.mjs → open-settings-PRBSGO6D.mjs} +6 -6
- package/dist/lib/neutral/open-settings-PRBSGO6D.mjs.map +7 -0
- package/dist/lib/neutral/operations/index.mjs +3 -3
- package/dist/lib/neutral/plugin.mjs +4 -4
- package/dist/lib/neutral/{react-root-2DJPZQT4.mjs → react-root-YLYRCSAZ.mjs} +2 -2
- package/dist/lib/neutral/{react-root-2DJPZQT4.mjs.map → react-root-YLYRCSAZ.mjs.map} +3 -3
- package/dist/lib/neutral/{react-surface-LYCTOQLY.mjs → react-surface-5EQ6X4CL.mjs} +48 -70
- package/dist/lib/neutral/react-surface-5EQ6X4CL.mjs.map +7 -0
- package/dist/lib/neutral/{remove-objects-OWDMA4IF.mjs → remove-objects-PWJJI36V.mjs} +5 -5
- package/dist/lib/neutral/remove-objects-PWJJI36V.mjs.map +7 -0
- package/dist/lib/neutral/{rename-SR6BBSPU.mjs → rename-4727PKI4.mjs} +8 -7
- package/dist/lib/neutral/rename-4727PKI4.mjs.map +7 -0
- package/dist/lib/neutral/{rename-object-5H6E5AOX.mjs → rename-object-FXUAB5FN.mjs} +8 -7
- package/dist/lib/neutral/rename-object-FXUAB5FN.mjs.map +7 -0
- package/dist/lib/neutral/{repair-PSYRVSJ6.mjs → repair-HMH476U3.mjs} +3 -3
- package/dist/lib/neutral/repair-HMH476U3.mjs.map +7 -0
- package/dist/lib/neutral/{restore-field-UHDG2ZQM.mjs → restore-field-3ICSIHGA.mjs} +3 -3
- package/dist/lib/neutral/{restore-objects-2UD5P6OC.mjs → restore-objects-V2BTEWN3.mjs} +3 -3
- package/dist/lib/neutral/{settings-Q32EQCHX.mjs → settings-5IBSYBVU.mjs} +3 -3
- package/dist/lib/neutral/{settings-Q32EQCHX.mjs.map → settings-5IBSYBVU.mjs.map} +3 -3
- package/dist/lib/neutral/{share-5Y4NZA75.mjs → share-ZOZPAUGI.mjs} +3 -3
- package/dist/lib/neutral/{snapshot-H3HKOFVP.mjs → snapshot-ZC5PU55W.mjs} +3 -3
- package/dist/lib/neutral/{spaces-ready-GBF72QJH.mjs → spaces-ready-EXPCJD4N.mjs} +11 -11
- package/dist/lib/neutral/spaces-ready-EXPCJD4N.mjs.map +7 -0
- package/dist/lib/neutral/{state-DPBOZRAW.mjs → state-KMH2NUAL.mjs} +2 -2
- package/dist/lib/neutral/state-KMH2NUAL.mjs.map +7 -0
- package/dist/lib/neutral/testing.mjs +1 -1
- package/dist/lib/neutral/translations.mjs +4 -2
- package/dist/lib/neutral/translations.mjs.map +3 -3
- package/dist/lib/neutral/types/index.mjs +9 -3
- package/dist/lib/neutral/{undo-mappings-OBRQOYN4.mjs → undo-mappings-P43EAUGI.mjs} +5 -5
- package/dist/lib/neutral/{undo-mappings-OBRQOYN4.mjs.map → undo-mappings-P43EAUGI.mjs.map} +3 -3
- package/dist/lib/neutral/{wait-for-object-3TAWUWTP.mjs → wait-for-object-WURK2SLQ.mjs} +3 -3
- package/dist/types/dx.config.d.ts +28 -0
- package/dist/types/dx.config.d.ts.map +1 -0
- package/dist/types/src/SpacePlugin.d.ts.map +1 -1
- package/dist/types/src/capabilities/app-graph-builder/extensions/collections.d.ts +12 -0
- package/dist/types/src/capabilities/app-graph-builder/extensions/collections.d.ts.map +1 -1
- package/dist/types/src/capabilities/app-graph-builder/extensions/database.d.ts.map +1 -1
- package/dist/types/src/capabilities/app-graph-builder/extensions/shared.d.ts +0 -1
- package/dist/types/src/capabilities/app-graph-builder/extensions/shared.d.ts.map +1 -1
- package/dist/types/src/capabilities/app-graph-builder/extensions/spaces.d.ts +13 -1
- package/dist/types/src/capabilities/app-graph-builder/extensions/spaces.d.ts.map +1 -1
- package/dist/types/src/capabilities/app-graph-builder/index.d.ts +1 -1
- package/dist/types/src/capabilities/app-graph-builder/index.d.ts.map +1 -1
- package/dist/types/src/capabilities/index.d.ts +10 -54
- package/dist/types/src/capabilities/index.d.ts.map +1 -1
- package/dist/types/src/capabilities/navigation-handler/index.d.ts +1 -1
- package/dist/types/src/capabilities/navigation-handler/index.d.ts.map +1 -1
- package/dist/types/src/capabilities/navigation-resolver.d.ts.map +1 -1
- package/dist/types/src/capabilities/node.d.ts +3 -33
- package/dist/types/src/capabilities/node.d.ts.map +1 -1
- package/dist/types/src/capabilities/react-surface.d.ts +2 -2
- package/dist/types/src/capabilities/react-surface.d.ts.map +1 -1
- package/dist/types/src/commands/database/add.d.ts.map +1 -1
- package/dist/types/src/commands/queue/query.d.ts.map +1 -1
- package/dist/types/src/components/SpaceSettings/SpaceSettings.stories.d.ts +20 -0
- package/dist/types/src/components/SpaceSettings/SpaceSettings.stories.d.ts.map +1 -1
- package/dist/types/src/constants.d.ts +1 -2
- package/dist/types/src/constants.d.ts.map +1 -1
- package/dist/types/src/containers/CreateObjectDialog/CreateObjectDialog.d.ts.map +1 -1
- package/dist/types/src/containers/CreateObjectDialog/CreateObjectDialog.stories.d.ts +20 -0
- package/dist/types/src/containers/CreateObjectDialog/CreateObjectDialog.stories.d.ts.map +1 -1
- package/dist/types/src/containers/CreateSpaceDialog/CreateSpaceDialog.d.ts.map +1 -1
- package/dist/types/src/containers/CreateSpaceDialog/CreateSpaceDialog.stories.d.ts +20 -0
- package/dist/types/src/containers/CreateSpaceDialog/CreateSpaceDialog.stories.d.ts.map +1 -1
- package/dist/types/src/containers/JoinDialog/JoinDialog.d.ts.map +1 -1
- package/dist/types/src/containers/JoinDialog/JoinDialog.stories.d.ts +20 -0
- package/dist/types/src/containers/JoinDialog/JoinDialog.stories.d.ts.map +1 -1
- package/dist/types/src/containers/ObjectProperties/ObjectProperties.d.ts +1 -1
- package/dist/types/src/containers/RecordArticle/RecordArticle.d.ts.map +1 -1
- package/dist/types/src/containers/RenamePopover/RenamePopover.d.ts +12 -0
- package/dist/types/src/containers/RenamePopover/RenamePopover.d.ts.map +1 -0
- package/dist/types/src/containers/RenamePopover/index.d.ts +3 -0
- package/dist/types/src/containers/RenamePopover/index.d.ts.map +1 -0
- package/dist/types/src/containers/SpaceHomeArticle/SpaceHomeArticle.d.ts +15 -0
- package/dist/types/src/containers/SpaceHomeArticle/SpaceHomeArticle.d.ts.map +1 -0
- package/dist/types/src/containers/SpaceHomeArticle/index.d.ts +2 -0
- package/dist/types/src/containers/SpaceHomeArticle/index.d.ts.map +1 -0
- package/dist/types/src/containers/SpaceHomeRecent/SpaceHomeRecent.d.ts +22 -0
- package/dist/types/src/containers/SpaceHomeRecent/SpaceHomeRecent.d.ts.map +1 -0
- package/dist/types/src/containers/SpaceHomeRecent/index.d.ts +2 -0
- package/dist/types/src/containers/SpaceHomeRecent/index.d.ts.map +1 -0
- package/dist/types/src/containers/SpacePresence/SpacePresence.stories.d.ts +20 -0
- package/dist/types/src/containers/SpacePresence/SpacePresence.stories.d.ts.map +1 -1
- package/dist/types/src/containers/SpaceSettingsContainer/SpaceSettingsContainer.stories.d.ts +20 -0
- package/dist/types/src/containers/SpaceSettingsContainer/SpaceSettingsContainer.stories.d.ts.map +1 -1
- package/dist/types/src/containers/SyncStatus/SyncStatus.stories.d.ts +20 -0
- package/dist/types/src/containers/SyncStatus/SyncStatus.stories.d.ts.map +1 -1
- package/dist/types/src/containers/index.d.ts +3 -2
- package/dist/types/src/containers/index.d.ts.map +1 -1
- package/dist/types/src/hooks/useInputSurfaceLookup.d.ts.map +1 -1
- package/dist/types/src/hooks/useRelatedObjects.d.ts.map +1 -1
- package/dist/types/src/meta.d.ts +28 -2
- package/dist/types/src/meta.d.ts.map +1 -1
- package/dist/types/src/operations/add-object.d.ts.map +1 -1
- package/dist/types/src/operations/helpers.d.ts.map +1 -1
- package/dist/types/src/operations/remove-objects.d.ts.map +1 -1
- package/dist/types/src/operations/rename-object.d.ts.map +1 -1
- package/dist/types/src/operations/rename.d.ts.map +1 -1
- package/dist/types/src/translations.d.ts +20 -0
- package/dist/types/src/translations.d.ts.map +1 -1
- package/dist/types/src/types/capabilities.d.ts.map +1 -1
- package/dist/types/src/types/events.d.ts.map +1 -1
- package/dist/types/src/types/form.d.ts +7 -1
- package/dist/types/src/types/form.d.ts.map +1 -1
- 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/surface.d.ts +26 -0
- package/dist/types/src/types/surface.d.ts.map +1 -0
- package/dist/types/src/types/types.d.ts +7 -0
- package/dist/types/src/types/types.d.ts.map +1 -1
- package/dist/types/src/util.d.ts.map +1 -1
- package/dist/types/tsconfig.tsbuildinfo +1 -1
- package/dx.config.ts +35 -0
- package/package.json +51 -50
- package/src/SpacePlugin.test.ts +1 -1
- package/src/SpacePlugin.ts +1 -7
- package/src/capabilities/app-graph-builder/extensions/collections.ts +44 -24
- package/src/capabilities/app-graph-builder/extensions/companions.ts +3 -3
- package/src/capabilities/app-graph-builder/extensions/database.ts +17 -14
- package/src/capabilities/app-graph-builder/extensions/settings.ts +9 -9
- package/src/capabilities/app-graph-builder/extensions/shared.ts +5 -20
- package/src/capabilities/app-graph-builder/extensions/spaces.ts +49 -26
- package/src/capabilities/identity-created.ts +3 -3
- package/src/capabilities/index.ts +0 -1
- package/src/capabilities/navigation-resolver.ts +6 -13
- package/src/capabilities/react-root.tsx +1 -1
- package/src/capabilities/react-surface.tsx +58 -88
- package/src/capabilities/repair.ts +4 -2
- package/src/capabilities/settings.ts +2 -2
- package/src/capabilities/spaces-ready.ts +8 -15
- package/src/capabilities/state.ts +1 -1
- package/src/capabilities/undo-mappings.ts +3 -3
- package/src/commands/database/add.ts +4 -2
- package/src/commands/queue/query.ts +4 -3
- package/src/components/AwaitingObject/AwaitingObject.tsx +1 -1
- package/src/components/CreateObjectPanel/CreateObjectPanel.tsx +2 -2
- package/src/components/ForeignKeys/ForeignKeys.tsx +1 -1
- package/src/components/SpaceSettings/SpaceSettings.tsx +3 -3
- package/src/constants.ts +5 -6
- package/src/containers/CollectionArticle/CollectionArticle.tsx +10 -6
- package/src/containers/CollectionSection/CollectionSection.tsx +1 -1
- package/src/containers/CreateObjectDialog/CreateObjectDialog.tsx +10 -7
- package/src/containers/CreateSpaceDialog/CreateSpaceDialog.tsx +5 -5
- package/src/containers/ImportSpaceDialog/ImportSpaceDialog.tsx +3 -3
- package/src/containers/InlineSyncStatus/InlineSyncStatus.tsx +3 -3
- package/src/containers/JoinDialog/JoinDialog.tsx +13 -11
- package/src/containers/MembersContainer/MembersContainer.tsx +5 -5
- package/src/containers/MenuFooter/MenuFooter.tsx +3 -3
- package/src/containers/ObjectCardStack/ObjectCardStack.tsx +3 -3
- package/src/containers/RecordArticle/RecordArticle.tsx +67 -8
- package/src/containers/RelatedArticle/RelatedArticle.tsx +17 -13
- package/src/containers/RenamePopover/RenamePopover.tsx +112 -0
- package/src/containers/RenamePopover/index.ts +6 -0
- package/src/containers/SchemaContainer/SchemaContainer.tsx +1 -1
- package/src/containers/SpaceHomeArticle/SpaceHomeArticle.tsx +100 -0
- package/src/containers/SpaceHomeArticle/index.ts +5 -0
- package/src/containers/SpaceHomeRecent/SpaceHomeRecent.tsx +101 -0
- package/src/containers/SpaceHomeRecent/index.ts +5 -0
- package/src/containers/SpacePresence/SpacePresence.tsx +1 -1
- package/src/containers/SpaceSettingsContainer/SpaceSettingsContainer.tsx +7 -7
- package/src/containers/SyncStatus/SyncStatus.tsx +2 -2
- package/src/containers/index.ts +3 -2
- package/src/hooks/useInputSurfaceLookup.tsx +3 -2
- package/src/hooks/useRelatedObjects.ts +13 -1
- package/src/meta.ts +2 -27
- package/src/operations/add-object.ts +7 -14
- package/src/operations/create.ts +2 -2
- package/src/operations/definitions.ts +1 -1
- package/src/operations/helpers.ts +1 -1
- package/src/operations/open-members.ts +3 -3
- package/src/operations/open-settings.ts +3 -3
- package/src/operations/remove-objects.ts +3 -2
- package/src/operations/rename-object.ts +3 -2
- package/src/operations/rename.ts +3 -2
- package/src/translations.ts +3 -1
- package/src/types/capabilities.ts +8 -8
- package/src/types/events.ts +5 -5
- package/src/types/form.ts +5 -1
- package/src/types/index.ts +1 -0
- package/src/types/surface.ts +31 -0
- package/src/types/types.ts +9 -1
- package/src/util.ts +3 -3
- package/dist/lib/neutral/CollectionArticle-S3OF5KJ7.mjs.map +0 -7
- package/dist/lib/neutral/CreateObjectDialog-66R3K6I3.mjs.map +0 -7
- package/dist/lib/neutral/CreateSpaceDialog-CDGSEIJB.mjs.map +0 -7
- package/dist/lib/neutral/EntityRenamePopover-MYSW262F.mjs +0 -59
- package/dist/lib/neutral/EntityRenamePopover-MYSW262F.mjs.map +0 -7
- package/dist/lib/neutral/ImportSpaceDialog-7GKV4OTF.mjs.map +0 -7
- package/dist/lib/neutral/InlineSyncStatus-TBJKZCH7.mjs.map +0 -7
- package/dist/lib/neutral/JoinDialog-SSFKRFTJ.mjs.map +0 -7
- package/dist/lib/neutral/MembersContainer-KMCQDWCS.mjs.map +0 -7
- package/dist/lib/neutral/MenuFooter-5JT7V5FZ.mjs.map +0 -7
- package/dist/lib/neutral/ObjectCardStack-IXNU3HEN.mjs.map +0 -7
- package/dist/lib/neutral/RecordArticle-QWGH25NT.mjs +0 -51
- package/dist/lib/neutral/RecordArticle-QWGH25NT.mjs.map +0 -7
- package/dist/lib/neutral/RelatedArticle-YDNGUDAJ.mjs.map +0 -7
- package/dist/lib/neutral/SchemaContainer-Q4BP6X2M.mjs.map +0 -7
- package/dist/lib/neutral/SpaceRenamePopover-KFWL4CTJ.mjs +0 -56
- package/dist/lib/neutral/SpaceRenamePopover-KFWL4CTJ.mjs.map +0 -7
- package/dist/lib/neutral/SpaceSettings-YAHBOY5T.mjs.map +0 -7
- package/dist/lib/neutral/SpaceSettingsContainer-IB34TEOB.mjs.map +0 -7
- package/dist/lib/neutral/SyncStatus-CWOXWDDZ.mjs.map +0 -7
- package/dist/lib/neutral/add-object-QYOMCBJA.mjs.map +0 -7
- package/dist/lib/neutral/app-graph-builder-SQGCUCDO.mjs.map +0 -7
- package/dist/lib/neutral/app-graph-serializer-IBPPU5VR.mjs +0 -81
- package/dist/lib/neutral/app-graph-serializer-IBPPU5VR.mjs.map +0 -7
- package/dist/lib/neutral/chunk-4RTSNTDC.mjs +0 -37
- package/dist/lib/neutral/chunk-4RTSNTDC.mjs.map +0 -7
- package/dist/lib/neutral/chunk-7WUJENBF.mjs.map +0 -7
- package/dist/lib/neutral/chunk-B7DBIARR.mjs +0 -8
- package/dist/lib/neutral/chunk-BBQR23DW.mjs.map +0 -7
- package/dist/lib/neutral/chunk-F5MESIRH.mjs +0 -19
- package/dist/lib/neutral/chunk-F5MESIRH.mjs.map +0 -7
- package/dist/lib/neutral/chunk-K34BPPQE.mjs.map +0 -7
- package/dist/lib/neutral/chunk-YY62663T.mjs.map +0 -7
- package/dist/lib/neutral/create-EPIFSRJA.mjs.map +0 -7
- package/dist/lib/neutral/identity-created-57RML5XT.mjs.map +0 -7
- package/dist/lib/neutral/navigation-resolver-IFVQRCGU.mjs.map +0 -7
- package/dist/lib/neutral/open-members-BEXOSSBS.mjs.map +0 -7
- package/dist/lib/neutral/open-settings-RHDBW2K5.mjs.map +0 -7
- package/dist/lib/neutral/react-surface-LYCTOQLY.mjs.map +0 -7
- package/dist/lib/neutral/remove-objects-OWDMA4IF.mjs.map +0 -7
- package/dist/lib/neutral/rename-SR6BBSPU.mjs.map +0 -7
- package/dist/lib/neutral/rename-object-5H6E5AOX.mjs.map +0 -7
- package/dist/lib/neutral/repair-PSYRVSJ6.mjs.map +0 -7
- package/dist/lib/neutral/spaces-ready-GBF72QJH.mjs.map +0 -7
- package/dist/lib/neutral/state-DPBOZRAW.mjs.map +0 -7
- package/dist/types/src/capabilities/app-graph-serializer.d.ts +0 -5
- package/dist/types/src/capabilities/app-graph-serializer.d.ts.map +0 -1
- package/dist/types/src/containers/EntityRenamePopover/EntityRenamePopover.d.ts +0 -7
- package/dist/types/src/containers/EntityRenamePopover/EntityRenamePopover.d.ts.map +0 -1
- package/dist/types/src/containers/EntityRenamePopover/index.d.ts +0 -2
- package/dist/types/src/containers/EntityRenamePopover/index.d.ts.map +0 -1
- package/dist/types/src/containers/SpaceRenamePopover/SpaceRenamePopover.d.ts +0 -7
- package/dist/types/src/containers/SpaceRenamePopover/SpaceRenamePopover.d.ts.map +0 -1
- package/dist/types/src/containers/SpaceRenamePopover/index.d.ts +0 -2
- package/dist/types/src/containers/SpaceRenamePopover/index.d.ts.map +0 -1
- package/src/capabilities/app-graph-serializer.ts +0 -85
- package/src/containers/EntityRenamePopover/EntityRenamePopover.tsx +0 -52
- package/src/containers/EntityRenamePopover/index.ts +0 -5
- package/src/containers/SpaceRenamePopover/SpaceRenamePopover.tsx +0 -54
- package/src/containers/SpaceRenamePopover/index.ts +0 -5
- /package/dist/lib/neutral/{SmallPresenceLive-GUF4WLUC.mjs.map → SmallPresenceLive-L4H7WJOA.mjs.map} +0 -0
- /package/dist/lib/neutral/{SpacePresence-ACEXUS3N.mjs.map → SpacePresence-PDTEDHDE.mjs.map} +0 -0
- /package/dist/lib/neutral/{add-relation-HV3VCMJG.mjs.map → add-relation-GWSE42BU.mjs.map} +0 -0
- /package/dist/lib/neutral/{add-type-CZVKSEIW.mjs.map → add-type-C3KYE6PI.mjs.map} +0 -0
- /package/dist/lib/neutral/{chunk-B7DBIARR.mjs.map → chunk-I5JXVBXX.mjs.map} +0 -0
- /package/dist/lib/neutral/{close-FGQN37PK.mjs.map → close-YZHFYPUN.mjs.map} +0 -0
- /package/dist/lib/neutral/{delete-LIA5M3WI.mjs.map → delete-EFM7CAVO.mjs.map} +0 -0
- /package/dist/lib/neutral/{delete-field-ZIGFXFHY.mjs.map → delete-field-ONAPFFO5.mjs.map} +0 -0
- /package/dist/lib/neutral/{duplicate-object-X37FM6PW.mjs.map → duplicate-object-OJRPFV5I.mjs.map} +0 -0
- /package/dist/lib/neutral/{export-space-VWJHVXWF.mjs.map → export-space-M5RNVUQX.mjs.map} +0 -0
- /package/dist/lib/neutral/{get-share-link-3LEA5FSK.mjs.map → get-share-link-FUQBJPSQ.mjs.map} +0 -0
- /package/dist/lib/neutral/{import-space-Y5L3QE3C.mjs.map → import-space-L3AUIARM.mjs.map} +0 -0
- /package/dist/lib/neutral/{join-Z5K4OAIG.mjs.map → join-VY3QYBU7.mjs.map} +0 -0
- /package/dist/lib/neutral/{migrate-G7I52UKD.mjs.map → migrate-WPUISBC4.mjs.map} +0 -0
- /package/dist/lib/neutral/{navigation-handler-QQJYEMAS.mjs.map → navigation-handler-IKXZGMII.mjs.map} +0 -0
- /package/dist/lib/neutral/{open-CPWVZSI4.mjs.map → open-RRYULTSY.mjs.map} +0 -0
- /package/dist/lib/neutral/{open-create-object-4LN4PR6N.mjs.map → open-create-object-BRUVFZSY.mjs.map} +0 -0
- /package/dist/lib/neutral/{open-create-space-VPAW3F2T.mjs.map → open-create-space-ARLQWW65.mjs.map} +0 -0
- /package/dist/lib/neutral/{open-import-space-VLQ5V55H.mjs.map → open-import-space-65H57JXX.mjs.map} +0 -0
- /package/dist/lib/neutral/{restore-field-UHDG2ZQM.mjs.map → restore-field-3ICSIHGA.mjs.map} +0 -0
- /package/dist/lib/neutral/{restore-objects-2UD5P6OC.mjs.map → restore-objects-V2BTEWN3.mjs.map} +0 -0
- /package/dist/lib/neutral/{share-5Y4NZA75.mjs.map → share-ZOZPAUGI.mjs.map} +0 -0
- /package/dist/lib/neutral/{snapshot-H3HKOFVP.mjs.map → snapshot-ZC5PU55W.mjs.map} +0 -0
- /package/dist/lib/neutral/{wait-for-object-3TAWUWTP.mjs.map → wait-for-object-WURK2SLQ.mjs.map} +0 -0
|
@@ -3,16 +3,16 @@ import "./chunk-J5LGTIGS.mjs";
|
|
|
3
3
|
// src/containers/CollectionArticle/CollectionArticle.tsx
|
|
4
4
|
import React, { useCallback, useMemo } from "react";
|
|
5
5
|
import { useOperationInvoker } from "@dxos/app-framework/ui";
|
|
6
|
-
import { LayoutOperation,
|
|
6
|
+
import { LayoutOperation, Paths } from "@dxos/app-toolkit";
|
|
7
7
|
import { Obj } from "@dxos/echo";
|
|
8
8
|
import { ScrollArea, toLocalizedString, useTranslation } from "@dxos/react-ui";
|
|
9
|
-
import { Card,
|
|
9
|
+
import { Card, Icon } from "@dxos/react-ui";
|
|
10
10
|
import { Mosaic } from "@dxos/react-ui-mosaic";
|
|
11
11
|
import { SearchPanel, useSearchListResults } from "@dxos/react-ui-search";
|
|
12
12
|
import { getStyles } from "@dxos/ui-theme";
|
|
13
13
|
import { meta } from "#meta";
|
|
14
14
|
var CollectionArticle = ({ subject, attendableId }) => {
|
|
15
|
-
const { t } = useTranslation(meta.
|
|
15
|
+
const { t } = useTranslation(meta.profile.key);
|
|
16
16
|
const { items, handleSearch } = useCollectionItems(subject, attendableId);
|
|
17
17
|
return /* @__PURE__ */ React.createElement(SearchPanel, {
|
|
18
18
|
onSearch: handleSearch
|
|
@@ -31,7 +31,7 @@ var CollectionArticle = ({ subject, attendableId }) => {
|
|
|
31
31
|
})))));
|
|
32
32
|
};
|
|
33
33
|
var ObjectTile = ({ data: item }) => {
|
|
34
|
-
const { t } = useTranslation(meta.
|
|
34
|
+
const { t } = useTranslation(meta.profile.key);
|
|
35
35
|
const { invokePromise } = useOperationInvoker();
|
|
36
36
|
const typename = Obj.getTypename(item.object) ?? "";
|
|
37
37
|
const label = Obj.getLabel(item.object) ?? toLocalizedString([
|
|
@@ -55,13 +55,10 @@ var ObjectTile = ({ data: item }) => {
|
|
|
55
55
|
role: "button",
|
|
56
56
|
classNames: "cursor-pointer",
|
|
57
57
|
onClick: handleClick
|
|
58
|
-
}, /* @__PURE__ */ React.createElement(Card.Header, null, /* @__PURE__ */ React.createElement(
|
|
59
|
-
variant: "ghost",
|
|
60
|
-
label,
|
|
58
|
+
}, /* @__PURE__ */ React.createElement(Card.Header, null, /* @__PURE__ */ React.createElement(Card.Block, null, /* @__PURE__ */ React.createElement(Icon, {
|
|
61
59
|
icon: item.icon,
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
}), /* @__PURE__ */ React.createElement(Card.Title, null, label), /* @__PURE__ */ React.createElement(Card.Menu, null)));
|
|
60
|
+
classNames: styles?.fg
|
|
61
|
+
})), /* @__PURE__ */ React.createElement(Card.Title, null, label), /* @__PURE__ */ React.createElement(Card.Menu, null)));
|
|
65
62
|
};
|
|
66
63
|
var useCollectionItems = (collection, attendableId) => {
|
|
67
64
|
const objects = useMemo(() => (collection.objects ?? []).map((ref) => ref.target).filter((obj) => Obj.isObject(obj)), [
|
|
@@ -69,7 +66,7 @@ var useCollectionItems = (collection, attendableId) => {
|
|
|
69
66
|
]);
|
|
70
67
|
const items = useMemo(() => objects.map((obj) => {
|
|
71
68
|
const iconAnnotation = Obj.getIcon(obj);
|
|
72
|
-
const targetPath = attendableId ? getCollectionObjectPath(attendableId, obj.id) : getObjectPathFromObject(obj);
|
|
69
|
+
const targetPath = attendableId ? Paths.getCollectionObjectPath(attendableId, obj.id) : Paths.getObjectPathFromObject(obj);
|
|
73
70
|
return {
|
|
74
71
|
id: Obj.getURI(obj),
|
|
75
72
|
object: obj,
|
|
@@ -93,4 +90,4 @@ var useCollectionItems = (collection, attendableId) => {
|
|
|
93
90
|
export {
|
|
94
91
|
CollectionArticle as default
|
|
95
92
|
};
|
|
96
|
-
//# sourceMappingURL=CollectionArticle-
|
|
93
|
+
//# sourceMappingURL=CollectionArticle-BMH7SZ7Q.mjs.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../src/containers/CollectionArticle/CollectionArticle.tsx"],
|
|
4
|
+
"sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport React, { useCallback, useMemo } from 'react';\n\nimport { useOperationInvoker } from '@dxos/app-framework/ui';\nimport { LayoutOperation, Paths } from '@dxos/app-toolkit';\nimport { type AppSurface } from '@dxos/app-toolkit/ui';\nimport { type Collection, Obj } from '@dxos/echo';\nimport { ScrollArea, toLocalizedString, useTranslation } from '@dxos/react-ui';\nimport { Card, Icon } from '@dxos/react-ui';\nimport { Mosaic, type MosaicStackTileComponent } from '@dxos/react-ui-mosaic';\nimport { SearchPanel, useSearchListResults } from '@dxos/react-ui-search';\nimport { getStyles } from '@dxos/ui-theme';\n\nimport { meta } from '#meta';\n\n/**\n * Article view for collections.\n */\nexport const CollectionArticle = ({ subject, attendableId }: AppSurface.ObjectArticleProps<Collection.Collection>) => {\n const { t } = useTranslation(meta.profile.key);\n const { items, handleSearch } = useCollectionItems(subject, attendableId);\n\n return (\n <SearchPanel onSearch={handleSearch}>\n <Mosaic.Container asChild>\n <ScrollArea.Root centered padding thin>\n <ScrollArea.Viewport>\n <Mosaic.Stack\n classNames='gap-1'\n draggable={false}\n items={items}\n getId={(item) => item.id}\n Tile={ObjectTile}\n />\n </ScrollArea.Viewport>\n </ScrollArea.Root>\n </Mosaic.Container>\n </SearchPanel>\n );\n};\n\ntype ObjectItem = {\n id: string;\n object: Obj.Unknown;\n targetPath: string;\n icon: string;\n iconHue?: string;\n};\n\nconst ObjectTile: MosaicStackTileComponent<ObjectItem> = ({ data: item }) => {\n const { t } = useTranslation(meta.profile.key);\n const { invokePromise } = useOperationInvoker();\n\n const typename = Obj.getTypename(item.object) ?? '';\n const label =\n Obj.getLabel(item.object) ??\n toLocalizedString(['object-name.placeholder', { ns: typename, defaultValue: item.id }], t);\n const styles = item.iconHue ? getStyles(item.iconHue) : undefined;\n\n const handleClick = useCallback(\n () => void invokePromise(LayoutOperation.Open, { subject: [item.targetPath] }),\n [invokePromise, item.targetPath],\n );\n\n return (\n <Card.Root fullWidth role='button' classNames='cursor-pointer' onClick={handleClick}>\n <Card.Header>\n <Card.Block>\n <Icon icon={item.icon} classNames={styles?.fg} />\n </Card.Block>\n <Card.Title>{label}</Card.Title>\n <Card.Menu />\n </Card.Header>\n </Card.Root>\n );\n};\n\n/**\n * Combined hook to get collection items with search/filter support.\n */\nconst useCollectionItems = (collection: Collection.Collection, attendableId?: string) => {\n const objects = useMemo(\n () => (collection.objects ?? []).map((ref) => ref.target).filter((obj): obj is Obj.Unknown => Obj.isObject(obj)),\n [collection.objects],\n );\n\n const items = useMemo(\n () =>\n objects.map((obj) => {\n const iconAnnotation = Obj.getIcon(obj);\n const targetPath = attendableId\n ? Paths.getCollectionObjectPath(attendableId, obj.id)\n : Paths.getObjectPathFromObject(obj);\n\n return {\n id: Obj.getURI(obj),\n object: obj,\n targetPath,\n icon: iconAnnotation?.icon ?? 'ph--circle-dashed--regular',\n iconHue: iconAnnotation?.hue,\n } satisfies ObjectItem;\n }),\n [objects, attendableId],\n );\n\n const { results, handleSearch } = useSearchListResults({\n items,\n extract: (item) => Obj.getLabel(item.object) ?? item.id,\n });\n\n return { items: results, handleSearch };\n};\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
|
+
"names": ["React", "useCallback", "useMemo", "useOperationInvoker", "LayoutOperation", "Paths", "Obj", "ScrollArea", "toLocalizedString", "useTranslation", "Card", "Icon", "Mosaic", "SearchPanel", "useSearchListResults", "getStyles", "meta", "CollectionArticle", "subject", "attendableId", "t", "profile", "key", "items", "handleSearch", "useCollectionItems", "onSearch", "Container", "asChild", "Root", "centered", "padding", "thin", "Viewport", "Stack", "classNames", "draggable", "getId", "item", "id", "Tile", "ObjectTile", "data", "invokePromise", "typename", "getTypename", "object", "label", "getLabel", "ns", "defaultValue", "styles", "iconHue", "undefined", "handleClick", "Open", "targetPath", "fullWidth", "role", "onClick", "Header", "Block", "icon", "fg", "Title", "Menu", "collection", "objects", "map", "ref", "target", "filter", "obj", "isObject", "iconAnnotation", "getIcon", "getCollectionObjectPath", "getObjectPathFromObject", "getURI", "hue", "results", "extract"]
|
|
7
|
+
}
|
|
@@ -5,7 +5,7 @@ import React from "react";
|
|
|
5
5
|
import { useTranslation } from "@dxos/react-ui";
|
|
6
6
|
import { meta } from "#meta";
|
|
7
7
|
var CollectionSection = ({ role, subject }) => {
|
|
8
|
-
const { t } = useTranslation(meta.
|
|
8
|
+
const { t } = useTranslation(meta.profile.key);
|
|
9
9
|
return /* @__PURE__ */ React.createElement("div", {
|
|
10
10
|
role,
|
|
11
11
|
className: "min-h-[3.5rem] grid grid-rows-subgrid grid-cols-subgrid items-center"
|
|
@@ -16,4 +16,4 @@ var CollectionSection = ({ role, subject }) => {
|
|
|
16
16
|
export {
|
|
17
17
|
CollectionSection as default
|
|
18
18
|
};
|
|
19
|
-
//# sourceMappingURL=CollectionSection-
|
|
19
|
+
//# sourceMappingURL=CollectionSection-BLYTGOKH.mjs.map
|
package/dist/lib/neutral/{CollectionSection-A5WRHE5Z.mjs.map → CollectionSection-BLYTGOKH.mjs.map}
RENAMED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../../../src/containers/CollectionSection/CollectionSection.tsx"],
|
|
4
|
-
"sourcesContent": ["//\n// Copyright 2023 DXOS.org\n//\n\nimport React from 'react';\n\nimport { type AppSurface } from '@dxos/app-toolkit/ui';\nimport { type Collection } from '@dxos/echo';\nimport { useTranslation } from '@dxos/react-ui';\n\nimport { meta } from '#meta';\n\nexport type CollectionSectionProps = AppSurface.ObjectSectionProps<Collection.Collection>;\n\nexport const CollectionSection = ({ role, subject }: CollectionSectionProps) => {\n const { t } = useTranslation(meta.
|
|
5
|
-
"mappings": ";;;AAIA,OAAOA,WAAW;AAIlB,SAASC,sBAAsB;AAE/B,SAASC,YAAY;AAId,IAAMC,oBAAoB,CAAC,EAAEC,MAAMC,QAAO,MAA0B;AACzE,QAAM,EAAEC,EAAC,IAAKL,eAAeC,KAAKK,
|
|
6
|
-
"names": ["React", "useTranslation", "meta", "CollectionSection", "role", "subject", "t", "
|
|
4
|
+
"sourcesContent": ["//\n// Copyright 2023 DXOS.org\n//\n\nimport React from 'react';\n\nimport { type AppSurface } from '@dxos/app-toolkit/ui';\nimport { type Collection } from '@dxos/echo';\nimport { useTranslation } from '@dxos/react-ui';\n\nimport { meta } from '#meta';\n\nexport type CollectionSectionProps = AppSurface.ObjectSectionProps<Collection.Collection>;\n\nexport const CollectionSection = ({ role, subject }: CollectionSectionProps) => {\n const { t } = useTranslation(meta.profile.key);\n\n // TODO(wittjosiah): Better placeholder.\n return (\n <div role={role} className='min-h-[3.5rem] grid grid-rows-subgrid grid-cols-subgrid items-center'>\n <span className='truncate'>{subject.name ?? t('unnamed-collection.label')}</span>\n </div>\n );\n};\n"],
|
|
5
|
+
"mappings": ";;;AAIA,OAAOA,WAAW;AAIlB,SAASC,sBAAsB;AAE/B,SAASC,YAAY;AAId,IAAMC,oBAAoB,CAAC,EAAEC,MAAMC,QAAO,MAA0B;AACzE,QAAM,EAAEC,EAAC,IAAKL,eAAeC,KAAKK,QAAQC,GAAG;AAG7C,SACE,sBAAA,cAACC,OAAAA;IAAIL;IAAYM,WAAU;KACzB,sBAAA,cAACC,QAAAA;IAAKD,WAAU;KAAYL,QAAQO,QAAQN,EAAE,0BAAA,CAAA,CAAA;AAGpD;",
|
|
6
|
+
"names": ["React", "useTranslation", "meta", "CollectionSection", "role", "subject", "t", "profile", "key", "div", "className", "span", "name"]
|
|
7
7
|
}
|
package/dist/lib/neutral/{CreateObjectDialog-66R3K6I3.mjs → CreateObjectDialog-4VMOUKM7.mjs}
RENAMED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import {
|
|
2
2
|
getSpaceDisplayName
|
|
3
|
-
} from "./chunk-
|
|
4
|
-
import "./chunk-
|
|
3
|
+
} from "./chunk-PSCIOT7Q.mjs";
|
|
4
|
+
import "./chunk-DSYEB2UN.mjs";
|
|
5
5
|
import "./chunk-J5LGTIGS.mjs";
|
|
6
6
|
|
|
7
7
|
// src/containers/CreateObjectDialog/CreateObjectDialog.tsx
|
|
@@ -11,7 +11,7 @@ import * as Option from "effect/Option";
|
|
|
11
11
|
import React, { useCallback, useMemo, useRef, useState } from "react";
|
|
12
12
|
import { Capability } from "@dxos/app-framework";
|
|
13
13
|
import { useOperationInvoker, usePluginManager } from "@dxos/app-framework/ui";
|
|
14
|
-
import {
|
|
14
|
+
import { AppSpace, LayoutOperation, TypeOptions } from "@dxos/app-toolkit";
|
|
15
15
|
import { PluginRegistryButton, useLayout } from "@dxos/app-toolkit/ui";
|
|
16
16
|
import { Operation } from "@dxos/compute";
|
|
17
17
|
import { Annotation, Database, Obj, Type } from "@dxos/echo";
|
|
@@ -26,9 +26,9 @@ import { CreateObjectPanel } from "#components";
|
|
|
26
26
|
import { meta } from "#meta";
|
|
27
27
|
import { SpaceCapabilities } from "#types";
|
|
28
28
|
var __dxlog_file = "/__w/dxos/dxos/packages/plugins/plugin-space/src/containers/CreateObjectDialog/CreateObjectDialog.tsx";
|
|
29
|
-
var CREATE_OBJECT_DIALOG = `${meta.
|
|
29
|
+
var CREATE_OBJECT_DIALOG = `${meta.profile.key}.CreateObjectDialog`;
|
|
30
30
|
var CreateObjectDialog = ({ target: initialTarget, typename: initialTypename, views, initialFormValues, onCreateObject, shouldNavigate: _shouldNavigate, targetNodeId }) => {
|
|
31
|
-
const { t } = useTranslation(meta.
|
|
31
|
+
const { t } = useTranslation(meta.profile.key);
|
|
32
32
|
const manager = usePluginManager();
|
|
33
33
|
const operationInvoker = useOperationInvoker();
|
|
34
34
|
const { invoke } = operationInvoker;
|
|
@@ -39,13 +39,13 @@ var CreateObjectDialog = ({ target: initialTarget, typename: initialTypename, vi
|
|
|
39
39
|
const layout = useLayout();
|
|
40
40
|
const closeRef = useRef(null);
|
|
41
41
|
const db = Database.isDatabase(target) ? target : target && Obj.getDatabase(target);
|
|
42
|
-
const allTypes = useQuery(db, allTypesQuery);
|
|
42
|
+
const allTypes = useQuery(db, TypeOptions.allTypesQuery);
|
|
43
43
|
const space = useMemo(() => spaces.find((s) => s.db === db), [
|
|
44
44
|
spaces,
|
|
45
45
|
db
|
|
46
46
|
]);
|
|
47
47
|
const spaceLabel = useMemo(() => space && toLocalizedString(getSpaceDisplayName(space, {
|
|
48
|
-
personal: space.id === getPersonalSpace(client)?.id
|
|
48
|
+
personal: space.id === AppSpace.getPersonalSpace(client)?.id
|
|
49
49
|
}), t), [
|
|
50
50
|
space,
|
|
51
51
|
client,
|
|
@@ -70,7 +70,7 @@ var CreateObjectDialog = ({ target: initialTarget, typename: initialTypename, vi
|
|
|
70
70
|
for (const entry of contributions) {
|
|
71
71
|
entries.push(entry);
|
|
72
72
|
if (owningPlugin) {
|
|
73
|
-
pluginByEntryId.set(entry.id, owningPlugin.meta.name);
|
|
73
|
+
pluginByEntryId.set(entry.id, owningPlugin.meta.profile.name);
|
|
74
74
|
}
|
|
75
75
|
}
|
|
76
76
|
}
|
|
@@ -190,7 +190,7 @@ var CreateObjectDialog = ({ target: initialTarget, typename: initialTypename, vi
|
|
|
190
190
|
target,
|
|
191
191
|
typename,
|
|
192
192
|
initialFormValues,
|
|
193
|
-
defaultSpaceId: getPersonalSpace(client)?.id ?? client.spaces.get()[0]?.id,
|
|
193
|
+
defaultSpaceId: AppSpace.getPersonalSpace(client)?.id ?? client.spaces.get()[0]?.id,
|
|
194
194
|
resolve,
|
|
195
195
|
onCreateObject: handleCreateObject,
|
|
196
196
|
onTargetChange: setTarget,
|
|
@@ -203,4 +203,4 @@ export {
|
|
|
203
203
|
CreateObjectDialog,
|
|
204
204
|
CreateObjectDialog as default
|
|
205
205
|
};
|
|
206
|
-
//# sourceMappingURL=CreateObjectDialog-
|
|
206
|
+
//# sourceMappingURL=CreateObjectDialog-4VMOUKM7.mjs.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../src/containers/CreateObjectDialog/CreateObjectDialog.tsx"],
|
|
4
|
+
"sourcesContent": ["//\n// Copyright 2024 DXOS.org\n//\n\nimport { useAtomValue } from '@effect-atom/atom-react';\nimport * as Effect from 'effect/Effect';\nimport * as Option from 'effect/Option';\nimport React, { useCallback, useMemo, useRef, useState } from 'react';\n\nimport { Capability } from '@dxos/app-framework';\nimport { useOperationInvoker, usePluginManager } from '@dxos/app-framework/ui';\nimport { AppSpace, LayoutOperation, TypeOptions } from '@dxos/app-toolkit';\nimport { PluginRegistryButton, useLayout } from '@dxos/app-toolkit/ui';\nimport { Operation } from '@dxos/compute';\nimport { Annotation, Collection, Database, Obj, Type } from '@dxos/echo';\nimport { EffectEx } from '@dxos/effect';\nimport { invariant } from '@dxos/invariant';\nimport { useClient } from '@dxos/react-client';\nimport { useQuery, useSpaces } from '@dxos/react-client/echo';\nimport { Dialog, toLocalizedString, useTranslation } from '@dxos/react-ui';\nimport { ViewAnnotation } from '@dxos/schema';\n\nimport { makeCreateObjectEntryForDatabaseType } from '#capabilities';\nimport { type CreateObjectOption, CreateObjectPanel, type CreateObjectPanelProps } from '#components';\nimport { meta } from '#meta';\nimport { SpaceCapabilities } from '#types';\n\nimport { getSpaceDisplayName } from '../../util';\n\nexport const CREATE_OBJECT_DIALOG = `${meta.profile.key}.CreateObjectDialog`;\n\nexport type CreateObjectDialogProps = Pick<CreateObjectPanelProps, 'target' | 'typename' | 'initialFormValues'> & {\n views?: boolean;\n onCreateObject?: (object: Obj.Unknown) => void;\n shouldNavigate?: (object: Obj.Unknown) => boolean;\n targetNodeId?: string;\n};\n\nexport const CreateObjectDialog = ({\n target: initialTarget,\n typename: initialTypename,\n views,\n initialFormValues,\n onCreateObject,\n shouldNavigate: _shouldNavigate,\n targetNodeId,\n}: CreateObjectDialogProps) => {\n const { t } = useTranslation(meta.profile.key);\n const manager = usePluginManager();\n const operationInvoker = useOperationInvoker();\n const { invoke } = operationInvoker;\n const [target, setTarget] = useState<Database.Database | Collection.Collection | undefined>(initialTarget);\n const [typename, setTypename] = useState<string | undefined>(initialTypename);\n const client = useClient();\n const spaces = useSpaces();\n const layout = useLayout();\n const closeRef = useRef<HTMLButtonElement | null>(null);\n\n const db = Database.isDatabase(target) ? target : target && Obj.getDatabase(target);\n const allTypes = useQuery(db, TypeOptions.allTypesQuery);\n const space = useMemo(() => spaces.find((s) => s.db === db), [spaces, db]);\n const spaceLabel = useMemo(\n () =>\n space &&\n toLocalizedString(\n getSpaceDisplayName(space, { personal: space.id === AppSpace.getPersonalSpace(client)?.id }),\n t,\n ),\n [space, client, t],\n );\n\n // Index all types by typename for label/icon lookups.\n const typeByTypename = useMemo(() => {\n const map = new Map<string, Type.AnyEntity>();\n for (const type of allTypes) {\n map.set(Type.getTypename(type), type);\n }\n return map;\n }, [allTypes]);\n\n const entriesByModule = useAtomValue(manager.capabilities.atomByModule(SpaceCapabilities.CreateObjectEntry));\n\n const { capabilityEntries, pluginNameByEntryId } = useMemo(() => {\n const entries: SpaceCapabilities.CreateObjectEntry[] = [];\n const pluginByEntryId = new Map<string, string>();\n const plugins = manager.getPlugins();\n for (const [moduleId, contributions] of Object.entries(entriesByModule)) {\n const owningPlugin = plugins.find((plugin) => plugin.modules.some((module) => module.id === moduleId));\n for (const entry of contributions) {\n entries.push(entry);\n if (owningPlugin) {\n pluginByEntryId.set(entry.id, owningPlugin.meta.profile.name);\n }\n }\n }\n return { capabilityEntries: entries, pluginNameByEntryId: pluginByEntryId };\n }, [entriesByModule, manager]);\n\n // Synthesize entries for database-persisted object schemas that have no registered capability.\n const createObjectEntries = useMemo(() => {\n const registeredIds = new Set(capabilityEntries.map((e) => e.id));\n // allTypesQuery returns meta-schema entities which may be any entity kind at runtime,\n // but the query's TypeScript type is conservatively AnyType[]; widen to enable kind narrowing below.\n const dbEntries = (allTypes as Type.AnyEntity[])\n .filter((type): type is Type.AnyObj => Type.isObject(type) && Type.getDatabase(type) != null)\n .filter((type) => !registeredIds.has(Type.getTypename(type)))\n .map((type) => makeCreateObjectEntryForDatabaseType(type));\n return [...capabilityEntries, ...dbEntries];\n }, [capabilityEntries, allTypes]);\n\n const resolve = useCallback<NonNullable<CreateObjectPanelProps['resolve']>>(\n (id) => createObjectEntries.find((entry) => entry.id === id),\n [createObjectEntries],\n );\n\n // The type selector is shown while no type has been resolved; the registry button is only relevant then.\n const showTypeSelector = !(typename && resolve(typename));\n\n const viewTypenames = useMemo(() => {\n const set = new Set<string>();\n for (const [name, type] of typeByTypename) {\n if (ViewAnnotation.has(type)) {\n set.add(name);\n }\n }\n return set;\n }, [typeByTypename]);\n\n const options = useMemo<CreateObjectOption[]>(\n () =>\n createObjectEntries\n .filter((entry) => (views === true ? viewTypenames.has(entry.id) : true))\n .map((entry) => {\n const type = typeByTypename.get(entry.id);\n const schema = type && Type.getSchema(type);\n const iconAnnotation = schema ? Annotation.IconAnnotation.get(schema).pipe(Option.getOrUndefined) : undefined;\n const isDatabase = type ? Type.getDatabase(type) != null : false;\n return {\n id: entry.id,\n label:\n (isDatabase && type ? Type.getLabel(type) : undefined) ??\n t('typename.label', { ns: entry.id, defaultValue: entry.id }),\n icon: iconAnnotation?.icon,\n iconHue: iconAnnotation?.hue,\n plugin: pluginNameByEntryId.get(entry.id),\n description: isDatabase ? spaceLabel : undefined,\n };\n }),\n [createObjectEntries, views, viewTypenames, typeByTypename, t, pluginNameByEntryId, spaceLabel],\n );\n\n const handleCreateObject = useCallback<NonNullable<CreateObjectPanelProps['onCreateObject']>>(\n ({ metadata, data = {} }) =>\n Effect.gen(function* () {\n if (!target) {\n // TODO(wittjosiah): UI feedback.\n return;\n }\n\n // NOTE: Must close before navigating or attention won't follow object.\n closeRef.current?.click();\n\n const db = Database.isDatabase(target) ? target : target && Obj.getDatabase(target);\n invariant(db, 'Missing database');\n const result = yield* metadata.createObject(data, { db, target, targetNodeId });\n const shouldNavigate = _shouldNavigate ?? (() => true);\n if (result.subject.length > 0 && shouldNavigate(result.object)) {\n if (layout.mode === 'multi') {\n yield* invoke(LayoutOperation.Set, {\n subject: [...result.subject],\n });\n yield* invoke(LayoutOperation.Expose, {\n subject: result.subject[0],\n });\n } else {\n yield* invoke(LayoutOperation.Open, {\n subject: [...result.subject],\n navigation: 'immediate',\n });\n }\n }\n\n onCreateObject?.(result.object);\n }).pipe(\n Effect.provideService(Capability.Service, manager.capabilities),\n Effect.provideService(Operation.Service, operationInvoker),\n EffectEx.runAndForwardErrors,\n ),\n [target, _shouldNavigate, onCreateObject, manager.capabilities, invoke, layout.mode],\n );\n\n return (\n <Dialog.Content>\n <Dialog.Header>\n <Dialog.Title>\n {t('create-object-dialog.title', {\n object: t('typename.label', { ns: typename, defaultValue: views ? 'View' : 'Object' }),\n })}\n </Dialog.Title>\n <Dialog.Close asChild>\n <Dialog.ActionIconButton action='close' ref={closeRef} />\n </Dialog.Close>\n </Dialog.Header>\n <Dialog.Body>\n <CreateObjectPanel\n options={options}\n spaces={spaces}\n target={target}\n typename={typename}\n initialFormValues={initialFormValues}\n defaultSpaceId={AppSpace.getPersonalSpace(client)?.id ?? client.spaces.get()[0]?.id}\n resolve={resolve}\n onCreateObject={handleCreateObject}\n onTargetChange={setTarget}\n onTypenameChange={setTypename}\n />\n </Dialog.Body>\n {showTypeSelector && (\n <Dialog.ActionBar>\n <Dialog.Close asChild>\n <PluginRegistryButton />\n </Dialog.Close>\n </Dialog.ActionBar>\n )}\n </Dialog.Content>\n );\n};\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
|
+
"names": ["useAtomValue", "Effect", "Option", "React", "useCallback", "useMemo", "useRef", "useState", "Capability", "useOperationInvoker", "usePluginManager", "AppSpace", "LayoutOperation", "TypeOptions", "PluginRegistryButton", "useLayout", "Operation", "Annotation", "Database", "Obj", "Type", "EffectEx", "invariant", "useClient", "useQuery", "useSpaces", "Dialog", "toLocalizedString", "useTranslation", "ViewAnnotation", "makeCreateObjectEntryForDatabaseType", "CreateObjectPanel", "meta", "SpaceCapabilities", "CREATE_OBJECT_DIALOG", "meta", "profile", "manager", "usePluginManager", "operationInvoker", "useOperationInvoker", "initialTarget", "typename", "setTypename", "client", "useClient", "spaces", "useSpaces", "layout", "useLayout", "closeRef", "db", "Database", "isDatabase", "allTypes", "useQuery", "space", "useMemo", "s", "t", "map", "Type", "getTypename", "pluginByEntryId", "Map", "plugins", "contributions", "owningPlugin", "find", "entry", "entries", "pluginNameByEntryId", "entriesByModule", "capabilityEntries", "dbEntries", "Set", "type", "typeByTypename", "ViewAnnotation", "set", "add", "name", "schema", "iconAnnotation", "Annotation", "getDatabase", "id", "label", "ns", "defaultValue", "icon", "iconHue", "plugin", "description", "createObjectEntries", "views", "viewTypenames", "spaceLabel", "invariant", "result", "createObject", "target", "targetNodeId", "invoke", "LayoutOperation", "subject", "navigation", "onCreateObject", "pipe", "_shouldNavigate", "mode", "Dialog", "asChild", "ActionIconButton", "action", "options", "initialFormValues", "defaultSpaceId", "resolve", "handleCreateObject", "onTargetChange", "onTypenameChange", "showTypeSelector", "PluginRegistryButton"]
|
|
7
|
+
}
|
|
@@ -4,7 +4,7 @@ import "./chunk-J5LGTIGS.mjs";
|
|
|
4
4
|
import * as Effect from "effect/Effect";
|
|
5
5
|
import React, { useCallback, useRef } from "react";
|
|
6
6
|
import { useOperationInvoker } from "@dxos/app-framework/ui";
|
|
7
|
-
import { LayoutOperation,
|
|
7
|
+
import { LayoutOperation, Paths } from "@dxos/app-toolkit";
|
|
8
8
|
import { EffectEx } from "@dxos/effect";
|
|
9
9
|
import { Column, Dialog, useTranslation } from "@dxos/react-ui";
|
|
10
10
|
import { Form } from "@dxos/react-ui-form";
|
|
@@ -12,13 +12,13 @@ import { useInputSurfaceLookup } from "#hooks";
|
|
|
12
12
|
import { meta } from "#meta";
|
|
13
13
|
import { SpaceOperation } from "#operations";
|
|
14
14
|
import { SpaceForm } from "#types";
|
|
15
|
-
var CREATE_SPACE_DIALOG = `${meta.
|
|
15
|
+
var CREATE_SPACE_DIALOG = `${meta.profile.key}.CreateSpaceDialog`;
|
|
16
16
|
var initialValues = {
|
|
17
17
|
edgeReplication: true
|
|
18
18
|
};
|
|
19
19
|
var CreateSpaceDialog = () => {
|
|
20
20
|
const closeRef = useRef(null);
|
|
21
|
-
const { t } = useTranslation(meta.
|
|
21
|
+
const { t } = useTranslation(meta.profile.key);
|
|
22
22
|
const { invokePromise } = useOperationInvoker();
|
|
23
23
|
const inputSurfaceLookup = useInputSurfaceLookup();
|
|
24
24
|
const handleCreateSpace = useCallback(async (data) => {
|
|
@@ -27,9 +27,9 @@ var CreateSpaceDialog = () => {
|
|
|
27
27
|
if (result?.space) {
|
|
28
28
|
yield* Effect.promise(() => invokePromise(LayoutOperation.Open, {
|
|
29
29
|
subject: [
|
|
30
|
-
getSpaceHomePath(result.space.id)
|
|
30
|
+
Paths.getSpaceHomePath(result.space.id)
|
|
31
31
|
],
|
|
32
|
-
workspace: getSpacePath(result.space.id),
|
|
32
|
+
workspace: Paths.getSpacePath(result.space.id),
|
|
33
33
|
navigation: "immediate"
|
|
34
34
|
}));
|
|
35
35
|
yield* Effect.promise(() => invokePromise(LayoutOperation.UpdateDialog, {
|
|
@@ -58,4 +58,4 @@ var CreateSpaceDialog = () => {
|
|
|
58
58
|
export {
|
|
59
59
|
CreateSpaceDialog as default
|
|
60
60
|
};
|
|
61
|
-
//# sourceMappingURL=CreateSpaceDialog-
|
|
61
|
+
//# sourceMappingURL=CreateSpaceDialog-WWNUTLVK.mjs.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../src/containers/CreateSpaceDialog/CreateSpaceDialog.tsx"],
|
|
4
|
+
"sourcesContent": ["//\n// Copyright 2024 DXOS.org\n//\n\nimport * as Effect from 'effect/Effect';\nimport type * as Schema from 'effect/Schema';\nimport React, { useCallback, useRef } from 'react';\n\nimport { useOperationInvoker } from '@dxos/app-framework/ui';\nimport { LayoutOperation, Paths } from '@dxos/app-toolkit';\nimport { EffectEx } from '@dxos/effect';\nimport { Column, Dialog, useTranslation } from '@dxos/react-ui';\nimport { Form } from '@dxos/react-ui-form';\n\nimport { useInputSurfaceLookup } from '#hooks';\nimport { meta } from '#meta';\nimport { SpaceOperation } from '#operations';\nimport { SpaceForm } from '#types';\n\nexport const CREATE_SPACE_DIALOG = `${meta.profile.key}.CreateSpaceDialog`;\n\ntype FormValues = Schema.Schema.Type<typeof SpaceForm>;\nconst initialValues: FormValues = { edgeReplication: true };\n\nexport const CreateSpaceDialog = () => {\n const closeRef = useRef<HTMLButtonElement | null>(null);\n const { t } = useTranslation(meta.profile.key);\n const { invokePromise } = useOperationInvoker();\n\n const inputSurfaceLookup = useInputSurfaceLookup();\n\n const handleCreateSpace = useCallback(\n async (data: FormValues) => {\n const program = Effect.gen(function* () {\n const { data: result } = yield* Effect.promise(() => invokePromise(SpaceOperation.Create, data));\n if (result?.space) {\n yield* Effect.promise(() =>\n invokePromise(LayoutOperation.Open, {\n subject: [Paths.getSpaceHomePath(result.space.id)],\n workspace: Paths.getSpacePath(result.space.id),\n navigation: 'immediate',\n }),\n );\n yield* Effect.promise(() => invokePromise(LayoutOperation.UpdateDialog, { state: false }));\n }\n });\n await EffectEx.runAndForwardErrors(program);\n },\n [invokePromise],\n );\n\n return (\n <Dialog.Content>\n <Dialog.Header>\n <Dialog.Title>{t('create-space-dialog.title')}</Dialog.Title>\n <Dialog.Close asChild>\n <Dialog.ActionIconButton action='close' ref={closeRef} />\n </Dialog.Close>\n </Dialog.Header>\n <Dialog.Body>\n <Form.Root\n testId='create-space-form'\n autoFocus\n schema={SpaceForm}\n defaultValues={initialValues}\n fieldProvider={inputSurfaceLookup}\n onSave={handleCreateSpace}\n >\n {/* Dialog.Body owns the gutter Column; place the form in its center column via Column.Center\n (not Form.Viewport's own Column.Root, which double-insets) so it aligns with the title. */}\n <Column.Center>\n <Form.Content>\n <Form.FieldSet />\n <Form.Submit />\n </Form.Content>\n </Column.Center>\n </Form.Root>\n </Dialog.Body>\n </Dialog.Content>\n );\n};\n"],
|
|
5
|
+
"mappings": ";;;AAIA,YAAYA,YAAY;AAExB,OAAOC,SAASC,aAAaC,cAAc;AAE3C,SAASC,2BAA2B;AACpC,SAASC,iBAAiBC,aAAa;AACvC,SAASC,gBAAgB;AACzB,SAASC,QAAQC,QAAQC,sBAAsB;AAC/C,SAASC,YAAY;AAErB,SAASC,6BAA6B;AACtC,SAASC,YAAY;AACrB,SAASC,sBAAsB;AAC/B,SAASC,iBAAiB;AAEnB,IAAMC,sBAAsB,GAAGH,KAAKI,QAAQC,GAAG;AAGtD,IAAMC,gBAA4B;EAAEC,iBAAiB;AAAK;AAEnD,IAAMC,oBAAoB,MAAA;AAC/B,QAAMC,WAAWnB,OAAiC,IAAA;AAClD,QAAM,EAAEoB,EAAC,IAAKb,eAAeG,KAAKI,QAAQC,GAAG;AAC7C,QAAM,EAAEM,cAAa,IAAKpB,oBAAAA;AAE1B,QAAMqB,qBAAqBb,sBAAAA;AAE3B,QAAMc,oBAAoBxB,YACxB,OAAOyB,SAAAA;AACL,UAAMC,UAAiBC,WAAI,aAAA;AACzB,YAAM,EAAEF,MAAMG,OAAM,IAAK,OAAcC,eAAQ,MAAMP,cAAcV,eAAekB,QAAQL,IAAAA,CAAAA;AAC1F,UAAIG,QAAQG,OAAO;AACjB,eAAcF,eAAQ,MACpBP,cAAcnB,gBAAgB6B,MAAM;UAClCC,SAAS;YAAC7B,MAAM8B,iBAAiBN,OAAOG,MAAMI,EAAE;;UAChDC,WAAWhC,MAAMiC,aAAaT,OAAOG,MAAMI,EAAE;UAC7CG,YAAY;QACd,CAAA,CAAA;AAEF,eAAcT,eAAQ,MAAMP,cAAcnB,gBAAgBoC,cAAc;UAAEC,OAAO;QAAM,CAAA,CAAA;MACzF;IACF,CAAA;AACA,UAAMnC,SAASoC,oBAAoBf,OAAAA;EACrC,GACA;IAACJ;GAAc;AAGjB,SACE,sBAAA,cAACf,OAAOmC,SAAO,MACb,sBAAA,cAACnC,OAAOoC,QAAM,MACZ,sBAAA,cAACpC,OAAOqC,OAAK,MAAEvB,EAAE,2BAAA,CAAA,GACjB,sBAAA,cAACd,OAAOsC,OAAK;IAACC,SAAAA;KACZ,sBAAA,cAACvC,OAAOwC,kBAAgB;IAACC,QAAO;IAAQC,KAAK7B;QAGjD,sBAAA,cAACb,OAAO2C,MAAI,MACV,sBAAA,cAACzC,KAAK0C,MAAI;IACRC,QAAO;IACPC,WAAAA;IACAC,QAAQzC;IACR0C,eAAetC;IACfuC,eAAejC;IACfkC,QAAQjC;KAIR,sBAAA,cAAClB,OAAOoD,QAAM,MACZ,sBAAA,cAACjD,KAAKiC,SAAO,MACX,sBAAA,cAACjC,KAAKkD,UAAQ,IAAA,GACd,sBAAA,cAAClD,KAAKmD,QAAM,IAAA,CAAA,CAAA,CAAA,CAAA,CAAA;AAO1B;",
|
|
6
|
+
"names": ["Effect", "React", "useCallback", "useRef", "useOperationInvoker", "LayoutOperation", "Paths", "EffectEx", "Column", "Dialog", "useTranslation", "Form", "useInputSurfaceLookup", "meta", "SpaceOperation", "SpaceForm", "CREATE_SPACE_DIALOG", "profile", "key", "initialValues", "edgeReplication", "CreateSpaceDialog", "closeRef", "t", "invokePromise", "inputSurfaceLookup", "handleCreateSpace", "data", "program", "gen", "result", "promise", "Create", "space", "Open", "subject", "getSpaceHomePath", "id", "workspace", "getSpacePath", "navigation", "UpdateDialog", "state", "runAndForwardErrors", "Content", "Header", "Title", "Close", "asChild", "ActionIconButton", "action", "ref", "Body", "Root", "testId", "autoFocus", "schema", "defaultValues", "fieldProvider", "onSave", "Center", "FieldSet", "Submit"]
|
|
7
|
+
}
|
|
@@ -4,12 +4,12 @@ import "./chunk-J5LGTIGS.mjs";
|
|
|
4
4
|
import React, { useCallback } from "react";
|
|
5
5
|
import { FileUploader } from "react-drag-drop-files";
|
|
6
6
|
import { useOperationInvoker } from "@dxos/app-framework/ui";
|
|
7
|
-
import { LayoutOperation,
|
|
7
|
+
import { LayoutOperation, Paths } from "@dxos/app-toolkit";
|
|
8
8
|
import { Button, Dialog, Icon, useTranslation } from "@dxos/react-ui";
|
|
9
9
|
import { meta } from "#meta";
|
|
10
10
|
import { SpaceOperation } from "#operations";
|
|
11
11
|
var ImportSpaceDialog = () => {
|
|
12
|
-
const { t } = useTranslation(meta.
|
|
12
|
+
const { t } = useTranslation(meta.profile.key);
|
|
13
13
|
const { invokePromise } = useOperationInvoker();
|
|
14
14
|
const handleFile = useCallback(async (file) => {
|
|
15
15
|
const contents = new Uint8Array(await file.arrayBuffer());
|
|
@@ -24,7 +24,7 @@ var ImportSpaceDialog = () => {
|
|
|
24
24
|
});
|
|
25
25
|
if (result?.space) {
|
|
26
26
|
await invokePromise(LayoutOperation.SwitchWorkspace, {
|
|
27
|
-
subject: getSpacePath(result.space.id)
|
|
27
|
+
subject: Paths.getSpacePath(result.space.id)
|
|
28
28
|
});
|
|
29
29
|
}
|
|
30
30
|
}, [
|
|
@@ -61,4 +61,4 @@ var ImportSpaceDialog = () => {
|
|
|
61
61
|
export {
|
|
62
62
|
ImportSpaceDialog as default
|
|
63
63
|
};
|
|
64
|
-
//# sourceMappingURL=ImportSpaceDialog-
|
|
64
|
+
//# sourceMappingURL=ImportSpaceDialog-CSSRTFAO.mjs.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../src/containers/ImportSpaceDialog/ImportSpaceDialog.tsx"],
|
|
4
|
+
"sourcesContent": ["//\n// Copyright 2026 DXOS.org\n//\n\nimport React, { useCallback } from 'react';\nimport { FileUploader } from 'react-drag-drop-files';\n\nimport { useOperationInvoker } from '@dxos/app-framework/ui';\nimport { LayoutOperation, Paths } from '@dxos/app-toolkit';\nimport { Button, Dialog, Icon, useTranslation } from '@dxos/react-ui';\n\nimport { meta } from '#meta';\nimport { SpaceOperation } from '#operations';\n\nexport const ImportSpaceDialog = () => {\n const { t } = useTranslation(meta.profile.key);\n const { invokePromise } = useOperationInvoker();\n\n const handleFile = useCallback(\n async (file: File) => {\n const contents = new Uint8Array(await file.arrayBuffer());\n const { data: result } = await invokePromise(SpaceOperation.ImportSpace, {\n archive: { filename: file.name, contents },\n });\n await invokePromise(LayoutOperation.UpdateDialog, { state: false });\n if (result?.space) {\n await invokePromise(LayoutOperation.SwitchWorkspace, { subject: Paths.getSpacePath(result.space.id) });\n }\n },\n [invokePromise],\n );\n\n return (\n <Dialog.Content>\n <Dialog.Header>\n <Dialog.Title>{t('import-space-dialog.title')}</Dialog.Title>\n <Dialog.Close asChild>\n <Dialog.ActionIconButton action='close' />\n </Dialog.Close>\n </Dialog.Header>\n <Dialog.Body>\n <p className='my-4'>{t('import-space-dialog.description')}</p>\n <FileUploader\n types={['json', 'tar']}\n classes='block my-4 p-8 border-2 border-dashed border-neutral-500/50 rounded-sm flex items-center justify-center gap-2 cursor-pointer'\n dropMessageStyle={{ border: 'none', backgroundColor: '#EEE' }}\n handleChange={(file: File) => {\n void handleFile(file);\n }}\n >\n <Icon icon='ph--file-plus--duotone' size={8} />\n <span>{t('import-space-dialog.upload.label')}</span>\n </FileUploader>\n </Dialog.Body>\n <Dialog.ActionBar>\n <Dialog.Close asChild>\n <Button variant='primary'>{t('cancel.label')}</Button>\n </Dialog.Close>\n </Dialog.ActionBar>\n </Dialog.Content>\n );\n};\n"],
|
|
5
|
+
"mappings": ";;;AAIA,OAAOA,SAASC,mBAAmB;AACnC,SAASC,oBAAoB;AAE7B,SAASC,2BAA2B;AACpC,SAASC,iBAAiBC,aAAa;AACvC,SAASC,QAAQC,QAAQC,MAAMC,sBAAsB;AAErD,SAASC,YAAY;AACrB,SAASC,sBAAsB;AAExB,IAAMC,oBAAoB,MAAA;AAC/B,QAAM,EAAEC,EAAC,IAAKJ,eAAeC,KAAKI,QAAQC,GAAG;AAC7C,QAAM,EAAEC,cAAa,IAAKb,oBAAAA;AAE1B,QAAMc,aAAahB,YACjB,OAAOiB,SAAAA;AACL,UAAMC,WAAW,IAAIC,WAAW,MAAMF,KAAKG,YAAW,CAAA;AACtD,UAAM,EAAEC,MAAMC,OAAM,IAAK,MAAMP,cAAcL,eAAea,aAAa;MACvEC,SAAS;QAAEC,UAAUR,KAAKS;QAAMR;MAAS;IAC3C,CAAA;AACA,UAAMH,cAAcZ,gBAAgBwB,cAAc;MAAEC,OAAO;IAAM,CAAA;AACjE,QAAIN,QAAQO,OAAO;AACjB,YAAMd,cAAcZ,gBAAgB2B,iBAAiB;QAAEC,SAAS3B,MAAM4B,aAAaV,OAAOO,MAAMI,EAAE;MAAE,CAAA;IACtG;EACF,GACA;IAAClB;GAAc;AAGjB,SACE,sBAAA,cAACT,OAAO4B,SAAO,MACb,sBAAA,cAAC5B,OAAO6B,QAAM,MACZ,sBAAA,cAAC7B,OAAO8B,OAAK,MAAExB,EAAE,2BAAA,CAAA,GACjB,sBAAA,cAACN,OAAO+B,OAAK;IAACC,SAAAA;KACZ,sBAAA,cAAChC,OAAOiC,kBAAgB;IAACC,QAAO;QAGpC,sBAAA,cAAClC,OAAOmC,MAAI,MACV,sBAAA,cAACC,KAAAA;IAAEC,WAAU;KAAQ/B,EAAE,iCAAA,CAAA,GACvB,sBAAA,cAACX,cAAAA;IACC2C,OAAO;MAAC;MAAQ;;IAChBC,SAAQ;IACRC,kBAAkB;MAAEC,QAAQ;MAAQC,iBAAiB;IAAO;IAC5DC,cAAc,CAAChC,SAAAA;AACb,WAAKD,WAAWC,IAAAA;IAClB;KAEA,sBAAA,cAACV,MAAAA;IAAK2C,MAAK;IAAyBC,MAAM;MAC1C,sBAAA,cAACC,QAAAA,MAAMxC,EAAE,kCAAA,CAAA,CAAA,CAAA,GAGb,sBAAA,cAACN,OAAO+C,WAAS,MACf,sBAAA,cAAC/C,OAAO+B,OAAK;IAACC,SAAAA;KACZ,sBAAA,cAACjC,QAAAA;IAAOiD,SAAQ;KAAW1C,EAAE,cAAA,CAAA,CAAA,CAAA,CAAA;AAKvC;",
|
|
6
|
+
"names": ["React", "useCallback", "FileUploader", "useOperationInvoker", "LayoutOperation", "Paths", "Button", "Dialog", "Icon", "useTranslation", "meta", "SpaceOperation", "ImportSpaceDialog", "t", "profile", "key", "invokePromise", "handleFile", "file", "contents", "Uint8Array", "arrayBuffer", "data", "result", "ImportSpace", "archive", "filename", "name", "UpdateDialog", "state", "space", "SwitchWorkspace", "subject", "getSpacePath", "id", "Content", "Header", "Title", "Close", "asChild", "ActionIconButton", "action", "Body", "p", "className", "types", "classes", "dropMessageStyle", "border", "backgroundColor", "handleChange", "icon", "size", "span", "ActionBar", "variant"]
|
|
7
|
+
}
|
|
@@ -2,7 +2,7 @@ import "./chunk-J5LGTIGS.mjs";
|
|
|
2
2
|
|
|
3
3
|
// src/containers/InlineSyncStatus/InlineSyncStatus.tsx
|
|
4
4
|
import React, { useEffect, useState } from "react";
|
|
5
|
-
import {
|
|
5
|
+
import { Paths } from "@dxos/app-toolkit";
|
|
6
6
|
import { EdgeStatus } from "@dxos/protocols/proto/dxos/client/services";
|
|
7
7
|
import { EdgeReplicationSetting } from "@dxos/protocols/proto/dxos/echo/metadata";
|
|
8
8
|
import { useClient } from "@dxos/react-client";
|
|
@@ -23,8 +23,8 @@ var useEdgeStatus = () => {
|
|
|
23
23
|
return status;
|
|
24
24
|
};
|
|
25
25
|
var InlineSyncStatus = ({ space, open }) => {
|
|
26
|
-
const { t } = useTranslation(meta.
|
|
27
|
-
const qualifiedId = getSpacePath(space.id);
|
|
26
|
+
const { t } = useTranslation(meta.profile.key);
|
|
27
|
+
const qualifiedId = Paths.getSpacePath(space.id);
|
|
28
28
|
const { hasAttention, isAncestor, isRelated } = useAttention(qualifiedId);
|
|
29
29
|
const attended = hasAttention || isRelated;
|
|
30
30
|
const containsAttended = isAncestor && !open;
|
|
@@ -46,4 +46,4 @@ var InlineSyncStatus = ({ space, open }) => {
|
|
|
46
46
|
export {
|
|
47
47
|
InlineSyncStatus as default
|
|
48
48
|
};
|
|
49
|
-
//# sourceMappingURL=InlineSyncStatus-
|
|
49
|
+
//# sourceMappingURL=InlineSyncStatus-UOUTAPCU.mjs.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../src/containers/InlineSyncStatus/InlineSyncStatus.tsx"],
|
|
4
|
+
"sourcesContent": ["//\n// Copyright 2024 DXOS.org\n//\n\nimport React, { useEffect, useState } from 'react';\n\nimport { Paths } from '@dxos/app-toolkit';\nimport { EdgeStatus } from '@dxos/protocols/proto/dxos/client/services';\nimport { EdgeReplicationSetting } from '@dxos/protocols/proto/dxos/echo/metadata';\nimport { useClient } from '@dxos/react-client';\nimport { type Space, useSpaceSyncState } from '@dxos/react-client/echo';\nimport { Tooltip, useTranslation } from '@dxos/react-ui';\nimport { AttentionGlyph, useAttention } from '@dxos/react-ui-attention';\n\nimport { meta } from '#meta';\n\nconst useEdgeStatus = (): EdgeStatus.ConnectionState => {\n const [status, setStatus] = useState(EdgeStatus.ConnectionState.NOT_CONNECTED);\n const client = useClient();\n useEffect(() => {\n client.services.services.EdgeAgentService?.queryEdgeStatus().subscribe(({ status }) => {\n setStatus(status.state);\n });\n }, [client]);\n\n return status;\n};\n\nexport const InlineSyncStatus = ({ space, open }: { space: Space; open?: boolean }) => {\n const { t } = useTranslation(meta.profile.key);\n const qualifiedId = Paths.getSpacePath(space.id);\n const { hasAttention, isAncestor, isRelated } = useAttention(qualifiedId);\n const attended = hasAttention || isRelated;\n const containsAttended = isAncestor && !open;\n const connectedToEdge = useEdgeStatus() === EdgeStatus.ConnectionState.CONNECTED;\n // TODO(wittjosiah): This is not reactive.\n const edgeSyncEnabled = space.internal.data.edgeReplication === EdgeReplicationSetting.ENABLED;\n const syncState = useSpaceSyncState(space);\n const syncing = connectedToEdge && edgeSyncEnabled && syncState && syncState.missingOnLocal > 0;\n\n return (\n <Tooltip.Trigger asChild content={t('syncing.label')} side='bottom'>\n <AttentionGlyph\n syncing={syncing}\n attended={attended}\n containsAttended={containsAttended}\n classNames='self-center mx-1'\n />\n </Tooltip.Trigger>\n );\n};\n"],
|
|
5
|
+
"mappings": ";;;AAIA,OAAOA,SAASC,WAAWC,gBAAgB;AAE3C,SAASC,aAAa;AACtB,SAASC,kBAAkB;AAC3B,SAASC,8BAA8B;AACvC,SAASC,iBAAiB;AAC1B,SAAqBC,yBAAyB;AAC9C,SAASC,SAASC,sBAAsB;AACxC,SAASC,gBAAgBC,oBAAoB;AAE7C,SAASC,YAAY;AAErB,IAAMC,gBAAgB,MAAA;AACpB,QAAM,CAACC,QAAQC,SAAAA,IAAab,SAASE,WAAWY,gBAAgBC,aAAa;AAC7E,QAAMC,SAASZ,UAAAA;AACfL,YAAU,MAAA;AACRiB,WAAOC,SAASA,SAASC,kBAAkBC,gBAAAA,EAAkBC,UAAU,CAAC,EAAER,QAAAA,QAAM,MAAE;AAChFC,gBAAUD,QAAOS,KAAK;IACxB,CAAA;EACF,GAAG;IAACL;GAAO;AAEX,SAAOJ;AACT;AAEO,IAAMU,mBAAmB,CAAC,EAAEC,OAAOC,KAAI,MAAoC;AAChF,QAAM,EAAEC,EAAC,IAAKlB,eAAeG,KAAKgB,QAAQC,GAAG;AAC7C,QAAMC,cAAc3B,MAAM4B,aAAaN,MAAMO,EAAE;AAC/C,QAAM,EAAEC,cAAcC,YAAYC,UAAS,IAAKxB,aAAamB,WAAAA;AAC7D,QAAMM,WAAWH,gBAAgBE;AACjC,QAAME,mBAAmBH,cAAc,CAACR;AACxC,QAAMY,kBAAkBzB,cAAAA,MAAoBT,WAAWY,gBAAgBuB;AAEvE,QAAMC,kBAAkBf,MAAMgB,SAASC,KAAKC,oBAAoBtC,uBAAuBuC;AACvF,QAAMC,YAAYtC,kBAAkBkB,KAAAA;AACpC,QAAMqB,UAAUR,mBAAmBE,mBAAmBK,aAAaA,UAAUE,iBAAiB;AAE9F,SACE,sBAAA,cAACvC,QAAQwC,SAAO;IAACC,SAAAA;IAAQC,SAASvB,EAAE,eAAA;IAAkBwB,MAAK;KACzD,sBAAA,cAACzC,gBAAAA;IACCoC;IACAV;IACAC;IACAe,YAAW;;AAInB;",
|
|
6
|
+
"names": ["React", "useEffect", "useState", "Paths", "EdgeStatus", "EdgeReplicationSetting", "useClient", "useSpaceSyncState", "Tooltip", "useTranslation", "AttentionGlyph", "useAttention", "meta", "useEdgeStatus", "status", "setStatus", "ConnectionState", "NOT_CONNECTED", "client", "services", "EdgeAgentService", "queryEdgeStatus", "subscribe", "state", "InlineSyncStatus", "space", "open", "t", "profile", "key", "qualifiedId", "getSpacePath", "id", "hasAttention", "isAncestor", "isRelated", "attended", "containsAttended", "connectedToEdge", "CONNECTED", "edgeSyncEnabled", "internal", "data", "edgeReplication", "ENABLED", "syncState", "syncing", "missingOnLocal", "Trigger", "asChild", "content", "side", "classNames"]
|
|
7
|
+
}
|
|
@@ -3,7 +3,7 @@ import "./chunk-J5LGTIGS.mjs";
|
|
|
3
3
|
// src/containers/JoinDialog/JoinDialog.tsx
|
|
4
4
|
import React, { useCallback } from "react";
|
|
5
5
|
import { useOperationInvoker } from "@dxos/app-framework/ui";
|
|
6
|
-
import { LayoutOperation,
|
|
6
|
+
import { LayoutOperation, Paths } from "@dxos/app-toolkit";
|
|
7
7
|
import { useAppGraph } from "@dxos/app-toolkit/ui";
|
|
8
8
|
import { Trigger } from "@dxos/async";
|
|
9
9
|
import { Graph } from "@dxos/plugin-graph";
|
|
@@ -13,12 +13,12 @@ import { Dialog, useTranslation } from "@dxos/react-ui";
|
|
|
13
13
|
import { JoinPanel } from "@dxos/shell/react";
|
|
14
14
|
import { osTranslations } from "@dxos/ui-theme";
|
|
15
15
|
import { meta } from "#meta";
|
|
16
|
-
var JOIN_DIALOG = `${meta.
|
|
16
|
+
var JOIN_DIALOG = `${meta.profile.key}.JoinDialog`;
|
|
17
17
|
var JoinDialog = ({ navigableCollections, onDone, ...props }) => {
|
|
18
18
|
const { invokePromise } = useOperationInvoker();
|
|
19
19
|
const client = useClient();
|
|
20
20
|
const { graph } = useAppGraph();
|
|
21
|
-
const { t } = useTranslation(meta.
|
|
21
|
+
const { t } = useTranslation(meta.profile.key);
|
|
22
22
|
const handleDone = useCallback(async (result) => {
|
|
23
23
|
const spaceKey = result?.spaceKey;
|
|
24
24
|
if (!spaceKey) {
|
|
@@ -26,18 +26,18 @@ var JoinDialog = ({ navigableCollections, onDone, ...props }) => {
|
|
|
26
26
|
}
|
|
27
27
|
await Promise.all([
|
|
28
28
|
invokePromise(LayoutOperation.AddToast, {
|
|
29
|
-
id: `${meta.
|
|
29
|
+
id: `${meta.profile.key}.join-success`,
|
|
30
30
|
duration: 5e3,
|
|
31
31
|
title: [
|
|
32
32
|
"join-success.label",
|
|
33
33
|
{
|
|
34
|
-
ns: meta.
|
|
34
|
+
ns: meta.profile.key
|
|
35
35
|
}
|
|
36
36
|
],
|
|
37
37
|
closeLabel: [
|
|
38
38
|
"dismiss.label",
|
|
39
39
|
{
|
|
40
|
-
ns: meta.
|
|
40
|
+
ns: meta.profile.key
|
|
41
41
|
}
|
|
42
42
|
]
|
|
43
43
|
}),
|
|
@@ -57,9 +57,9 @@ var JoinDialog = ({ navigableCollections, onDone, ...props }) => {
|
|
|
57
57
|
space = await trigger.wait();
|
|
58
58
|
}
|
|
59
59
|
await invokePromise(LayoutOperation.SwitchWorkspace, {
|
|
60
|
-
subject: getSpacePath(space.id)
|
|
60
|
+
subject: Paths.getSpacePath(space.id)
|
|
61
61
|
});
|
|
62
|
-
const target = result?.target
|
|
62
|
+
const target = result?.target;
|
|
63
63
|
if (target) {
|
|
64
64
|
await Graph.waitForPath(graph, {
|
|
65
65
|
target
|
|
@@ -75,6 +75,13 @@ var JoinDialog = ({ navigableCollections, onDone, ...props }) => {
|
|
|
75
75
|
subject: target
|
|
76
76
|
})
|
|
77
77
|
]);
|
|
78
|
+
} else {
|
|
79
|
+
await invokePromise(LayoutOperation.Open, {
|
|
80
|
+
subject: [
|
|
81
|
+
Paths.getSpaceHomePath(space.id)
|
|
82
|
+
],
|
|
83
|
+
workspace: Paths.getSpacePath(space.id)
|
|
84
|
+
});
|
|
78
85
|
}
|
|
79
86
|
onDone?.(result);
|
|
80
87
|
if (space) {
|
|
@@ -111,4 +118,4 @@ export {
|
|
|
111
118
|
JoinDialog,
|
|
112
119
|
JoinDialog as default
|
|
113
120
|
};
|
|
114
|
-
//# sourceMappingURL=JoinDialog-
|
|
121
|
+
//# sourceMappingURL=JoinDialog-QZGNRJ4P.mjs.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../src/containers/JoinDialog/JoinDialog.tsx"],
|
|
4
|
+
"sourcesContent": ["//\n// Copyright 2024 DXOS.org\n//\n\nimport React, { useCallback } from 'react';\n\nimport { useOperationInvoker } from '@dxos/app-framework/ui';\nimport { LayoutOperation, Paths } from '@dxos/app-toolkit';\nimport { useAppGraph } from '@dxos/app-toolkit/ui';\nimport { Trigger } from '@dxos/async';\nimport { Graph } from '@dxos/plugin-graph';\nimport { ObservabilityOperation } from '@dxos/plugin-observability';\nimport { useClient } from '@dxos/react-client';\nimport { type Space } from '@dxos/react-client/echo';\nimport { type InvitationResult } from '@dxos/react-client/invitations';\nimport { Dialog, useTranslation } from '@dxos/react-ui';\nimport { JoinPanel, type JoinPanelProps } from '@dxos/shell/react';\nimport { osTranslations } from '@dxos/ui-theme';\n\nimport { meta } from '#meta';\n\nexport const JOIN_DIALOG = `${meta.profile.key}.JoinDialog`;\n\nexport type JoinDialogProps = JoinPanelProps & {\n navigableCollections?: boolean;\n};\n\nexport const JoinDialog = ({ navigableCollections, onDone, ...props }: JoinDialogProps) => {\n const { invokePromise } = useOperationInvoker();\n const client = useClient();\n const { graph } = useAppGraph();\n const { t } = useTranslation(meta.profile.key);\n\n const handleDone = useCallback(\n async (result: InvitationResult | null) => {\n const spaceKey = result?.spaceKey;\n if (!spaceKey) {\n return;\n }\n\n await Promise.all([\n invokePromise(LayoutOperation.AddToast, {\n id: `${meta.profile.key}.join-success`,\n duration: 5_000,\n title: ['join-success.label', { ns: meta.profile.key }],\n closeLabel: ['dismiss.label', { ns: meta.profile.key }],\n }),\n invokePromise(LayoutOperation.UpdateDialog, { state: false }),\n ]);\n\n let space = client.spaces.get(spaceKey);\n if (!space) {\n // TODO(wittjosiah): Add api to wait for a space.\n const trigger = new Trigger<Space>();\n client.spaces.subscribe(() => {\n const space = client.spaces.get(spaceKey);\n if (space) {\n trigger.wake(space);\n }\n });\n space = await trigger.wait();\n }\n\n await invokePromise(LayoutOperation.SwitchWorkspace, { subject: Paths.getSpacePath(space.id) });\n\n const target = result?.target;\n if (target) {\n // Wait before navigating to the target node.\n // If the target has not yet replicated, this will trigger a loading toast.\n await Graph.waitForPath(graph, { target }).catch(() => {});\n await Promise.all([\n invokePromise(LayoutOperation.Open, { subject: [target] }),\n invokePromise(LayoutOperation.Expose, { subject: target }),\n ]);\n } else {\n await invokePromise(LayoutOperation.Open, {\n subject: [Paths.getSpaceHomePath(space.id)],\n workspace: Paths.getSpacePath(space.id),\n });\n }\n\n onDone?.(result);\n\n if (space) {\n await invokePromise(ObservabilityOperation.SendEvent, {\n name: 'space.join',\n properties: {\n spaceId: space.id,\n },\n });\n }\n },\n [invokePromise, client, graph, navigableCollections, onDone],\n );\n\n // TODO(burdon): Move JoinHeading into Dialog.Heading.\n return (\n <Dialog.Content>\n <Dialog.Title classNames='sr-only'>{t('join-space.label', { ns: osTranslations })}</Dialog.Title>\n <Dialog.Body>\n <JoinPanel\n {...props}\n exitActionParent={<Dialog.Close asChild />}\n doneActionParent={<Dialog.Close asChild />}\n onDone={handleDone}\n />\n </Dialog.Body>\n </Dialog.Content>\n );\n};\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
|
+
"names": ["React", "useCallback", "useOperationInvoker", "LayoutOperation", "Paths", "useAppGraph", "Trigger", "Graph", "ObservabilityOperation", "useClient", "Dialog", "useTranslation", "JoinPanel", "osTranslations", "meta", "JOIN_DIALOG", "profile", "key", "JoinDialog", "navigableCollections", "onDone", "props", "invokePromise", "client", "graph", "t", "handleDone", "result", "spaceKey", "Promise", "all", "AddToast", "id", "duration", "title", "ns", "closeLabel", "UpdateDialog", "state", "space", "spaces", "get", "trigger", "subscribe", "wake", "wait", "SwitchWorkspace", "subject", "getSpacePath", "target", "waitForPath", "catch", "Open", "Expose", "getSpaceHomePath", "workspace", "SendEvent", "name", "properties", "spaceId", "Content", "Title", "classNames", "Body", "exitActionParent", "Close", "asChild", "doneActionParent"]
|
|
7
|
+
}
|
|
@@ -5,7 +5,7 @@ import * as Option from "effect/Option";
|
|
|
5
5
|
import React, { useMemo, useState } from "react";
|
|
6
6
|
import { QR } from "react-qr-rounded";
|
|
7
7
|
import { useOperationInvoker } from "@dxos/app-framework/ui";
|
|
8
|
-
import {
|
|
8
|
+
import { AppAnnotation } from "@dxos/app-toolkit";
|
|
9
9
|
import { Annotation, Obj } from "@dxos/echo";
|
|
10
10
|
import { log } from "@dxos/log";
|
|
11
11
|
import { useConfig } from "@dxos/react-client";
|
|
@@ -30,7 +30,7 @@ var handleInvitationEvent = (invitation, subscription) => {
|
|
|
30
30
|
}
|
|
31
31
|
};
|
|
32
32
|
var MembersContainer = ({ space, createInvitationUrl }) => {
|
|
33
|
-
const { t } = useTranslation(meta.
|
|
33
|
+
const { t } = useTranslation(meta.profile.key);
|
|
34
34
|
const config = useConfig();
|
|
35
35
|
const { invokePromise } = useOperationInvoker();
|
|
36
36
|
const invitations = useSpaceInvitations(space.key);
|
|
@@ -42,7 +42,7 @@ var MembersContainer = ({ space, createInvitationUrl }) => {
|
|
|
42
42
|
setInternalActiveAction(nextAction);
|
|
43
43
|
localStorage.setItem(activeActionKey, nextAction);
|
|
44
44
|
};
|
|
45
|
-
const target = Annotation.get(space.properties, RootCollectionAnnotation).pipe(Option.getOrUndefined)?.target?.objects[0]?.target;
|
|
45
|
+
const target = Annotation.get(space.properties, AppAnnotation.RootCollectionAnnotation).pipe(Option.getOrUndefined)?.target?.objects[0]?.target;
|
|
46
46
|
const inviteActions = useMemo(() => ({
|
|
47
47
|
inviteOne: {
|
|
48
48
|
label: t("invite-one.label", {
|
|
@@ -166,7 +166,7 @@ var InvitationQR = ({ id, url, onCancel }) => {
|
|
|
166
166
|
return /* @__PURE__ */ React.createElement(React.Fragment, null, /* @__PURE__ */ React.createElement("p", {
|
|
167
167
|
className: "text-description"
|
|
168
168
|
}, t("qr-code.description", {
|
|
169
|
-
ns: meta.
|
|
169
|
+
ns: meta.profile.key
|
|
170
170
|
})), /* @__PURE__ */ React.createElement("div", {
|
|
171
171
|
role: "group",
|
|
172
172
|
className: "grid grid-cols-[1fr_min-content] my-2 gap-2"
|
|
@@ -224,4 +224,4 @@ var InvitationComplete = ({ statusValue }) => {
|
|
|
224
224
|
export {
|
|
225
225
|
MembersContainer as default
|
|
226
226
|
};
|
|
227
|
-
//# sourceMappingURL=MembersContainer-
|
|
227
|
+
//# sourceMappingURL=MembersContainer-OWCAMBKS.mjs.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../src/containers/MembersContainer/MembersContainer.tsx"],
|
|
4
|
+
"sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport * as Option from 'effect/Option';\nimport React, { type Dispatch, type SetStateAction, useMemo, useState } from 'react';\nimport { QR } from 'react-qr-rounded';\n\nimport { useOperationInvoker } from '@dxos/app-framework/ui';\nimport { AppAnnotation } from '@dxos/app-toolkit';\nimport { AppSurface } from '@dxos/app-toolkit/ui';\nimport { Annotation, Obj } from '@dxos/echo';\nimport { log } from '@dxos/log';\nimport { useConfig } from '@dxos/react-client';\nimport { useSpaceInvitations } from '@dxos/react-client/echo';\nimport { type CancellableInvitationObservable, Invitation, InvitationEncoder } from '@dxos/react-client/invitations';\nimport { Button, Clipboard, Icon, useId, useTranslation } from '@dxos/react-ui';\nimport { Settings } from '@dxos/react-ui-form';\nimport {\n type ActionMenuItem,\n AuthCode,\n BifurcatedAction,\n Centered,\n Emoji,\n InvitationList,\n SpaceMemberList,\n Viewport,\n translationKey as shellTranslationKey,\n} from '@dxos/shell/react';\nimport { hexToEmoji } from '@dxos/util';\n\nimport { meta } from '#meta';\nimport { SpaceOperation } from '#operations';\n\n// TODO(wittjosiah): Copied from Shell.\nconst activeActionKey = 'dxos:react-shell/space-manager/active-action';\n\nconst handleInvitationEvent = (invitation: Invitation, subscription: ZenObservable.Subscription) => {\n const invitationCode = InvitationEncoder.encode(invitation);\n if (invitation.state === Invitation.State.CONNECTING) {\n log.info(JSON.stringify({ invitationCode, authCode: invitation.authCode }));\n subscription.unsubscribe();\n }\n};\n\nexport type MembersContainerProps = AppSurface.SpaceArticleProps<{\n createInvitationUrl: (invitationCode: string) => string;\n}>;\n\nexport const MembersContainer = ({ space, createInvitationUrl }: MembersContainerProps) => {\n const { t } = useTranslation(meta.profile.key);\n const config = useConfig();\n const { invokePromise } = useOperationInvoker();\n const invitations = useSpaceInvitations(space.key);\n const visibleInvitations = invitations?.filter(\n (invitation) => ![Invitation.State.CANCELLED].includes(invitation.get().state),\n );\n\n const [activeAction, setInternalActiveAction] = useState(localStorage.getItem(activeActionKey) ?? 'inviteMany');\n\n const setActiveAction = (nextAction: string) => {\n setInternalActiveAction(nextAction);\n localStorage.setItem(activeActionKey, nextAction);\n };\n\n // TODO(wittjosiah): Track which was the most recently viewed object.\n const target = Annotation.get(space.properties, AppAnnotation.RootCollectionAnnotation).pipe(Option.getOrUndefined)\n ?.target?.objects[0]?.target;\n\n const inviteActions = useMemo(\n (): Record<string, ActionMenuItem> => ({\n inviteOne: {\n label: t('invite-one.label', { ns: shellTranslationKey }),\n description: t('invite-one.description', { ns: shellTranslationKey }),\n icon: 'ph--user-plus--regular',\n testId: 'membersContainer.inviteOne',\n onClick: async () => {\n const { data: invitation } = await invokePromise(SpaceOperation.Share, {\n space,\n type: Invitation.Type.INTERACTIVE,\n authMethod: Invitation.AuthMethod.SHARED_SECRET,\n multiUse: false,\n target: target && Obj.getURI(target),\n });\n if (invitation && config.values.runtime?.app?.env?.DX_ENVIRONMENT !== 'production') {\n const subscription: ZenObservable.Subscription = (invitation as CancellableInvitationObservable).subscribe(\n (invitation: Invitation) => handleInvitationEvent(invitation, subscription),\n );\n }\n },\n },\n inviteMany: {\n label: t('invite-many.label', { ns: shellTranslationKey }),\n description: t('invite-many.description', { ns: shellTranslationKey }),\n icon: 'ph--users-three--regular',\n testId: 'membersContainer.inviteMany',\n onClick: async () => {\n const { data: invitation } = await invokePromise(SpaceOperation.Share, {\n space,\n type: Invitation.Type.DELEGATED,\n authMethod: Invitation.AuthMethod.KNOWN_PUBLIC_KEY,\n multiUse: true,\n target: target && Obj.getURI(target),\n });\n if (invitation && config.values.runtime?.app?.env?.DX_ENVIRONMENT !== 'production') {\n const subscription: ZenObservable.Subscription = (invitation as CancellableInvitationObservable).subscribe(\n (invitation: Invitation) => handleInvitationEvent(invitation, subscription),\n );\n }\n },\n },\n }),\n [t, space, target, invokePromise],\n );\n\n const [selectedInvitation, setSelectedInvitation] = useState<CancellableInvitationObservable | null>(null);\n const handleSend = (event: { type: 'selectInvitation'; invitation: CancellableInvitationObservable }) => {\n setSelectedInvitation(event.invitation);\n };\n const handleBack = () => {\n setSelectedInvitation(null);\n };\n\n return (\n <Clipboard.Provider>\n <Settings.Viewport>\n <Settings.Section title={t('members-verbose.label')} description={t('members.description')}>\n <Settings.Panel>\n <div role='group' className='min-w-0'>\n <h3 className='text-lg mb-2'>{t('members.label')}</h3>\n <SpaceMemberList spaceKey={space.key} includeSelf />\n </div>\n <div role='group' className='min-w-0'>\n <h3 className='text-lg mb-2'>{t('invitations.label')}</h3>\n {selectedInvitation && <InvitationSection {...selectedInvitation} onBack={handleBack} />}\n {!selectedInvitation && (\n <>\n <p className='text-description mb-2'>{t('space-invitation.description')}</p>\n <InvitationList\n className='mb-2'\n send={handleSend}\n invitations={visibleInvitations ?? []}\n onClickRemove={(invitation) => invitation.cancel()}\n createInvitationUrl={createInvitationUrl}\n />\n <BifurcatedAction\n actions={inviteActions}\n activeAction={activeAction}\n onChangeActiveAction={setActiveAction as Dispatch<SetStateAction<string>>}\n data-testid='membersContainer.createInvitation'\n />\n </>\n )}\n </div>\n </Settings.Panel>\n </Settings.Section>\n </Settings.Viewport>\n </Clipboard.Provider>\n );\n};\n\n// TODO(wittjosiah): Reconcile the below components with DevicesContainer in @dxos/plugin-client.\n\ntype InvitationComponentProps = Partial<\n Pick<Invitation, 'authCode' | 'invitationId'> & {\n state: Invitation.State;\n url: string;\n onBack: () => void;\n }\n>;\n\nconst InvitationSection = ({\n state = Invitation.State.INIT,\n authCode,\n invitationId = 'never',\n url = 'never',\n onBack,\n}: InvitationComponentProps) => {\n const activeView =\n state < 0\n ? 'init'\n : state >= Invitation.State.CANCELLED\n ? 'complete'\n : state >= Invitation.State.READY_FOR_AUTHENTICATION && authCode\n ? 'auth-code'\n : 'qr-code';\n return (\n <Viewport.Root activeView={activeView}>\n <Viewport.Views>\n <Viewport.View id='init'>\n {/* This view intentionally left blank while conditionally rendering the viewport. */}\n </Viewport.View>\n <Viewport.View id='complete'>\n <InvitationComplete statusValue={state} />\n </Viewport.View>\n <Viewport.View id='auth-code'>\n <InvitationAuthCode id={invitationId} code={authCode ?? 'never'} onCancel={onBack} />\n </Viewport.View>\n <Viewport.View id='qr-code'>\n <InvitationQR id={invitationId} url={url} onCancel={onBack} />\n </Viewport.View>\n </Viewport.Views>\n </Viewport.Root>\n );\n};\n\nconst InvitationQR = ({ id, url, onCancel }: { id: string; url: string; onCancel?: () => void }) => {\n const { t } = useTranslation(shellTranslationKey);\n const qrLabel = useId('members-container__qr-code');\n const emoji = hexToEmoji(id);\n return (\n <>\n <p className='text-description'>{t('qr-code.description', { ns: meta.profile.key })}</p>\n <div role='group' className='grid grid-cols-[1fr_min-content] my-2 gap-2'>\n <div className='w-full aspect-square relative text-description'>\n <QR\n rounding={100}\n backgroundColor='transparent'\n color='currentColor'\n aria-labelledby={qrLabel}\n errorCorrectionLevel='Q'\n cutout={true}\n >\n {url ?? 'never'}\n </QR>\n <Centered>\n <Emoji text={emoji} />\n </Centered>\n </div>\n <span id={qrLabel} className='sr-only'>\n {t('qr.label')}\n </span>\n <Clipboard.Button value={url ?? 'never'} />\n </div>\n <Button variant='ghost' onClick={onCancel}>\n {t('cancel.label')}\n </Button>\n </>\n );\n};\n\nconst InvitationAuthCode = ({ id, code, onCancel }: { id: string; code: string; onCancel?: () => void }) => {\n const { t } = useTranslation(shellTranslationKey);\n const emoji = hexToEmoji(id);\n\n return (\n <>\n <p className='text-description'>{t('auth-other-device-emoji.message')}</p>\n {emoji && <Emoji text={emoji} className='mx-auto my-2 text-center' />}\n <p className='text-description'>{t('auth-code.message')}</p>\n <AuthCode code={code} large classNames='mx-auto my-2 text-center grow' />\n <Button variant='ghost' onClick={onCancel}>\n {t('cancel.label')}\n </Button>\n </>\n );\n};\n\nconst InvitationComplete = ({ statusValue }: { statusValue: number }) => {\n return statusValue > 0 ? (\n <Icon icon='ph--check--regular' size={6} classNames='m-1.5' />\n ) : (\n <Icon icon='ph--x--regular' size={6} classNames='m-1.5' />\n );\n};\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
|
+
"names": ["Option", "React", "useMemo", "useState", "QR", "useOperationInvoker", "AppAnnotation", "Annotation", "Obj", "log", "useConfig", "useSpaceInvitations", "Invitation", "InvitationEncoder", "Button", "Clipboard", "Icon", "useId", "useTranslation", "Settings", "AuthCode", "BifurcatedAction", "Centered", "Emoji", "InvitationList", "SpaceMemberList", "Viewport", "translationKey", "shellTranslationKey", "hexToEmoji", "meta", "SpaceOperation", "invitationCode", "State", "stringify", "authCode", "invitation", "subscription", "unsubscribe", "config", "invokePromise", "invitations", "visibleInvitations", "filter", "includes", "get", "activeAction", "setInternalActiveAction", "setActiveAction", "nextAction", "localStorage", "activeActionKey", "inviteOne", "ns", "description", "icon", "testId", "onClick", "space", "type", "INTERACTIVE", "authMethod", "multiUse", "target", "getURI", "values", "runtime", "inviteMany", "DELEGATED", "t", "setSelectedInvitation", "event", "role", "className", "spaceKey", "includeSelf", "selectedInvitation", "onBack", "handleBack", "send", "handleSend", "onClickRemove", "createInvitationUrl", "actions", "onChangeActiveAction", "data-testid", "InvitationSection", "Root", "activeView", "Views", "id", "InvitationComplete", "statusValue", "InvitationAuthCode", "invitationId", "onCancel", "InvitationQR", "url", "emoji", "profile", "rounding", "backgroundColor", "color", "aria-labelledby", "errorCorrectionLevel", "cutout", "text", "span", "qrLabel", "value", "variant", "code", "large", "classNames", "size"]
|
|
7
|
+
}
|
|
@@ -1,20 +1,20 @@
|
|
|
1
1
|
import {
|
|
2
2
|
getSpaceDisplayName
|
|
3
|
-
} from "./chunk-
|
|
4
|
-
import "./chunk-
|
|
3
|
+
} from "./chunk-PSCIOT7Q.mjs";
|
|
4
|
+
import "./chunk-DSYEB2UN.mjs";
|
|
5
5
|
import "./chunk-J5LGTIGS.mjs";
|
|
6
6
|
|
|
7
7
|
// src/containers/MenuFooter/MenuFooter.tsx
|
|
8
8
|
import React from "react";
|
|
9
|
-
import {
|
|
9
|
+
import { AppSpace } from "@dxos/app-toolkit";
|
|
10
10
|
import { getSpace } from "@dxos/client/echo";
|
|
11
11
|
import { DropdownMenu, Icon, toLocalizedString, useTranslation } from "@dxos/react-ui";
|
|
12
12
|
import { meta } from "#meta";
|
|
13
13
|
var MenuFooter = ({ object }) => {
|
|
14
|
-
const { t } = useTranslation(meta.
|
|
14
|
+
const { t } = useTranslation(meta.profile.key);
|
|
15
15
|
const space = getSpace(object);
|
|
16
16
|
const spaceName = space ? getSpaceDisplayName(space, {
|
|
17
|
-
personal: isPersonalSpace(space)
|
|
17
|
+
personal: AppSpace.isPersonalSpace(space)
|
|
18
18
|
}) : "";
|
|
19
19
|
return space ? /* @__PURE__ */ React.createElement(React.Fragment, null, /* @__PURE__ */ React.createElement(DropdownMenu.Separator, null), /* @__PURE__ */ React.createElement(DropdownMenu.GroupLabel, null, t("menu-footer.label")), /* @__PURE__ */ React.createElement("dl", {
|
|
20
20
|
className: "ps-2 mb-2 text-xs grid grid-cols-[max-content_1fr] gap-2"
|
|
@@ -30,4 +30,4 @@ var MenuFooter = ({ object }) => {
|
|
|
30
30
|
export {
|
|
31
31
|
MenuFooter as default
|
|
32
32
|
};
|
|
33
|
-
//# sourceMappingURL=MenuFooter-
|
|
33
|
+
//# sourceMappingURL=MenuFooter-QCNFUIAO.mjs.map
|