All checks were successful
ci/woodpecker/push/ci Pipeline was successful
Co-authored-by: Jason Woltje <jason@diversecanvas.com> Co-committed-by: Jason Woltje <jason@diversecanvas.com>
42 lines
1.3 KiB
TypeScript
42 lines
1.3 KiB
TypeScript
import type { Metadata } from 'next';
|
|
import type { ReactNode } from 'react';
|
|
import { ThemeProvider } from '@/providers/theme-provider';
|
|
import './globals.css';
|
|
|
|
export const metadata: Metadata = {
|
|
title: 'Mosaic',
|
|
description: 'Mosaic Stack Dashboard',
|
|
};
|
|
|
|
function themeScript(): string {
|
|
return `
|
|
(function () {
|
|
try {
|
|
var theme = window.localStorage.getItem('mosaic-theme') || 'dark';
|
|
document.documentElement.setAttribute('data-theme', theme === 'light' ? 'light' : 'dark');
|
|
} catch (error) {
|
|
document.documentElement.setAttribute('data-theme', 'dark');
|
|
}
|
|
})();
|
|
`;
|
|
}
|
|
|
|
export default function RootLayout({ children }: { children: ReactNode }): React.ReactElement {
|
|
return (
|
|
<html lang="en" suppressHydrationWarning>
|
|
<head>
|
|
<link rel="preconnect" href="https://fonts.googleapis.com" />
|
|
<link rel="preconnect" href="https://fonts.gstatic.com" crossOrigin="anonymous" />
|
|
<link
|
|
rel="stylesheet"
|
|
href="https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700&family=Fira+Code:wght@400;500&display=swap"
|
|
/>
|
|
<script dangerouslySetInnerHTML={{ __html: themeScript() }} />
|
|
</head>
|
|
<body>
|
|
<ThemeProvider>{children}</ThemeProvider>
|
|
</body>
|
|
</html>
|
|
);
|
|
}
|