2024-05-26 17:28:52 -07:00
|
|
|
import type { Metadata } from "next"
|
|
|
|
import { GeistSans } from "geist/font/sans"
|
|
|
|
import { GeistMono } from "geist/font/mono"
|
|
|
|
import "./globals.css"
|
|
|
|
import { ThemeProvider } from "@/components/layout/themeProvider"
|
|
|
|
import { ClerkProvider } from "@clerk/nextjs"
|
|
|
|
import { Toaster } from "@/components/ui/sonner"
|
|
|
|
import { Analytics } from "@vercel/analytics/react"
|
2024-07-14 06:00:03 -04:00
|
|
|
import { PHProvider } from "./providers"
|
2024-03-19 12:13:18 -04:00
|
|
|
|
|
|
|
export const metadata: Metadata = {
|
2024-04-11 05:14:10 -04:00
|
|
|
title: "Sandbox",
|
2024-05-26 17:28:52 -07:00
|
|
|
description: "A collaborative, AI-powered cloud code editing environment",
|
|
|
|
}
|
2024-03-19 12:13:18 -04:00
|
|
|
|
|
|
|
export default function RootLayout({
|
|
|
|
children,
|
|
|
|
}: Readonly<{
|
2024-05-26 17:28:52 -07:00
|
|
|
children: React.ReactNode
|
2024-03-19 12:13:18 -04:00
|
|
|
}>) {
|
|
|
|
return (
|
2024-04-09 01:20:15 -04:00
|
|
|
<ClerkProvider>
|
2024-04-11 05:14:10 -04:00
|
|
|
<html lang="en" className={`${GeistSans.variable} ${GeistMono.variable}`}>
|
2024-07-14 06:00:03 -04:00
|
|
|
<PHProvider>
|
|
|
|
<body>
|
|
|
|
<ThemeProvider
|
|
|
|
attribute="class"
|
|
|
|
defaultTheme="dark"
|
|
|
|
forcedTheme="dark"
|
|
|
|
disableTransitionOnChange
|
|
|
|
>
|
|
|
|
{children}
|
|
|
|
<Analytics />
|
|
|
|
<Toaster position="bottom-left" richColors />
|
|
|
|
</ThemeProvider>
|
|
|
|
</body>
|
|
|
|
</PHProvider>
|
2024-04-09 01:20:15 -04:00
|
|
|
</html>
|
|
|
|
</ClerkProvider>
|
2024-05-26 17:28:52 -07:00
|
|
|
)
|
2024-03-19 12:13:18 -04:00
|
|
|
}
|