// app/forgot-password/page.tsx "use client" import { useState } from "react" import { useRouter } from "next/navigation" import Link from "next/link" export default function ForgotPasswordPage() { const router = useRouter() const [email, setEmail] = useState("") const [loading, setLoading] = useState(false) const [error, setError] = useState("") const [success, setSuccess] = useState(false) const [resetUrl, setResetUrl] = useState(null) const handleSubmit = async (e: React.FormEvent) => { e.preventDefault() setLoading(true) setError("") setSuccess(false) setResetUrl(null) try { const response = await fetch("/api/auth/forgot-password", { method: "POST", headers: { "Content-Type": "application/json" }, body: JSON.stringify({ email }) }) const data = await response.json() if (!response.ok) { throw new Error(data.error || "Erro ao solicitar reset de senha") } setSuccess(true) // Se estiver em desenvolvimento, mostrar o link if (data.resetUrl) { setResetUrl(data.resetUrl) } } catch (err: any) { setError(err.message) } finally { setLoading(false) } } return (

🔐 Esqueci minha senha

Digite seu email para receber um link de redefinição de senha

{!success ? (
setEmail(e.target.value)} required style={{ width: "100%", padding: "0.75rem", border: "1px solid #e2e8f0", borderRadius: "0.375rem", fontSize: "1rem" }} />
{error && (
{error}
)}
← Voltar para Login
) : (
Email enviado!
Se o email existir em nossa base, você receberá um link para redefinir sua senha em alguns instantes.
{resetUrl && (
🔗 Link de Redefinição (Desenvolvimento):
{resetUrl}
)}
Voltar para Login
)}
) }