2024-10-21 10:32:37 +08:00
|
|
|
import cn from '@/utils/classnames'
|
|
|
|
|
|
|
|
type FileImageRenderProps = {
|
|
|
|
imageUrl: string
|
|
|
|
className?: string
|
|
|
|
alt?: string
|
|
|
|
onLoad?: () => void
|
|
|
|
onError?: () => void
|
|
|
|
showDownloadAction?: boolean
|
|
|
|
}
|
|
|
|
const FileImageRender = ({
|
|
|
|
imageUrl,
|
|
|
|
className,
|
|
|
|
alt,
|
|
|
|
onLoad,
|
|
|
|
onError,
|
|
|
|
showDownloadAction,
|
|
|
|
}: FileImageRenderProps) => {
|
|
|
|
return (
|
|
|
|
<div className={cn('border-[2px] border-effects-image-frame shadow-xs', className)}>
|
|
|
|
<img
|
2025-03-21 17:41:03 +08:00
|
|
|
className={cn('h-full w-full object-cover', showDownloadAction && 'cursor-pointer')}
|
2024-12-10 10:53:37 +08:00
|
|
|
alt={alt || 'Preview'}
|
2024-10-21 10:32:37 +08:00
|
|
|
onLoad={onLoad}
|
|
|
|
onError={onError}
|
|
|
|
src={imageUrl}
|
|
|
|
/>
|
|
|
|
</div>
|
|
|
|
)
|
|
|
|
}
|
|
|
|
|
|
|
|
export default FileImageRender
|