28 lines
697 B
TypeScript
28 lines
697 B
TypeScript
import * as React from 'react';
|
|
|
|
const MOBILE_BREAKPOINT = 768;
|
|
|
|
/**
|
|
* Determine if it's on the current mobile screen (768px)
|
|
* @returns boolean
|
|
*/
|
|
const useIsMobile = () => {
|
|
const [isMobile, setIsMobile] = React.useState<boolean | undefined>(
|
|
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 default useIsMobile;
|