'use client' import type { CustomFile as File } from '@/models/datasets' import { RiCloseLine } from '@remixicon/react' import * as React from 'react' import { useMemo } from 'react' import { useTranslation } from 'react-i18next' import { useFilePreview } from '@/service/use-common' import { formatFileSize, formatNumberAbbreviated } from '@/utils/format' import DocumentFileIcon from '../../../common/document-file-icon' import Loading from './loading' type FilePreviewProps = { file: File hidePreview: () => void } const FilePreview = ({ file, hidePreview, }: FilePreviewProps) => { const { t } = useTranslation() const { data: fileData, isFetching } = useFilePreview(file.id || '') const fileName = useMemo(() => { if (!file) return '' const arr = file.name.split('.') return arr.slice(0, -1).join() }, [file]) return (
{t('addDocuments.stepOne.preview', { ns: 'datasetPipeline' })}
{`${fileName}.${file.extension || ''}`}
{file.extension} · {formatFileSize(file.size)} {fileData && ( <> · {`${formatNumberAbbreviated(fileData.content.length)} ${t('addDocuments.characters', { ns: 'datasetPipeline' })}`} )}
{isFetching && (
)} {!isFetching && fileData && (
{fileData.content}
)}
) } export default FilePreview