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