| gio | d002661 | 2025-05-08 13:00:36 +0000 | [diff] [blame] | 1 | import * as React from "react"; |
| gio | 5f2f100 | 2025-03-20 18:38:48 +0400 | [diff] [blame] | 2 | |
| gio | d002661 | 2025-05-08 13:00:36 +0000 | [diff] [blame] | 3 | const MOBILE_BREAKPOINT = 768; |
| gio | 5f2f100 | 2025-03-20 18:38:48 +0400 | [diff] [blame] | 4 | |
| 5 | export function useIsMobile() { |
| gio | d002661 | 2025-05-08 13:00:36 +0000 | [diff] [blame] | 6 | const [isMobile, setIsMobile] = React.useState<boolean | undefined>(undefined); |
| gio | 5f2f100 | 2025-03-20 18:38:48 +0400 | [diff] [blame] | 7 | |
| gio | d002661 | 2025-05-08 13:00:36 +0000 | [diff] [blame] | 8 | React.useEffect(() => { |
| 9 | const mql = window.matchMedia(`(max-width: ${MOBILE_BREAKPOINT - 1}px)`); |
| 10 | const onChange = () => { |
| 11 | setIsMobile(window.innerWidth < MOBILE_BREAKPOINT); |
| 12 | }; |
| 13 | mql.addEventListener("change", onChange); |
| 14 | setIsMobile(window.innerWidth < MOBILE_BREAKPOINT); |
| 15 | return () => mql.removeEventListener("change", onChange); |
| 16 | }, []); |
| gio | 5f2f100 | 2025-03-20 18:38:48 +0400 | [diff] [blame] | 17 | |
| gio | d002661 | 2025-05-08 13:00:36 +0000 | [diff] [blame] | 18 | return !!isMobile; |
| gio | 5f2f100 | 2025-03-20 18:38:48 +0400 | [diff] [blame] | 19 | } |