Spaces:
Build error
Build error
File size: 1,531 Bytes
3054d55 |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 |
import '@/styles/globals.css';
import Head from 'next/head';
import { useState, useEffect } from 'react';
function MyApp({ Component, pageProps }) {
const [darkMode, setDarkMode] = useState(false);
useEffect(() => {
if (localStorage.theme === 'dark' || (!('theme' in localStorage) && window.matchMedia('(prefers-color-scheme: dark)').matches)) {
setDarkMode(true);
document.documentElement.classList.add('dark');
} else {
setDarkMode(false);
document.documentElement.classList.remove('dark');
}
}, []);
const toggleTheme = () => {
if (darkMode) {
document.documentElement.classList.remove('dark');
localStorage.theme = 'light';
setDarkMode(false);
} else {
document.documentElement.classList.add('dark');
localStorage.theme = 'dark';
setDarkMode(true);
}
};
return (
<>
<Head>
<title>Nexus Dashboard | Enterprise Analytics</title>
<meta name="description" content="Advanced analytics and project management dashboard" />
<link rel="icon" href="/favicon.ico" />
<link href="https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap" rel="stylesheet" />
</Head>
<ThemeContext.Provider value={{ darkMode, toggleTheme }}>
<Component {...pageProps} />
</ThemeContext.Provider>
</>
);
}
export const ThemeContext = React.createContext({
darkMode: false,
toggleTheme: () => {},
});
import React from 'react';
export default MyApp; |