overleaf/services/web/frontend/js/features/settings/components/leave/modal-content.tsx

59 lines
1.4 KiB
TypeScript
Raw Normal View History

import { useState, Dispatch, SetStateAction } from 'react'
import { Modal, Button } from 'react-bootstrap'
import { useTranslation, Trans } from 'react-i18next'
import LeaveModalForm from './modal-form'
type LeaveModalContentProps = {
handleHide: () => void
inFlight: boolean
setInFlight: Dispatch<SetStateAction<boolean>>
}
function LeaveModalContent({
handleHide,
inFlight,
setInFlight,
}: LeaveModalContentProps) {
const { t } = useTranslation()
const [isFormValid, setIsFormValid] = useState(false)
return (
<>
<Modal.Header closeButton>
<Modal.Title>{t('delete_account')}</Modal.Title>
</Modal.Header>
<Modal.Body>
<p>
<Trans
i18nKey="delete_account_warning_message_3"
components={[<strong />]} // eslint-disable-line react/jsx-key
/>
</p>
<LeaveModalForm
setInFlight={setInFlight}
isFormValid={isFormValid}
setIsFormValid={setIsFormValid}
/>
</Modal.Body>
<Modal.Footer>
<Button type="button" disabled={inFlight} onClick={handleHide}>
{t('cancel')}
</Button>
<Button
form="leave-form"
type="submit"
bsStyle="danger"
disabled={inFlight || !isFormValid}
>
{inFlight ? <>{t('deleting')}</> : t('delete')}
</Button>
</Modal.Footer>
</>
)
}
export default LeaveModalContent