instalasi-sim-rs/resources/js/layouts/auth/auth-split-layout.tsx

53 lines
2.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';
import BackgroundRumahSakit from '/public/bg-rsab-harapan_kita.jpeg';
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="bg-muted relative hidden h-full flex-col p-10 text-white lg:flex dark:border-r">
<div className="absolute inset-0">
<img src={BackgroundRumahSakit} alt="background rumah sakit harapan kita" className="h-full w-full object-cover" />
<div className="bg-primary/70 absolute inset-0" />
</div>
<Link href={route('home')} className="relative z-20 flex items-center">
<AppLogoIcon className="mr-2 size-24 fill-current text-white" />
<div className="grid flex-1 text-left">
<span className="mb-0.5 truncate leading-none font-semibold text-2xl">{name}</span>
<span className="font-regular text-lg truncate leading-none">RSAB Harapan Kita</span>
</div>
</Link>
{quote && (
<div className="relative z-20 mt-auto">
<blockquote className="space-y-2">
<p className="text-lg">&ldquo;{quote.message}&rdquo;</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={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>
);
}