mhsf-dev/src/app/layout.tsx

90 lines
2.9 KiB
TypeScript
Raw Normal View History

2024-07-23 18:49:21 -05:00
import { GeistSans } from "geist/font/sans";
2024-08-07 16:37:54 -05:00
import { SpeedInsights } from "@vercel/speed-insights/next";
import { Analytics } from "@vercel/analytics/react";
2024-05-31 16:22:34 -05:00
import "./globals.css";
2024-07-23 18:49:21 -05:00
import { TooltipProvider } from "@/components/ui/tooltip";
import { ThemeProvider } from "@/components/ThemeProvider";
import { ClerkThemeProvider } from "@/components/clerk/ClerkThemeProvider";
2024-08-07 16:37:54 -05:00
import NextTopLoader from "@/lib/top-loader";
2024-09-03 23:56:15 -05:00
import { banner } from "@/config/banner";
2024-07-26 00:46:53 -05:00
import {
Breadcrumb,
BreadcrumbList,
BreadcrumbPage,
} from "@/components/ui/breadcrumb";
import Link from "next/link";
import TopBar from "@/components/clerk/Topbar";
import TextFromPathname from "@/components/TextFromPathname";
import { Inter as interFont } from "next/font/google";
import { CommandBarer } from "@/components/CommandBar";
2024-08-10 11:24:54 -05:00
import ThemedToaster from "@/components/misc/ThemedToaster";
2024-08-17 14:15:30 -05:00
import UnofficalDialog from "@/components/misc/UnofficalDialog";
2024-08-18 01:15:27 -05:00
import ClientFadeIn from "@/components/ClientFadeIn";
2024-08-24 12:37:08 -05:00
import { BrandingGenericIcon } from "@/components/Icon";
2024-09-06 20:14:59 -05:00
import type { Metadata } from "next";
export const metadata = {
openGraph: {
images: [
{
url: "/branding/meta-banner.png",
},
],
},
} satisfies Metadata;
2024-05-31 16:22:34 -05:00
2024-07-26 00:46:53 -05:00
const inter = interFont({ variable: "--font-inter", subsets: ["latin"] });
2024-07-23 18:49:21 -05:00
export default async function RootLayout({
2024-05-31 16:22:34 -05:00
children,
}: Readonly<{
children: React.ReactNode;
}>) {
return (
2024-07-23 18:49:21 -05:00
<ClerkThemeProvider className={GeistSans.className}>
<ThemeProvider
attribute="class"
defaultTheme="system"
enableSystem
disableTransitionOnChange
>
<TooltipProvider>
2024-07-26 00:46:53 -05:00
{banner.isBanner && (
<div className="bg-orange-600 w-screen h-8 border-b fixed text-black flex items-center text-center font-medium pl-2">
{banner.bannerText}
</div>
)}
<div
className={
2024-08-24 12:37:08 -05:00
"w-screen h-[3rem] border-b fixed backdrop-blur flex z-10 " +
2024-07-26 00:46:53 -05:00
(banner.isBanner == true ? "mt-8" : "")
}
>
2024-09-03 23:56:15 -05:00
<div className="items-center me-auto mt-2 pl-7 max-sm:mt-3">
2024-07-26 00:46:53 -05:00
<Breadcrumb>
<BreadcrumbList>
<Link href="/">
<BreadcrumbPage className="max-sm:hidden">
2024-08-24 12:37:08 -05:00
<BrandingGenericIcon className="max-w-[32px] max-h-[32px] " />
2024-07-26 00:46:53 -05:00
</BreadcrumbPage>
</Link>
<TextFromPathname />
</BreadcrumbList>
</Breadcrumb>
</div>
<TopBar inter={inter.className} />
</div>
2024-08-07 16:37:54 -05:00
<div>
<NextTopLoader />
2024-08-18 01:15:27 -05:00
<ClientFadeIn>{children}</ClientFadeIn>
2024-08-07 16:37:54 -05:00
</div>{" "}
2024-08-10 11:24:54 -05:00
<ThemedToaster />
2024-08-03 09:51:45 -05:00
<CommandBarer />
2024-08-07 16:37:54 -05:00
<SpeedInsights />
<Analytics />
2024-08-17 14:15:30 -05:00
<UnofficalDialog />
2024-07-23 18:49:21 -05:00
</TooltipProvider>
</ThemeProvider>
</ClerkThemeProvider>
2024-05-31 16:22:34 -05:00
);
}