- Enhance layout and responsiveness of camera components #12
@@ -9,7 +9,7 @@ const CameraGrid = () => {
|
|||||||
const [tabIndex, setTabIndex] = useState(0);
|
const [tabIndex, setTabIndex] = useState(0);
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<div className="grid grid-cols-1 md:grid-cols-5 md:grid-rows-5 max-h-screen">
|
<div className="flex flex-col gap-4 p-4 md:grid md:grid-cols-5 md:grid-rows-5 md:max-h-screen md:gap-0 md:p-0">
|
||||||
<VideoFeedGridPainter />
|
<VideoFeedGridPainter />
|
||||||
<CameraSettings tabIndex={tabIndex} setTabIndex={setTabIndex} />
|
<CameraSettings tabIndex={tabIndex} setTabIndex={setTabIndex} />
|
||||||
<PlatePatch />
|
<PlatePatch />
|
||||||
|
|||||||
@@ -10,7 +10,7 @@ type CameraSettingsProps = {
|
|||||||
|
|
||||||
const CameraSettings = ({ tabIndex, setTabIndex }: CameraSettingsProps) => {
|
const CameraSettings = ({ tabIndex, setTabIndex }: CameraSettingsProps) => {
|
||||||
return (
|
return (
|
||||||
<Card className="p-4 col-span-2 row-span-5 col-start-3 md:col-span-3 md:row-span-5 overflow-auto">
|
<Card className="p-4 w-full overflow-auto md:col-span-2 md:row-span-5 md:col-start-4 md:row-start-1">
|
||||||
<Tabs
|
<Tabs
|
||||||
selectedTabClassName="bg-gray-300 text-gray-900 font-semibold border-none rounded-sm mb-1"
|
selectedTabClassName="bg-gray-300 text-gray-900 font-semibold border-none rounded-sm mb-1"
|
||||||
className="react-tabs"
|
className="react-tabs"
|
||||||
|
|||||||
@@ -19,14 +19,6 @@ const RegionSelector = ({ regions, selectedRegionIndex, mode, cameraFeedID }: Re
|
|||||||
dispatch({ type: "CHANGE_MODE", payload: { cameraFeedID: cameraFeedID, mode: e.target.value } });
|
dispatch({ type: "CHANGE_MODE", payload: { cameraFeedID: cameraFeedID, mode: e.target.value } });
|
||||||
};
|
};
|
||||||
|
|
||||||
const handleAddRegionClick = () => {
|
|
||||||
const regionName = `Region ${regions.length + 1}`;
|
|
||||||
dispatch({
|
|
||||||
type: "ADD_NEW_REGION",
|
|
||||||
payload: { cameraFeedID: cameraFeedID, regionName: regionName, brushColour: "#ffffff" },
|
|
||||||
});
|
|
||||||
};
|
|
||||||
|
|
||||||
const handleResetRegion = () => {
|
const handleResetRegion = () => {
|
||||||
dispatch({
|
dispatch({
|
||||||
type: "RESET_PAINTED_CELLS",
|
type: "RESET_PAINTED_CELLS",
|
||||||
@@ -34,13 +26,6 @@ const RegionSelector = ({ regions, selectedRegionIndex, mode, cameraFeedID }: Re
|
|||||||
});
|
});
|
||||||
};
|
};
|
||||||
|
|
||||||
const handleRemoveClick = () => {
|
|
||||||
dispatch({
|
|
||||||
type: "REMOVE_REGION",
|
|
||||||
payload: { cameraFeedID: cameraFeedID, regionName: regions[selectedRegionIndex].name },
|
|
||||||
});
|
|
||||||
};
|
|
||||||
|
|
||||||
const handleModeChange = (newMode: string) => {
|
const handleModeChange = (newMode: string) => {
|
||||||
dispatch({ type: "CHANGE_MODE", payload: { cameraFeedID: cameraFeedID, mode: newMode } });
|
dispatch({ type: "CHANGE_MODE", payload: { cameraFeedID: cameraFeedID, mode: newMode } });
|
||||||
};
|
};
|
||||||
@@ -177,14 +162,6 @@ const RegionSelector = ({ regions, selectedRegionIndex, mode, cameraFeedID }: Re
|
|||||||
);
|
);
|
||||||
})}
|
})}
|
||||||
</>
|
</>
|
||||||
<div className=" mx-auto flex flex-row gap-4 mt-4">
|
|
||||||
<button className="border border-blue-900 bg-blue-700 px-4 py-1 rounded-md" onClick={handleAddRegionClick}>
|
|
||||||
Add Region
|
|
||||||
</button>
|
|
||||||
<button className="border border-red-900 bg-red-700 px-4 py-1 rounded-md" onClick={handleRemoveClick}>
|
|
||||||
Remove Region
|
|
||||||
</button>
|
|
||||||
</div>
|
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div className="p-2 border border-gray-600 rounded-lg flex flex-col md:col-span-2 h-50">
|
<div className="p-2 border border-gray-600 rounded-lg flex flex-col md:col-span-2 h-50">
|
||||||
|
|||||||
@@ -6,7 +6,7 @@ import SightingExitTable from "./SightingExitTable";
|
|||||||
|
|
||||||
const PlatePatch = () => {
|
const PlatePatch = () => {
|
||||||
return (
|
return (
|
||||||
<Card className="md:row-start-4 md:col-span-2 p-4 h-[190%]">
|
<Card className="p-4 w-full md:w-[95%] md:row-start-4 md:col-span-3 md:h-[190%]">
|
||||||
<CardHeader title="Entry / Exit" />
|
<CardHeader title="Entry / Exit" />
|
||||||
<Tabs>
|
<Tabs>
|
||||||
<TabList>
|
<TabList>
|
||||||
|
|||||||
@@ -93,7 +93,7 @@ const VideoFeedGridPainter = () => {
|
|||||||
const width = window.innerWidth;
|
const width = window.innerWidth;
|
||||||
|
|
||||||
const aspectRatio = BACKEND_WIDTH / BACKEND_HEIGHT;
|
const aspectRatio = BACKEND_WIDTH / BACKEND_HEIGHT;
|
||||||
const newWidth = width * 0.39;
|
const newWidth = width * 0.55;
|
||||||
const newHeight = newWidth / aspectRatio;
|
const newHeight = newWidth / aspectRatio;
|
||||||
setStageSize({ width: newWidth, height: newHeight });
|
setStageSize({ width: newWidth, height: newHeight });
|
||||||
};
|
};
|
||||||
@@ -107,7 +107,7 @@ const VideoFeedGridPainter = () => {
|
|||||||
if (image === null || isloading) return <span className="text-slate-500">Loading Video feed…</span>;
|
if (image === null || isloading) return <span className="text-slate-500">Loading Video feed…</span>;
|
||||||
return (
|
return (
|
||||||
<div
|
<div
|
||||||
className={`mt-4.5 row-span-1 col-span-2 ${mode === "painter" ? "hover:cursor-crosshair" : ""} ${
|
className={`w-full md:row-span-3 md:col-span-3 ${mode === "painter" ? "hover:cursor-crosshair" : ""} ${
|
||||||
mode === "eraser" ? "hover:cursor-pointer" : ""
|
mode === "eraser" ? "hover:cursor-pointer" : ""
|
||||||
}`}
|
}`}
|
||||||
>
|
>
|
||||||
|
|||||||
@@ -38,7 +38,7 @@ const SystemHealth = ({ startTime, uptime, statuses, isLoading, isError, dateUpd
|
|||||||
return <span className="text-slate-500">Loading system health…</span>;
|
return <span className="text-slate-500">Loading system health…</span>;
|
||||||
}
|
}
|
||||||
return (
|
return (
|
||||||
<div className="h-100 md:h-75 overflow-y-auto flex flex-col gap-4">
|
<div className="relative h-100 md:h-75 overflow-y-auto flex flex-col gap-4">
|
||||||
<div className="p-2 border-b border-gray-600 grid grid-cols-2 justify-between">
|
<div className="p-2 border-b border-gray-600 grid grid-cols-2 justify-between">
|
||||||
<div className="flex flex-col border border-gray-600 p-4 rounded-lg mr-4 hover:bg-[#233241]">
|
<div className="flex flex-col border border-gray-600 p-4 rounded-lg mr-4 hover:bg-[#233241]">
|
||||||
<h3 className="text-lg">Start Time</h3> <span className="text-slate-300">{startTime}</span>
|
<h3 className="text-lg">Start Time</h3> <span className="text-slate-300">{startTime}</span>
|
||||||
@@ -50,8 +50,8 @@ const SystemHealth = ({ startTime, uptime, statuses, isLoading, isError, dateUpd
|
|||||||
<div className="overflow-auto gap-4">
|
<div className="overflow-auto gap-4">
|
||||||
<StatusGridItem title={"Modules"} statusCategory={categoryDefault} />
|
<StatusGridItem title={"Modules"} statusCategory={categoryDefault} />
|
||||||
</div>
|
</div>
|
||||||
<div className="border-t border-gray-500">
|
<div className="absolute bottom-0 left-0 border-t border-gray-500 w-full">
|
||||||
<small className="italic text-gray-400">{`Last refeshed ${updatedDate}`}</small>
|
<small className="italic text-gray-400 ">{`Last refeshed ${updatedDate}`}</small>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
);
|
);
|
||||||
|
|||||||
@@ -11,6 +11,7 @@ export const useGetSystemHealth = () => {
|
|||||||
const query = useQuery({
|
const query = useQuery({
|
||||||
queryKey: ["fetchSystemData"],
|
queryKey: ["fetchSystemData"],
|
||||||
queryFn: fetchData,
|
queryFn: fetchData,
|
||||||
|
refetchInterval: 300000,
|
||||||
});
|
});
|
||||||
return { query };
|
return { query };
|
||||||
};
|
};
|
||||||
|
|||||||
Reference in New Issue
Block a user