1234567891011121314151617181920212223242526272829303132333435363738394041424344454647 |
- import { Link, usePage } from '@inertiajs/react';
- import { type PropsWithChildren } from 'react';
- import { AppLogoIcon } from '@/common/AppLogoIcon';
- import { type SharedData } from '@/common/types';
- import { home } from '@/routes';
- interface AuthLayoutProps {
- title?: string;
- description?: string;
- }
- export default function AuthSplitLayout({ children, title, description }: PropsWithChildren<AuthLayoutProps>) {
- const { name, quote } = usePage<SharedData>().props;
- return (
- <div className="relative grid h-dvh flex-col items-center justify-center px-8 sm:px-0 lg:max-w-none lg:grid-cols-2 lg:px-0">
- <div className="relative hidden h-full flex-col bg-muted p-10 text-white lg:flex dark:border-r">
- <div className="absolute inset-0 bg-zinc-900" />
- <Link href={home()} className="relative z-20 flex items-center text-lg font-medium">
- <AppLogoIcon className="mr-2 size-8 fill-current text-white" />
- {name}
- </Link>
- {quote && (
- <div className="relative z-20 mt-auto">
- <blockquote className="space-y-2">
- <p className="text-lg">“{quote.message}”</p>
- <footer className="text-sm text-neutral-300">{quote.author}</footer>
- </blockquote>
- </div>
- )}
- </div>
- <div className="w-full lg:p-8">
- <div className="mx-auto flex w-full flex-col justify-center space-y-6 sm:w-[350px]">
- <Link href={home()} className="relative z-20 flex items-center justify-center lg:hidden">
- <AppLogoIcon className="h-10 fill-current text-black sm:h-12" />
- </Link>
- <div className="flex flex-col items-start gap-2 text-left sm:items-center sm:text-center">
- <h1 className="text-xl font-medium">{title}</h1>
- <p className="text-sm text-balance text-muted-foreground">{description}</p>
- </div>
- {children}
- </div>
- </div>
- </div>
- );
- }
|