Files
BayIQ-UI/src/features/dashboard/components/DashboardGrid.tsx

59 lines
1.9 KiB
TypeScript
Raw Normal View History

import type { SystemHealthStatus } from "../../../types/types";
import { useGetSystemHealth } from "../hooks/useGetSystemHealth";
import CameraStatus from "./CameraStatus";
2025-11-24 14:54:05 +00:00
import SystemOverview from "./SystemOverview";
2025-11-20 19:09:43 +00:00
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 ?? [];
2025-11-20 19:09:43 +00:00
return (
2025-11-24 14:54:05 +00:00
<div className="grid grid-cols-1 md:grid-rows-2 md:grid-cols-2">
2025-11-20 19:09:43 +00:00
<SystemStatusCard />
<SystemOverview
startTime={startTime}
uptime={uptime}
statuses={statuses}
isLoading={isLoading}
isError={isError}
dateUpdatedAt={dateUpdatedAt}
refetch={refetch}
/>
2025-11-24 16:17:27 +00:00
<div className="grid grid-cols-1 md:col-span-2 md:grid-cols-3">
<CameraStatus title="Camera A" category={categoryA} />
<CameraStatus title="Camera B" category={categoryB} />
<CameraStatus title="Camera C" category={categoryC} />
2025-11-24 16:17:27 +00:00
</div>
2025-11-20 19:09:43 +00:00
</div>
);
};
export default DashboardGrid;