38 lines
1.7 KiB
TypeScript
38 lines
1.7 KiB
TypeScript
import AppLogoIcon from '@/components/app-logo-icon';
|
|
import { type SharedData } from '@/types';
|
|
import { Link, usePage } from '@inertiajs/react';
|
|
import { type PropsWithChildren } from 'react';
|
|
|
|
interface AuthLayoutProps {
|
|
title?: string;
|
|
description?: string;
|
|
}
|
|
|
|
export default function AuthSplitLayout({ children, title, description }: PropsWithChildren<AuthLayoutProps>) {
|
|
const appName = 'MEMEFAST';
|
|
|
|
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="bg-muted relative hidden h-full flex-col p-10 text-white lg:flex dark:border-r">
|
|
<div className="absolute inset-0 bg-zinc-900" />
|
|
<Link href={route('home')} className="relative z-20 flex items-center text-lg font-medium">
|
|
<AppLogoIcon className="mr-2 size-8 fill-current text-white" />
|
|
{appName}
|
|
</Link>
|
|
</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={route('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-muted-foreground text-sm text-balance">{description}</p>
|
|
</div>
|
|
{children}
|
|
</div>
|
|
</div>
|
|
</div>
|
|
);
|
|
}
|