import {useCallback, useEffect, useState} from 'react'; const VISIBILITY_STATE_SUPPORTED = 'visibilityState' in document; function isWindowVisible() { return !VISIBILITY_STATE_SUPPORTED || document.visibilityState !== 'hidden'; } /** * Returns whether the window is currently visible to the user. */ export default function useIsWindowVisible(): boolean { const [focused, setFocused] = useState(isWindowVisible()); const listener = useCallback(() => { setFocused(isWindowVisible()); }, [setFocused]); useEffect(() => { if (!VISIBILITY_STATE_SUPPORTED) return undefined; document.addEventListener('visibilitychange', listener); return () => { document.removeEventListener('visibilitychange', listener); }; }, [listener]); return focused; }