diff options
Diffstat (limited to 'src/hooks/useDarkMode.tsx')
| -rw-r--r-- | src/hooks/useDarkMode.tsx | 21 |
1 files changed, 21 insertions, 0 deletions
diff --git a/src/hooks/useDarkMode.tsx b/src/hooks/useDarkMode.tsx new file mode 100644 index 0000000..fe4ce95 --- /dev/null +++ b/src/hooks/useDarkMode.tsx | |||
| @@ -0,0 +1,21 @@ | |||
| 1 | import {useEffect, useMemo, useState} from "react"; | ||
| 2 | import {ThemeConfig} from "bootstrap-darkmode"; | ||
| 3 | |||
| 4 | export interface UseDarkMode { | ||
| 5 | darkMode: boolean | ||
| 6 | toggle: () => void | ||
| 7 | } | ||
| 8 | |||
| 9 | export default function useDarkMode() { | ||
| 10 | const themeConfig = useMemo(() => new ThemeConfig(), []); | ||
| 11 | const [darkMode, setDarkMode] = useState(() => themeConfig.getTheme() === 'dark') | ||
| 12 | |||
| 13 | useEffect(() => { | ||
| 14 | themeConfig.setTheme(darkMode ? 'dark' : 'light'); | ||
| 15 | }, [darkMode]) | ||
| 16 | |||
| 17 | return { | ||
| 18 | darkMode, | ||
| 19 | toggle: () => setDarkMode(dm => !dm), | ||
| 20 | } | ||
| 21 | } | ||
