import React, { useState } from 'react'; import styles from './PublishForm.module.css'; const PublishForm = ({ isAdmin = false, formData, onSubmit, onCancel, onApprove, onDeny }) => { const [state, setState] = useState(isAdmin ? 'viewing' : 'writing'); const [form, setForm] = useState( formData || { id: -1, name: '', lastName: '', mapName: '', mapType: 'Other', googleMapsUrl: '', } ); const [errors, setErrors] = useState({}); const [denyReason, setDenyReason] = useState(''); const [isDenying, setIsDenying] = useState(false); const mapTypeOptions = ['Hospital', 'Faculty', 'House', 'Other']; const handleChange = (e) => { const { name, value } = e.target; setForm((prev) => ({ ...prev, [name]: value })); setErrors((prev) => ({ ...prev, [name]: '' })); }; const validateForm = () => { const newErrors = {}; if (!form.name.trim()) newErrors.name = 'Name is required.'; if (!form.lastName.trim()) newErrors.lastName = 'Last Name is required.'; if (!form.googleMapsUrl.trim()) newErrors.googleMapsUrl = 'Google Maps URL is required.'; return newErrors; }; const handleSubmit = () => { const formErrors = validateForm(); if (Object.keys(formErrors).length > 0) { setErrors(formErrors); return; } if (state === 'writing') { onSubmit(form); } }; const handleDeny = () => { if (!denyReason.trim()) { alert('Please provide a reason for denial.'); return; } onDeny(form.id, form.mapName, denyReason); setIsDenying(false); }; return ( <>
Map Name: {form.mapName}
Name: {form.name}
Last Name: {form.lastName}
Google Maps URL:{' '} {form.googleMapsUrl}
Type of Map: {form.mapType}