mirror of
https://github.com/karl0ss/homepage.git
synced 2025-04-29 12:03:41 +01:00
27 lines
633 B
JavaScript
27 lines
633 B
JavaScript
![]() |
import { useState, useEffect } from "react";
|
||
|
|
||
|
const hasFocus = () => typeof document !== "undefined" && document.hasFocus();
|
||
|
|
||
|
const useWindowFocus = () => {
|
||
|
const [focused, setFocused] = useState(hasFocus);
|
||
|
|
||
|
useEffect(() => {
|
||
|
setFocused(hasFocus());
|
||
|
|
||
|
const onFocus = () => setFocused(true);
|
||
|
const onBlur = () => setFocused(false);
|
||
|
|
||
|
window.addEventListener("focus", onFocus);
|
||
|
window.addEventListener("blur", onBlur);
|
||
|
|
||
|
return () => {
|
||
|
window.removeEventListener("focus", onFocus);
|
||
|
window.removeEventListener("blur", onBlur);
|
||
|
};
|
||
|
}, []);
|
||
|
|
||
|
return focused;
|
||
|
};
|
||
|
|
||
|
export default useWindowFocus;
|