import { useState, type FormEvent } from "react"; import { useNavigate, Link } from "react-router"; import { api } from "~/api/client"; import { Button } from "~/components/Button"; import { Input } from "~/components/Input"; export default function Login() { const navigate = useNavigate(); const [email, setEmail] = useState(""); const [password, setPassword] = useState(""); const [error, setError] = useState(""); const [loading, setLoading] = useState(false); const handleSubmit = async (e: FormEvent) => { e.preventDefault(); setError(""); setLoading(true); try { await api.login({ email, password }); navigate("/dashboard"); } catch (err) { setError(err instanceof Error ? err.message : "Login failed"); } finally { setLoading(false); } }; return (

Grademaxxing

Sign in to your account

setEmail(e.target.value)} placeholder="your@email.com" required autoComplete="email" /> setPassword(e.target.value)} placeholder="••••••••" required autoComplete="current-password" /> {error && (
{error}
)}

Don't have an account?{" "} Sign up

); }