RocketChat/Rocket.Chat

View on GitHub
apps/meteor/client/views/account/security/BackupCodesModal.tsx

Summary

Maintainability
A
1 hr
Test Coverage
import { Box, Button, Modal } from '@rocket.chat/fuselage';
import { useTranslation } from '@rocket.chat/ui-contexts';
import React, { useMemo } from 'react';

import TextCopy from '../../../components/TextCopy';

type BackupCodesModalProps = {
    codes: string[];
    onClose: () => void;
};

const BackupCodesModal = ({ codes, onClose, ...props }: BackupCodesModalProps) => {
    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={8} withRichContent>
                    {t('Make_sure_you_have_a_copy_of_your_codes_1')}
                </Box>
                <TextCopy text={codesText} mb={8} />
                <Box mb={8} 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;