import React, { useEffect, useState } from 'react'; import Modal, { RequiredModalProps } from '@/components/elements/Modal'; import { Form, Formik, FormikActions } from 'formik'; import { object, string } from 'yup'; import Field from '@/components/elements/Field'; import getTwoFactorTokenUrl from '@/api/account/getTwoFactorTokenUrl'; import enableAccountTwoFactor from '@/api/account/enableAccountTwoFactor'; import FlashMessageRender from '@/components/FlashMessageRender'; import { Actions, useStoreActions } from 'easy-peasy'; import { ApplicationStore } from '@/state'; import { httpErrorToHuman } from '@/api/http'; interface Values { code: string; } export default ({ visible, onDismissed }: RequiredModalProps) => { const [ token, setToken ] = useState(''); const [ loading, setLoading ] = useState(true); const { addError, clearFlashes } = useStoreActions((actions: Actions) => actions.flashes); useEffect(() => { if (!visible) { clearFlashes('account:two-factor'); getTwoFactorTokenUrl() .then(setToken) .catch(error => { console.error(error); }); } }, [ visible ]); const submit = ({ code }: Values, { resetForm, setSubmitting }: FormikActions) => { clearFlashes('account:two-factor'); enableAccountTwoFactor(code) .then(() => { resetForm(); setToken(''); setLoading(true); }) .catch(error => { console.error(error); addError({ message: httpErrorToHuman(error), key: 'account:two-factor' }); setSubmitting(false); }); }; return ( {({ isSubmitting, isValid, resetForm }) => ( { resetForm(); setToken(''); setLoading(true); onDismissed(); }} dismissable={!isSubmitting} showSpinnerOverlay={loading || isSubmitting} >
{!token || !token.length ? : setLoading(false)} className={'w-full h-full shadow-none rounded-0'} /> }
)}
); };