diff --git a/src/actions/accounts.ts b/src/actions/accounts.ts index 2099cb63ff..37dea3cc77 100644 --- a/src/actions/accounts.ts +++ b/src/actions/accounts.ts @@ -154,7 +154,7 @@ const fetchAccount = (id: string) => const account = selectAccount(getState(), id); if (account) { - return null; + return Promise.resolve(null); } dispatch(fetchAccountRequest(id)); diff --git a/src/features/ui/components/modals/nostr-signin-modal/nostr-signin-modal.tsx b/src/features/ui/components/modals/nostr-signin-modal/nostr-signin-modal.tsx index 215202ebf5..40a7c86e92 100644 --- a/src/features/ui/components/modals/nostr-signin-modal/nostr-signin-modal.tsx +++ b/src/features/ui/components/modals/nostr-signin-modal/nostr-signin-modal.tsx @@ -30,7 +30,7 @@ const NostrSigninModal: React.FC = ({ onClose }) => { case 'key': return ; case 'keygen': - return ; + return ; case 'account': return ; case 'register': diff --git a/src/features/ui/components/modals/nostr-signin-modal/steps/account-step.tsx b/src/features/ui/components/modals/nostr-signin-modal/steps/account-step.tsx index fcd023a2a6..4d8d889acd 100644 --- a/src/features/ui/components/modals/nostr-signin-modal/steps/account-step.tsx +++ b/src/features/ui/components/modals/nostr-signin-modal/steps/account-step.tsx @@ -4,6 +4,7 @@ import { FormattedMessage } from 'react-intl'; import { useAccount } from 'soapbox/api/hooks'; import { Avatar, Text, Stack, Emoji, Button, Tooltip, Modal } from 'soapbox/components/ui'; +import ModalLoading from 'soapbox/features/ui/components/modal-loading'; import { useInstance } from 'soapbox/hooks'; import { Step } from '../nostr-signin-modal'; @@ -24,7 +25,7 @@ const AccountStep: React.FC = ({ accountId, setStep, onClose }) => ); if (!account) { - return null; + return ; } return ( diff --git a/src/features/ui/components/modals/nostr-signin-modal/steps/keygen-step.tsx b/src/features/ui/components/modals/nostr-signin-modal/steps/keygen-step.tsx index cb4fd34acc..ff73fb1dd8 100644 --- a/src/features/ui/components/modals/nostr-signin-modal/steps/keygen-step.tsx +++ b/src/features/ui/components/modals/nostr-signin-modal/steps/keygen-step.tsx @@ -1,12 +1,13 @@ import { generateSecretKey, getPublicKey, nip19 } from 'nostr-tools'; import { NostrSigner } from 'nspec'; -import React, { useMemo, useState } from 'react'; +import React, { useEffect, useMemo, useState } from 'react'; import { FormattedMessage } from 'react-intl'; +import { fetchAccount } from 'soapbox/actions/accounts'; import CopyableInput from 'soapbox/components/copyable-input'; import { Button, Stack, Modal, FormGroup, Text, Tooltip } from 'soapbox/components/ui'; import { NKeys } from 'soapbox/features/nostr/keys'; -import { useInstance } from 'soapbox/hooks'; +import { useAppDispatch, useInstance } from 'soapbox/hooks'; import { download } from 'soapbox/utils/download'; import { slugify } from 'soapbox/utils/input'; @@ -14,13 +15,15 @@ import EmojiGraphic from '../components/emoji-graphic'; import { Step } from '../nostr-signin-modal'; interface IKeygenStep { + setAccountId(accountId: string): void; setSigner(signer: NostrSigner): void; setStep(step: Step): void; onClose(): void; } -const KeygenStep: React.FC = ({ setSigner, setStep, onClose }) => { +const KeygenStep: React.FC = ({ setAccountId, setSigner, setStep, onClose }) => { const instance = useInstance(); + const dispatch = useAppDispatch(); const secretKey = useMemo(() => generateSecretKey(), []); const pubkey = useMemo(() => getPublicKey(secretKey), [secretKey]); @@ -30,6 +33,11 @@ const KeygenStep: React.FC = ({ setSigner, setStep, onClose }) => { const [downloaded, setDownloaded] = useState(false); + useEffect(() => { + // Pre-fetch into cache. + dispatch(fetchAccount(pubkey)).catch(() => {}); + }, [pubkey]); + const handleDownload = () => { download(nsec, `${slugify(instance.title)}-${npub.slice(5, 9)}.nsec.txt`); setDownloaded(true); @@ -40,6 +48,8 @@ const KeygenStep: React.FC = ({ setSigner, setStep, onClose }) => { const handleNext = () => { const signer = NKeys.add(secretKey); setSigner(signer); + setAccountId(pubkey); // HACK: Ditto uses pubkeys as account IDs. + setStep('account'); }; return (