ConceptPortal-public/rsconcept/frontend/src/pages/RSFormPage/DlgUploadRSForm.tsx

65 lines
1.8 KiB
TypeScript
Raw Normal View History

2023-07-27 22:04:25 +03:00
import { useState } from 'react';
import { toast } from 'react-toastify';
import Checkbox from '../../components/Common/Checkbox';
import FileInput from '../../components/Common/FileInput';
import Modal from '../../components/Common/Modal';
import { useRSForm } from '../../context/RSFormContext';
import { IRSFormUploadData } from '../../utils/models';
2023-07-28 00:03:37 +03:00
interface DlgUploadRSFormProps {
2023-07-27 22:04:25 +03:00
hideWindow: () => void
}
2023-07-29 03:31:21 +03:00
function DlgUploadRSForm({ hideWindow }: DlgUploadRSFormProps) {
2023-07-27 22:04:25 +03:00
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 {
2023-08-27 16:35:17 +03:00
setFile(undefined);
2023-07-27 22:04:25 +03:00
}
}
return (
<Modal
title='Импорт схемы из Экстеора'
2023-07-27 22:04:25 +03:00
hideWindow={hideWindow}
canSubmit={!!file}
onSubmit={handleSubmit}
submitText='Загрузить'
2023-07-27 22:04:25 +03:00
>
2023-09-07 16:30:43 +03:00
<div className='flex flex-col items-center'>
<FileInput
label='Выбрать файл'
acceptType='.trs'
onChange={handleFile}
/>
<Checkbox
label='Загружать название и комментарий'
value={loadMetadata}
setValue={value => setLoadMetadata(value)}
widthClass='w-fit pb-2'
/>
2023-07-27 22:04:25 +03:00
</div>
</Modal>
2023-07-29 03:31:21 +03:00
);
2023-07-27 22:04:25 +03:00
}
2023-07-28 00:03:37 +03:00
export default DlgUploadRSForm;