"use client"; import { Suspense, useState } from "react"; import { signIn } from "next-auth/react"; import { useRouter, useSearchParams } from "next/navigation"; import Link from "next/link"; import { Code2, CheckCircle, Loader2 } from "lucide-react"; import { cn } from "@/lib/utils"; export default function LoginPage() { return ( ); } function LoginForm() { const router = useRouter(); const searchParams = useSearchParams(); const verified = searchParams.get("verified") === "true"; const [email, setEmail] = useState(""); const [password, setPassword] = useState(""); const [error, setError] = useState(""); const [loading, setLoading] = useState(false); const emailValid = /^[^\s@]+@[^\s@]+\.[^\s@]+$/.test(email); const passwordValid = password.length >= 8; async function handleSubmit(e: React.FormEvent) { e.preventDefault(); setError(""); if (!emailValid) { setError("Please enter a valid email address"); return; } if (!passwordValid) { setError("Password must be at least 8 characters"); return; } setLoading(true); const result = await signIn("credentials", { email, password, redirect: false }); if (result?.error) { setError("Invalid email or password"); setLoading(false); return; } router.push("/dashboard"); router.refresh(); } return (

Welcome back

Sign in to your CodeBoard account

{verified && (

Email verified! You can now sign in.

)}
setEmail(e.target.value)} placeholder="you@example.com" className={cn("w-full px-3 py-2.5 bg-neutral-950 border rounded-lg text-sm text-neutral-100 placeholder-neutral-500 outline-none transition-colors", email && !emailValid ? "border-red-500/50 focus:border-red-500" : "border-neutral-800 focus:border-blue-500")} /> {email && !emailValid &&

Please enter a valid email address

}
setPassword(e.target.value)} placeholder="••••••••" className={cn("w-full px-3 py-2.5 bg-neutral-950 border rounded-lg text-sm text-neutral-100 placeholder-neutral-500 outline-none transition-colors", password && !passwordValid ? "border-red-500/50 focus:border-red-500" : "border-neutral-800 focus:border-blue-500")} /> {password && !passwordValid &&

Password must be at least 8 characters

}
Forgot password?
{error && (

{error}

)}

Don't have an account?{" "}Create one

); }