"use client"; import { useEffect, useState } from "react"; import { useRouter } from "next/navigation"; import { Button } from "@/components/ui/button"; import { Input } from "@/components/ui/input"; import { Label } from "@/components/ui/label"; import { Card, CardContent, CardHeader, CardTitle } from "@/components/ui/card"; export default function InitPage() { const router = useRouter(); const [loading, setLoading] = useState(true); const [initialized, setInitialized] = useState(true); const [form, setForm] = useState({ username: "", email: "", password: "", confirmPassword: "", }); const [error, setError] = useState(""); useEffect(() => { fetch("/api/proxy/admin/users", { headers: { "X-User-Role": "admin" }, }) .then((res) => { if (res.ok) { setInitialized(true); } else { setInitialized(false); } }) .catch(() => setInitialized(false)) .finally(() => setLoading(false)); }, []); async function handleSubmit(e: React.FormEvent) { e.preventDefault(); setError(""); if (form.password !== form.confirmPassword) { setError("两次输入的密码不一致"); return; } const res = await fetch("/api/proxy/auth/init", { method: "POST", headers: { "Content-Type": "application/json" }, body: JSON.stringify({ username: form.username, email: form.email, password: form.password, }), }); if (!res.ok) { const data = await res.json(); setError(data.error || "初始化失败"); return; } router.push("/login"); } if (loading) { return (
加载中...
); } if (initialized) { return (
系统已初始化

系统中已有用户,无法再次初始化。

); } return (
系统初始化

这是系统首次启动,请创建第一个管理员账号。

setForm({ ...form, username: e.target.value })} required />
setForm({ ...form, email: e.target.value })} required />
setForm({ ...form, password: e.target.value })} required />
setForm({ ...form, confirmPassword: e.target.value }) } required />
{error &&

{error}

}
); }