47 lines
1.3 KiB
TypeScript
47 lines
1.3 KiB
TypeScript
import DeployButton from "@/components/deploy-button";
|
|
import { EnvVarWarning } from "@/components/env-var-warning";
|
|
import HeaderAuth from "@/components/header-auth";
|
|
import { ThemeSwitcher } from "@/components/theme-switcher";
|
|
import { hasEnvVars } from "@/utils/supabase/check-env-vars";
|
|
import { Geist } from "next/font/google";
|
|
import { ThemeProvider } from "next-themes";
|
|
import Link from "next/link";
|
|
import "./globals.css";
|
|
|
|
const defaultUrl = process.env.VERCEL_URL
|
|
? `https://${process.env.VERCEL_URL}`
|
|
: "http://localhost:3000";
|
|
|
|
export const metadata = {
|
|
metadataBase: new URL(defaultUrl),
|
|
title: "Next.js and Supabase Starter Kit",
|
|
description: "The fastest way to build apps with Next.js and Supabase",
|
|
};
|
|
|
|
const geistSans = Geist({
|
|
display: "swap",
|
|
subsets: ["latin"],
|
|
});
|
|
|
|
export default function RootLayout({
|
|
children,
|
|
}: Readonly<{
|
|
children: React.ReactNode;
|
|
}>) {
|
|
return (
|
|
<html lang="en" className={geistSans.className} suppressHydrationWarning>
|
|
<body className="bg-background text-foreground">
|
|
<ThemeProvider
|
|
attribute="class"
|
|
defaultTheme="system"
|
|
enableSystem
|
|
disableTransitionOnChange
|
|
>
|
|
{children}
|
|
<ThemeSwitcher />
|
|
</ThemeProvider>
|
|
</body>
|
|
</html>
|
|
);
|
|
}
|