@dxos/plugin-client 0.8.4-main.fffef41 → 0.8.4-staging.60fe92afc8
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/LICENSE +102 -5
- package/README.md +1 -1
- package/dist/lib/neutral/AccountContainer-FZ3IC6H4.mjs +182 -0
- package/dist/lib/neutral/AccountContainer-FZ3IC6H4.mjs.map +7 -0
- package/dist/lib/neutral/ClientPlugin.mjs +72 -0
- package/dist/lib/neutral/ClientPlugin.mjs.map +7 -0
- package/dist/lib/neutral/ClientPlugin.node.mjs +1049 -0
- package/dist/lib/neutral/ClientPlugin.node.mjs.map +7 -0
- package/dist/lib/neutral/ClientPlugin.workerd.mjs +16 -0
- package/dist/lib/neutral/ClientPlugin.workerd.mjs.map +7 -0
- package/dist/lib/neutral/DevicesContainer-6MWNUC3I.mjs +262 -0
- package/dist/lib/neutral/DevicesContainer-6MWNUC3I.mjs.map +7 -0
- package/dist/lib/neutral/InvitationsContainer-ME722VKS.mjs +132 -0
- package/dist/lib/neutral/InvitationsContainer-ME722VKS.mjs.map +7 -0
- package/dist/lib/neutral/JoinDialog-2NXAKPLP.mjs +53 -0
- package/dist/lib/neutral/JoinDialog-2NXAKPLP.mjs.map +7 -0
- package/dist/lib/neutral/ProfileContainer-VPX3FPWG.mjs +168 -0
- package/dist/lib/neutral/ProfileContainer-VPX3FPWG.mjs.map +7 -0
- package/dist/lib/neutral/RecoveryCodeDialog-EWHB6U5T.mjs +59 -0
- package/dist/lib/neutral/RecoveryCodeDialog-EWHB6U5T.mjs.map +7 -0
- package/dist/lib/neutral/RecoveryCredentialsContainer-IPBGDMIA.mjs +51 -0
- package/dist/lib/neutral/RecoveryCredentialsContainer-IPBGDMIA.mjs.map +7 -0
- package/dist/lib/neutral/ResetDialog-KUWX45JY.mjs +57 -0
- package/dist/lib/neutral/ResetDialog-KUWX45JY.mjs.map +7 -0
- package/dist/lib/neutral/account-cache-4EKGEUJI.mjs +43 -0
- package/dist/lib/neutral/account-cache-4EKGEUJI.mjs.map +7 -0
- package/dist/lib/neutral/app-graph-builder-A74W7C36.mjs +145 -0
- package/dist/lib/neutral/app-graph-builder-A74W7C36.mjs.map +7 -0
- package/dist/lib/neutral/capabilities/index.mjs +34 -0
- package/dist/lib/neutral/capabilities/index.mjs.map +7 -0
- package/dist/lib/neutral/capabilities/node.mjs +21 -0
- package/dist/lib/neutral/capabilities/node.mjs.map +7 -0
- package/dist/lib/neutral/chunk-D6HPCLTS.mjs +185 -0
- package/dist/lib/neutral/chunk-D6HPCLTS.mjs.map +7 -0
- package/dist/lib/neutral/chunk-J5LGTIGS.mjs +10 -0
- package/dist/lib/neutral/chunk-JEF2FQGB.mjs +27 -0
- package/dist/lib/neutral/chunk-JEF2FQGB.mjs.map +7 -0
- package/dist/lib/{browser/chunk-ZRVMXLDR.mjs → neutral/chunk-JOCCVODY.mjs} +11 -5
- package/dist/lib/neutral/chunk-JOCCVODY.mjs.map +7 -0
- package/dist/lib/neutral/chunk-NTVDGDQ3.mjs +8 -0
- package/dist/lib/neutral/chunk-NTVDGDQ3.mjs.map +7 -0
- package/dist/lib/neutral/chunk-TUK3ELUU.mjs +135 -0
- package/dist/lib/neutral/chunk-TUK3ELUU.mjs.map +7 -0
- package/dist/lib/neutral/chunk-WWCVZG3K.mjs +13 -0
- package/dist/lib/neutral/chunk-WWCVZG3K.mjs.map +7 -0
- package/dist/lib/neutral/client-7I5Y5SOA.mjs +62 -0
- package/dist/lib/neutral/client-7I5Y5SOA.mjs.map +7 -0
- package/dist/lib/neutral/components/index.mjs +1 -0
- package/dist/lib/neutral/containers/index.mjs +23 -0
- package/dist/lib/neutral/containers/index.mjs.map +7 -0
- package/dist/lib/neutral/create-agent-6HLW4D3A.mjs +26 -0
- package/dist/lib/neutral/create-agent-6HLW4D3A.mjs.map +7 -0
- package/dist/lib/neutral/create-identity-JIWAR5GW.mjs +42 -0
- package/dist/lib/neutral/create-identity-JIWAR5GW.mjs.map +7 -0
- package/dist/lib/neutral/create-passkey-FOXEMXGF.mjs +81 -0
- package/dist/lib/neutral/create-passkey-FOXEMXGF.mjs.map +7 -0
- package/dist/lib/neutral/create-recovery-code-ZWDKLPH4.mjs +36 -0
- package/dist/lib/neutral/create-recovery-code-ZWDKLPH4.mjs.map +7 -0
- package/dist/lib/neutral/hub-http-client-WOJUCDKV.mjs +19 -0
- package/dist/lib/neutral/hub-http-client-WOJUCDKV.mjs.map +7 -0
- package/dist/lib/neutral/index.mjs +23 -0
- package/dist/lib/neutral/index.mjs.map +7 -0
- package/dist/lib/neutral/join-identity-QEQFAE2S.mjs +27 -0
- package/dist/lib/neutral/join-identity-QEQFAE2S.mjs.map +7 -0
- package/dist/lib/neutral/layer-specs-CQLXQBQJ.mjs +61 -0
- package/dist/lib/neutral/layer-specs-CQLXQBQJ.mjs.map +7 -0
- package/dist/lib/neutral/meta.json +1 -0
- package/dist/lib/neutral/meta.mjs +8 -0
- package/dist/lib/neutral/meta.mjs.map +7 -0
- package/dist/lib/neutral/migrations-7FTW55ER.mjs +23 -0
- package/dist/lib/neutral/migrations-7FTW55ER.mjs.map +7 -0
- package/dist/lib/neutral/navigation-handler-LU26CDFR.mjs +46 -0
- package/dist/lib/neutral/navigation-handler-LU26CDFR.mjs.map +7 -0
- package/dist/lib/neutral/operation-handler-E3HB7E2T.mjs +13 -0
- package/dist/lib/neutral/operation-handler-E3HB7E2T.mjs.map +7 -0
- package/dist/lib/neutral/operations/index.mjs +12 -0
- package/dist/lib/neutral/operations/index.mjs.map +7 -0
- package/dist/lib/neutral/plugin.mjs +17 -0
- package/dist/lib/neutral/plugin.mjs.map +7 -0
- package/dist/lib/neutral/react-context-B5LXMHVM.mjs +23 -0
- package/dist/lib/neutral/react-context-B5LXMHVM.mjs.map +7 -0
- package/dist/lib/neutral/react-surface-DEKGWTCD.mjs +70 -0
- package/dist/lib/neutral/react-surface-DEKGWTCD.mjs.map +7 -0
- package/dist/lib/neutral/recover-identity-JNFKLCUD.mjs +26 -0
- package/dist/lib/neutral/recover-identity-JNFKLCUD.mjs.map +7 -0
- package/dist/lib/neutral/redeem-passkey-4SBAI4AG.mjs +66 -0
- package/dist/lib/neutral/redeem-passkey-4SBAI4AG.mjs.map +7 -0
- package/dist/lib/neutral/redeem-token-POBD6TMN.mjs +29 -0
- package/dist/lib/neutral/redeem-token-POBD6TMN.mjs.map +7 -0
- package/dist/lib/neutral/reset-storage-LQKUV5RA.mjs +26 -0
- package/dist/lib/neutral/reset-storage-LQKUV5RA.mjs.map +7 -0
- package/dist/lib/neutral/schema-defs-IHBCKTMM.mjs +51 -0
- package/dist/lib/neutral/schema-defs-IHBCKTMM.mjs.map +7 -0
- package/dist/lib/neutral/share-identity-KNQ2XNXV.mjs +31 -0
- package/dist/lib/neutral/share-identity-KNQ2XNXV.mjs.map +7 -0
- package/dist/lib/neutral/testing/index.mjs +25 -0
- package/dist/lib/neutral/testing/index.mjs.map +7 -0
- package/dist/lib/neutral/translations.mjs +101 -0
- package/dist/lib/neutral/translations.mjs.map +7 -0
- package/dist/lib/neutral/types/index.mjs +14 -0
- package/dist/lib/neutral/types/index.mjs.map +7 -0
- package/dist/types/src/ClientPlugin.d.ts +4 -2
- package/dist/types/src/ClientPlugin.d.ts.map +1 -1
- package/dist/types/src/ClientPlugin.node.d.ts +5 -0
- package/dist/types/src/ClientPlugin.node.d.ts.map +1 -0
- package/dist/types/src/ClientPlugin.test.d.ts +2 -0
- package/dist/types/src/ClientPlugin.test.d.ts.map +1 -0
- package/dist/types/src/ClientPlugin.workerd.d.ts +4 -0
- package/dist/types/src/ClientPlugin.workerd.d.ts.map +1 -0
- package/dist/types/src/capabilities/account-cache.d.ts +35 -0
- package/dist/types/src/capabilities/account-cache.d.ts.map +1 -0
- package/dist/types/src/capabilities/app-graph-builder.d.ts +4 -2
- package/dist/types/src/capabilities/app-graph-builder.d.ts.map +1 -1
- package/dist/types/src/capabilities/client.d.ts +6 -7
- package/dist/types/src/capabilities/client.d.ts.map +1 -1
- package/dist/types/src/capabilities/hub-http-client.d.ts +6 -0
- package/dist/types/src/capabilities/hub-http-client.d.ts.map +1 -0
- package/dist/types/src/capabilities/index.d.ts +61 -15
- package/dist/types/src/capabilities/index.d.ts.map +1 -1
- package/dist/types/src/capabilities/layer-specs.d.ts +6 -0
- package/dist/types/src/capabilities/layer-specs.d.ts.map +1 -0
- package/dist/types/src/capabilities/migrations.d.ts +3 -2
- package/dist/types/src/capabilities/migrations.d.ts.map +1 -1
- package/dist/types/src/capabilities/navigation-handler/index.d.ts +4 -0
- package/dist/types/src/capabilities/navigation-handler/index.d.ts.map +1 -0
- package/dist/types/src/capabilities/navigation-handler/navigation-handler.d.ts +15 -0
- package/dist/types/src/capabilities/navigation-handler/navigation-handler.d.ts.map +1 -0
- package/dist/types/src/capabilities/node.d.ts +26 -0
- package/dist/types/src/capabilities/node.d.ts.map +1 -0
- package/dist/types/src/capabilities/operation-handler.d.ts +6 -0
- package/dist/types/src/capabilities/operation-handler.d.ts.map +1 -0
- package/dist/types/src/capabilities/react-context.d.ts +4 -2
- package/dist/types/src/capabilities/react-context.d.ts.map +1 -1
- package/dist/types/src/capabilities/react-surface.d.ts +4 -3
- package/dist/types/src/capabilities/react-surface.d.ts.map +1 -1
- package/dist/types/src/capabilities/schema-defs.d.ts +3 -2
- package/dist/types/src/capabilities/schema-defs.d.ts.map +1 -1
- package/dist/types/src/commands/config/index.d.ts +5 -0
- package/dist/types/src/commands/config/index.d.ts.map +1 -0
- package/dist/types/src/commands/config/view.d.ts +5 -0
- package/dist/types/src/commands/config/view.d.ts.map +1 -0
- package/dist/types/src/commands/device/index.d.ts +7 -0
- package/dist/types/src/commands/device/index.d.ts.map +1 -0
- package/dist/types/src/commands/device/info/index.d.ts +2 -0
- package/dist/types/src/commands/device/info/index.d.ts.map +1 -0
- package/dist/types/src/commands/device/info/info.d.ts +7 -0
- package/dist/types/src/commands/device/info/info.d.ts.map +1 -0
- package/dist/types/src/commands/device/info/info.test.d.ts +2 -0
- package/dist/types/src/commands/device/info/info.test.d.ts.map +1 -0
- package/dist/types/src/commands/device/list/index.d.ts +2 -0
- package/dist/types/src/commands/device/list/index.d.ts.map +1 -0
- package/dist/types/src/commands/device/list/list.d.ts +7 -0
- package/dist/types/src/commands/device/list/list.d.ts.map +1 -0
- package/dist/types/src/commands/device/list/list.test.d.ts +2 -0
- package/dist/types/src/commands/device/list/list.test.d.ts.map +1 -0
- package/dist/types/src/commands/device/update/index.d.ts +2 -0
- package/dist/types/src/commands/device/update/index.d.ts.map +1 -0
- package/dist/types/src/commands/device/update/update.d.ts +11 -0
- package/dist/types/src/commands/device/update/update.d.ts.map +1 -0
- package/dist/types/src/commands/device/util.d.ts +16 -0
- package/dist/types/src/commands/device/util.d.ts.map +1 -0
- package/dist/types/src/commands/edge/index.d.ts +5 -0
- package/dist/types/src/commands/edge/index.d.ts.map +1 -0
- package/dist/types/src/commands/edge/status.d.ts +7 -0
- package/dist/types/src/commands/edge/status.d.ts.map +1 -0
- package/dist/types/src/commands/halo/create/create.d.ts +15 -0
- package/dist/types/src/commands/halo/create/create.d.ts.map +1 -0
- package/dist/types/src/commands/halo/create/create.test.d.ts +2 -0
- package/dist/types/src/commands/halo/create/create.test.d.ts.map +1 -0
- package/dist/types/src/commands/halo/create/index.d.ts +2 -0
- package/dist/types/src/commands/halo/create/index.d.ts.map +1 -0
- package/dist/types/src/commands/halo/credential/add/add.d.ts +13 -0
- package/dist/types/src/commands/halo/credential/add/add.d.ts.map +1 -0
- package/dist/types/src/commands/halo/credential/add/index.d.ts +2 -0
- package/dist/types/src/commands/halo/credential/add/index.d.ts.map +1 -0
- package/dist/types/src/commands/halo/credential/index.d.ts +12 -0
- package/dist/types/src/commands/halo/credential/index.d.ts.map +1 -0
- package/dist/types/src/commands/halo/credential/list/index.d.ts +2 -0
- package/dist/types/src/commands/halo/credential/list/index.d.ts.map +1 -0
- package/dist/types/src/commands/halo/credential/list/list.d.ts +19 -0
- package/dist/types/src/commands/halo/credential/list/list.d.ts.map +1 -0
- package/dist/types/src/commands/halo/credential/list/list.test.d.ts +2 -0
- package/dist/types/src/commands/halo/credential/list/list.test.d.ts.map +1 -0
- package/dist/types/src/commands/halo/identity/identity.d.ts +7 -0
- package/dist/types/src/commands/halo/identity/identity.d.ts.map +1 -0
- package/dist/types/src/commands/halo/identity/identity.test.d.ts +2 -0
- package/dist/types/src/commands/halo/identity/identity.test.d.ts.map +1 -0
- package/dist/types/src/commands/halo/identity/index.d.ts +2 -0
- package/dist/types/src/commands/halo/identity/index.d.ts.map +1 -0
- package/dist/types/src/commands/halo/index.d.ts +3 -0
- package/dist/types/src/commands/halo/index.d.ts.map +1 -0
- package/dist/types/src/commands/halo/join/index.d.ts +2 -0
- package/dist/types/src/commands/halo/join/index.d.ts.map +1 -0
- package/dist/types/src/commands/halo/join/join.d.ts +8 -0
- package/dist/types/src/commands/halo/join/join.d.ts.map +1 -0
- package/dist/types/src/commands/halo/join/join.test.d.ts +2 -0
- package/dist/types/src/commands/halo/join/join.test.d.ts.map +1 -0
- package/dist/types/src/commands/halo/keys/index.d.ts +2 -0
- package/dist/types/src/commands/halo/keys/index.d.ts.map +1 -0
- package/dist/types/src/commands/halo/keys/keys.d.ts +7 -0
- package/dist/types/src/commands/halo/keys/keys.d.ts.map +1 -0
- package/dist/types/src/commands/halo/keys/keys.test.d.ts +2 -0
- package/dist/types/src/commands/halo/keys/keys.test.d.ts.map +1 -0
- package/dist/types/src/commands/halo/recover/index.d.ts +2 -0
- package/dist/types/src/commands/halo/recover/index.d.ts.map +1 -0
- package/dist/types/src/commands/halo/recover/recover.d.ts +7 -0
- package/dist/types/src/commands/halo/recover/recover.d.ts.map +1 -0
- package/dist/types/src/commands/halo/recover/recover.test.d.ts +2 -0
- package/dist/types/src/commands/halo/recover/recover.test.d.ts.map +1 -0
- package/dist/types/src/commands/halo/seed/index.d.ts +2 -0
- package/dist/types/src/commands/halo/seed/index.d.ts.map +1 -0
- package/dist/types/src/commands/halo/seed/seed.d.ts +7 -0
- package/dist/types/src/commands/halo/seed/seed.d.ts.map +1 -0
- package/dist/types/src/commands/halo/share/index.d.ts +2 -0
- package/dist/types/src/commands/halo/share/index.d.ts.map +1 -0
- package/dist/types/src/commands/halo/share/share.d.ts +15 -0
- package/dist/types/src/commands/halo/share/share.d.ts.map +1 -0
- package/dist/types/src/commands/halo/update/index.d.ts +2 -0
- package/dist/types/src/commands/halo/update/index.d.ts.map +1 -0
- package/dist/types/src/commands/halo/update/update.d.ts +11 -0
- package/dist/types/src/commands/halo/update/update.d.ts.map +1 -0
- package/dist/types/src/commands/halo/update/update.test.d.ts +2 -0
- package/dist/types/src/commands/halo/update/update.test.d.ts.map +1 -0
- package/dist/types/src/commands/halo/util.d.ts +10 -0
- package/dist/types/src/commands/halo/util.d.ts.map +1 -0
- package/dist/types/src/commands/index.d.ts +6 -0
- package/dist/types/src/commands/index.d.ts.map +1 -0
- package/dist/types/src/commands/profile/create.d.ts +10 -0
- package/dist/types/src/commands/profile/create.d.ts.map +1 -0
- package/dist/types/src/commands/profile/delete.d.ts +8 -0
- package/dist/types/src/commands/profile/delete.d.ts.map +1 -0
- package/dist/types/src/commands/profile/import.d.ts +17 -0
- package/dist/types/src/commands/profile/import.d.ts.map +1 -0
- package/dist/types/src/commands/profile/index.d.ts +19 -0
- package/dist/types/src/commands/profile/index.d.ts.map +1 -0
- package/dist/types/src/commands/profile/inspect.d.ts +13 -0
- package/dist/types/src/commands/profile/inspect.d.ts.map +1 -0
- package/dist/types/src/commands/profile/list.d.ts +6 -0
- package/dist/types/src/commands/profile/list.d.ts.map +1 -0
- package/dist/types/src/commands/profile/reset.d.ts +8 -0
- package/dist/types/src/commands/profile/reset.d.ts.map +1 -0
- package/dist/types/src/commands/profile/util.d.ts +24 -0
- package/dist/types/src/commands/profile/util.d.ts.map +1 -0
- package/dist/types/src/components/index.d.ts +0 -6
- package/dist/types/src/components/index.d.ts.map +1 -1
- package/dist/types/src/constants.d.ts +5 -0
- package/dist/types/src/constants.d.ts.map +1 -0
- package/dist/types/src/containers/AccountContainer/AccountContainer.d.ts +3 -0
- package/dist/types/src/containers/AccountContainer/AccountContainer.d.ts.map +1 -0
- package/dist/types/src/containers/AccountContainer/index.d.ts +2 -0
- package/dist/types/src/containers/AccountContainer/index.d.ts.map +1 -0
- package/dist/types/src/containers/DevicesContainer/DevicesContainer.d.ts.map +1 -0
- package/dist/types/src/containers/DevicesContainer/DevicesContainer.stories.d.ts +184 -0
- package/dist/types/src/containers/DevicesContainer/DevicesContainer.stories.d.ts.map +1 -0
- package/dist/types/src/containers/DevicesContainer/index.d.ts +2 -0
- package/dist/types/src/containers/DevicesContainer/index.d.ts.map +1 -0
- package/dist/types/src/containers/InvitationsContainer/InvitationsContainer.d.ts +3 -0
- package/dist/types/src/containers/InvitationsContainer/InvitationsContainer.d.ts.map +1 -0
- package/dist/types/src/containers/InvitationsContainer/index.d.ts +2 -0
- package/dist/types/src/containers/InvitationsContainer/index.d.ts.map +1 -0
- package/dist/types/src/{components → containers/JoinDialog}/JoinDialog.d.ts +0 -1
- package/dist/types/src/containers/JoinDialog/JoinDialog.d.ts.map +1 -0
- package/dist/types/src/containers/JoinDialog/JoinDialog.stories.d.ts +15 -0
- package/dist/types/src/containers/JoinDialog/JoinDialog.stories.d.ts.map +1 -0
- package/dist/types/src/containers/JoinDialog/index.d.ts +2 -0
- package/dist/types/src/containers/JoinDialog/index.d.ts.map +1 -0
- package/dist/types/src/containers/ProfileContainer/ProfileContainer.d.ts.map +1 -0
- package/dist/types/src/containers/ProfileContainer/ProfileContainer.stories.d.ts +14 -0
- package/dist/types/src/containers/ProfileContainer/ProfileContainer.stories.d.ts.map +1 -0
- package/dist/types/src/containers/ProfileContainer/index.d.ts +2 -0
- package/dist/types/src/containers/ProfileContainer/index.d.ts.map +1 -0
- package/dist/types/src/{components → containers/RecoveryCodeDialog}/RecoveryCodeDialog.d.ts +0 -1
- package/dist/types/src/containers/RecoveryCodeDialog/RecoveryCodeDialog.d.ts.map +1 -0
- package/dist/types/src/containers/RecoveryCodeDialog/RecoveryCodeDialog.stories.d.ts +16 -0
- package/dist/types/src/containers/RecoveryCodeDialog/RecoveryCodeDialog.stories.d.ts.map +1 -0
- package/dist/types/src/containers/RecoveryCodeDialog/index.d.ts +4 -0
- package/dist/types/src/containers/RecoveryCodeDialog/index.d.ts.map +1 -0
- package/dist/types/src/containers/RecoveryCredentialsContainer/RecoveryCredentialsContainer.d.ts.map +1 -0
- package/dist/types/src/containers/RecoveryCredentialsContainer/RecoveryCredentialsContainer.stories.d.ts +14 -0
- package/dist/types/src/containers/RecoveryCredentialsContainer/RecoveryCredentialsContainer.stories.d.ts.map +1 -0
- package/dist/types/src/containers/RecoveryCredentialsContainer/index.d.ts +2 -0
- package/dist/types/src/containers/RecoveryCredentialsContainer/index.d.ts.map +1 -0
- package/dist/types/src/containers/ResetDialog/ResetDialog.d.ts +14 -0
- package/dist/types/src/containers/ResetDialog/ResetDialog.d.ts.map +1 -0
- package/dist/types/src/containers/ResetDialog/ResetDialog.stories.d.ts +19 -0
- package/dist/types/src/containers/ResetDialog/ResetDialog.stories.d.ts.map +1 -0
- package/dist/types/src/containers/ResetDialog/index.d.ts +4 -0
- package/dist/types/src/containers/ResetDialog/index.d.ts.map +1 -0
- package/dist/types/src/containers/index.d.ts +12 -0
- package/dist/types/src/containers/index.d.ts.map +1 -0
- package/dist/types/src/index.d.ts +2 -4
- package/dist/types/src/index.d.ts.map +1 -1
- package/dist/types/src/meta.d.ts +2 -2
- package/dist/types/src/meta.d.ts.map +1 -1
- package/dist/types/src/operations/create-agent.d.ts +5 -0
- package/dist/types/src/operations/create-agent.d.ts.map +1 -0
- package/dist/types/src/operations/create-identity.d.ts +5 -0
- package/dist/types/src/operations/create-identity.d.ts.map +1 -0
- package/dist/types/src/operations/create-passkey.d.ts +5 -0
- package/dist/types/src/operations/create-passkey.d.ts.map +1 -0
- package/dist/types/src/operations/create-recovery-code.d.ts +5 -0
- package/dist/types/src/operations/create-recovery-code.d.ts.map +1 -0
- package/dist/types/src/operations/definitions.d.ts +36 -0
- package/dist/types/src/operations/definitions.d.ts.map +1 -0
- package/dist/types/src/operations/index.d.ts +4 -0
- package/dist/types/src/operations/index.d.ts.map +1 -0
- package/dist/types/src/operations/join-identity.d.ts +5 -0
- package/dist/types/src/operations/join-identity.d.ts.map +1 -0
- package/dist/types/src/operations/recover-identity.d.ts +5 -0
- package/dist/types/src/operations/recover-identity.d.ts.map +1 -0
- package/dist/types/src/operations/redeem-passkey.d.ts +5 -0
- package/dist/types/src/operations/redeem-passkey.d.ts.map +1 -0
- package/dist/types/src/operations/redeem-token.d.ts +5 -0
- package/dist/types/src/operations/redeem-token.d.ts.map +1 -0
- package/dist/types/src/operations/reset-storage.d.ts +5 -0
- package/dist/types/src/operations/reset-storage.d.ts.map +1 -0
- package/dist/types/src/operations/share-identity.d.ts +5 -0
- package/dist/types/src/operations/share-identity.d.ts.map +1 -0
- package/dist/types/src/plugin.d.ts +4 -0
- package/dist/types/src/plugin.d.ts.map +1 -0
- package/dist/types/src/state/account-cache.d.ts +42 -0
- package/dist/types/src/state/account-cache.d.ts.map +1 -0
- package/dist/types/src/state/use-hub-http.d.ts +8 -0
- package/dist/types/src/state/use-hub-http.d.ts.map +1 -0
- package/dist/types/src/testing/index.d.ts +3 -0
- package/dist/types/src/testing/index.d.ts.map +1 -0
- package/dist/types/src/testing/initializeIdentity.d.ts +14 -0
- package/dist/types/src/testing/initializeIdentity.d.ts.map +1 -0
- package/dist/types/src/translations.d.ts +2 -48
- package/dist/types/src/translations.d.ts.map +1 -1
- package/dist/types/src/types/capabilities.d.ts +43 -0
- package/dist/types/src/types/capabilities.d.ts.map +1 -0
- package/dist/types/src/types/events.d.ts +9 -0
- package/dist/types/src/types/events.d.ts.map +1 -0
- package/dist/types/src/types/index.d.ts +2 -0
- package/dist/types/src/types/index.d.ts.map +1 -1
- package/dist/types/src/types/schema.d.ts +55 -33
- package/dist/types/src/types/schema.d.ts.map +1 -1
- package/dist/types/tsconfig.tsbuildinfo +1 -1
- package/package.json +134 -53
- package/src/ClientPlugin.node.ts +42 -0
- package/src/ClientPlugin.test.ts +29 -0
- package/src/ClientPlugin.ts +70 -59
- package/src/ClientPlugin.workerd.ts +16 -0
- package/src/capabilities/account-cache.ts +25 -0
- package/src/capabilities/app-graph-builder.ts +104 -104
- package/src/capabilities/client.ts +67 -30
- package/src/capabilities/hub-http-client.ts +21 -0
- package/src/capabilities/index.ts +17 -10
- package/src/capabilities/layer-specs.ts +92 -0
- package/src/capabilities/migrations.ts +22 -17
- package/src/capabilities/navigation-handler/index.ts +9 -0
- package/src/capabilities/navigation-handler/navigation-handler.ts +64 -0
- package/src/capabilities/node.ts +21 -0
- package/src/capabilities/operation-handler.ts +16 -0
- package/src/capabilities/react-context.tsx +17 -14
- package/src/capabilities/react-surface.tsx +64 -49
- package/src/capabilities/schema-defs.ts +52 -25
- package/src/commands/config/index.ts +12 -0
- package/src/commands/config/view.ts +29 -0
- package/src/commands/device/index.ts +14 -0
- package/src/commands/device/info/index.ts +5 -0
- package/src/commands/device/info/info.test.ts +28 -0
- package/src/commands/device/info/info.ts +48 -0
- package/src/commands/device/list/index.ts +5 -0
- package/src/commands/device/list/list.test.ts +30 -0
- package/src/commands/device/list/list.ts +28 -0
- package/src/commands/device/update/index.ts +5 -0
- package/src/commands/device/update/update.ts +68 -0
- package/src/commands/device/util.ts +55 -0
- package/src/commands/edge/index.ts +12 -0
- package/src/commands/edge/status.ts +46 -0
- package/src/commands/halo/create/create.test.ts +53 -0
- package/src/commands/halo/create/create.ts +82 -0
- package/src/commands/halo/create/index.ts +5 -0
- package/src/commands/halo/credential/add/add.ts +97 -0
- package/src/commands/halo/credential/add/index.ts +5 -0
- package/src/commands/halo/credential/index.ts +13 -0
- package/src/commands/halo/credential/list/index.ts +5 -0
- package/src/commands/halo/credential/list/list.test.ts +27 -0
- package/src/commands/halo/credential/list/list.ts +115 -0
- package/src/commands/halo/identity/identity.test.ts +40 -0
- package/src/commands/halo/identity/identity.ts +45 -0
- package/src/commands/halo/identity/index.ts +5 -0
- package/src/commands/halo/index.ts +21 -0
- package/src/commands/halo/join/index.ts +5 -0
- package/src/commands/halo/join/join.test.ts +10 -0
- package/src/commands/halo/join/join.ts +87 -0
- package/src/commands/halo/keys/index.ts +5 -0
- package/src/commands/halo/keys/keys.test.ts +29 -0
- package/src/commands/halo/keys/keys.ts +40 -0
- package/src/commands/halo/recover/index.ts +5 -0
- package/src/commands/halo/recover/recover.test.ts +10 -0
- package/src/commands/halo/recover/recover.ts +44 -0
- package/src/commands/halo/seed/index.ts +5 -0
- package/src/commands/halo/seed/seed.ts +36 -0
- package/src/commands/halo/share/index.ts +5 -0
- package/src/commands/halo/share/share.ts +97 -0
- package/src/commands/halo/update/index.ts +5 -0
- package/src/commands/halo/update/update.test.ts +28 -0
- package/src/commands/halo/update/update.ts +67 -0
- package/src/commands/halo/util.ts +15 -0
- package/src/commands/index.ts +9 -0
- package/src/commands/profile/create.ts +90 -0
- package/src/commands/profile/delete.ts +36 -0
- package/src/commands/profile/import.ts +101 -0
- package/src/commands/profile/index.ts +17 -0
- package/src/commands/profile/inspect.ts +64 -0
- package/src/commands/profile/list.ts +55 -0
- package/src/commands/profile/reset.ts +45 -0
- package/src/commands/profile/util.ts +48 -0
- package/src/components/index.ts +0 -7
- package/src/constants.ts +11 -0
- package/src/containers/AccountContainer/AccountContainer.tsx +179 -0
- package/src/containers/AccountContainer/index.ts +5 -0
- package/src/{components → containers/DevicesContainer}/DevicesContainer.stories.tsx +14 -10
- package/src/{components → containers/DevicesContainer}/DevicesContainer.tsx +85 -91
- package/src/containers/DevicesContainer/index.ts +5 -0
- package/src/containers/InvitationsContainer/InvitationsContainer.tsx +137 -0
- package/src/containers/InvitationsContainer/index.ts +5 -0
- package/src/containers/JoinDialog/JoinDialog.stories.tsx +43 -0
- package/src/containers/JoinDialog/JoinDialog.tsx +56 -0
- package/src/containers/JoinDialog/index.ts +5 -0
- package/src/{components → containers/ProfileContainer}/ProfileContainer.stories.tsx +4 -4
- package/src/{components → containers/ProfileContainer}/ProfileContainer.tsx +66 -55
- package/src/containers/ProfileContainer/index.ts +5 -0
- package/src/{components → containers/RecoveryCodeDialog}/RecoveryCodeDialog.stories.tsx +4 -4
- package/src/{components → containers/RecoveryCodeDialog}/RecoveryCodeDialog.tsx +29 -28
- package/src/containers/RecoveryCodeDialog/index.ts +8 -0
- package/src/{components → containers/RecoveryCredentialsContainer}/RecoveryCredentialsContainer.stories.tsx +14 -10
- package/src/containers/RecoveryCredentialsContainer/RecoveryCredentialsContainer.tsx +66 -0
- package/src/containers/RecoveryCredentialsContainer/index.ts +5 -0
- package/src/containers/ResetDialog/ResetDialog.stories.tsx +73 -0
- package/src/containers/ResetDialog/ResetDialog.tsx +62 -0
- package/src/containers/ResetDialog/index.ts +8 -0
- package/src/containers/index.ts +17 -0
- package/src/index.ts +2 -5
- package/src/meta.ts +7 -4
- package/src/operations/create-agent.ts +26 -0
- package/src/operations/create-identity.ts +37 -0
- package/src/operations/create-passkey.ts +88 -0
- package/src/operations/create-recovery-code.ts +34 -0
- package/src/operations/definitions.ts +115 -0
- package/src/operations/index.ts +20 -0
- package/src/operations/join-identity.ts +28 -0
- package/src/operations/recover-identity.ts +28 -0
- package/src/operations/redeem-passkey.ts +85 -0
- package/src/operations/redeem-token.ts +31 -0
- package/src/operations/reset-storage.ts +27 -0
- package/src/operations/share-identity.ts +26 -0
- package/src/plugin.ts +11 -0
- package/src/state/account-cache.ts +33 -0
- package/src/state/use-hub-http.ts +32 -0
- package/src/testing/index.ts +6 -0
- package/src/testing/initializeIdentity.ts +30 -0
- package/src/translations.ts +89 -44
- package/src/types/capabilities.ts +23 -0
- package/src/types/events.ts +15 -0
- package/src/types/index.ts +2 -0
- package/src/types/schema.ts +33 -22
- package/dist/lib/browser/app-graph-builder-ARY4H3VC.mjs +0 -124
- package/dist/lib/browser/app-graph-builder-ARY4H3VC.mjs.map +0 -7
- package/dist/lib/browser/chunk-4G4YWIUQ.mjs +0 -686
- package/dist/lib/browser/chunk-4G4YWIUQ.mjs.map +0 -7
- package/dist/lib/browser/chunk-4LRO3Y2O.mjs +0 -19
- package/dist/lib/browser/chunk-4LRO3Y2O.mjs.map +0 -7
- package/dist/lib/browser/chunk-N5UR2HOE.mjs +0 -18
- package/dist/lib/browser/chunk-N5UR2HOE.mjs.map +0 -7
- package/dist/lib/browser/chunk-RDIG75CA.mjs +0 -110
- package/dist/lib/browser/chunk-RDIG75CA.mjs.map +0 -7
- package/dist/lib/browser/chunk-ZRVMXLDR.mjs.map +0 -7
- package/dist/lib/browser/client-O7U3MQ6J.mjs +0 -43
- package/dist/lib/browser/client-O7U3MQ6J.mjs.map +0 -7
- package/dist/lib/browser/index.mjs +0 -156
- package/dist/lib/browser/index.mjs.map +0 -7
- package/dist/lib/browser/intent-resolver-KLK7PJZK.mjs +0 -305
- package/dist/lib/browser/intent-resolver-KLK7PJZK.mjs.map +0 -7
- package/dist/lib/browser/meta.json +0 -1
- package/dist/lib/browser/migrations-RUAKBBTF.mjs +0 -23
- package/dist/lib/browser/migrations-RUAKBBTF.mjs.map +0 -7
- package/dist/lib/browser/react-context-PCT5C3BN.mjs +0 -25
- package/dist/lib/browser/react-context-PCT5C3BN.mjs.map +0 -7
- package/dist/lib/browser/react-surface-RCXEA65V.mjs +0 -66
- package/dist/lib/browser/react-surface-RCXEA65V.mjs.map +0 -7
- package/dist/lib/browser/schema-defs-UNNBAEFW.mjs +0 -25
- package/dist/lib/browser/schema-defs-UNNBAEFW.mjs.map +0 -7
- package/dist/lib/browser/types/index.mjs +0 -10
- package/dist/lib/node-esm/app-graph-builder-LLM25DRR.mjs +0 -125
- package/dist/lib/node-esm/app-graph-builder-LLM25DRR.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-6ANOJ7ZM.mjs +0 -19
- package/dist/lib/node-esm/chunk-6ANOJ7ZM.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-7M7VWQJW.mjs +0 -20
- package/dist/lib/node-esm/chunk-7M7VWQJW.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-DJ6XKSE4.mjs +0 -687
- package/dist/lib/node-esm/chunk-DJ6XKSE4.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-QT3EQXDU.mjs +0 -17
- package/dist/lib/node-esm/chunk-QT3EQXDU.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-VENKFPBC.mjs +0 -111
- package/dist/lib/node-esm/chunk-VENKFPBC.mjs.map +0 -7
- package/dist/lib/node-esm/client-6MTNT7M6.mjs +0 -44
- package/dist/lib/node-esm/client-6MTNT7M6.mjs.map +0 -7
- package/dist/lib/node-esm/index.mjs +0 -157
- package/dist/lib/node-esm/index.mjs.map +0 -7
- package/dist/lib/node-esm/intent-resolver-YR2C224X.mjs +0 -306
- package/dist/lib/node-esm/intent-resolver-YR2C224X.mjs.map +0 -7
- package/dist/lib/node-esm/meta.json +0 -1
- package/dist/lib/node-esm/migrations-ASF2SAUR.mjs +0 -24
- package/dist/lib/node-esm/migrations-ASF2SAUR.mjs.map +0 -7
- package/dist/lib/node-esm/react-context-F4QOBWSP.mjs +0 -26
- package/dist/lib/node-esm/react-context-F4QOBWSP.mjs.map +0 -7
- package/dist/lib/node-esm/react-surface-SQBRXVMZ.mjs +0 -67
- package/dist/lib/node-esm/react-surface-SQBRXVMZ.mjs.map +0 -7
- package/dist/lib/node-esm/schema-defs-MSIT2KK2.mjs +0 -26
- package/dist/lib/node-esm/schema-defs-MSIT2KK2.mjs.map +0 -7
- package/dist/lib/node-esm/types/index.mjs +0 -11
- package/dist/types/src/capabilities/capabilities.d.ts +0 -9
- package/dist/types/src/capabilities/capabilities.d.ts.map +0 -1
- package/dist/types/src/capabilities/intent-resolver.d.ts +0 -8
- package/dist/types/src/capabilities/intent-resolver.d.ts.map +0 -1
- package/dist/types/src/components/DevicesContainer.d.ts.map +0 -1
- package/dist/types/src/components/DevicesContainer.stories.d.ts +0 -227
- package/dist/types/src/components/DevicesContainer.stories.d.ts.map +0 -1
- package/dist/types/src/components/JoinDialog.d.ts.map +0 -1
- package/dist/types/src/components/ProfileContainer.d.ts.map +0 -1
- package/dist/types/src/components/ProfileContainer.stories.d.ts +0 -60
- package/dist/types/src/components/ProfileContainer.stories.d.ts.map +0 -1
- package/dist/types/src/components/RecoveryCodeDialog.d.ts.map +0 -1
- package/dist/types/src/components/RecoveryCodeDialog.stories.d.ts +0 -62
- package/dist/types/src/components/RecoveryCodeDialog.stories.d.ts.map +0 -1
- package/dist/types/src/components/RecoveryCredentialsContainer.d.ts.map +0 -1
- package/dist/types/src/components/RecoveryCredentialsContainer.stories.d.ts +0 -60
- package/dist/types/src/components/RecoveryCredentialsContainer.stories.d.ts.map +0 -1
- package/dist/types/src/components/ResetDialog.d.ts +0 -7
- package/dist/types/src/components/ResetDialog.d.ts.map +0 -1
- package/dist/types/src/components/ResetDialog.stories.d.ts +0 -65
- package/dist/types/src/components/ResetDialog.stories.d.ts.map +0 -1
- package/dist/types/src/events.d.ts +0 -8
- package/dist/types/src/events.d.ts.map +0 -1
- package/src/capabilities/capabilities.ts +0 -18
- package/src/capabilities/intent-resolver.ts +0 -251
- package/src/components/JoinDialog.tsx +0 -54
- package/src/components/RecoveryCredentialsContainer.tsx +0 -69
- package/src/components/ResetDialog.stories.tsx +0 -52
- package/src/components/ResetDialog.tsx +0 -50
- package/src/events.ts +0 -15
- /package/dist/lib/{browser/types/index.mjs.map → neutral/chunk-J5LGTIGS.mjs.map} +0 -0
- /package/dist/lib/{node-esm/types → neutral/components}/index.mjs.map +0 -0
- /package/dist/types/src/{components → containers/DevicesContainer}/DevicesContainer.d.ts +0 -0
- /package/dist/types/src/{components → containers/ProfileContainer}/ProfileContainer.d.ts +0 -0
- /package/dist/types/src/{components → containers/RecoveryCredentialsContainer}/RecoveryCredentialsContainer.d.ts +0 -0
|
@@ -0,0 +1,132 @@
|
|
|
1
|
+
import {
|
|
2
|
+
useHubHttpClient
|
|
3
|
+
} from "./chunk-JEF2FQGB.mjs";
|
|
4
|
+
import "./chunk-J5LGTIGS.mjs";
|
|
5
|
+
|
|
6
|
+
// src/containers/InvitationsContainer/InvitationsContainer.tsx
|
|
7
|
+
import { useAtom, useAtomSet } from "@effect-atom/atom-react";
|
|
8
|
+
import React, { useCallback, useState } from "react";
|
|
9
|
+
import { useCapability } from "@dxos/app-framework/ui";
|
|
10
|
+
import { Context } from "@dxos/context";
|
|
11
|
+
import { Clipboard, Icon, IconButton, List, ListItem, useAsyncEffect, useTranslation } from "@dxos/react-ui";
|
|
12
|
+
import { Settings } from "@dxos/react-ui-form";
|
|
13
|
+
import { meta } from "#meta";
|
|
14
|
+
import { ClientCapabilities } from "#types";
|
|
15
|
+
var __dxlog_file = "/__w/dxos/dxos/packages/plugins/plugin-client/src/containers/InvitationsContainer/InvitationsContainer.tsx";
|
|
16
|
+
var InvitationsContainer = () => {
|
|
17
|
+
const { t } = useTranslation(meta.id);
|
|
18
|
+
const accountCacheAtom = useCapability(ClientCapabilities.AccountCache);
|
|
19
|
+
const [cache] = useAtom(accountCacheAtom);
|
|
20
|
+
const setCache = useAtomSet(accountCacheAtom);
|
|
21
|
+
const [pending, setPending] = useState(false);
|
|
22
|
+
const hubHttp = useHubHttpClient();
|
|
23
|
+
useAsyncEffect(async () => {
|
|
24
|
+
if (!hubHttp) {
|
|
25
|
+
return;
|
|
26
|
+
}
|
|
27
|
+
try {
|
|
28
|
+
const result = await hubHttp.listAccountInvitations(new Context(void 0, { "~LogMeta": "~LogMeta", F: __dxlog_file, L: 26 }));
|
|
29
|
+
setCache((prev) => ({
|
|
30
|
+
...prev,
|
|
31
|
+
invitations: result.invitations,
|
|
32
|
+
fetchedAt: Date.now()
|
|
33
|
+
}));
|
|
34
|
+
} catch {
|
|
35
|
+
}
|
|
36
|
+
}, [
|
|
37
|
+
hubHttp,
|
|
38
|
+
setCache
|
|
39
|
+
]);
|
|
40
|
+
const handleIssue = useCallback(async () => {
|
|
41
|
+
if (!hubHttp) {
|
|
42
|
+
return;
|
|
43
|
+
}
|
|
44
|
+
setPending(true);
|
|
45
|
+
try {
|
|
46
|
+
const result = await hubHttp.issueAccountInvitation(new Context(void 0, { "~LogMeta": "~LogMeta", F: __dxlog_file, L: 45 }));
|
|
47
|
+
setCache((prev) => ({
|
|
48
|
+
...prev,
|
|
49
|
+
account: prev.account ? {
|
|
50
|
+
...prev.account,
|
|
51
|
+
invitationsRemaining: Math.max(0, prev.account.invitationsRemaining - 1)
|
|
52
|
+
} : prev.account,
|
|
53
|
+
invitations: [
|
|
54
|
+
{
|
|
55
|
+
code: result.code,
|
|
56
|
+
createdAt: (/* @__PURE__ */ new Date()).toISOString()
|
|
57
|
+
},
|
|
58
|
+
...prev.invitations ?? []
|
|
59
|
+
]
|
|
60
|
+
}));
|
|
61
|
+
} finally {
|
|
62
|
+
setPending(false);
|
|
63
|
+
}
|
|
64
|
+
}, [
|
|
65
|
+
hubHttp,
|
|
66
|
+
setCache
|
|
67
|
+
]);
|
|
68
|
+
const remaining = cache.account?.invitationsRemaining ?? 0;
|
|
69
|
+
const list = cache.invitations ?? [];
|
|
70
|
+
const available = list.filter((row) => !row.redeemedByIdentityDid);
|
|
71
|
+
const redeemed = list.filter((row) => Boolean(row.redeemedByIdentityDid));
|
|
72
|
+
return /* @__PURE__ */ React.createElement(Clipboard.Provider, null, /* @__PURE__ */ React.createElement(Settings.Viewport, null, /* @__PURE__ */ React.createElement(Settings.Section, {
|
|
73
|
+
title: t("invitations-section.title"),
|
|
74
|
+
description: t("invitations-section.description")
|
|
75
|
+
}, /* @__PURE__ */ React.createElement(Settings.Item, {
|
|
76
|
+
title: t("generate-invitation.label"),
|
|
77
|
+
description: t("generate-invitation.description", {
|
|
78
|
+
count: remaining
|
|
79
|
+
})
|
|
80
|
+
}, /* @__PURE__ */ React.createElement(IconButton, {
|
|
81
|
+
icon: "ph--plus--regular",
|
|
82
|
+
label: t("generate-invitation.label"),
|
|
83
|
+
variant: "primary",
|
|
84
|
+
onClick: handleIssue,
|
|
85
|
+
disabled: pending || remaining <= 0
|
|
86
|
+
}))), available.length > 0 ? /* @__PURE__ */ React.createElement(Settings.Section, {
|
|
87
|
+
title: t("available-invitations.title")
|
|
88
|
+
}, /* @__PURE__ */ React.createElement(List, null, available.map((row) => /* @__PURE__ */ React.createElement(AvailableInvitationItem, {
|
|
89
|
+
key: row.code,
|
|
90
|
+
row
|
|
91
|
+
})))) : null, redeemed.length > 0 ? /* @__PURE__ */ React.createElement(Settings.Section, {
|
|
92
|
+
title: t("redeemed-invitations.title")
|
|
93
|
+
}, /* @__PURE__ */ React.createElement(List, null, redeemed.map((row) => /* @__PURE__ */ React.createElement(RedeemedInvitationItem, {
|
|
94
|
+
key: row.code,
|
|
95
|
+
row
|
|
96
|
+
})))) : null));
|
|
97
|
+
};
|
|
98
|
+
var AvailableInvitationItem = ({ row }) => /* @__PURE__ */ React.createElement(ListItem.Root, {
|
|
99
|
+
classNames: "grid grid-cols-[min-content_1fr_min-content] items-center gap-2"
|
|
100
|
+
}, /* @__PURE__ */ React.createElement(ListItem.Endcap, null, /* @__PURE__ */ React.createElement(Icon, {
|
|
101
|
+
icon: "ph--paper-plane-tilt--duotone",
|
|
102
|
+
size: 5,
|
|
103
|
+
classNames: "text-description"
|
|
104
|
+
})), /* @__PURE__ */ React.createElement("div", {
|
|
105
|
+
className: "flex flex-col min-w-0"
|
|
106
|
+
}, /* @__PURE__ */ React.createElement(ListItem.Heading, {
|
|
107
|
+
classNames: "font-mono truncate"
|
|
108
|
+
}, row.code), /* @__PURE__ */ React.createElement("p", {
|
|
109
|
+
className: "text-description text-xs"
|
|
110
|
+
}, new Date(row.createdAt).toLocaleString())), /* @__PURE__ */ React.createElement(ListItem.Endcap, null, /* @__PURE__ */ React.createElement(Clipboard.IconButton, {
|
|
111
|
+
value: row.code
|
|
112
|
+
})));
|
|
113
|
+
var RedeemedInvitationItem = ({ row }) => {
|
|
114
|
+
const date = row.redeemedAt ?? row.createdAt;
|
|
115
|
+
return /* @__PURE__ */ React.createElement(ListItem.Root, {
|
|
116
|
+
classNames: "grid grid-cols-[min-content_1fr] items-center gap-2"
|
|
117
|
+
}, /* @__PURE__ */ React.createElement(ListItem.Endcap, null, /* @__PURE__ */ React.createElement(Icon, {
|
|
118
|
+
icon: "ph--check-circle--duotone",
|
|
119
|
+
size: 5,
|
|
120
|
+
classNames: "text-success-text"
|
|
121
|
+
})), /* @__PURE__ */ React.createElement("div", {
|
|
122
|
+
className: "flex flex-col min-w-0"
|
|
123
|
+
}, /* @__PURE__ */ React.createElement(ListItem.Heading, {
|
|
124
|
+
classNames: "font-mono truncate"
|
|
125
|
+
}, row.code), /* @__PURE__ */ React.createElement("p", {
|
|
126
|
+
className: "text-description text-xs"
|
|
127
|
+
}, new Date(date).toLocaleString())));
|
|
128
|
+
};
|
|
129
|
+
export {
|
|
130
|
+
InvitationsContainer as default
|
|
131
|
+
};
|
|
132
|
+
//# sourceMappingURL=InvitationsContainer-ME722VKS.mjs.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../src/containers/InvitationsContainer/InvitationsContainer.tsx"],
|
|
4
|
+
"sourcesContent": ["//\n// Copyright 2026 DXOS.org\n//\n\nimport { useAtom, useAtomSet } from '@effect-atom/atom-react';\nimport React, { useCallback, useState } from 'react';\n\nimport { useCapability } from '@dxos/app-framework/ui';\nimport { Context } from '@dxos/context';\nimport { Clipboard, Icon, IconButton, List, ListItem, useAsyncEffect, useTranslation } from '@dxos/react-ui';\nimport { Settings } from '@dxos/react-ui-form';\n\nimport { meta } from '#meta';\nimport { ClientCapabilities } from '#types';\n\nimport { type AccountCacheInvitation } from '../../state/account-cache';\nimport { useHubHttpClient } from '../../state/use-hub-http';\n\nexport const InvitationsContainer = () => {\n const { t } = useTranslation(meta.id);\n const accountCacheAtom = useCapability(ClientCapabilities.AccountCache);\n const [cache] = useAtom(accountCacheAtom);\n const setCache = useAtomSet(accountCacheAtom);\n const [pending, setPending] = useState(false);\n\n // Account/invitation routes live on hub-service, not the edge worker.\n const hubHttp = useHubHttpClient();\n\n useAsyncEffect(async () => {\n if (!hubHttp) {\n return;\n }\n try {\n const result = await hubHttp.listAccountInvitations(new Context());\n setCache((prev) => ({ ...prev, invitations: result.invitations, fetchedAt: Date.now() }));\n } catch {\n // Offline: keep cache.\n }\n }, [hubHttp, setCache]);\n\n const handleIssue = useCallback(async () => {\n if (!hubHttp) {\n return;\n }\n setPending(true);\n try {\n const result = await hubHttp.issueAccountInvitation(new Context());\n // Optimistically push the new code and decrement the remaining quota; the\n // server consumes one slot at issue time. Next refresh reconciles.\n setCache((prev) => ({\n ...prev,\n account: prev.account\n ? { ...prev.account, invitationsRemaining: Math.max(0, prev.account.invitationsRemaining - 1) }\n : prev.account,\n invitations: [{ code: result.code, createdAt: new Date().toISOString() }, ...(prev.invitations ?? [])],\n }));\n } finally {\n setPending(false);\n }\n }, [hubHttp, setCache]);\n\n const remaining = cache.account?.invitationsRemaining ?? 0;\n const list = cache.invitations ?? [];\n const available = list.filter((row) => !row.redeemedByIdentityDid);\n const redeemed = list.filter((row) => Boolean(row.redeemedByIdentityDid));\n\n return (\n <Clipboard.Provider>\n <Settings.Viewport>\n <Settings.Section title={t('invitations-section.title')} description={t('invitations-section.description')}>\n <Settings.Item\n title={t('generate-invitation.label')}\n description={t('generate-invitation.description', { count: remaining })}\n >\n <IconButton\n icon='ph--plus--regular'\n label={t('generate-invitation.label')}\n variant='primary'\n onClick={handleIssue}\n disabled={pending || remaining <= 0}\n />\n </Settings.Item>\n </Settings.Section>\n\n {available.length > 0 ? (\n <Settings.Section title={t('available-invitations.title')}>\n <List>\n {available.map((row) => (\n <AvailableInvitationItem key={row.code} row={row} />\n ))}\n </List>\n </Settings.Section>\n ) : null}\n\n {redeemed.length > 0 ? (\n <Settings.Section title={t('redeemed-invitations.title')}>\n <List>\n {redeemed.map((row) => (\n <RedeemedInvitationItem key={row.code} row={row} />\n ))}\n </List>\n </Settings.Section>\n ) : null}\n </Settings.Viewport>\n </Clipboard.Provider>\n );\n};\n\nconst AvailableInvitationItem = ({ row }: { row: AccountCacheInvitation }) => (\n <ListItem.Root classNames='grid grid-cols-[min-content_1fr_min-content] items-center gap-2'>\n <ListItem.Endcap>\n <Icon icon='ph--paper-plane-tilt--duotone' size={5} classNames='text-description' />\n </ListItem.Endcap>\n <div className='flex flex-col min-w-0'>\n <ListItem.Heading classNames='font-mono truncate'>{row.code}</ListItem.Heading>\n <p className='text-description text-xs'>{new Date(row.createdAt).toLocaleString()}</p>\n </div>\n <ListItem.Endcap>\n <Clipboard.IconButton value={row.code} />\n </ListItem.Endcap>\n </ListItem.Root>\n);\n\nconst RedeemedInvitationItem = ({ row }: { row: AccountCacheInvitation }) => {\n const date = row.redeemedAt ?? row.createdAt;\n return (\n <ListItem.Root classNames='grid grid-cols-[min-content_1fr] items-center gap-2'>\n <ListItem.Endcap>\n <Icon icon='ph--check-circle--duotone' size={5} classNames='text-success-text' />\n </ListItem.Endcap>\n <div className='flex flex-col min-w-0'>\n <ListItem.Heading classNames='font-mono truncate'>{row.code}</ListItem.Heading>\n <p className='text-description text-xs'>{new Date(date).toLocaleString()}</p>\n </div>\n </ListItem.Root>\n );\n};\n"],
|
|
5
|
+
"mappings": ";;;;;;AAIA,SAASA,SAASC,kBAAkB;AACpC,OAAOC,SAASC,aAAaC,gBAAgB;AAE7C,SAASC,qBAAqB;AAC9B,SAASC,eAAe;AACxB,SAASC,WAAWC,MAAMC,YAAYC,MAAMC,UAAUC,gBAAgBC,sBAAsB;AAC5F,SAASC,gBAAgB;AAEzB,SAASC,YAAY;AACrB,SAASC,0BAA0B;AAKnC,IAAA,eAAaC;AAEX,IAAMC,uBAAmBC,MAAAA;AACzB,QAAM,EAACC,EAAAA,IAAM,eAAWF,KAAAA,EAAAA;AACxB,QAAMG,mBAAWC,cAAWJ,mBAAAA,YAAAA;AAC5B,QAAM,CAACK,KAAAA,IAASC,QAAAA,gBAAuB;AAEvC,QAAA,WAAA,WAAA,gBAAA;AACA,QAAMC,CAAAA,SAAUC,UAAAA,IAAAA,SAAAA,KAAAA;QAGd,UAAKD,iBAAS;iBACZ,YAAA;AACF,QAAA,CAAA,SAAA;AACI;;QAEFJ;qBAA6B,MAAA,QAAA,uBAAA,IAAA,QAAA,QAAA,EAAA,YAAA,YAAA,GAAA,cAAA,GAAA,GAAA,CAAA,CAAA;eAAEM,CAAAA,UAAAA;QAAiCC,GAAAA;QAAsB,aAAA,OAAA;QAChF,WAAA,KAAA,IAAA;MACN,EAAA;IACF,QAAA;IACEH;;IAAkB;IAEtB;;sBAEI,YAAA,YAAA;AACF,QAAA,CAAA,SAAA;AACAD;IACA;eACQK,IAAAA;QACN;AACA,YAAA,SAAA,MAAA,QAAA,uBAAA,IAAA,QAAA,QAAmE,EAAA,YAAA,YAAA,GAAA,cAAA,GAAA,GAAA,CAAA,CAAA;eAGjEC,CAAAA,UAASC;;iBACcC,KAAAA,UAAAA;UACnBD,GAAAA,KAAKD;UACTH,sBAAa,KAAA,IAAA,GAAA,KAAA,QAAA,uBAAA,CAAA;YAAC,KAAA;qBAAEM;;YAAuD,MAAA,OAAA;YAAOF,YAAKJ,oBAAW,KAAI,GAAE,YAAA;UAAE;UACxG,GAAA,KAAA,eAAA,CAAA;QACQ;MACRH,EAAAA;IACF,UAAA;AACC,iBAAA,KAAA;IAACC;;IAAkB;IAEtB;EACA,CAAA;AACA,QAAMS,YAAYC,MAAKC,SAAQC,wBAAaC;AAC5C,QAAMC,OAAAA,MAAWJ,eAAaE,CAAAA;AAE9B,QAAA,YAAA,KACE,OAAA,CAAA,QAAA,CAAA,IAACG,qBAAkB;QAEGC,WAAS,KAAA,OAAA,CAAA,QAAA,QAAA,IAAA,qBAAA,CAAA;SAA6C,sBAAA,cAAA,UAAA,UAAA,MAAA,sBAAA,cAAA,SAAA,UAAA,MAAA,sBAAA,cAAA,SAAA,SAAA;wCACrEC;IACCD,aAAS,EAAA,iCAAA;KACIE,sBAAE,cAAA,SAAA,MAAA;WAAqCC,EAAAA,2BAAOC;IAAU,aAAA,EAAA,mCAAA;;IAGnEC,CAAAA;KACS,sBAAA,cAAA,YAAA;IACTC,MAAAA;IACAC,OAAAA,EAASC,2BAAAA;IACTC,SAAAA;aAKLhB;IACmBO,UAAS,WAAA,aAAA;2BACzB,IAACU,sBACEjB,cAAc,SAACG,SAAAA;WACWe,EAAKf,6BAAQ;KAAOA,sBAAAA,cAAAA,MAAAA,MAAAA,UAAAA,IAAAA,CAAAA,QAAAA,sBAAAA,cAAAA,yBAAAA;SAIjD,IAAA;IAGgBI;gBAChB,SAAA,SAAA,IACGF,sBAASc,cAAKhB,SACb,SAAA;WAAwBe,EAAKf,4BAAQ;KAAOA,sBAAAA,cAAAA,MAAAA,MAAAA,SAAAA,IAAAA,CAAAA,QAAAA,sBAAAA,cAAAA,wBAAAA;SAIhD,IAAA;IAIV;EAEIiB,CAAAA,CAAAA,CAAAA,CAAAA,IAAAA,IAAAA,CAAAA;;8BAEF,CAAA,EAAA,IAAA,MAAgB,sBAAA,cAAA,SACd,MAAA;EAAMR,YAAK;GAAsC,sBAAA,cAAA,SAAA,QAAA,MAAA,sBAAA,cAAA,MAAA;EAAGS,MAAAA;;EAEjDC,YAAU;KACb,sBAAA,cAACC,OAASC;EAAQH,WAAAA;GAAyC,sBAAA,cAC3D,SAAA,SAACI;EAAEH,YAAU;GAA4B,IAAII,IAAAA,GAAoBC,sBAAAA,cAAc,KAAA;EAGzDC,WAAW7B;;EAKjC8B,OAAAA,IAAAA;AACJ,CAAA,CAAA,CAAA;IACA,yBACE,CAAA,EAAA,IAAA,MAAA;QAAeR,OAAAA,IAAW,cAAA,IAAA;SACxB,sBAAA,cAACE,SAASO,MAAM;IACRlB,YAAK;KAAkC,sBAAA,cAAA,SAAA,QAAA,MAAA,sBAAA,cAAA,MAAA;IAAGS,MAAAA;;IAE7CC,YAAU;OACb,sBAAA,cAACC,OAASC;IAAQH,WAAAA;KAAyC,sBAAA,cAC3D,SAAA,SAACI;IAAEH,YAAU;KAA4B,IAAII,IAAAA,GAAWC,sBAAc,cAAA,KAAA;IAI9E,WAAA;;;",
|
|
6
|
+
"names": ["useAtom", "useAtomSet", "React", "useCallback", "useState", "useCapability", "Context", "Clipboard", "Icon", "IconButton", "List", "ListItem", "useAsyncEffect", "useTranslation", "Settings", "meta", "ClientCapabilities", "InvitationsContainer", "accountCacheAtom", "useCapability", "cache", "setCache", "useAtomSet", "pending", "setPending", "hubHttp", "useHubHttpClient", "invitations", "fetchedAt", "result", "account", "prev", "invitationsRemaining", "code", "available", "list", "filter", "row", "redeemedByIdentityDid", "redeemed", "Clipboard", "title", "Settings", "t", "count", "remaining", "icon", "variant", "onClick", "handleIssue", "disabled", "List", "key", "map", "AvailableInvitationItem", "classNames", "className", "ListItem", "Heading", "p", "Date", "toLocaleString", "value", "RedeemedInvitationItem", "Endcap"]
|
|
7
|
+
}
|
|
@@ -0,0 +1,53 @@
|
|
|
1
|
+
import "./chunk-J5LGTIGS.mjs";
|
|
2
|
+
|
|
3
|
+
// src/containers/JoinDialog/JoinDialog.tsx
|
|
4
|
+
import React, { useCallback } from "react";
|
|
5
|
+
import { useOperationInvoker } from "@dxos/app-framework/ui";
|
|
6
|
+
import { LayoutOperation } from "@dxos/app-toolkit";
|
|
7
|
+
import { ObservabilityOperation } from "@dxos/plugin-observability";
|
|
8
|
+
import { Dialog, useTranslation } from "@dxos/react-ui";
|
|
9
|
+
import { JoinPanel } from "@dxos/shell/react";
|
|
10
|
+
import { osTranslations } from "@dxos/ui-theme";
|
|
11
|
+
import { meta } from "#meta";
|
|
12
|
+
import { ClientOperation } from "#operations";
|
|
13
|
+
var JoinDialog = (props) => {
|
|
14
|
+
const { invokePromise } = useOperationInvoker();
|
|
15
|
+
const { t } = useTranslation(meta.id);
|
|
16
|
+
const handleCancelResetStorage = useCallback(() => invokePromise(ClientOperation.ShareIdentity), [
|
|
17
|
+
invokePromise
|
|
18
|
+
]);
|
|
19
|
+
const handleDone = useCallback(async (result) => {
|
|
20
|
+
if (result?.identityKey) {
|
|
21
|
+
await Promise.all([
|
|
22
|
+
invokePromise(LayoutOperation.UpdateDialog, {
|
|
23
|
+
state: false
|
|
24
|
+
}),
|
|
25
|
+
invokePromise(ObservabilityOperation.SendEvent, {
|
|
26
|
+
name: props.initialDisposition === "recover-identity" ? "identity.recover" : "identity.join"
|
|
27
|
+
})
|
|
28
|
+
]);
|
|
29
|
+
}
|
|
30
|
+
}, [
|
|
31
|
+
invokePromise
|
|
32
|
+
]);
|
|
33
|
+
return /* @__PURE__ */ React.createElement(Dialog.Content, null, /* @__PURE__ */ React.createElement(Dialog.Header, null, /* @__PURE__ */ React.createElement(Dialog.Title, {
|
|
34
|
+
classNames: "sr-only"
|
|
35
|
+
}, t("join-space.label", {
|
|
36
|
+
ns: osTranslations
|
|
37
|
+
}))), /* @__PURE__ */ React.createElement(Dialog.Body, null, /* @__PURE__ */ React.createElement(JoinPanel, {
|
|
38
|
+
...props,
|
|
39
|
+
mode: "halo-only",
|
|
40
|
+
exitActionParent: /* @__PURE__ */ React.createElement(Dialog.Close, {
|
|
41
|
+
asChild: true
|
|
42
|
+
}),
|
|
43
|
+
doneActionParent: /* @__PURE__ */ React.createElement(Dialog.Close, {
|
|
44
|
+
asChild: true
|
|
45
|
+
}),
|
|
46
|
+
onCancelResetStorage: handleCancelResetStorage,
|
|
47
|
+
onDone: handleDone
|
|
48
|
+
})));
|
|
49
|
+
};
|
|
50
|
+
export {
|
|
51
|
+
JoinDialog as default
|
|
52
|
+
};
|
|
53
|
+
//# sourceMappingURL=JoinDialog-2NXAKPLP.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 } from '@dxos/app-toolkit';\nimport { ObservabilityOperation } from '@dxos/plugin-observability';\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';\nimport { ClientOperation } from '#operations';\n\nexport const JoinDialog = (props: JoinPanelProps) => {\n const { invokePromise } = useOperationInvoker();\n const { t } = useTranslation(meta.id);\n\n const handleCancelResetStorage = useCallback(() => invokePromise(ClientOperation.ShareIdentity), [invokePromise]);\n\n const handleDone = useCallback(\n async (result: InvitationResult | null) => {\n if (result?.identityKey) {\n await Promise.all([\n invokePromise(LayoutOperation.UpdateDialog, { state: false }),\n invokePromise(ObservabilityOperation.SendEvent, {\n name: props.initialDisposition === 'recover-identity' ? 'identity.recover' : 'identity.join',\n }),\n ]);\n }\n },\n [invokePromise],\n );\n\n // TODO(burdon): Move JoinHeading into Dialog.Heading.\n return (\n <Dialog.Content>\n <Dialog.Header>\n <Dialog.Title classNames='sr-only'>{t('join-space.label', { ns: osTranslations })}</Dialog.Title>\n </Dialog.Header>\n <Dialog.Body>\n <JoinPanel\n {...props}\n mode='halo-only'\n exitActionParent={<Dialog.Close asChild />}\n doneActionParent={<Dialog.Close asChild />}\n onCancelResetStorage={handleCancelResetStorage}\n onDone={handleDone}\n />\n </Dialog.Body>\n </Dialog.Content>\n );\n};\n"],
|
|
5
|
+
"mappings": ";;;AAIA,OAAOA,SAASC,mBAAmB;AAEnC,SAASC,2BAA2B;AACpC,SAASC,uBAAuB;AAChC,SAASC,8BAA8B;AAEvC,SAASC,QAAQC,sBAAsB;AACvC,SAASC,iBAAsC;AAC/C,SAASC,sBAAsB;AAE/B,SAASC,YAAY;AACrB,SAASC,uBAAuB;AAEzB,IAAMC,aAAa,CAACC,UAAAA;AACzB,QAAM,EAAEC,cAAa,IAAKX,oBAAAA;AAC1B,QAAM,EAAEY,EAAC,IAAKR,eAAeG,KAAKM,EAAE;AAEpC,QAAMC,2BAA2Bf,YAAY,MAAMY,cAAcH,gBAAgBO,aAAa,GAAG;IAACJ;GAAc;AAEhH,QAAMK,aAAajB,YACjB,OAAOkB,WAAAA;AACL,QAAIA,QAAQC,aAAa;AACvB,YAAMC,QAAQC,IAAI;QAChBT,cAAcV,gBAAgBoB,cAAc;UAAEC,OAAO;QAAM,CAAA;QAC3DX,cAAcT,uBAAuBqB,WAAW;UAC9CC,MAAMd,MAAMe,uBAAuB,qBAAqB,qBAAqB;QAC/E,CAAA;OACD;IACH;EACF,GACA;IAACd;GAAc;AAIjB,SACE,sBAAA,cAACR,OAAOuB,SAAO,MACb,sBAAA,cAACvB,OAAOwB,QAAM,MACZ,sBAAA,cAACxB,OAAOyB,OAAK;IAACC,YAAW;KAAWjB,EAAE,oBAAoB;IAAEkB,IAAIxB;EAAe,CAAA,CAAA,CAAA,GAEjF,sBAAA,cAACH,OAAO4B,MAAI,MACV,sBAAA,cAAC1B,WAAAA;IACE,GAAGK;IACJsB,MAAK;IACLC,kBAAkB,sBAAA,cAAC9B,OAAO+B,OAAK;MAACC,SAAAA;;IAChCC,kBAAkB,sBAAA,cAACjC,OAAO+B,OAAK;MAACC,SAAAA;;IAChCE,sBAAsBvB;IACtBwB,QAAQtB;;AAKlB;",
|
|
6
|
+
"names": ["React", "useCallback", "useOperationInvoker", "LayoutOperation", "ObservabilityOperation", "Dialog", "useTranslation", "JoinPanel", "osTranslations", "meta", "ClientOperation", "JoinDialog", "props", "invokePromise", "t", "id", "handleCancelResetStorage", "ShareIdentity", "handleDone", "result", "identityKey", "Promise", "all", "UpdateDialog", "state", "SendEvent", "name", "initialDisposition", "Content", "Header", "Title", "classNames", "ns", "Body", "mode", "exitActionParent", "Close", "asChild", "doneActionParent", "onCancelResetStorage", "onDone"]
|
|
7
|
+
}
|
|
@@ -0,0 +1,168 @@
|
|
|
1
|
+
import "./chunk-J5LGTIGS.mjs";
|
|
2
|
+
|
|
3
|
+
// src/containers/ProfileContainer/ProfileContainer.tsx
|
|
4
|
+
import * as Schema from "effect/Schema";
|
|
5
|
+
import React, { useCallback, useMemo, useState } from "react";
|
|
6
|
+
import { debounce } from "@dxos/async";
|
|
7
|
+
import { useClient } from "@dxos/react-client";
|
|
8
|
+
import { useIdentity } from "@dxos/react-client/halo";
|
|
9
|
+
import { ButtonGroup, Clipboard, Input, useTranslation } from "@dxos/react-ui";
|
|
10
|
+
import { Form, Settings } from "@dxos/react-ui-form";
|
|
11
|
+
import { EmojiPickerBlock, HuePicker } from "@dxos/react-ui-pickers";
|
|
12
|
+
import { hexToEmoji, hexToHue } from "@dxos/util";
|
|
13
|
+
import { meta } from "#meta";
|
|
14
|
+
var UserProfile = Schema.Struct({
|
|
15
|
+
did: Schema.String.annotations({
|
|
16
|
+
title: "DID"
|
|
17
|
+
}),
|
|
18
|
+
displayName: Schema.String.annotations({
|
|
19
|
+
title: "Display name"
|
|
20
|
+
}),
|
|
21
|
+
emoji: Schema.String.annotations({
|
|
22
|
+
title: "Avatar"
|
|
23
|
+
}),
|
|
24
|
+
hue: Schema.String.annotations({
|
|
25
|
+
title: "Color"
|
|
26
|
+
})
|
|
27
|
+
});
|
|
28
|
+
var getDefaultHueValue = (identity) => hexToHue(identity?.identityKey.toHex() ?? "0");
|
|
29
|
+
var getHueValue = (identity) => identity?.profile?.data?.hue || getDefaultHueValue(identity);
|
|
30
|
+
var getDefaultEmojiValue = (identity) => hexToEmoji(identity?.identityKey.toHex() ?? "0");
|
|
31
|
+
var getEmojiValue = (identity) => identity?.profile?.data?.emoji || getDefaultEmojiValue(identity);
|
|
32
|
+
var ProfileContainer = () => {
|
|
33
|
+
const { t } = useTranslation(meta.id);
|
|
34
|
+
const client = useClient();
|
|
35
|
+
const identity = useIdentity();
|
|
36
|
+
const [displayName, setDisplayNameDirectly] = useState(identity?.profile?.displayName ?? "");
|
|
37
|
+
const [emoji, setEmojiDirectly] = useState(getEmojiValue(identity));
|
|
38
|
+
const [hue, setHueDirectly] = useState(getHueValue(identity));
|
|
39
|
+
const updateProfile = useMemo(() => debounce((profile) => client.halo.updateProfile({
|
|
40
|
+
displayName: profile.displayName,
|
|
41
|
+
data: {
|
|
42
|
+
emoji: profile.emoji,
|
|
43
|
+
hue: profile.hue
|
|
44
|
+
}
|
|
45
|
+
}), 2e3), []);
|
|
46
|
+
const handleChange = useCallback((profile, meta2) => {
|
|
47
|
+
for (const [path, changed] of Object.entries(meta2.changed)) {
|
|
48
|
+
if (changed) {
|
|
49
|
+
switch (path) {
|
|
50
|
+
case "displayName":
|
|
51
|
+
setDisplayNameDirectly(profile.displayName ?? "");
|
|
52
|
+
break;
|
|
53
|
+
case "emoji":
|
|
54
|
+
setEmojiDirectly(profile.emoji ?? getDefaultEmojiValue(identity));
|
|
55
|
+
break;
|
|
56
|
+
case "hue":
|
|
57
|
+
setHueDirectly(profile.hue ?? getDefaultHueValue(identity));
|
|
58
|
+
break;
|
|
59
|
+
default:
|
|
60
|
+
break;
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
void updateProfile(profile);
|
|
65
|
+
}, [
|
|
66
|
+
identity
|
|
67
|
+
]);
|
|
68
|
+
const values = useMemo(() => ({
|
|
69
|
+
did: identity?.did,
|
|
70
|
+
displayName,
|
|
71
|
+
emoji,
|
|
72
|
+
hue
|
|
73
|
+
}), [
|
|
74
|
+
identity,
|
|
75
|
+
displayName,
|
|
76
|
+
emoji,
|
|
77
|
+
hue
|
|
78
|
+
]);
|
|
79
|
+
const fieldMap = useMemo(() => ({
|
|
80
|
+
displayName: ({ type, label, getValue, onValueChange }) => {
|
|
81
|
+
const handleChange2 = useCallback(({ target: { value } }) => onValueChange(type, value), [
|
|
82
|
+
onValueChange,
|
|
83
|
+
type
|
|
84
|
+
]);
|
|
85
|
+
return /* @__PURE__ */ React.createElement(Settings.Item, {
|
|
86
|
+
title: label,
|
|
87
|
+
description: t("display-name.description")
|
|
88
|
+
}, /* @__PURE__ */ React.createElement(Input.TextInput, {
|
|
89
|
+
value: getValue(),
|
|
90
|
+
onChange: handleChange2,
|
|
91
|
+
placeholder: t("display-name-input.placeholder"),
|
|
92
|
+
classNames: "min-w-64"
|
|
93
|
+
}));
|
|
94
|
+
},
|
|
95
|
+
emoji: ({ type, label, getValue, onValueChange }) => {
|
|
96
|
+
const handleChange2 = useCallback((nextEmoji) => onValueChange(type, nextEmoji), [
|
|
97
|
+
onValueChange,
|
|
98
|
+
type
|
|
99
|
+
]);
|
|
100
|
+
const handleEmojiReset = useCallback(() => onValueChange(type, getDefaultEmojiValue(identity)), [
|
|
101
|
+
onValueChange,
|
|
102
|
+
type
|
|
103
|
+
]);
|
|
104
|
+
return /* @__PURE__ */ React.createElement(Settings.Item, {
|
|
105
|
+
title: label,
|
|
106
|
+
description: t("icon.description")
|
|
107
|
+
}, /* @__PURE__ */ React.createElement(EmojiPickerBlock, {
|
|
108
|
+
triggerVariant: "default",
|
|
109
|
+
emoji: getValue(),
|
|
110
|
+
onChangeEmoji: handleChange2,
|
|
111
|
+
onClickClear: handleEmojiReset,
|
|
112
|
+
classNames: "justify-self-end"
|
|
113
|
+
}));
|
|
114
|
+
},
|
|
115
|
+
hue: ({ type, label, getValue, onValueChange }) => {
|
|
116
|
+
const handleChange2 = useCallback((nextHue) => onValueChange(type, nextHue), [
|
|
117
|
+
onValueChange,
|
|
118
|
+
type
|
|
119
|
+
]);
|
|
120
|
+
const handleHueReset = useCallback(() => onValueChange(type, getDefaultHueValue(identity)), [
|
|
121
|
+
onValueChange,
|
|
122
|
+
type
|
|
123
|
+
]);
|
|
124
|
+
return /* @__PURE__ */ React.createElement(Settings.Item, {
|
|
125
|
+
title: label,
|
|
126
|
+
description: t("hue.description")
|
|
127
|
+
}, /* @__PURE__ */ React.createElement("div", {
|
|
128
|
+
className: "flex justify-self-end"
|
|
129
|
+
}, /* @__PURE__ */ React.createElement(HuePicker, {
|
|
130
|
+
value: getValue(),
|
|
131
|
+
onChange: handleChange2,
|
|
132
|
+
onReset: handleHueReset
|
|
133
|
+
})));
|
|
134
|
+
},
|
|
135
|
+
// TODO(wittjosiah): We need text input annotations for disabled and copyable.
|
|
136
|
+
did: ({ label, getValue }) => {
|
|
137
|
+
return /* @__PURE__ */ React.createElement(Settings.Item, {
|
|
138
|
+
title: label,
|
|
139
|
+
description: t("did.description")
|
|
140
|
+
}, /* @__PURE__ */ React.createElement(ButtonGroup, {
|
|
141
|
+
classNames: "w-full"
|
|
142
|
+
}, /* @__PURE__ */ React.createElement(Input.TextInput, {
|
|
143
|
+
value: getValue(),
|
|
144
|
+
disabled: true,
|
|
145
|
+
classNames: "min-w-64"
|
|
146
|
+
}), /* @__PURE__ */ React.createElement(Clipboard.IconButton, {
|
|
147
|
+
value: getValue() ?? ""
|
|
148
|
+
})));
|
|
149
|
+
}
|
|
150
|
+
}), [
|
|
151
|
+
t
|
|
152
|
+
]);
|
|
153
|
+
return /* @__PURE__ */ React.createElement(Clipboard.Provider, null, /* @__PURE__ */ React.createElement(Settings.Viewport, null, /* @__PURE__ */ React.createElement(Settings.Section, {
|
|
154
|
+
title: t("profile.label"),
|
|
155
|
+
description: t("profile.description")
|
|
156
|
+
}, /* @__PURE__ */ React.createElement(Form.Root, {
|
|
157
|
+
schema: UserProfile,
|
|
158
|
+
values,
|
|
159
|
+
fieldMap,
|
|
160
|
+
onValuesChanged: handleChange
|
|
161
|
+
}, /* @__PURE__ */ React.createElement(Form.Content, {
|
|
162
|
+
classNames: "gap-form-gap"
|
|
163
|
+
}, /* @__PURE__ */ React.createElement(Form.FieldSet, null))))));
|
|
164
|
+
};
|
|
165
|
+
export {
|
|
166
|
+
ProfileContainer as default
|
|
167
|
+
};
|
|
168
|
+
//# sourceMappingURL=ProfileContainer-VPX3FPWG.mjs.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../src/containers/ProfileContainer/ProfileContainer.tsx"],
|
|
4
|
+
"sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport * as Schema from 'effect/Schema';\nimport React, { type ChangeEvent, useCallback, useMemo, useState } from 'react';\n\nimport { debounce } from '@dxos/async';\nimport { useClient } from '@dxos/react-client';\nimport { type Identity, useIdentity } from '@dxos/react-client/halo';\nimport { ButtonGroup, Clipboard, Input, useTranslation } from '@dxos/react-ui';\nimport { Form, type FormFieldMap, type FormUpdateMeta, Settings } from '@dxos/react-ui-form';\nimport { EmojiPickerBlock, HuePicker } from '@dxos/react-ui-pickers';\nimport { hexToEmoji, hexToHue } from '@dxos/util';\n\nimport { meta } from '#meta';\n\n// TOOD(burdon): Factor out?\n// TODO(wittjosiah): Integrate annotations with translations.\nconst UserProfile = Schema.Struct({\n did: Schema.String.annotations({ title: 'DID' }),\n displayName: Schema.String.annotations({ title: 'Display name' }),\n emoji: Schema.String.annotations({ title: 'Avatar' }),\n hue: Schema.String.annotations({ title: 'Color' }),\n});\n\ntype UserProfile = Schema.Schema.Type<typeof UserProfile>;\n\n// TODO(thure): Factor out?\nconst getDefaultHueValue = (identity: Identity | null) => hexToHue(identity?.identityKey.toHex() ?? '0');\nconst getHueValue = (identity: Identity | null) => identity?.profile?.data?.hue || getDefaultHueValue(identity);\nconst getDefaultEmojiValue = (identity: Identity | null) => hexToEmoji(identity?.identityKey.toHex() ?? '0');\nconst getEmojiValue = (identity: Identity | null) => identity?.profile?.data?.emoji || getDefaultEmojiValue(identity);\n\nexport const ProfileContainer = () => {\n const { t } = useTranslation(meta.id);\n const client = useClient();\n const identity = useIdentity();\n const [displayName, setDisplayNameDirectly] = useState(identity?.profile?.displayName ?? '');\n const [emoji, setEmojiDirectly] = useState<string>(getEmojiValue(identity));\n const [hue, setHueDirectly] = useState<string>(getHueValue(identity));\n\n const updateProfile = useMemo(\n () =>\n debounce(\n (profile: Partial<UserProfile>) =>\n client.halo.updateProfile({\n displayName: profile.displayName,\n data: {\n emoji: profile.emoji,\n hue: profile.hue,\n },\n }),\n 2_000,\n ),\n [],\n );\n\n const handleChange = useCallback(\n (profile: Partial<UserProfile>, meta: FormUpdateMeta<UserProfile>) => {\n for (const [path, changed] of Object.entries(meta.changed)) {\n if (changed) {\n switch (path) {\n case 'displayName':\n setDisplayNameDirectly(profile.displayName ?? '');\n break;\n case 'emoji':\n setEmojiDirectly(profile.emoji ?? getDefaultEmojiValue(identity));\n break;\n case 'hue':\n setHueDirectly(profile.hue ?? getDefaultHueValue(identity));\n break;\n default:\n break;\n }\n }\n }\n\n void updateProfile(profile);\n },\n [identity],\n );\n\n const values = useMemo(\n () => ({\n did: identity?.did,\n displayName,\n emoji,\n hue,\n }),\n [identity, displayName, emoji, hue],\n );\n\n // TODO(wittjosiah): Integrate descriptions with the form schema.\n const fieldMap = useMemo<FormFieldMap>(\n () => ({\n displayName: ({ type, label, getValue, onValueChange }) => {\n const handleChange = useCallback(\n ({ target: { value } }: ChangeEvent<HTMLInputElement>) => onValueChange(type, value),\n [onValueChange, type],\n );\n\n return (\n <Settings.Item title={label} description={t('display-name.description')}>\n <Input.TextInput\n value={getValue()}\n onChange={handleChange}\n placeholder={t('display-name-input.placeholder')}\n classNames='min-w-64'\n />\n </Settings.Item>\n );\n },\n emoji: ({ type, label, getValue, onValueChange }) => {\n const handleChange = useCallback((nextEmoji: string) => onValueChange(type, nextEmoji), [onValueChange, type]);\n const handleEmojiReset = useCallback(\n () => onValueChange(type, getDefaultEmojiValue(identity)),\n [onValueChange, type],\n );\n\n return (\n <Settings.Item title={label} description={t('icon.description')}>\n <EmojiPickerBlock\n triggerVariant='default'\n emoji={getValue()}\n onChangeEmoji={handleChange}\n onClickClear={handleEmojiReset}\n classNames='justify-self-end'\n />\n </Settings.Item>\n );\n },\n hue: ({ type, label, getValue, onValueChange }) => {\n const handleChange = useCallback((nextHue: string) => onValueChange(type, nextHue), [onValueChange, type]);\n const handleHueReset = useCallback(\n () => onValueChange(type, getDefaultHueValue(identity)),\n [onValueChange, type],\n );\n\n return (\n <Settings.Item title={label} description={t('hue.description')}>\n <div className='flex justify-self-end'>\n <HuePicker value={getValue()} onChange={handleChange} onReset={handleHueReset} />\n </div>\n </Settings.Item>\n );\n },\n // TODO(wittjosiah): We need text input annotations for disabled and copyable.\n did: ({ label, getValue }) => {\n return (\n <Settings.Item title={label} description={t('did.description')}>\n <ButtonGroup classNames='w-full'>\n <Input.TextInput value={getValue()} disabled classNames='min-w-64' />\n <Clipboard.IconButton value={getValue() ?? ''} />\n </ButtonGroup>\n </Settings.Item>\n );\n },\n }),\n [t],\n );\n\n return (\n <Clipboard.Provider>\n <Settings.Viewport>\n <Settings.Section title={t('profile.label')} description={t('profile.description')}>\n <Form.Root schema={UserProfile} values={values} fieldMap={fieldMap} onValuesChanged={handleChange}>\n <Form.Content classNames='gap-form-gap'>\n <Form.FieldSet />\n </Form.Content>\n </Form.Root>\n </Settings.Section>\n </Settings.Viewport>\n </Clipboard.Provider>\n );\n};\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
|
+
"names": ["Schema", "React", "useCallback", "useMemo", "useState", "debounce", "useClient", "useIdentity", "ButtonGroup", "Clipboard", "Input", "useTranslation", "Form", "Settings", "EmojiPickerBlock", "HuePicker", "hexToEmoji", "hexToHue", "meta", "UserProfile", "Struct", "did", "String", "annotations", "title", "displayName", "emoji", "hue", "getDefaultHueValue", "identity", "identityKey", "toHex", "getHueValue", "profile", "data", "getDefaultEmojiValue", "getEmojiValue", "ProfileContainer", "t", "id", "client", "setDisplayNameDirectly", "setEmojiDirectly", "setHueDirectly", "updateProfile", "halo", "handleChange", "path", "changed", "Object", "entries", "values", "fieldMap", "type", "label", "getValue", "onValueChange", "target", "value", "Item", "description", "TextInput", "onChange", "placeholder", "classNames", "nextEmoji", "handleEmojiReset", "triggerVariant", "onChangeEmoji", "onClickClear", "nextHue", "handleHueReset", "div", "className", "onReset", "disabled", "IconButton", "Provider", "Viewport", "Section", "Root", "schema", "onValuesChanged", "Content", "FieldSet"]
|
|
7
|
+
}
|
|
@@ -0,0 +1,59 @@
|
|
|
1
|
+
import "./chunk-J5LGTIGS.mjs";
|
|
2
|
+
|
|
3
|
+
// src/containers/RecoveryCodeDialog/RecoveryCodeDialog.tsx
|
|
4
|
+
import React, { useCallback, useState } from "react";
|
|
5
|
+
import { AlertDialog, Button, Clipboard, Input, useTranslation } from "@dxos/react-ui";
|
|
6
|
+
import { meta } from "#meta";
|
|
7
|
+
var RecoveryCodeDialog = ({ code }) => {
|
|
8
|
+
const { t } = useTranslation(meta.id);
|
|
9
|
+
const [confirmation, setConfirmation] = useState(false);
|
|
10
|
+
const handleConfirmation = useCallback((checked) => setConfirmation(checked), []);
|
|
11
|
+
return /* @__PURE__ */ React.createElement(AlertDialog.Content, {
|
|
12
|
+
size: "md",
|
|
13
|
+
classNames: "min-h-[15rem]"
|
|
14
|
+
}, /* @__PURE__ */ React.createElement(AlertDialog.Body, null, /* @__PURE__ */ React.createElement(AlertDialog.Title, null, t("recovery-code-dialog.title")), /* @__PURE__ */ React.createElement(AlertDialog.Description, {
|
|
15
|
+
classNames: "py-4"
|
|
16
|
+
}, t("recovery-code-dialog.description")), /* @__PURE__ */ React.createElement(Clipboard.Provider, null, /* @__PURE__ */ React.createElement(Code, {
|
|
17
|
+
code
|
|
18
|
+
})), /* @__PURE__ */ React.createElement("div", {
|
|
19
|
+
className: "flex flex-col py-4 gap-2"
|
|
20
|
+
}, /* @__PURE__ */ React.createElement("p", null, t("recovery-code-dialog-warning-1.message")), /* @__PURE__ */ React.createElement("p", null, t("recovery-code-dialog-warning-2.message"))), /* @__PURE__ */ React.createElement("div", {
|
|
21
|
+
className: "flex items-center gap-2 pb-4"
|
|
22
|
+
}, /* @__PURE__ */ React.createElement(Input.Root, null, /* @__PURE__ */ React.createElement(Input.Checkbox, {
|
|
23
|
+
"data-testid": "recoveryCode.confirm",
|
|
24
|
+
checked: confirmation,
|
|
25
|
+
onCheckedChange: handleConfirmation
|
|
26
|
+
}), /* @__PURE__ */ React.createElement(Input.Label, null, t("recovery-code-confirmation.label"))))), /* @__PURE__ */ React.createElement(AlertDialog.ActionBar, null, /* @__PURE__ */ React.createElement(AlertDialog.Action, {
|
|
27
|
+
asChild: true
|
|
28
|
+
}, /* @__PURE__ */ React.createElement(Button, {
|
|
29
|
+
"data-testid": "recoveryCode.continue",
|
|
30
|
+
variant: "primary",
|
|
31
|
+
disabled: !confirmation
|
|
32
|
+
}, t("continue.label")))));
|
|
33
|
+
};
|
|
34
|
+
var Code = ({ code }) => {
|
|
35
|
+
const words = code.split(" ");
|
|
36
|
+
return /* @__PURE__ */ React.createElement("div", {
|
|
37
|
+
className: "relative p-2 border border-separator rounded-sm group"
|
|
38
|
+
}, /* @__PURE__ */ React.createElement(Clipboard.IconButton, {
|
|
39
|
+
value: code,
|
|
40
|
+
classNames: "absolute top-2 right-2 invisible group-hover:visible"
|
|
41
|
+
}), /* @__PURE__ */ React.createElement("div", {
|
|
42
|
+
className: "grid grid-cols-4"
|
|
43
|
+
}, words.map((word, i) => /* @__PURE__ */ React.createElement("div", {
|
|
44
|
+
key: i,
|
|
45
|
+
className: "flex items-center p-2 gap-2"
|
|
46
|
+
}, /* @__PURE__ */ React.createElement("div", {
|
|
47
|
+
className: "w-4 text-xs text-center text-subdued"
|
|
48
|
+
}, i + 1), /* @__PURE__ */ React.createElement("div", {
|
|
49
|
+
className: "text-sm"
|
|
50
|
+
}, word)))));
|
|
51
|
+
};
|
|
52
|
+
|
|
53
|
+
// src/containers/RecoveryCodeDialog/index.ts
|
|
54
|
+
var RecoveryCodeDialog_default = RecoveryCodeDialog;
|
|
55
|
+
export {
|
|
56
|
+
RecoveryCodeDialog,
|
|
57
|
+
RecoveryCodeDialog_default as default
|
|
58
|
+
};
|
|
59
|
+
//# sourceMappingURL=RecoveryCodeDialog-EWHB6U5T.mjs.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../src/containers/RecoveryCodeDialog/RecoveryCodeDialog.tsx", "../../../src/containers/RecoveryCodeDialog/index.ts"],
|
|
4
|
+
"sourcesContent": ["//\n// Copyright 2024 DXOS.org\n//\n\nimport React, { useCallback, useState } from 'react';\n\nimport { AlertDialog, Button, Clipboard, Input, useTranslation } from '@dxos/react-ui';\n\nimport { meta } from '#meta';\n\nexport type RecoveryCodeDialogProps = {\n code: string;\n};\n\n// TODO(burdon): Should have cancel button.\nexport const RecoveryCodeDialog = ({ code }: RecoveryCodeDialogProps) => {\n const { t } = useTranslation(meta.id);\n const [confirmation, setConfirmation] = useState(false);\n\n const handleConfirmation = useCallback((checked: boolean) => setConfirmation(checked), []);\n\n return (\n <AlertDialog.Content size='md' classNames='min-h-[15rem]'>\n <AlertDialog.Body>\n <AlertDialog.Title>{t('recovery-code-dialog.title')}</AlertDialog.Title>\n <AlertDialog.Description classNames='py-4'>{t('recovery-code-dialog.description')}</AlertDialog.Description>\n <Clipboard.Provider>\n <Code code={code} />\n </Clipboard.Provider>\n <div className='flex flex-col py-4 gap-2'>\n <p>{t('recovery-code-dialog-warning-1.message')}</p>\n <p>{t('recovery-code-dialog-warning-2.message')}</p>\n </div>\n <div className='flex items-center gap-2 pb-4'>\n <Input.Root>\n <Input.Checkbox\n data-testid='recoveryCode.confirm'\n checked={confirmation}\n onCheckedChange={handleConfirmation}\n />\n <Input.Label>{t('recovery-code-confirmation.label')}</Input.Label>\n </Input.Root>\n </div>\n </AlertDialog.Body>\n <AlertDialog.ActionBar>\n <AlertDialog.Action asChild>\n <Button data-testid='recoveryCode.continue' variant='primary' disabled={!confirmation}>\n {t('continue.label')}\n </Button>\n </AlertDialog.Action>\n </AlertDialog.ActionBar>\n </AlertDialog.Content>\n );\n};\n\nconst Code = ({ code }: { code: string }) => {\n const words = code.split(' ');\n return (\n <div className='relative p-2 border border-separator rounded-sm group'>\n <Clipboard.IconButton value={code} classNames='absolute top-2 right-2 invisible group-hover:visible' />\n <div className='grid grid-cols-4'>\n {words.map((word, i) => (\n <div key={i} className='flex items-center p-2 gap-2'>\n <div className='w-4 text-xs text-center text-subdued'>{i + 1}</div>\n <div className='text-sm'>{word}</div>\n </div>\n ))}\n </div>\n </div>\n );\n};\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport { RecoveryCodeDialog } from './RecoveryCodeDialog';\n\nexport * from './RecoveryCodeDialog';\nexport default RecoveryCodeDialog;\n"],
|
|
5
|
+
"mappings": ";;;AAIA,OAAOA,SAASC,aAAaC,gBAAgB;AAE7C,SAASC,aAAaC,QAAQC,WAAWC,OAAOC,sBAAsB;AAEtE,SAASC,YAAY;AAOd,IAAMC,qBAAqB,CAAC,EAAEC,KAAI,MAA2B;AAClE,QAAM,EAAEC,EAAC,IAAKJ,eAAeC,KAAKI,EAAE;AACpC,QAAM,CAACC,cAAcC,eAAAA,IAAmBZ,SAAS,KAAA;AAEjD,QAAMa,qBAAqBd,YAAY,CAACe,YAAqBF,gBAAgBE,OAAAA,GAAU,CAAA,CAAE;AAEzF,SACE,sBAAA,cAACb,YAAYc,SAAO;IAACC,MAAK;IAAKC,YAAW;KACxC,sBAAA,cAAChB,YAAYiB,MAAI,MACf,sBAAA,cAACjB,YAAYkB,OAAK,MAAEV,EAAE,4BAAA,CAAA,GACtB,sBAAA,cAACR,YAAYmB,aAAW;IAACH,YAAW;KAAQR,EAAE,kCAAA,CAAA,GAC9C,sBAAA,cAACN,UAAUkB,UAAQ,MACjB,sBAAA,cAACC,MAAAA;IAAKd;OAER,sBAAA,cAACe,OAAAA;IAAIC,WAAU;KACb,sBAAA,cAACC,KAAAA,MAAGhB,EAAE,wCAAA,CAAA,GACN,sBAAA,cAACgB,KAAAA,MAAGhB,EAAE,wCAAA,CAAA,CAAA,GAER,sBAAA,cAACc,OAAAA;IAAIC,WAAU;KACb,sBAAA,cAACpB,MAAMsB,MAAI,MACT,sBAAA,cAACtB,MAAMuB,UAAQ;IACbC,eAAY;IACZd,SAASH;IACTkB,iBAAiBhB;MAEnB,sBAAA,cAACT,MAAM0B,OAAK,MAAErB,EAAE,kCAAA,CAAA,CAAA,CAAA,CAAA,GAItB,sBAAA,cAACR,YAAY8B,WAAS,MACpB,sBAAA,cAAC9B,YAAY+B,QAAM;IAACC,SAAAA;KAClB,sBAAA,cAAC/B,QAAAA;IAAO0B,eAAY;IAAwBM,SAAQ;IAAUC,UAAU,CAACxB;KACtEF,EAAE,gBAAA,CAAA,CAAA,CAAA,CAAA;AAMf;AAEA,IAAMa,OAAO,CAAC,EAAEd,KAAI,MAAoB;AACtC,QAAM4B,QAAQ5B,KAAK6B,MAAM,GAAA;AACzB,SACE,sBAAA,cAACd,OAAAA;IAAIC,WAAU;KACb,sBAAA,cAACrB,UAAUmC,YAAU;IAACC,OAAO/B;IAAMS,YAAW;MAC9C,sBAAA,cAACM,OAAAA;IAAIC,WAAU;KACZY,MAAMI,IAAI,CAACC,MAAMC,MAChB,sBAAA,cAACnB,OAAAA;IAAIoB,KAAKD;IAAGlB,WAAU;KACrB,sBAAA,cAACD,OAAAA;IAAIC,WAAU;KAAwCkB,IAAI,CAAA,GAC3D,sBAAA,cAACnB,OAAAA;IAAIC,WAAU;KAAWiB,IAAAA,CAAAA,CAAAA,CAAAA,CAAAA;AAMtC;;;AC/DA,IAAA,6BAAeG;",
|
|
6
|
+
"names": ["React", "useCallback", "useState", "AlertDialog", "Button", "Clipboard", "Input", "useTranslation", "meta", "RecoveryCodeDialog", "code", "t", "id", "confirmation", "setConfirmation", "handleConfirmation", "checked", "Content", "size", "classNames", "Body", "Title", "Description", "Provider", "Code", "div", "className", "p", "Root", "Checkbox", "data-testid", "onCheckedChange", "Label", "ActionBar", "Action", "asChild", "variant", "disabled", "words", "split", "IconButton", "value", "map", "word", "i", "key", "RecoveryCodeDialog"]
|
|
7
|
+
}
|
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
import "./chunk-J5LGTIGS.mjs";
|
|
2
|
+
|
|
3
|
+
// src/containers/RecoveryCredentialsContainer/RecoveryCredentialsContainer.tsx
|
|
4
|
+
import React from "react";
|
|
5
|
+
import { useOperationInvoker } from "@dxos/app-framework/ui";
|
|
6
|
+
import { useCredentials } from "@dxos/react-client/halo";
|
|
7
|
+
import { Icon, IconButton, List, ListItem, Message, useTranslation } from "@dxos/react-ui";
|
|
8
|
+
import { Settings } from "@dxos/react-ui-form";
|
|
9
|
+
import { meta } from "#meta";
|
|
10
|
+
import { ClientOperation } from "#operations";
|
|
11
|
+
var MANAGE_CREDENTIALS_DIALOG = `${meta.id}.ManageCredentialsDialog`;
|
|
12
|
+
var RecoveryCredentialsContainer = () => {
|
|
13
|
+
const { t } = useTranslation(meta.id);
|
|
14
|
+
const { invokePromise } = useOperationInvoker();
|
|
15
|
+
const credentials = useCredentials();
|
|
16
|
+
const recoveryCredentials = credentials.filter((credential) => credential.subject.assertion["@type"] === "dxos.halo.credentials.IdentityRecovery");
|
|
17
|
+
return /* @__PURE__ */ React.createElement(Settings.Viewport, null, /* @__PURE__ */ React.createElement(Settings.Section, {
|
|
18
|
+
title: t("recovery-setup-dialog.title"),
|
|
19
|
+
description: t("recovery-setup-dialog.description")
|
|
20
|
+
}, /* @__PURE__ */ React.createElement(Settings.Item, {
|
|
21
|
+
title: t("create-passkey.label"),
|
|
22
|
+
description: t("create-passkey.description")
|
|
23
|
+
}, /* @__PURE__ */ React.createElement(IconButton, {
|
|
24
|
+
label: t("create-passkey.label"),
|
|
25
|
+
icon: "ph--key--duotone",
|
|
26
|
+
variant: "primary",
|
|
27
|
+
onClick: () => invokePromise(ClientOperation.CreatePasskey)
|
|
28
|
+
})), /* @__PURE__ */ React.createElement(Settings.Item, {
|
|
29
|
+
title: t("create-recovery-code.label"),
|
|
30
|
+
description: t("create-recovery-code.description")
|
|
31
|
+
}, /* @__PURE__ */ React.createElement(IconButton, {
|
|
32
|
+
label: t("create-recovery-code.label"),
|
|
33
|
+
icon: "ph--receipt--duotone",
|
|
34
|
+
variant: "default",
|
|
35
|
+
onClick: () => invokePromise(ClientOperation.CreateRecoveryCode)
|
|
36
|
+
}))), /* @__PURE__ */ React.createElement(Settings.Section, {
|
|
37
|
+
title: t("credentials-list.label")
|
|
38
|
+
}, recoveryCredentials.length < 1 ? /* @__PURE__ */ React.createElement(Message.Root, {
|
|
39
|
+
valence: "error"
|
|
40
|
+
}, /* @__PURE__ */ React.createElement(Message.Title, {
|
|
41
|
+
icon: "ph--shield-warning--duotone"
|
|
42
|
+
}, t("no-credentials.title")), /* @__PURE__ */ React.createElement(Message.Content, null, t("no-credentials.message"))) : /* @__PURE__ */ React.createElement(List, null, recoveryCredentials.map((credential) => /* @__PURE__ */ React.createElement(ListItem.Root, {
|
|
43
|
+
key: credential.id?.toHex()
|
|
44
|
+
}, /* @__PURE__ */ React.createElement(ListItem.Endcap, null, /* @__PURE__ */ React.createElement(Icon, {
|
|
45
|
+
icon: "ph--key--regular"
|
|
46
|
+
})), /* @__PURE__ */ React.createElement(ListItem.Heading, null, credential.issuanceDate.toLocaleString()))))));
|
|
47
|
+
};
|
|
48
|
+
export {
|
|
49
|
+
RecoveryCredentialsContainer as default
|
|
50
|
+
};
|
|
51
|
+
//# sourceMappingURL=RecoveryCredentialsContainer-IPBGDMIA.mjs.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../src/containers/RecoveryCredentialsContainer/RecoveryCredentialsContainer.tsx"],
|
|
4
|
+
"sourcesContent": ["//\n// Copyright 2024 DXOS.org\n//\n\nimport React from 'react';\n\nimport { useOperationInvoker } from '@dxos/app-framework/ui';\nimport { useCredentials } from '@dxos/react-client/halo';\nimport { Icon, IconButton, List, ListItem, Message, useTranslation } from '@dxos/react-ui';\nimport { Settings } from '@dxos/react-ui-form';\n\nimport { meta } from '#meta';\nimport { ClientOperation } from '#operations';\n\nexport const MANAGE_CREDENTIALS_DIALOG = `${meta.id}.ManageCredentialsDialog`;\n\nexport const RecoveryCredentialsContainer = () => {\n const { t } = useTranslation(meta.id);\n const { invokePromise } = useOperationInvoker();\n const credentials = useCredentials();\n const recoveryCredentials = credentials.filter(\n (credential) => credential.subject.assertion['@type'] === 'dxos.halo.credentials.IdentityRecovery',\n );\n\n return (\n <Settings.Viewport>\n <Settings.Section title={t('recovery-setup-dialog.title')} description={t('recovery-setup-dialog.description')}>\n <Settings.Item title={t('create-passkey.label')} description={t('create-passkey.description')}>\n <IconButton\n label={t('create-passkey.label')}\n icon='ph--key--duotone'\n variant='primary'\n onClick={() => invokePromise(ClientOperation.CreatePasskey)}\n />\n </Settings.Item>\n <Settings.Item title={t('create-recovery-code.label')} description={t('create-recovery-code.description')}>\n <IconButton\n label={t('create-recovery-code.label')}\n icon='ph--receipt--duotone'\n variant='default'\n onClick={() => invokePromise(ClientOperation.CreateRecoveryCode)}\n />\n </Settings.Item>\n </Settings.Section>\n <Settings.Section title={t('credentials-list.label')}>\n {recoveryCredentials.length < 1 ? (\n <Message.Root valence='error'>\n <Message.Title icon='ph--shield-warning--duotone'>{t('no-credentials.title')}</Message.Title>\n <Message.Content>{t('no-credentials.message')}</Message.Content>\n </Message.Root>\n ) : (\n <List>\n {recoveryCredentials.map((credential) => (\n <ListItem.Root key={credential.id?.toHex()}>\n <ListItem.Endcap>\n <Icon icon='ph--key--regular' />\n </ListItem.Endcap>\n <ListItem.Heading>{credential.issuanceDate.toLocaleString()}</ListItem.Heading>\n </ListItem.Root>\n ))}\n </List>\n )}\n </Settings.Section>\n </Settings.Viewport>\n );\n};\n"],
|
|
5
|
+
"mappings": ";;;AAIA,OAAOA,WAAW;AAElB,SAASC,2BAA2B;AACpC,SAASC,sBAAsB;AAC/B,SAASC,MAAMC,YAAYC,MAAMC,UAAUC,SAASC,sBAAsB;AAC1E,SAASC,gBAAgB;AAEzB,SAASC,YAAY;AACrB,SAASC,uBAAuB;AAEzB,IAAMC,4BAA4B,GAAGF,KAAKG,EAAE;AAE5C,IAAMC,+BAA+B,MAAA;AAC1C,QAAM,EAAEC,EAAC,IAAKP,eAAeE,KAAKG,EAAE;AACpC,QAAM,EAAEG,cAAa,IAAKf,oBAAAA;AAC1B,QAAMgB,cAAcf,eAAAA;AACpB,QAAMgB,sBAAsBD,YAAYE,OACtC,CAACC,eAAeA,WAAWC,QAAQC,UAAU,OAAA,MAAa,wCAAA;AAG5D,SACE,sBAAA,cAACb,SAASc,UAAQ,MAChB,sBAAA,cAACd,SAASe,SAAO;IAACC,OAAOV,EAAE,6BAAA;IAAgCW,aAAaX,EAAE,mCAAA;KACxE,sBAAA,cAACN,SAASkB,MAAI;IAACF,OAAOV,EAAE,sBAAA;IAAyBW,aAAaX,EAAE,4BAAA;KAC9D,sBAAA,cAACX,YAAAA;IACCwB,OAAOb,EAAE,sBAAA;IACTc,MAAK;IACLC,SAAQ;IACRC,SAAS,MAAMf,cAAcL,gBAAgBqB,aAAa;OAG9D,sBAAA,cAACvB,SAASkB,MAAI;IAACF,OAAOV,EAAE,4BAAA;IAA+BW,aAAaX,EAAE,kCAAA;KACpE,sBAAA,cAACX,YAAAA;IACCwB,OAAOb,EAAE,4BAAA;IACTc,MAAK;IACLC,SAAQ;IACRC,SAAS,MAAMf,cAAcL,gBAAgBsB,kBAAkB;QAIrE,sBAAA,cAACxB,SAASe,SAAO;IAACC,OAAOV,EAAE,wBAAA;KACxBG,oBAAoBgB,SAAS,IAC5B,sBAAA,cAAC3B,QAAQ4B,MAAI;IAACC,SAAQ;KACpB,sBAAA,cAAC7B,QAAQ8B,OAAK;IAACR,MAAK;KAA+Bd,EAAE,sBAAA,CAAA,GACrD,sBAAA,cAACR,QAAQ+B,SAAO,MAAEvB,EAAE,wBAAA,CAAA,CAAA,IAGtB,sBAAA,cAACV,MAAAA,MACEa,oBAAoBqB,IAAI,CAACnB,eACxB,sBAAA,cAACd,SAAS6B,MAAI;IAACK,KAAKpB,WAAWP,IAAI4B,MAAAA;KACjC,sBAAA,cAACnC,SAASoC,QAAM,MACd,sBAAA,cAACvC,MAAAA;IAAK0B,MAAK;OAEb,sBAAA,cAACvB,SAASqC,SAAO,MAAEvB,WAAWwB,aAAaC,eAAc,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA;AAQzE;",
|
|
6
|
+
"names": ["React", "useOperationInvoker", "useCredentials", "Icon", "IconButton", "List", "ListItem", "Message", "useTranslation", "Settings", "meta", "ClientOperation", "MANAGE_CREDENTIALS_DIALOG", "id", "RecoveryCredentialsContainer", "t", "invokePromise", "credentials", "recoveryCredentials", "filter", "credential", "subject", "assertion", "Viewport", "Section", "title", "description", "Item", "label", "icon", "variant", "onClick", "CreatePasskey", "CreateRecoveryCode", "length", "Root", "valence", "Title", "Content", "map", "key", "toHex", "Endcap", "Heading", "issuanceDate", "toLocaleString"]
|
|
7
|
+
}
|
|
@@ -0,0 +1,57 @@
|
|
|
1
|
+
import "./chunk-J5LGTIGS.mjs";
|
|
2
|
+
|
|
3
|
+
// src/containers/ResetDialog/ResetDialog.tsx
|
|
4
|
+
import * as Effect from "effect/Effect";
|
|
5
|
+
import React, { useCallback } from "react";
|
|
6
|
+
import { Capability } from "@dxos/app-framework";
|
|
7
|
+
import { useOperationInvoker } from "@dxos/app-framework/ui";
|
|
8
|
+
import { LayoutOperation } from "@dxos/app-toolkit";
|
|
9
|
+
import { EffectEx } from "@dxos/effect";
|
|
10
|
+
import { useClient } from "@dxos/react-client";
|
|
11
|
+
import { Dialog, useTranslation } from "@dxos/react-ui";
|
|
12
|
+
import { ConfirmReset, translationKey } from "@dxos/shell/react";
|
|
13
|
+
var ResetDialog = ({ mode, onReset, onBeforeReset, capabilityManager }) => {
|
|
14
|
+
const { t } = useTranslation(translationKey);
|
|
15
|
+
const { invokePromise } = useOperationInvoker();
|
|
16
|
+
const client = useClient();
|
|
17
|
+
const handleReset = useCallback(async () => {
|
|
18
|
+
if (onBeforeReset) {
|
|
19
|
+
await onBeforeReset();
|
|
20
|
+
}
|
|
21
|
+
await client.reset();
|
|
22
|
+
const target = mode === "join-new-identity" ? "deviceInvitation" : mode === "recover" ? "recoverIdentity" : void 0;
|
|
23
|
+
if (onReset) {
|
|
24
|
+
await EffectEx.runAndForwardErrors(onReset({
|
|
25
|
+
target
|
|
26
|
+
}).pipe(Effect.provideService(Capability.Service, capabilityManager)));
|
|
27
|
+
}
|
|
28
|
+
}, [
|
|
29
|
+
client,
|
|
30
|
+
mode,
|
|
31
|
+
onReset,
|
|
32
|
+
capabilityManager
|
|
33
|
+
]);
|
|
34
|
+
const handleCancel = useCallback(() => {
|
|
35
|
+
void invokePromise(LayoutOperation.UpdateDialog, {
|
|
36
|
+
state: false
|
|
37
|
+
});
|
|
38
|
+
}, [
|
|
39
|
+
invokePromise
|
|
40
|
+
]);
|
|
41
|
+
return /* @__PURE__ */ React.createElement(Dialog.Content, null, /* @__PURE__ */ React.createElement(Dialog.Header, null, /* @__PURE__ */ React.createElement(Dialog.Title, null, t("reset-dialog.title"))), /* @__PURE__ */ React.createElement(Dialog.Body, null, /* @__PURE__ */ React.createElement(Dialog.Description, {
|
|
42
|
+
classNames: "sr-only"
|
|
43
|
+
}, t("reset-dialog.description")), /* @__PURE__ */ React.createElement(ConfirmReset, {
|
|
44
|
+
active: true,
|
|
45
|
+
mode,
|
|
46
|
+
onConfirm: handleReset,
|
|
47
|
+
onCancel: handleCancel
|
|
48
|
+
})));
|
|
49
|
+
};
|
|
50
|
+
|
|
51
|
+
// src/containers/ResetDialog/index.ts
|
|
52
|
+
var ResetDialog_default = ResetDialog;
|
|
53
|
+
export {
|
|
54
|
+
ResetDialog,
|
|
55
|
+
ResetDialog_default as default
|
|
56
|
+
};
|
|
57
|
+
//# sourceMappingURL=ResetDialog-KUWX45JY.mjs.map
|