"use client" import { useState } from "react" import { useAuth } from "@/contexts/auth-context" import { useRouter } from "next/navigation" import { Button } from "@/components/ui/button" import { Input } from "@/components/ui/input" import { Card, CardContent, CardHeader, CardTitle, CardDescription, CardFooter } from "@/components/ui/card" import { Label } from "@/components/ui/label" import { getApiUrl } from "@/lib/api-config" import Link from "next/link" export default function LoginPage() { const [email, setEmail] = useState("") const [password, setPassword] = useState("") const [error, setError] = useState("") const { login } = useAuth() const router = useRouter() const [loading, setLoading] = useState(false) const handleSubmit = async (e: React.FormEvent) => { e.preventDefault() setLoading(true) setError("") try { const formData = new URLSearchParams() formData.append('username', email) formData.append('password', password) const res = await fetch(`${getApiUrl()}/auth/token`, { method: "POST", headers: { "Content-Type": "application/x-www-form-urlencoded", }, body: formData, }) if (!res.ok) { const data = await res.json() throw new Error(data.detail || "Login failed") } const data = await res.json() await login(data.access_token) router.push("/") } catch (err: any) { setError(err.message) } finally { setLoading(false) } } return (