2024-05-31 16:22:34 -05:00
|
|
|
import type { Metadata } from "next";
|
2024-07-23 18:49:21 -05:00
|
|
|
import { GeistSans } from "geist/font/sans";
|
2024-07-26 00:46:53 -05:00
|
|
|
import { Github, CodeXml, Server } from "lucide-react";
|
2024-07-23 18:49:21 -05:00
|
|
|
|
2024-05-31 16:22:34 -05:00
|
|
|
import "./globals.css";
|
2024-07-23 18:49:21 -05:00
|
|
|
import { Toaster } from "react-hot-toast";
|
|
|
|
|
import { headers } from "next/headers";
|
2024-05-31 16:22:34 -05:00
|
|
|
|
2024-07-23 18:49:21 -05:00
|
|
|
import { Button } from "@/components/ui/button";
|
|
|
|
|
import { TooltipProvider } from "@/components/ui/tooltip";
|
|
|
|
|
import { ThemeProvider } from "@/components/ThemeProvider";
|
|
|
|
|
import Image from "next/image";
|
|
|
|
|
import { ClerkThemeProvider } from "@/components/clerk/ClerkThemeProvider";
|
|
|
|
|
import { useEffectOnce } from "@/lib/useEffectOnce";
|
2024-07-26 00:46:53 -05:00
|
|
|
import { banner } from "@/banner";
|
|
|
|
|
import {
|
|
|
|
|
Breadcrumb,
|
|
|
|
|
BreadcrumbItem,
|
|
|
|
|
BreadcrumbList,
|
|
|
|
|
BreadcrumbPage,
|
|
|
|
|
BreadcrumbSeparator,
|
|
|
|
|
} 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";
|
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={
|
|
|
|
|
"w-screen h-12 border-b fixed backdrop-blur flex " +
|
|
|
|
|
(banner.isBanner == true ? "mt-8" : "")
|
|
|
|
|
}
|
|
|
|
|
>
|
|
|
|
|
<div className=" me-auto mt-3 pl-7">
|
|
|
|
|
<Breadcrumb>
|
|
|
|
|
<BreadcrumbList>
|
|
|
|
|
<Link href="/">
|
|
|
|
|
<BreadcrumbPage className="max-sm:hidden">
|
|
|
|
|
<Server />
|
|
|
|
|
</BreadcrumbPage>
|
|
|
|
|
</Link>
|
|
|
|
|
<TextFromPathname />
|
|
|
|
|
</BreadcrumbList>
|
|
|
|
|
</Breadcrumb>
|
|
|
|
|
</div>
|
|
|
|
|
<TopBar inter={inter.className} />
|
|
|
|
|
</div>
|
2024-07-23 18:49:21 -05:00
|
|
|
<div>{children}</div>{" "}
|
|
|
|
|
<Toaster position="bottom-center" reverseOrder={false} />
|
|
|
|
|
</TooltipProvider>
|
|
|
|
|
</ThemeProvider>
|
|
|
|
|
</ClerkThemeProvider>
|
2024-05-31 16:22:34 -05:00
|
|
|
);
|
|
|
|
|
}
|