mosaicmap/hooks/use-mobile.ts
2025-08-12 21:25:52 +08:00

20 lines
553 B
TypeScript

"use client"
import * as React from "react"
export function useIsMobile(breakpoint = 768) {
const [isMobile, setIsMobile] = React.useState<boolean | undefined>(undefined)
React.useEffect(() => {
const mql = window.matchMedia(`(max-width: ${breakpoint - 1}px)`)
const onChange = () => {
setIsMobile(window.innerWidth < breakpoint)
}
mql.addEventListener("change", onChange)
setIsMobile(window.innerWidth < breakpoint)
return () => mql.removeEventListener("change", onChange)
}, [breakpoint])
return !!isMobile
}