(breakpoint: Breakpoint)
| 9 | }; |
| 10 | |
| 11 | const useMediaQuery = (breakpoint: Breakpoint): boolean => { |
| 12 | const [matches, setMatches] = useState(() => { |
| 13 | if (typeof window === "undefined") return false; |
| 14 | return window.matchMedia(`(min-width: ${BREAKPOINTS[breakpoint]}px)`).matches; |
| 15 | }); |
| 16 | |
| 17 | useEffect(() => { |
| 18 | const mediaQuery = window.matchMedia(`(min-width: ${BREAKPOINTS[breakpoint]}px)`); |
| 19 | |
| 20 | const handleChange = (e: MediaQueryListEvent) => { |
| 21 | setMatches(e.matches); |
| 22 | }; |
| 23 | |
| 24 | mediaQuery.addEventListener("change", handleChange); |
| 25 | |
| 26 | return () => { |
| 27 | mediaQuery.removeEventListener("change", handleChange); |
| 28 | }; |
| 29 | }, [breakpoint]); |
| 30 | |
| 31 | return matches; |
| 32 | }; |
| 33 | |
| 34 | export default useMediaQuery; |
no test coverage detected