The communications platform that puts data protection first.
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
Rocket.Chat/apps/meteor/client/views/account/security/BackupCodesModal.tsx

45 lines
1.2 KiB

import { Box, Button, Modal } from '@rocket.chat/fuselage';
import { useTranslation } from '@rocket.chat/ui-contexts';
import type { FC } from 'react';
import React, { useMemo } from 'react';
import TextCopy from '../../../components/TextCopy';
type BackupCodesModalProps = {
codes: string[];
onClose: () => void;
};
const BackupCodesModal: FC<BackupCodesModalProps> = ({ codes, onClose, ...props }) => {
const t = useTranslation();
const codesText = useMemo(() => codes.join(' '), [codes]);
return (
<Modal {...props}>
<Modal.Header>
<Modal.Icon name='info' />
<Modal.Title>{t('Backup_codes')}</Modal.Title>
<Modal.Close onClick={onClose} />
</Modal.Header>
<Modal.Content fontScale='p2'>
<Box mb='x8' withRichContent>
{t('Make_sure_you_have_a_copy_of_your_codes_1')}
</Box>
<TextCopy text={codesText} mb='x8' />
<Box mb='x8' withRichContent>
{t('Make_sure_you_have_a_copy_of_your_codes_2')}
</Box>
</Modal.Content>
<Modal.Footer>
<Modal.FooterControllers>
<Button primary onClick={onClose}>
{t('Ok')}
</Button>
</Modal.FooterControllers>
</Modal.Footer>
</Modal>
);
};
export default BackupCodesModal;