2023-07-25 20:27:29 +03:00
|
|
|
import { useEffect, useState } from 'react';
|
|
|
|
|
2023-07-30 15:49:30 +03:00
|
|
|
import ConceptSelect from '../../components/Common/ConceptSelect';
|
2023-07-25 20:27:29 +03:00
|
|
|
import Modal from '../../components/Common/Modal';
|
|
|
|
import { type CstType } from '../../utils/models';
|
2023-07-23 21:38:04 +03:00
|
|
|
import { CstTypeSelector, getCstTypeLabel } from '../../utils/staticUI';
|
2023-07-22 12:24:14 +03:00
|
|
|
|
2023-07-28 00:03:37 +03:00
|
|
|
interface DlgCreateCstProps {
|
2023-07-25 22:29:33 +03:00
|
|
|
hideWindow: () => void
|
2023-07-23 21:38:04 +03:00
|
|
|
defaultType?: CstType
|
2023-07-22 12:24:14 +03:00
|
|
|
onCreate: (type: CstType) => void
|
|
|
|
}
|
|
|
|
|
2023-07-29 03:31:21 +03:00
|
|
|
function DlgCreateCst({ hideWindow, defaultType, onCreate }: DlgCreateCstProps) {
|
2023-07-22 12:24:14 +03:00
|
|
|
const [validated, setValidated] = useState(false);
|
2023-07-25 20:27:29 +03:00
|
|
|
const [selectedType, setSelectedType] = useState<CstType | undefined>(undefined);
|
2023-07-22 12:24:14 +03:00
|
|
|
|
|
|
|
const handleSubmit = () => {
|
2023-07-23 15:23:01 +03:00
|
|
|
if (selectedType) onCreate(selectedType);
|
2023-07-22 12:24:14 +03:00
|
|
|
};
|
|
|
|
|
2023-07-23 21:38:04 +03:00
|
|
|
useEffect(() => {
|
|
|
|
setSelectedType(defaultType);
|
|
|
|
}, [defaultType]);
|
|
|
|
|
2023-07-23 15:23:01 +03:00
|
|
|
useEffect(() => {
|
|
|
|
setValidated(selectedType !== undefined);
|
|
|
|
}, [selectedType]
|
|
|
|
);
|
|
|
|
|
2023-07-22 12:24:14 +03:00
|
|
|
return (
|
2023-07-25 20:27:29 +03:00
|
|
|
<Modal
|
2023-07-22 12:24:14 +03:00
|
|
|
title='Создание конституенты'
|
2023-07-25 22:29:33 +03:00
|
|
|
hideWindow={hideWindow}
|
2023-07-22 12:24:14 +03:00
|
|
|
canSubmit={validated}
|
|
|
|
onSubmit={handleSubmit}
|
|
|
|
>
|
2023-08-13 21:25:59 +03:00
|
|
|
<div className='fixed h-fit w-[15rem] px-2'>
|
2023-07-30 15:49:30 +03:00
|
|
|
<ConceptSelect
|
2023-08-01 21:55:18 +03:00
|
|
|
className='my-4'
|
2023-07-23 15:23:01 +03:00
|
|
|
options={CstTypeSelector}
|
|
|
|
placeholder='Выберите тип'
|
2023-07-30 15:49:30 +03:00
|
|
|
values={selectedType ? [{ value: selectedType, label: getCstTypeLabel(selectedType) }] : []}
|
2023-07-31 22:38:58 +03:00
|
|
|
onChange={data => { setSelectedType(data.length > 0 ? data[0].value : undefined); }}
|
2023-07-23 15:23:01 +03:00
|
|
|
/>
|
2023-08-13 21:25:59 +03:00
|
|
|
</div>
|
|
|
|
<div className='h-[4rem]'></div>
|
2023-07-22 12:24:14 +03:00
|
|
|
</Modal>
|
2023-07-29 03:31:21 +03:00
|
|
|
);
|
2023-07-22 12:24:14 +03:00
|
|
|
}
|
|
|
|
|
2023-07-28 00:03:37 +03:00
|
|
|
export default DlgCreateCst;
|