"use client"; import { useState } from "react"; import { useRouter, useSearchParams } from "next/navigation"; export default function LoginForm() { const [password, setPassword] = useState(""); const [loading, setLoading] = useState(false); const [error, setError] = useState(""); const router = useRouter(); const params = useSearchParams(); async function handleSubmit(e: React.FormEvent) { e.preventDefault(); setLoading(true); setError(""); try { const res = await fetch("/api/login", { method: "POST", headers: { "Content-Type": "application/json" }, body: JSON.stringify({ password }) }); if (!res.ok) { const data = await res.json().catch(() => ({})); setError(data.error || "登录失败"); } else { const next = params.get("next") || "/admin"; router.push(next); router.refresh(); } } finally { setLoading(false); } } return (
); }