import { useState } from 'react'; import { useNavigate } from 'react-router-dom'; import { apiClient } from '@/shared/api/serverClient'; import { Button } from '@/components/ui/button'; import { Input } from '@/components/ui/input'; import { Label } from '@/components/ui/label'; import { Card, CardContent, CardDescription, CardFooter, CardHeader, CardTitle } from '@/components/ui/card'; import { toast } from 'sonner'; export default function Register() { const [email, setEmail] = useState(''); const [password, setPassword] = useState(''); const [fullName, setFullName] = useState(''); const [loading, setLoading] = useState(false); const navigate = useNavigate(); const handleSubmit = async (e: React.FormEvent) => { e.preventDefault(); setLoading(true); try { await apiClient.post('/auth/register', { email, password, full_name: fullName, }); toast.success('注册成功,请登录'); navigate('/login'); } catch (error: any) { const detail = error.response?.data?.detail; // 处理 Pydantic 验证错误(数组格式) if (Array.isArray(detail)) { const messages = detail.map((err: any) => err.msg || err.message || JSON.stringify(err)).join('; '); toast.error(messages || '注册失败'); } else if (typeof detail === 'object') { toast.error(detail.msg || detail.message || JSON.stringify(detail)); } else { toast.error(detail || '注册失败'); } } finally { setLoading(false); } }; return (