'use client'; import { signUp, useSession } from '@/lib/better-auth'; import { useRouter } from 'next/navigation'; import { useEffect, useState } from 'react'; export default function SignUp() { const { data: session, isPending: sessionPending } = useSession(); const router = useRouter(); const [name, setName] = useState(''); const [email, setEmail] = useState(''); const [password, setPassword] = useState(''); const [loading, setLoading] = useState(false); const [error, setError] = useState(''); useEffect(() => { if (!sessionPending && session?.user) { router.replace('/'); } }, [sessionPending, session, router]); const handleSignUp = async (e: React.FormEvent) => { e.preventDefault(); setLoading(true); setError(''); try { const result = await signUp.email({ email, password, name, }); if (result.error) { setError(result.error.message || 'Sign up failed'); } else { router.replace('/'); router.refresh(); } } catch (err) { setError('Sign up failed'); } finally { setLoading(false); } }; return (

Fiscal Clone

Create your account

{error && (
{error}
)}
setName(e.target.value)} className="w-full bg-slate-700/50 border border-slate-600 rounded-lg px-4 py-3 text-white placeholder-slate-400 focus:outline-none focus:ring-2 focus:ring-blue-500" placeholder="Your name" required />
setEmail(e.target.value)} className="w-full bg-slate-700/50 border border-slate-600 rounded-lg px-4 py-3 text-white placeholder-slate-400 focus:outline-none focus:ring-2 focus:ring-blue-500" placeholder="you@example.com" required />
setPassword(e.target.value)} className="w-full bg-slate-700/50 border border-slate-600 rounded-lg px-4 py-3 text-white placeholder-slate-400 focus:outline-none focus:ring-2 focus:ring-blue-500" placeholder="•••••••••" required minLength={8} />

Already have an account?{' '} Sign in

); }