import { RiCloseLine, RiDownloadLine, } from '@remixicon/react' import { useState } from 'react' import { downloadFile, fileIsUploaded, getFileAppearanceType, getFileExtension, } from '../utils' import FileTypeIcon from '../file-type-icon' import type { FileEntity } from '../types' import cn from '@/utils/classnames' import { formatFileSize } from '@/utils/format' import ProgressCircle from '@/app/components/base/progress-bar/progress-circle' import { ReplayLine } from '@/app/components/base/icons/src/vender/other' import ActionButton from '@/app/components/base/action-button' import Button from '@/app/components/base/button' import PdfPreview from '@/app/components/base/file-uploader/dynamic-pdf-preview' import AudioPreview from '@/app/components/base/file-uploader/audio-preview' import VideoPreview from '@/app/components/base/file-uploader/video-preview' type FileItemProps = { file: FileEntity showDeleteAction?: boolean showDownloadAction?: boolean canPreview?: boolean onRemove?: (fileId: string) => void onReUpload?: (fileId: string) => void } const FileItem = ({ file, showDeleteAction, showDownloadAction = true, onRemove, onReUpload, canPreview, }: FileItemProps) => { const { id, name, type, progress, url, base64Url, isRemote } = file const [previewUrl, setPreviewUrl] = useState('') const ext = getFileExtension(name, type, isRemote) const uploadError = progress === -1 let tmp_preview_url = url || base64Url if (!tmp_preview_url && file?.originalFile) tmp_preview_url = URL.createObjectURL(file.originalFile.slice()).toString() return ( <>