()
| 29 | } |
| 30 | |
| 31 | export default function useTheme() { |
| 32 | const [theme, _setTheme] = useState<ThemeType>(getTheme()); |
| 33 | |
| 34 | function setTheme(theme: ThemeType) { |
| 35 | updateClass(theme); |
| 36 | persistTheme(theme); |
| 37 | _setTheme(theme); |
| 38 | } |
| 39 | |
| 40 | function toggleTheme() { |
| 41 | setTheme(theme === 'dark' ? 'light' : 'dark'); |
| 42 | } |
| 43 | |
| 44 | return { |
| 45 | theme, |
| 46 | codeTheme: getTheme() === 'dark' ? srcbookDark : srcbookLight, |
| 47 | toggleTheme, |
| 48 | setTheme, |
| 49 | }; |
| 50 | } |
no test coverage detected