bigbuffet-rw/app/soapbox/features/security/mfa-form.tsx

54 lines
1.5 KiB
TypeScript
Raw Normal View History

2022-04-26 10:29:28 -07:00
import React, { useEffect, useState } from 'react';
import { useIntl, defineMessages } from 'react-intl';
import { fetchMfa } from 'soapbox/actions/mfa';
import { Column, Stack } from 'soapbox/components/ui';
2022-04-26 10:29:28 -07:00
import { useAppSelector, useAppDispatch } from 'soapbox/hooks';
2022-11-15 11:00:40 -08:00
import DisableOtpForm from './mfa/disable-otp-form';
import EnableOtpForm from './mfa/enable-otp-form';
import OtpConfirmForm from './mfa/otp-confirm-form';
2022-04-26 10:29:28 -07:00
/*
Security settings page for user account
Routed to /settings/mfa
Includes following features:
- Set up Multi-factor Auth
*/
const messages = defineMessages({
heading: { id: 'column.mfa', defaultMessage: 'Multi-Factor Authentication' },
});
const MfaForm: React.FC = () => {
const intl = useIntl();
const dispatch = useAppDispatch();
const [displayOtpForm, setDisplayOtpForm] = useState<boolean>(false);
useEffect(() => {
dispatch(fetchMfa());
}, []);
const handleSetupProceedClick = (event: React.MouseEvent) => {
event.preventDefault();
setDisplayOtpForm(true);
};
const mfa = useAppSelector((state) => state.security.get('mfa'));
return (
<Column label={intl.formatMessage(messages.heading)}>
{mfa.getIn(['settings', 'totp']) ? (
<DisableOtpForm />
) : (
<Stack space={4}>
<EnableOtpForm displayOtpForm={displayOtpForm} handleSetupProceedClick={handleSetupProceedClick} />
{displayOtpForm && <OtpConfirmForm />}
</Stack>
)}
2022-04-26 10:29:28 -07:00
</Column>
);
};
export default MfaForm;