diff options
| author | 2022-01-25 21:42:51 +0100 | |
|---|---|---|
| committer | 2022-01-25 22:06:58 +0100 | |
| commit | f9cd68181137c72e92c6951efd9b8d29c4b73bc1 (patch) | |
| tree | a58451fb140d9c5ea023a45bd393127519a7918f /src/hooks/useDarkMode.tsx | |
| parent | 2f27e222add9bf10b55971ab915ac411e81d24f0 (diff) | |
| download | client-f9cd68181137c72e92c6951efd9b8d29c4b73bc1.tar.gz client-f9cd68181137c72e92c6951efd9b8d29c4b73bc1.tar.bz2 client-f9cd68181137c72e92c6951efd9b8d29c4b73bc1.zip | |
Added dark mode
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 | } | ||
