import { useCallback, useState } from "react"; import CameraImage from "./CameraImage"; type AutoUpdatingCameraImageProps = { camera: string; searchParams?: {}; showFps?: boolean; className?: string; }; const MIN_LOAD_TIMEOUT_MS = 200; export default function AutoUpdatingCameraImage({ camera, searchParams = "", showFps = true, className, }: 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, MIN_LOAD_TIMEOUT_MS)).toFixed(1)); } setTimeout( () => { setKey(Date.now()); }, loadTime > MIN_LOAD_TIMEOUT_MS ? 1 : MIN_LOAD_TIMEOUT_MS ); }, [key, setFps]); return (
{showFps ? Displaying at {fps}fps : null}
); }