- added new dashboard items
- added camera module statuses
This commit is contained in:
@@ -1,16 +1,55 @@
|
||||
import type { SystemHealthStatus } from "../../../types/types";
|
||||
import { useGetSystemHealth } from "../hooks/useGetSystemHealth";
|
||||
import CameraStatus from "./CameraStatus";
|
||||
import SystemOverview from "./SystemOverview";
|
||||
import SystemStatusCard from "./SystemStatusCard";
|
||||
|
||||
const DashboardGrid = () => {
|
||||
const { query } = useGetSystemHealth();
|
||||
const startTime = query?.data?.StartTimeHumane;
|
||||
const uptime = query?.data?.UptimeHumane;
|
||||
const statuses: SystemHealthStatus[] = query?.data?.Status;
|
||||
const isLoading = query?.isLoading;
|
||||
const isError = query?.isError;
|
||||
const dateUpdatedAt = query?.dataUpdatedAt;
|
||||
const refetch = query?.refetch;
|
||||
|
||||
const statusCategories = statuses?.reduce<Record<string, SystemHealthStatus[]>>(
|
||||
(acc, cur) => {
|
||||
if (cur?.groupID === "ChannelA") acc?.channelA?.push(cur);
|
||||
if (cur?.groupID === "ChannelB") acc?.channelB?.push(cur);
|
||||
if (cur?.groupID === "ChannelC") acc?.channelC?.push(cur);
|
||||
if (cur?.groupID === "Default") acc?.default?.push(cur);
|
||||
return acc;
|
||||
},
|
||||
{
|
||||
channelA: [],
|
||||
channelB: [],
|
||||
channelC: [],
|
||||
default: [],
|
||||
},
|
||||
);
|
||||
|
||||
const categoryA = statusCategories?.channelA ?? [];
|
||||
const categoryB = statusCategories?.channelB ?? [];
|
||||
const categoryC = statusCategories?.channelC ?? [];
|
||||
|
||||
return (
|
||||
<div className="grid grid-cols-1 md:grid-rows-2 md:grid-cols-2">
|
||||
<SystemStatusCard />
|
||||
<SystemOverview />
|
||||
<SystemOverview
|
||||
startTime={startTime}
|
||||
uptime={uptime}
|
||||
statuses={statuses}
|
||||
isLoading={isLoading}
|
||||
isError={isError}
|
||||
dateUpdatedAt={dateUpdatedAt}
|
||||
refetch={refetch}
|
||||
/>
|
||||
<div className="grid grid-cols-1 md:col-span-2 md:grid-cols-3">
|
||||
<CameraStatus title="Camera 1" status={"bg-red-500"} description={"Camera not responding"} />
|
||||
<CameraStatus title="Camera 2" status={"bg-gray-500"} description={"Camera Offline"} />
|
||||
<CameraStatus title="Camera 3" status={"bg-gray-500"} description={"Camera Offline"} />
|
||||
<CameraStatus title="Camera A" category={categoryA} />
|
||||
<CameraStatus title="Camera B" category={categoryB} />
|
||||
<CameraStatus title="Camera C" category={categoryC} />
|
||||
</div>
|
||||
</div>
|
||||
);
|
||||
|
||||
Reference in New Issue
Block a user