import { createSignal, createEffect, Show } from "solid-js"; import { A, useNavigate } from "@solidjs/router"; import { PageHead } from "~/components/PageHead"; import CountdownCircleTimer from "~/components/CountdownCircleTimer"; import { isValidEmail } from "~/lib/validation"; import { getClientCookie } from "~/lib/cookies.client"; import { COUNTDOWN_CONFIG } from "~/config"; import Input from "~/components/ui/Input"; import { Button } from "~/components/ui/Button"; import FormFeedback from "~/components/ui/FormFeedback"; import { useCountdown } from "~/lib/useCountdown"; export default function RequestPasswordResetPage() { const navigate = useNavigate(); const [loading, setLoading] = createSignal(false); const [showSuccessMessage, setShowSuccessMessage] = createSignal(false); const [error, setError] = createSignal(""); const { remainingTime, startCountdown } = useCountdown(); let emailRef: HTMLInputElement | undefined; createEffect(() => { const timer = getClientCookie("passwordResetRequested"); if (timer) { startCountdown(timer); } }); const requestPasswordResetTrigger = async (e: Event) => { e.preventDefault(); setError(""); setShowSuccessMessage(false); if (!emailRef) { setError("Please enter an email address"); return; } const email = emailRef.value; if (!isValidEmail(email)) { setError("Invalid email address"); return; } setLoading(true); try { const response = await fetch("/api/trpc/auth.requestPasswordReset", { method: "POST", headers: { "Content-Type": "application/json" }, body: JSON.stringify({ email }) }); const result = await response.json(); if (response.ok && result.result?.data) { setShowSuccessMessage(true); setError(""); const timer = getClientCookie("passwordResetRequested"); if (timer) { startCountdown(timer); } } else { const errorMsg = result.error?.message || "Failed to send reset email"; const errorCode = result.error?.data?.code; if ( errorCode === "TOO_MANY_REQUESTS" || errorMsg.includes("Too many attempts") ) { setError(errorMsg); } else if (errorMsg.includes("countdown not expired")) { setError("Please wait before requesting another reset email"); } else { setError(errorMsg); } } } catch (err) { console.error("Password reset request error:", err); setError("An error occurred. Please try again."); } finally { setLoading(false); } }; const renderTime = ({ remainingTime }: { remainingTime: number }) => { return (
{remainingTime.toFixed(0)}
); }; return ( <>
Password Reset Request
requestPasswordResetTrigger(e)} class="mt-4 flex w-full justify-center" >
0} fallback={ } >
false} > {renderTime}
); }