"use client" import { useState } from "react" 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" import { useAuth } from "@/contexts/auth-context" export default function RegisterPage() { const [email, setEmail] = useState("") const [username, setUsername] = useState("") const [password, setPassword] = useState("") const [error, setError] = useState("") const router = useRouter() const { login } = useAuth() const [loading, setLoading] = useState(false) const handleSubmit = async (e: React.FormEvent) => { e.preventDefault() setLoading(true) setError("") try { // 1. Register const res = await fetch(`${getApiUrl()}/auth/register`, { method: "POST", headers: { "Content-Type": "application/json", }, body: JSON.stringify({ email, username, password }), }) if (!res.ok) { const data = await res.json() throw new Error(data.detail || "Registration failed") } // 2. Login automatically const formData = new URLSearchParams() formData.append('username', email) formData.append('password', password) const loginRes = await fetch(`${getApiUrl()}/auth/token`, { method: "POST", headers: { "Content-Type": "application/x-www-form-urlencoded" }, body: formData, }) if (loginRes.ok) { const loginData = await loginRes.json() await login(loginData.access_token) router.push("/") } else { router.push("/login") } } catch (err: any) { setError(err.message) } finally { setLoading(false) } } return (
Create Account Join the community to track shows and rate sets
{error && (
{error}
)}
setEmail(e.target.value)} required />
setUsername(e.target.value)} required />
setPassword(e.target.value)} required />

Already have an account?{" "} Sign in

) }