mirror of
https://github.com/Infisical/infisical.git
synced 2025-03-29 22:02:57 +00:00
108 lines
3.6 KiB
TypeScript
108 lines
3.6 KiB
TypeScript
import { Fragment, useState } from 'react';
|
|
import { useTranslation } from 'next-i18next';
|
|
import { Dialog, Transition } from '@headlessui/react';
|
|
|
|
import addIncidentContact from '@app/pages/api/organization/addIncidentContact';
|
|
|
|
import Button from '../buttons/Button';
|
|
import InputField from '../InputField';
|
|
|
|
type Props = {
|
|
isOpen: boolean;
|
|
closeModal: () => void;
|
|
incidentContacts: string[];
|
|
setIncidentContacts: (arg: string[]) => void;
|
|
};
|
|
|
|
const AddIncidentContactDialog = ({
|
|
isOpen,
|
|
closeModal,
|
|
incidentContacts,
|
|
setIncidentContacts,
|
|
}: Props) => {
|
|
const [incidentContactEmail, setIncidentContactEmail] = useState('');
|
|
const { t } = useTranslation();
|
|
|
|
const submit = () => {
|
|
setIncidentContacts(
|
|
incidentContacts?.length > 0
|
|
? incidentContacts.concat([incidentContactEmail])
|
|
: [incidentContactEmail]
|
|
);
|
|
addIncidentContact(
|
|
localStorage.getItem('orgData.id') as string,
|
|
incidentContactEmail
|
|
);
|
|
closeModal();
|
|
};
|
|
return (
|
|
<div>
|
|
<Transition appear show={isOpen} as={Fragment}>
|
|
<Dialog as='div' className='relative z-10' onClose={closeModal}>
|
|
<Transition.Child
|
|
as={Fragment}
|
|
enter='ease-out duration-300'
|
|
enterFrom='opacity-0'
|
|
enterTo='opacity-100'
|
|
leave='ease-in duration-200'
|
|
leaveFrom='opacity-100'
|
|
leaveTo='opacity-0'
|
|
>
|
|
<div className='fixed inset-0 bg-black bg-opacity-70' />
|
|
</Transition.Child>
|
|
|
|
<div className='fixed inset-0 overflow-y-auto'>
|
|
<div className='flex min-h-full items-center justify-center p-4 text-center'>
|
|
<Transition.Child
|
|
as={Fragment}
|
|
enter='ease-out duration-300'
|
|
enterFrom='opacity-0 scale-95'
|
|
enterTo='opacity-100 scale-100'
|
|
leave='ease-in duration-200'
|
|
leaveFrom='opacity-100 scale-100'
|
|
leaveTo='opacity-0 scale-95'
|
|
>
|
|
<Dialog.Panel className='w-full max-w-md transform overflow-hidden rounded-md bg-bunker-800 border border-gray-700 p-6 text-left align-middle shadow-xl transition-all'>
|
|
<Dialog.Title
|
|
as='h3'
|
|
className='text-lg font-medium leading-6 text-gray-400'
|
|
>
|
|
{t('section-incident:add-dialog.title')}
|
|
</Dialog.Title>
|
|
<div className='mt-2 mb-2'>
|
|
<p className='text-sm text-gray-500'>
|
|
{t('section-incident:add-dialog.description')}
|
|
</p>
|
|
</div>
|
|
<div className='max-h-28'>
|
|
<InputField
|
|
label={t('common:email')}
|
|
onChangeHandler={setIncidentContactEmail}
|
|
type='varName'
|
|
value={incidentContactEmail}
|
|
placeholder=''
|
|
isRequired
|
|
/>
|
|
</div>
|
|
<div className='mt-6 max-w-max'>
|
|
<Button
|
|
onButtonPressed={submit}
|
|
color='mineshaft'
|
|
text={
|
|
t('section-incident:add-dialog.add-incident') as string
|
|
}
|
|
size='md'
|
|
/>
|
|
</div>
|
|
</Dialog.Panel>
|
|
</Transition.Child>
|
|
</div>
|
|
</div>
|
|
</Dialog>
|
|
</Transition>
|
|
</div>
|
|
);
|
|
};
|
|
|
|
export default AddIncidentContactDialog;
|