mirror of
https://github.com/mastodon/mastodon.git
synced 2025-11-28 02:20:47 +00:00
33 lines
825 B
TypeScript
33 lines
825 B
TypeScript
import { useEffect, useRef, useState } from 'react';
|
|
|
|
export function useIsDocumentVisible({
|
|
onChange,
|
|
}: {
|
|
onChange?: (isVisible: boolean) => void;
|
|
} = {}) {
|
|
const [isDocumentVisible, setIsDocumentVisible] = useState(
|
|
() => document.visibilityState === 'visible',
|
|
);
|
|
|
|
const onChangeRef = useRef(onChange);
|
|
useEffect(() => {
|
|
onChangeRef.current = onChange;
|
|
}, [onChange]);
|
|
|
|
useEffect(() => {
|
|
function handleVisibilityChange() {
|
|
const isVisible = document.visibilityState === 'visible';
|
|
|
|
setIsDocumentVisible(isVisible);
|
|
onChangeRef.current?.(isVisible);
|
|
}
|
|
window.addEventListener('visibilitychange', handleVisibilityChange);
|
|
|
|
return () => {
|
|
window.removeEventListener('visibilitychange', handleVisibilityChange);
|
|
};
|
|
}, []);
|
|
|
|
return isDocumentVisible;
|
|
}
|