import { useState, type FormEventHandler } from "react"; import Icon, { ICONS } from "./Icon"; import Modal from "./Modal"; import { useLocation, useNavigate } from "react-router"; import { API } from "~/api/api"; import { getApiErrorMessage, useAuth } from "~/context/AuthContext"; export default function Header() { const [isMobileMenuOpen, setIsMobileMenuOpen] = useState(false); const { user, login, logout, isLoading } = useAuth(); const navigate = useNavigate(); const onBack = () => { navigate("/") }; const onUploadClick= () => setIsUploadModalOpen(true) const [isLoginModalOpen, setIsLoginModalOpen] = useState(false); const [isRegisterModalOpen, setIsRegisterModalOpen] = useState(false); const [isUploadModalOpen, setIsUploadModalOpen] = useState(false); const onTagsClick = () => { navigate("/tags") } const onLoginClick = () => { setIsLoginModalOpen(true); } const onRegisterClick = () => { setIsRegisterModalOpen(true); } const onLogout = () => { logout(); if(isMobileMenuOpen) setIsMobileMenuOpen(false); } type NavButtonProps = { onClick: () => void; icon: string; children: React.ReactNode; className?: string; }; const NavButton = ({ onClick, icon, children, className = '' }: NavButtonProps) => ( ); type MobileNavLinkProps = { onClick: () => void; icon: string; children: React.ReactNode; className?: string; }; const MobileNavLink = ({ onClick, icon, children, className = '' }: MobileNavLinkProps) => ( { e.preventDefault(); onClick(); setIsMobileMenuOpen(false); }} className={`flex items-center space-x-3 px-3 py-2 text-base font-medium rounded-md ${className}`}> {children} ); const UploadModal = ({ isOpen, onClose }: { isOpen: boolean; onClose: () => void; }) => { const [title, setTitle] = useState(''); const [description, setDescription] = useState(''); const [tags, setTags] = useState(''); const [imageFile, setImageFile] = useState(null); const [error, setError] = useState(''); const handleSubmit: FormEventHandler = async (e) => { e.preventDefault(); setError(''); if (!user) return; const enteredTags = tags.split(' ').filter(t => t); if (!title || !imageFile || !description) { setError('Please fill in all fields and select an image.'); return; } try { const response = await API.createPostRequest( title, description, enteredTags, imageFile.name, imageFile.type, imageFile.size, user ); const data = await response.json(); if (!response.ok) { setError(getApiErrorMessage(data)); return; } const uploadUrl = data.fileUrl; if (!uploadUrl) { setError('Upload URL not provided by server.'); return; } const uploadResponse = await API.patchFileUploadUrl(uploadUrl, imageFile, user); if (!uploadResponse.ok) { const uploadError = await uploadResponse.json(); setError(getApiErrorMessage(uploadError)); return; } navigate(`/posts/${data.id}`); onClose(); } catch (err: any) { setError(getApiErrorMessage(err)); } }; return (

Upload a Post

setTitle(e.target.value)} className="shadow appearance-none border rounded w-full py-2 px-3 text-gray-700 leading-tight focus:outline-none focus:shadow-outline" placeholder="e.g., My Awesome Picture"/>