import { h, Fragment } from 'preact'; import ActivityIndicator from '../components/ActivityIndicator'; import Button from '../components/Button'; import Heading from '../components/Heading'; import Link from '../components/Link'; import { useMqtt } from '../api/mqtt'; import { useConfig, useStats } from '../api'; import { Table, Tbody, Thead, Tr, Th, Td } from '../components/Table'; import { useCallback } from 'preact/hooks'; const emptyObject = Object.freeze({}); export default function Debug() { const { data: config } = useConfig(); const { value: { payload: stats }, } = useMqtt('stats'); const { data: initialStats } = useStats(); const { detectors, service = {}, detection_fps, ...cameras } = stats || initialStats || emptyObject; const detectorNames = Object.keys(detectors || emptyObject); const detectorDataKeys = Object.keys(detectors ? detectors[detectorNames[0]] : emptyObject); const cameraNames = Object.keys(cameras || emptyObject); const cameraDataKeys = Object.keys(cameras[cameraNames[0]] || emptyObject); const handleCopyConfig = useCallback(() => { async function copy() { await window.navigator.clipboard.writeText(JSON.stringify(config, null, 2)); } copy(); }, [config]); return (
Debug {service.version} {!detectors ? (
) : (
{detectorDataKeys.map((name) => ( ))} {detectorNames.map((detector, i) => ( {detectorDataKeys.map((name) => ( ))} ))}
detector{name.replace('_', ' ')}
{detector}{detectors[detector][name]}
{cameraDataKeys.map((name) => ( ))} {cameraNames.map((camera, i) => ( {cameraDataKeys.map((name) => ( ))} ))}
camera{name.replace('_', ' ')}
{camera} {cameras[camera][name]}

Debug stats update automatically every {config.mqtt.stats_interval} seconds.

)}
Config
          {JSON.stringify(config, null, 2)}
        
); }