import * as React from "react" const MOBILE_BREAKPOINT = 768 export function useIsMobile() { const [isMobile, setIsMobile] = React.useState(undefined) React.useEffect(() => { const mql = window.matchMedia(`(max-width: ${MOBILE_BREAKPOINT - 1}px)`) const onChange = () => { setIsMobile(window.innerWidth < MOBILE_BREAKPOINT) } mql.addEventListener("change", onChange) setIsMobile(window.innerWidth < MOBILE_BREAKPOINT) return () => mql.removeEventListener("change", onChange) }, []) return !!isMobile } export function useIsTouchDevice() { const [isTouch, setIsTouch] = React.useState(undefined) React.useEffect(() => { const checkTouch = () => { const hasTouch = 'ontouchstart' in window || navigator.maxTouchPoints > 0 setIsTouch(hasTouch) } checkTouch() // Listen for changes in touch capability const mediaQuery = window.matchMedia('(pointer: coarse)') const handleChange = () => checkTouch() mediaQuery.addEventListener('change', handleChange) return () => mediaQuery.removeEventListener('change', handleChange) }, []) return !!isTouch }