moonlight-relay-server/src/hooks/useStatus.ts

31 lines
915 B
TypeScript
Raw Normal View History

2026-03-31 15:30:00 -04:00
import { useEffect, useState, useCallback } from "react";
import { api, AppStatus, Host } from "../api";
export function useStatus(pollMs = 3000) {
const [status, setStatus] = useState<AppStatus | null>(null);
const [hosts, setHosts] = useState<Host[]>([]);
const [error, setError] = useState<string | null>(null);
const [loading, setLoading] = useState(true);
const refresh = useCallback(async () => {
try {
const [s, h] = await Promise.all([api.getStatus(), api.getHosts()]);
setStatus(s);
setHosts(h);
setError(null);
} catch (e: unknown) {
setError(e instanceof Error ? e.message : "Backend unreachable");
} finally {
setLoading(false);
}
}, []);
useEffect(() => {
refresh();
const id = setInterval(refresh, pollMs);
return () => clearInterval(id);
}, [refresh, pollMs]);
return { status, hosts, error, loading, refresh };
}