diff options
Diffstat (limited to 'src/hooks')
| -rw-r--r-- | src/hooks/useDarkMode.tsx | 21 | ||||
| -rw-r--r-- | src/hooks/useRequests.tsx | 5 |
2 files changed, 26 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 | } | ||
diff --git a/src/hooks/useRequests.tsx b/src/hooks/useRequests.tsx index 5ac70a4..cb85162 100644 --- a/src/hooks/useRequests.tsx +++ b/src/hooks/useRequests.tsx | |||
| @@ -57,6 +57,7 @@ export interface useRequestsProps { | |||
| 57 | export interface UseRequests { | 57 | export interface UseRequests { |
| 58 | calls: RequestResponse[] | 58 | calls: RequestResponse[] |
| 59 | readyState: ReadyState | 59 | readyState: ReadyState |
| 60 | clear: () => void | ||
| 60 | } | 61 | } |
| 61 | 62 | ||
| 62 | export default function useRequests({ onConnect }: useRequestsProps): UseRequests { | 63 | export default function useRequests({ onConnect }: useRequestsProps): UseRequests { |
| @@ -124,5 +125,9 @@ export default function useRequests({ onConnect }: useRequestsProps): UseRequest | |||
| 124 | response: responses.find(({id}) => id === request.id) | 125 | response: responses.find(({id}) => id === request.id) |
| 125 | })), [requests, responses]), | 126 | })), [requests, responses]), |
| 126 | readyState, | 127 | readyState, |
| 128 | clear: () => { | ||
| 129 | setRequests([]) | ||
| 130 | setResponses([]) | ||
| 131 | } | ||
| 127 | } | 132 | } |
| 128 | } | 133 | } |
