()
| 2 | |
| 3 | const MOBILE_BREAKPOINT = 768 |
| 4 | export function useIsMobile() { |
| 5 | const [isMobile, setIsMobile] = useState<boolean | undefined>(undefined) |
| 6 | |
| 7 | useEffect(() => { |
| 8 | const mql = window.matchMedia(`(max-width: ${MOBILE_BREAKPOINT - 1}px)`) |
| 9 | const onChange = () => { |
| 10 | setIsMobile(window.innerWidth < MOBILE_BREAKPOINT) |
| 11 | } |
| 12 | mql.addEventListener('change', onChange) |
| 13 | setIsMobile(window.innerWidth < MOBILE_BREAKPOINT) |
| 14 | return () => mql.removeEventListener('change', onChange) |
| 15 | }, []) |
| 16 | |
| 17 | return !!isMobile |
| 18 | } |
no outgoing calls
no test coverage detected