import React, { useState, useCallback } from 'react'; import { Box, Flex, Button, Modal, ModalOverlay, ModalContent, ModalHeader, ModalCloseButton, Textarea } from '@chakra-ui/react'; import { useForm } from 'react-hook-form'; import { postKbDataFromList, putKbDataById } from '@/api/plugins/kb'; import { useToast } from '@/hooks/useToast'; export type FormData = { dataId?: string; a: string; q: string }; const InputDataModal = ({ onClose, onSuccess, kbId, defaultValues = { a: '', q: '' } }: { onClose: () => void; onSuccess: () => void; kbId: string; defaultValues?: FormData; }) => { const [importing, setImporting] = useState(false); const { toast } = useToast(); const { register, handleSubmit, reset } = useForm({ defaultValues }); /** * 确认导入新数据 */ const sureImportData = useCallback( async (e: FormData) => { if (e.a.length + e.q.length >= 3000) { toast({ title: '总长度超长了', status: 'warning' }); return; } setImporting(true); try { const res = await postKbDataFromList({ kbId, data: [ { a: e.a, q: e.q } ] }); toast({ title: res === 0 ? '可能已存在完全一致的数据' : '导入数据成功,需要一段时间训练', status: 'success' }); reset({ a: '', q: '' }); onSuccess(); } catch (err: any) { toast({ title: err?.message || '出现了点意外~', status: 'error' }); console.log(err); } setImporting(false); }, [kbId, onSuccess, reset, toast] ); const updateData = useCallback( async (e: FormData) => { if (!e.dataId) return; if (e.a !== defaultValues.a || e.q !== defaultValues.q) { await putKbDataById({ dataId: e.dataId, a: e.a, q: e.q === defaultValues.q ? '' : e.q }); onSuccess(); } toast({ title: '修改回答成功', status: 'success' }); onClose(); }, [defaultValues, onClose, onSuccess, toast] ); return ( 手动导入 {'匹配的知识点'}