import React, { useEffect, useMemo, useState } from 'react'; import { Box, Textarea, Button, Flex, useTheme, useDisclosure } from '@chakra-ui/react'; import { useSearchTestStore, SearchTestStoreItemType } from '@/web/core/dataset/store/searchTest'; import { postSearchText } from '@/web/core/dataset/api'; import MyIcon from '@fastgpt/web/components/common/Icon'; import { useRequest, useRequest2 } from '@fastgpt/web/hooks/useRequest'; import { formatTimeToChatTime } from '@fastgpt/global/common/string/time'; import { getErrText } from '@fastgpt/global/common/error/utils'; import { useToast } from '@fastgpt/web/hooks/useToast'; import { customAlphabet } from 'nanoid'; import MyTooltip from '@fastgpt/web/components/common/MyTooltip'; import { useTranslation } from 'next-i18next'; import { SearchTestResponse } from '@/global/core/dataset/api'; import { DatasetSearchModeEnum, DatasetSearchModeMap } from '@fastgpt/global/core/dataset/constants'; import dynamic from 'next/dynamic'; import { useForm } from 'react-hook-form'; import MySelect from '@fastgpt/web/components/common/MySelect'; import { useSelectFile } from '@/web/common/file/hooks/useSelectFile'; import { fileDownload } from '@/web/common/file/utils'; import QuoteItem from '@/components/core/dataset/QuoteItem'; import { useSystemStore } from '@/web/common/system/useSystemStore'; import SearchParamsTip from '@/components/core/dataset/SearchParamsTip'; import { useContextSelector } from 'use-context-selector'; import { DatasetPageContext } from '@/web/core/dataset/context/datasetPageContext'; import EmptyTip from '@fastgpt/web/components/common/EmptyTip'; import QuestionTip from '@fastgpt/web/components/common/MyTooltip/QuestionTip'; const nanoid = customAlphabet('abcdefghijklmnopqrstuvwxyz1234567890', 12); const DatasetParamsModal = dynamic(() => import('@/components/core/app/DatasetParamsModal')); type FormType = { inputText: string; searchParams: { searchMode: `${DatasetSearchModeEnum}`; similarity?: number; limit?: number; usingReRank?: boolean; datasetSearchUsingExtensionQuery?: boolean; datasetSearchExtensionModel?: string; datasetSearchExtensionBg?: string; }; }; const Test = ({ datasetId }: { datasetId: string }) => { const { t } = useTranslation(); const { toast } = useToast(); const { defaultModels } = useSystemStore(); const datasetDetail = useContextSelector(DatasetPageContext, (v) => v.datasetDetail); const { pushDatasetTestItem } = useSearchTestStore(); const [inputType, setInputType] = useState<'text' | 'file'>('text'); const [datasetTestItem, setDatasetTestItem] = useState(); const [refresh, setRefresh] = useState(false); const [isFocus, setIsFocus] = useState(false); const { File, onOpen } = useSelectFile({ fileType: '.csv', multiple: false }); const [selectFile, setSelectFile] = useState(); const { getValues, setValue, register, handleSubmit } = useForm({ defaultValues: { inputText: '', searchParams: { searchMode: DatasetSearchModeEnum.embedding, usingReRank: false, limit: 5000, similarity: 0, datasetSearchUsingExtensionQuery: false, datasetSearchExtensionModel: defaultModels.llm?.model, datasetSearchExtensionBg: '' } } }); const searchModeData = DatasetSearchModeMap[getValues(`searchParams.searchMode`)]; const { isOpen: isOpenSelectMode, onOpen: onOpenSelectMode, onClose: onCloseSelectMode } = useDisclosure(); const { runAsync: onTextTest, loading: textTestIsLoading } = useRequest2( ({ inputText, searchParams }: FormType) => postSearchText({ datasetId, text: inputText.trim(), ...searchParams }), { onSuccess(res: SearchTestResponse) { if (!res || res.list.length === 0) { return toast({ status: 'warning', title: t('common:dataset.test.noResult') }); } const testItem: SearchTestStoreItemType = { id: nanoid(), datasetId, text: getValues('inputText').trim(), time: new Date(), results: res.list, duration: res.duration, searchMode: res.searchMode, usingReRank: res.usingReRank, limit: res.limit, similarity: res.similarity, queryExtensionModel: res.queryExtensionModel }; pushDatasetTestItem(testItem); setDatasetTestItem(testItem); }, onError(err) { toast({ title: getErrText(err), status: 'error' }); } } ); const onSelectFile = async (files: File[]) => { const file = files[0]; if (!file) return; setSelectFile(file); }; useEffect(() => { setDatasetTestItem(undefined); }, [datasetId]); return ( {/* left */} {/* header */} size={'sm'} w={'150px'} list={[ { label: ( {t('common:core.dataset.test.Test Text')} ), value: 'text' } // { // label: ( // // // // {t('common:core.dataset.test.Batch test')} // // // ), // value: 'file' // } ]} value={inputType} onChange={(e) => setInputType(e)} /> {inputType === 'text' && (