2023-04-04 23:18:58 -04:00
|
|
|
import React from 'react';
|
|
|
|
|
import { FileUp } from 'lucide-react';
|
2023-04-05 16:16:11 +08:00
|
|
|
import cleanupPreset from '~/utils/cleanupPreset.js';
|
2023-04-05 21:21:02 +08:00
|
|
|
import { useRecoilValue } from 'recoil';
|
|
|
|
|
|
|
|
|
|
import store from '~/store';
|
2023-04-04 23:18:58 -04:00
|
|
|
|
|
|
|
|
const FileUpload = ({ onFileSelected }) => {
|
2023-04-05 16:16:11 +08:00
|
|
|
// const setPresets = useSetRecoilState(store.presets);
|
2023-04-05 21:21:02 +08:00
|
|
|
const endpointsFilter = useRecoilValue(store.endpointsFilter);
|
2023-04-04 23:18:58 -04:00
|
|
|
|
|
|
|
|
const handleFileChange = event => {
|
|
|
|
|
const file = event.target.files[0];
|
|
|
|
|
if (!file) return;
|
|
|
|
|
|
|
|
|
|
const reader = new FileReader();
|
|
|
|
|
reader.onload = e => {
|
|
|
|
|
const jsonData = JSON.parse(e.target.result);
|
2023-04-05 21:21:02 +08:00
|
|
|
onFileSelected({ ...cleanupPreset({ preset: jsonData, endpointsFilter }), presetId: null });
|
2023-04-04 23:18:58 -04:00
|
|
|
};
|
|
|
|
|
reader.readAsText(file);
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
return (
|
|
|
|
|
<label
|
|
|
|
|
htmlFor="file-upload"
|
|
|
|
|
className=" mr-1 flex h-auto cursor-pointer items-center rounded bg-transparent px-2 py-1 text-xs font-medium font-normal text-gray-600 hover:bg-slate-200 hover:text-green-700 dark:bg-transparent dark:text-gray-300 dark:hover:bg-gray-800 dark:hover:text-green-500"
|
|
|
|
|
>
|
|
|
|
|
<FileUp className="flex w-[22px] items-center stroke-1" />
|
|
|
|
|
<span className="ml-1 flex text-xs ">Import</span>
|
|
|
|
|
<input
|
|
|
|
|
id="file-upload"
|
2023-04-05 16:16:11 +08:00
|
|
|
value=""
|
2023-04-04 23:18:58 -04:00
|
|
|
type="file"
|
|
|
|
|
className="hidden "
|
|
|
|
|
accept=".json"
|
|
|
|
|
onChange={handleFileChange}
|
|
|
|
|
/>
|
|
|
|
|
</label>
|
|
|
|
|
);
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
export default FileUpload;
|