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 c6ed261960..69f0852aa0 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 @@ -4,10 +4,11 @@ import React, { useState } from 'react'; import AccountStep from './steps/account-step'; import ExtensionStep from './steps/extension-step'; import IdentityStep from './steps/identity-step'; +import KeyAddStep from './steps/key-add-step'; import KeyStep from './steps/key-step'; import KeygenStep from './steps/keygen-step'; -type Step = 'extension' | 'identity' | 'key' | 'keygen' | 'account'; +type Step = 'extension' | 'identity' | 'key' | 'keygen' | 'key-add' | 'account'; interface INostrSigninModal { onClose: (type?: string) => void; @@ -28,6 +29,8 @@ const NostrSigninModal: React.FC = ({ onClose }) => { return ; case 'key': return ; + case 'key-add': + return ; case 'keygen': return ; case 'account': diff --git a/src/features/ui/components/modals/nostr-signin-modal/steps/extension-step.tsx b/src/features/ui/components/modals/nostr-signin-modal/steps/extension-step.tsx index d4c5bc26e9..2e6a1a7964 100644 --- a/src/features/ui/components/modals/nostr-signin-modal/steps/extension-step.tsx +++ b/src/features/ui/components/modals/nostr-signin-modal/steps/extension-step.tsx @@ -17,7 +17,7 @@ const ExtensionStep: React.FC = ({ setStep, onClose }) => { const dispatch = useAppDispatch(); const onClick = () => dispatch(nostrExtensionLogIn()); - const onClickAlt = () => setStep('identity'); + const onClickAlt = () => setStep('key-add'); return ( } onClose={onClose}> diff --git a/src/features/ui/components/modals/nostr-signin-modal/steps/key-add-step.tsx b/src/features/ui/components/modals/nostr-signin-modal/steps/key-add-step.tsx new file mode 100644 index 0000000000..d44c7accd8 --- /dev/null +++ b/src/features/ui/components/modals/nostr-signin-modal/steps/key-add-step.tsx @@ -0,0 +1,73 @@ +import { NostrSigner } from '@soapbox/nspec'; +import { getPublicKey, nip19 } from 'nostr-tools'; +import React, { useState } from 'react'; +import { FormattedMessage } from 'react-intl'; + +import { Button, Stack, Modal, Input, FormGroup, Form } from 'soapbox/components/ui'; +import { NKeys } from 'soapbox/features/nostr/keys'; + +import EmojiGraphic from '../components/emoji-graphic'; +import NostrExtensionIndicator from '../components/nostr-extension-indicator'; +import { Step } from '../nostr-signin-modal'; + +interface IKeyAddStep { + setAccountId(accountId: string): void; + setSigner(signer: NostrSigner): void; + setStep(step: Step): void; + onClose(): void; +} + +const KeyAddStep: React.FC = ({ setAccountId, setSigner, setStep, onClose }) => { + const [nsec, setNsec] = useState(''); + const [error, setError] = useState(); + + const handleChange = (e: React.ChangeEvent) => { + setNsec(e.target.value); + setError(undefined); + }; + + const handleSubmit = () => { + try { + const result = nip19.decode(nsec); + if (result.type === 'nsec') { + const seckey = result.data; + const pubkey = getPublicKey(seckey); + const signer = NKeys.add(seckey); + setAccountId(pubkey); + setSigner(signer); + setStep('account'); + } + } catch (e) { + setError('Invalid nsec'); + } + }; + + return ( + } onClose={onClose}> + + + + + +
+ + + + + + + +
+
+
+ ); +}; + +export default KeyAddStep;