ConceptPortal-public/rsconcept/frontend/src/dialogs/DlgUploadRSForm.tsx

63 lines
1.7 KiB
TypeScript
Raw Normal View History

'use client';
2023-07-27 22:04:25 +03:00
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';
2023-07-27 22:04:25 +03:00
2023-07-28 00:03:37 +03:00
interface DlgUploadRSFormProps {
2023-12-28 14:04:44 +03:00
hideWindow: () => void;
2023-07-27 22:04:25 +03:00
}
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);
2023-12-28 14:04:44 +03:00
const [file, setFile] = useState<File | undefined>();
2023-07-27 22:04:25 +03:00
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
}
2023-12-28 14:04:44 +03:00
};
2023-07-27 22:04:25 +03:00
return (
2023-12-28 14:04:44 +03:00
<Modal
header='Импорт схемы из Экстеора'
hideWindow={hideWindow}
canSubmit={!!file}
onSubmit={handleSubmit}
submitText='Загрузить'
className='w-[20rem] px-6'
>
<FileInput label='Выбрать файл' acceptType={EXTEOR_TRS_FILE} onChange={handleFile} />
<Checkbox
label='Загружать название и комментарий'
className='py-2'
value={loadMetadata}
setValue={value => setLoadMetadata(value)}
/>
</Modal>
);
2023-07-27 22:04:25 +03:00
}
2023-12-28 14:04:44 +03:00
export default DlgUploadRSForm;