import { useEffect, useRef } from "react"; /** * Custom hook for polling a function call at specified intervals. * * @param callback - The function to be called repeatedly. * @param interval - The interval in milliseconds between each call. */ const usePolling = (callback: () => void, interval: number): void => { const savedCallback = useRef<() => void>(); // Remember the latest callback. useEffect(() => { savedCallback.current = callback; }, [callback]); // Set up the interval. useEffect(() => { const tick = () => { savedCallback.current?.(); }; if (interval !== null) { const id = setInterval(tick, interval); return () => clearInterval(id); } }, [interval]); }; export default usePolling;