Spaces:
Sleeping
Sleeping
| import React, { createContext, useContext, useState, useEffect } from 'react'; | |
| const ThemeContext = createContext(); | |
| export const useTheme = () => { | |
| const context = useContext(ThemeContext); | |
| if (!context) { | |
| throw new Error('useTheme must be used within a ThemeProvider'); | |
| } | |
| return context; | |
| }; | |
| export const ThemeProvider = ({ children }) => { | |
| // Check for saved theme preference or default to 'light' | |
| const [theme, setTheme] = useState(() => { | |
| const savedTheme = localStorage.getItem('theme'); | |
| return savedTheme || 'light'; | |
| }); | |
| // Apply theme to document root and save to localStorage | |
| useEffect(() => { | |
| document.documentElement.setAttribute('data-theme', theme); | |
| localStorage.setItem('theme', theme); | |
| }, [theme]); | |
| const toggleTheme = () => { | |
| setTheme(prevTheme => prevTheme === 'light' ? 'dark' : 'light'); | |
| }; | |
| const value = { | |
| theme, | |
| toggleTheme, | |
| isLight: theme === 'light', | |
| isDark: theme === 'dark' | |
| }; | |
| return ( | |
| <ThemeContext.Provider value={value}> | |
| {children} | |
| </ThemeContext.Provider> | |
| ); | |
| }; |