Press n or j to go to the next uncovered block, b, p or k for the previous block.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 | 1x 1x 1x 1x 10x 10x 4x 4x 4x 4x 4x 4x 4x 10x 10x 10x | import { useEffect, useState } from 'react'; const MOBILE_WIDTH = 768; const DEBOUNCE_DELAY = 150; export function useIsMobile(): boolean { const [isMobile, setIsMobile] = useState(() => window.innerWidth < MOBILE_WIDTH); useEffect(() => { let timeout: NodeJS.Timeout; const handleResize = () => { clearTimeout(timeout); timeout = setTimeout(() => { setIsMobile(window.innerWidth < MOBILE_WIDTH); }, DEBOUNCE_DELAY); }; window.addEventListener('resize', handleResize); return () => { clearTimeout(timeout); window.removeEventListener('resize', handleResize); }; }, []); return isMobile; } |