'use client'; import * as React from 'react'; import { Upload, X, FileImage, HardDrive, Film } from 'lucide-react'; import { cn } from '@/lib/utils/cn'; export interface FaviconFileUploadProps { onFileSelect: (file: File) => void; onFileRemove: () => void; selectedFile?: File | null; disabled?: boolean; } export function FaviconFileUpload({ onFileSelect, onFileRemove, selectedFile, disabled = false, }: FaviconFileUploadProps) { const [isDragging, setIsDragging] = React.useState(false); const [dimensions, setDimensions] = React.useState(null); const fileInputRef = React.useRef(null); React.useEffect(() => { if (selectedFile) { const img = new Image(); img.onload = () => { setDimensions(`${img.width}×${img.height}`); URL.revokeObjectURL(img.src); }; img.src = URL.createObjectURL(selectedFile); } else { setDimensions(null); } }, [selectedFile]); const handleDrop = (e: React.DragEvent) => { e.preventDefault(); e.stopPropagation(); setIsDragging(false); if (disabled) return; const files = Array.from(e.dataTransfer.files); if (files.length > 0 && files[0].type.startsWith('image/')) onFileSelect(files[0]); }; const handleFileInput = (e: React.ChangeEvent) => { const files = Array.from(e.target.files || []); if (files.length > 0 && files[0].type.startsWith('image/')) onFileSelect(files[0]); }; return (
{selectedFile ? (

{selectedFile.name}

{selectedFile.size < 1024 * 1024 ? `${(selectedFile.size / 1024).toFixed(1)} KB` : `${(selectedFile.size / (1024 * 1024)).toFixed(1)} MB`} {dimensions && ( {dimensions} )}
) : (
!disabled && fileInputRef.current?.click()} onDragEnter={(e) => { e.preventDefault(); if (!disabled) setIsDragging(true); }} onDragLeave={(e) => { e.preventDefault(); setIsDragging(false); }} onDragOver={(e) => e.preventDefault()} onDrop={handleDrop} className={cn( 'flex flex-col items-center justify-center rounded-xl border-2 border-dashed transition-all cursor-pointer text-center select-none py-8', isDragging ? 'border-primary bg-primary/10 scale-[0.99]' : 'border-border/35 hover:border-primary/40 hover:bg-primary/5', disabled && 'opacity-50 cursor-not-allowed pointer-events-none' )} >

{isDragging ? 'Drop to upload' : 'Drop icon here or click to browse'}

PNG · SVG · 512×512 recommended

)}
); }