mirror of
https://github.com/rive-app/rive-react.git
synced 2026-03-13 08:22:30 +08:00
25 lines
617 B
TypeScript
25 lines
617 B
TypeScript
import { useState, useEffect } from 'react';
|
|
import { Dimensions } from './types';
|
|
|
|
export function useWindowSize() {
|
|
const [windowSize, setWindowSize] = useState<Dimensions>({
|
|
width: 0,
|
|
height: 0,
|
|
});
|
|
|
|
useEffect(() => {
|
|
if (typeof window !== 'undefined') {
|
|
const handleResize = () => {
|
|
setWindowSize({
|
|
width: window.innerWidth,
|
|
height: window.innerHeight,
|
|
});
|
|
};
|
|
window.addEventListener('resize', handleResize);
|
|
handleResize();
|
|
return () => window.removeEventListener('resize', handleResize);
|
|
}
|
|
}, []);
|
|
return windowSize;
|
|
}
|