Files
gridpilot.gg/apps/website/app/auth/login/page.tsx
2026-01-14 10:51:05 +01:00

30 lines
752 B
TypeScript

/**
* Login Page
*
* RSC composition pattern:
* 1. PageQuery executes to get ViewData
* 2. Client component renders with ViewData
*/
import { LoginPageQuery } from '@/lib/page-queries/auth/LoginPageQuery';
import { LoginClient } from './LoginClient';
import { AuthError } from '@/components/ui/AuthError';
export default async function LoginPage({
searchParams,
}: {
searchParams: Promise<URLSearchParams>;
}) {
// Execute PageQuery
const params = await searchParams;
const queryResult = await LoginPageQuery.execute(params);
if (queryResult.isErr()) {
return <AuthError action="login" />;
}
const viewData = queryResult.unwrap();
// Render client component with ViewData
return <LoginClient viewData={viewData} />;
}