'use client'; import { useState, useRef } from 'react'; import { Box, Avatar, IconButton, TextField, Typography, Paper, Alert, } from '@mui/material'; import { PhotoCamera, Person } from '@mui/icons-material'; interface PhotoUploadProps { value: string; onChange: (url: string) => void; label: string; disabled?: boolean; size?: number; } export function PhotoUpload({ value, onChange, label, disabled = false, size = 100 }: PhotoUploadProps) { const [imageError, setImageError] = useState(false); const [uploadError, setUploadError] = useState(''); const fileInputRef = useRef(null); const handleImageError = () => { setImageError(true); }; const handleImageLoad = () => { setImageError(false); }; const handleFileSelect = async (event: React.ChangeEvent) => { const file = event.target.files?.[0]; if (!file) return; // Validate file type if (!file.type.startsWith('image/')) { setUploadError('Please select an image file'); return; } // Validate file size (max 5MB) const maxSize = 5 * 1024 * 1024; // 5MB if (file.size > maxSize) { setUploadError('Image size must be less than 5MB'); return; } // Convert to base64 const reader = new FileReader(); reader.onload = (e) => { const base64String = e.target?.result as string; onChange(base64String); setUploadError(''); setImageError(false); }; reader.onerror = () => { setUploadError('Failed to read image file'); }; reader.readAsDataURL(file); // Reset input if (fileInputRef.current) { fileInputRef.current.value = ''; } }; const handleCameraClick = () => { fileInputRef.current?.click(); }; return ( {label} {uploadError && ( setUploadError('')} sx={{ width: '100%' }}> {uploadError} )} {!value || imageError ? : null} onChange(e.target.value)} fullWidth size="small" placeholder="https://example.com/photo.jpg" disabled={disabled} helperText="Click camera to upload or paste an image URL" /> ); }