Files
gridpilot.gg/apps/website/app/auth/forgot-password/page.tsx
2026-01-14 02:02:24 +01:00

34 lines
955 B
TypeScript

/**
* Forgot Password Page
*
* RSC composition pattern:
* 1. PageQuery executes to get ViewData
* 2. Client component renders with ViewData
*/
import { ForgotPasswordPageQuery } from '@/lib/page-queries/auth/ForgotPasswordPageQuery';
import { ForgotPasswordClient } from './ForgotPasswordClient';
export default async function ForgotPasswordPage({
searchParams,
}: {
searchParams: Promise<URLSearchParams>;
}) {
// Execute PageQuery
const params = await searchParams;
const queryResult = await ForgotPasswordPageQuery.execute(params);
if (queryResult.isErr()) {
// Handle query error
return (
<div className="min-h-screen bg-deep-graphite flex items-center justify-center">
<div className="text-red-400">Failed to load forgot password page</div>
</div>
);
}
const viewData = queryResult.unwrap();
// Render client component with ViewData
return <ForgotPasswordClient viewData={viewData} />;
}