import { useCallback, useState } from "react"; import CameraImage from "./CameraImage"; type AutoUpdatingCameraImageProps = { camera: string; searchParams?: {}; showFps?: boolean; className?: string; reloadInterval?: number; }; const MIN_LOAD_TIMEOUT_MS = 200; export default function AutoUpdatingCameraImage({ camera, searchParams = "", showFps = true, className, reloadInterval = MIN_LOAD_TIMEOUT_MS, }: AutoUpdatingCameraImageProps) { const [key, setKey] = useState(Date.now()); const [fps, setFps] = useState("0"); const handleLoad = useCallback(() => { const loadTime = Date.now() - key; if (showFps) { setFps((1000 / Math.max(loadTime, reloadInterval)).toFixed(1)); } setTimeout( () => { setKey(Date.now()); }, loadTime > reloadInterval ? 1 : reloadInterval ); }, [key, setFps]); return (
{showFps ? Displaying at {fps}fps : null}
); }