misc_pterodactyl-panel/resources/scripts/components/dashboard/AccountOverviewContainer.tsx

56 lines
2 KiB
TypeScript
Raw Normal View History

2021-02-05 16:42:57 +00:00
import React from 'react';
import ContentBox from '@/components/elements/ContentBox';
2019-06-26 04:28:56 +00:00
import UpdatePasswordForm from '@/components/dashboard/forms/UpdatePasswordForm';
import UpdateEmailAddressForm from '@/components/dashboard/forms/UpdateEmailAddressForm';
import ConfigureTwoFactorForm from '@/components/dashboard/forms/ConfigureTwoFactorForm';
import PageContentBlock from '@/components/elements/PageContentBlock';
2021-02-05 16:42:57 +00:00
import { useLocation } from 'react-router-dom';
import tw, { styled } from 'twin.macro';
2020-07-03 21:19:05 +00:00
import { breakpoint } from '@/theme';
import MessageBox from '@/components/MessageBox';
const Container = styled.div`
${tw`flex flex-wrap`};
& > div {
${tw`w-full`};
${breakpoint('md')`
width: calc(50% - 1rem);
`}
${breakpoint('xl')`
${tw`w-auto flex-1`};
`}
}
`;
2021-02-05 16:42:57 +00:00
export default () => {
const { state } = useLocation<{ twoFactorRedirect?: boolean } | undefined>();
2021-02-05 16:42:57 +00:00
return (
2020-09-08 03:26:18 +00:00
<PageContentBlock title={'Account Overview'}>
{state?.twoFactorRedirect &&
<MessageBox title={'2-Factor Required'} type={'error'}>
Your account must have two-factor authentication enabled in order to continue.
</MessageBox>
}
<Container css={[ tw`mb-10`, state?.twoFactorRedirect ? tw`mt-4` : tw`mt-10` ]}>
<ContentBox title={'Update Password'} showFlashes={'account:password'}>
<UpdatePasswordForm/>
</ContentBox>
<ContentBox
2020-07-03 21:19:05 +00:00
css={tw`mt-8 md:mt-0 md:ml-8`}
title={'Update Email Address'}
showFlashes={'account:email'}
>
<UpdateEmailAddressForm/>
</ContentBox>
2020-07-03 21:19:05 +00:00
<ContentBox css={tw`xl:ml-8 mt-8 xl:mt-0`} title={'Configure Two Factor'}>
<ConfigureTwoFactorForm/>
</ContentBox>
</Container>
</PageContentBlock>
);
};