ConceptPortal-public/rsconcept/frontend/src/dialogs/DlgUploadRSForm.tsx
2024-05-10 15:28:33 +03:00

63 lines
1.7 KiB
TypeScript

'use client';
import { useState } from 'react';
import { toast } from 'react-toastify';
import Checkbox from '@/components/ui/Checkbox';
import FileInput from '@/components/ui/FileInput';
import Modal from '@/components/ui/Modal';
import { useRSForm } from '@/context/RSFormContext';
import { IRSFormUploadData } from '@/models/rsform';
import { EXTEOR_TRS_FILE } from '@/utils/constants';
interface DlgUploadRSFormProps {
hideWindow: () => void;
}
function DlgUploadRSForm({ hideWindow }: DlgUploadRSFormProps) {
const { upload } = useRSForm();
const [loadMetadata, setLoadMetadata] = useState(false);
const [file, setFile] = useState<File | undefined>();
const handleSubmit = () => {
if (!file) {
return;
}
const data: IRSFormUploadData = {
load_metadata: loadMetadata,
file: file,
fileName: file.name
};
upload(data, () => toast.success('Схема загружена из файла'));
};
const handleFile = (event: React.ChangeEvent<HTMLInputElement>) => {
if (event.target.files && event.target.files.length > 0) {
setFile(event.target.files[0]);
} else {
setFile(undefined);
}
};
return (
<Modal
header='Импорт схемы из Экстеора'
hideWindow={hideWindow}
canSubmit={!!file}
onSubmit={handleSubmit}
submitText='Загрузить'
className='w-[25rem] px-6'
>
<FileInput label='Выбрать файл' acceptType={EXTEOR_TRS_FILE} onChange={handleFile} />
<Checkbox
label='Загружать название и комментарий'
className='py-2'
value={loadMetadata}
setValue={value => setLoadMetadata(value)}
/>
</Modal>
);
}
export default DlgUploadRSForm;