Files
lettersoup-online/002_source/cms/src/app/auth/supabase/recovery-link-sent/page.tsx
louiscklaw 6c931c1fe8 build ok,
2025-04-14 09:26:24 +08:00

64 lines
2.1 KiB
TypeScript

import * as React from 'react';
import type { Metadata } from 'next';
import RouterLink from 'next/link';
import Alert from '@mui/material/Alert';
import Box from '@mui/material/Box';
import Link from '@mui/material/Link';
import Stack from '@mui/material/Stack';
import Typography from '@mui/material/Typography';
import { config } from '@/config';
import { paths } from '@/paths';
import { GuestGuard } from '@/components/auth/guest-guard';
import { SplitLayout } from '@/components/auth/split-layout';
import { ResetPasswordButton } from '@/components/auth/supabase/reset-password-button';
import { DynamicLogo } from '@/components/core/logo';
export const metadata: Metadata = { title: `Recovery link sent | Supabase | Auth | ${config.site.name}` };
interface PageProps {
searchParams: { email?: string };
}
export default function Page({ searchParams }: PageProps): React.JSX.Element {
const { email } = searchParams;
if (!email) {
return (
<Box sx={{ p: 3 }}>
<Alert color="error">Email is required</Alert>
</Box>
);
}
return (
<GuestGuard>
<SplitLayout>
<Stack spacing={4}>
<div>
<Box component={RouterLink} href={paths.home} sx={{ display: 'inline-block', fontSize: 0 }}>
<DynamicLogo colorDark="light" colorLight="dark" height={32} width={122} />
</Box>
</div>
<Typography variant="h5">Recovery link sent</Typography>
<Stack spacing={1}>
<Typography>
If an account exists with email{' '}
<Typography component="span" variant="subtitle1">
&quot;{email}&quot;
</Typography>
, you will receive a recovery email.
</Typography>
<div>
<Link component={RouterLink} href={paths.auth.supabase.resetPassword} variant="subtitle2">
Use another email
</Link>
</div>
</Stack>
<ResetPasswordButton email={email}>Resend</ResetPasswordButton>
</Stack>
</SplitLayout>
</GuestGuard>
);
}