Files
DataMate/frontend/src/pages/DataManagement/Create/CreateDataset.tsx
Jerry Yan 05e6842fc8 refactor(DataManagement): 移除不必要的数据集类型过滤逻辑
- 删除了对数据集类型的过滤操作
- 移除了不再使用的 textDatasetTypeOptions 变量
- 简化了 BasicInformation 组件的数据传递逻辑
- 减少了代码冗余,提高了组件性能
2026-02-03 13:33:12 +08:00

106 lines
3.0 KiB
TypeScript

import { useEffect, useMemo, useState } from "react";
import { ArrowLeft } from "lucide-react";
import { Button, Form, App } from "antd";
import { Link, useLocation, useNavigate } from "react-router";
import { createDatasetUsingPost } from "../dataset.api";
import { DatasetType } from "../dataset.model";
import BasicInformation from "./components/BasicInformation";
export default function DatasetCreate() {
const navigate = useNavigate();
const location = useLocation();
const { message } = App.useApp();
const [form] = Form.useForm();
const parentDatasetId = useMemo(() => {
const state = location.state as CreateDatasetLocationState | null;
return state?.parentDatasetId || "";
}, [location.state]);
const [newDataset, setNewDataset] = useState(() => ({
name: "",
description: "",
datasetType: DatasetType.TEXT,
tags: [],
parentDatasetId,
}));
useEffect(() => {
if (!parentDatasetId) {
return;
}
setNewDataset((prev) => ({ ...prev, parentDatasetId }));
form.setFieldsValue({ parentDatasetId });
}, [form, parentDatasetId]);
const handleSubmit = async () => {
const formValues = await form.validateFields();
const params = {
...formValues,
files: undefined,
};
try {
const { data } = await createDatasetUsingPost(params);
message.success(`数据集创建成功`);
navigate("/data/management/detail/" + data.id);
} catch (error) {
console.error(error);
message.error("数据集创建失败,请重试");
return;
}
};
const handleValuesChange = (_, allValues) => {
setNewDataset((prev) => ({ ...prev, ...allValues }));
};
return (
<div className="h-full flex flex-col flex-1">
{/* Header */}
<div className="flex items-center justify-between mb-2">
<div className="flex items-center">
<Link to="/data/management">
<Button type="text">
<ArrowLeft className="w-4 h-4 mr-1" />
</Button>
</Link>
<h1 className="text-xl font-bold bg-clip-text"></h1>
</div>
</div>
{/* form */}
<div className="flex-overflow-auto border-card">
<div className="flex-1 p-6 overflow-auto">
<Form
form={form}
initialValues={newDataset}
onValuesChange={handleValuesChange}
layout="vertical"
>
<BasicInformation
data={newDataset}
setData={setNewDataset}
hidden={["dataSource"]}
/>
</Form>
</div>
<div className="flex gap-2 justify-end p-6 border-top">
<Button onClick={() => navigate("/data/management")}></Button>
<Button
type="primary"
disabled={!newDataset.name || !newDataset.datasetType}
onClick={handleSubmit}
>
</Button>
</div>
</div>
</div>
);
}
interface CreateDatasetLocationState {
parentDatasetId?: string;
}