import type { FC } from 'react' import type { IndexingType } from '../../../create/step-two' import type { RETRIEVE_METHOD } from '@/types/app' import * as React from 'react' import { useCallback } from 'react' import { useTranslation } from 'react-i18next' import { toast } from '@/app/components/base/ui/toast' import { useProcessRule } from '@/service/knowledge/use-dataset' import { useDocumentContext } from '../context' import { ProgressBar, RuleDetail, SegmentProgress, StatusHeader } from './components' import { useEmbeddingStatus, usePauseIndexing, useResumeIndexing } from './hooks' import EmbeddingSkeleton from './skeleton' type EmbeddingDetailProps = { datasetId?: string documentId?: string indexingType?: IndexingType retrievalMethod?: RETRIEVE_METHOD detailUpdate: VoidFunction } const EmbeddingDetail: FC = ({ datasetId: dstId, documentId: docId, detailUpdate, indexingType, retrievalMethod }) => { const { t } = useTranslation() const contextDatasetId = useDocumentContext(s => s.datasetId) const contextDocumentId = useDocumentContext(s => s.documentId) const datasetId = dstId ?? contextDatasetId const documentId = docId ?? contextDocumentId const { data: indexingStatus, isEmbedding, isCompleted, isPaused, isError, percent, resetStatus, refetch } = useEmbeddingStatus({ datasetId, documentId, onComplete: detailUpdate, }) const { data: ruleDetail } = useProcessRule(documentId) const handleSuccess = useCallback(() => { toast.success(t('actionMsg.modifiedSuccessfully', { ns: 'common' })) }, [t]) const handleError = useCallback(() => { toast.error(t('actionMsg.modifiedUnsuccessfully', { ns: 'common' })) }, [t]) const pauseMutation = usePauseIndexing({ datasetId, documentId, onSuccess: () => { handleSuccess() resetStatus() }, onError: handleError, }) const resumeMutation = useResumeIndexing({ datasetId, documentId, onSuccess: () => { handleSuccess() refetch() detailUpdate() }, onError: handleError, }) const handlePause = useCallback(() => { pauseMutation.mutate() }, [pauseMutation]) const handleResume = useCallback(() => { resumeMutation.mutate() }, [resumeMutation]) return ( <>
) } export default React.memo(EmbeddingDetail)