From 07d24c91d843ea992376d6fa34dce0ce598a2297 Mon Sep 17 00:00:00 2001 From: Chewbacca Date: Mon, 24 Oct 2022 09:05:17 -0400 Subject: [PATCH] Allow tab continuation on Email confirmation --- app/soapbox/actions/verification.ts | 44 ++++++++++++++++--- .../features/verification/email-passthru.tsx | 11 ++--- 2 files changed, 44 insertions(+), 11 deletions(-) diff --git a/app/soapbox/actions/verification.ts b/app/soapbox/actions/verification.ts index ce3d27009..d038a79a9 100644 --- a/app/soapbox/actions/verification.ts +++ b/app/soapbox/actions/verification.ts @@ -32,13 +32,14 @@ export type Challenge = 'age' | 'sms' | 'email' type Challenges = { email?: 0 | 1, - sms?: number, - age?: number, + sms?: 0 | 1, + age?: 0 | 1, } type Verification = { token?: string, challenges?: Challenges, + challengeTypes?: Array<'age' | 'sms' | 'email'> }; /** @@ -83,6 +84,18 @@ const fetchStoredChallenges = () => { } }; +/** + * Fetch and return the state of the verification challenge types. + */ +const fetchStoredChallengeTypes = () => { + try { + const verification: Verification | null = fetchStoredVerification(); + return verification!.challengeTypes; + } catch { + return null; + } +}; + /** * Update the verification object in local storage. * @@ -131,7 +144,10 @@ function saveChallenges(challenges: Array<'age' | 'sms' | 'email'>) { } } - updateStorage({ challenges: currentChallenges }); + updateStorage({ + challenges: currentChallenges, + challengeTypes: challenges, + }); } /** @@ -267,13 +283,29 @@ const confirmEmailVerification = (emailToken: string) => return api(getState).post('/api/v1/pepe/verify_email/confirm', { token: emailToken }, { headers: { Authorization: `Bearer ${token}` }, }) - .then(() => { - finishChallenge(EMAIL); - dispatchNextChallenge(dispatch); + .then((response) => { + updateStorageFromEmailConfirmation(dispatch, response.data.token); }) .finally(() => dispatch({ type: SET_LOADING, value: false })); }; +const updateStorageFromEmailConfirmation = (dispatch: AppDispatch, token: string) => { + const challengeTypes = fetchStoredChallengeTypes(); + if (!challengeTypes) { + return; + } + + const indexOfEmail = challengeTypes.indexOf('email'); + const challenges: Challenges = {}; + challengeTypes?.forEach((challengeType, idx) => { + const value = idx <= indexOfEmail ? 1 : 0; + challenges[challengeType] = value; + }); + + updateStorage({ token, challengeTypes, challenges }); + dispatchNextChallenge(dispatch); +}; + const postEmailVerification = () => (dispatch: AppDispatch) => { finishChallenge(EMAIL); diff --git a/app/soapbox/features/verification/email-passthru.tsx b/app/soapbox/features/verification/email-passthru.tsx index bfdc017de..b615de757 100644 --- a/app/soapbox/features/verification/email-passthru.tsx +++ b/app/soapbox/features/verification/email-passthru.tsx @@ -40,11 +40,12 @@ const Success = () => { const history = useHistory(); const currentChallenge = useAppSelector((state) => state.verification.currentChallenge as ChallengeTypes); - // Bypass the user straight to the next step. - if (currentChallenge === ChallengeTypes.SMS) { - history.push('/verify'); - return null; - } + React.useEffect(() => { + // Bypass the user straight to the next step. + if (currentChallenge === ChallengeTypes.SMS) { + history.push('/verify'); + } + }, [currentChallenge]); return (