46 lines
1.2 KiB
TypeScript
46 lines
1.2 KiB
TypeScript
import type { Metadata } from 'next';
|
|
import { Montserrat } from 'next/font/google';
|
|
import './globals.css';
|
|
import { cn } from '@/lib/utils';
|
|
import Sidebar from '@/components/Sidebar';
|
|
import { Toaster } from 'sonner';
|
|
import ThemeProvider from '@/components/theme/Provider';
|
|
|
|
const montserrat = Montserrat({
|
|
weight: ['300', '400', '500', '700'],
|
|
subsets: ['latin'],
|
|
display: 'swap',
|
|
fallback: ['Arial', 'sans-serif'],
|
|
});
|
|
|
|
export const metadata: Metadata = {
|
|
title: 'Perplexica - Chat with the internet',
|
|
description:
|
|
'Perplexica is an AI powered chatbot that is connected to the internet.',
|
|
};
|
|
|
|
export default function RootLayout({
|
|
children,
|
|
}: Readonly<{
|
|
children: React.ReactNode;
|
|
}>) {
|
|
return (
|
|
<html className="h-full" lang="en" suppressHydrationWarning>
|
|
<body className={cn('h-full', montserrat.className)}>
|
|
<ThemeProvider>
|
|
<Sidebar>{children}</Sidebar>
|
|
<Toaster
|
|
toastOptions={{
|
|
unstyled: true,
|
|
classNames: {
|
|
toast:
|
|
'bg-light-primary dark:bg-dark-primary text-white rounded-lg p-4 flex flex-row items-center space-x-2',
|
|
},
|
|
}}
|
|
/>
|
|
</ThemeProvider>
|
|
</body>
|
|
</html>
|
|
);
|
|
}
|