- added download button

- added reads for number plate sightings
This commit is contained in:
2025-12-03 10:46:36 +00:00
parent 2a4afc7eae
commit f7964d4fc0
5 changed files with 151 additions and 4 deletions

View File

@@ -0,0 +1,50 @@
import { faDownload } from "@fortawesome/free-solid-svg-icons";
import { FontAwesomeIcon } from "@fortawesome/react-fontawesome";
import { useDownloadLogFiles } from "../../../hooks/useDownloadLogFiles";
import { toast } from "sonner";
const DownloadLogButton = () => {
const { downloadLogFilesQuery } = useDownloadLogFiles();
const isLoading = downloadLogFilesQuery?.isFetching;
const handleDownloadClick = async () => {
try {
const blob = await downloadLogFilesQuery?.refetch().then((res) => res.data);
if (!blob) {
throw new Error("No log file data received");
}
const url = window.URL.createObjectURL(new Blob([blob]));
const link = document.createElement("a");
if (!link) {
throw new Error("Failed to create download link");
} else {
link.href = url;
link.setAttribute("download", "FlexiAI-0.log");
document.body.appendChild(link);
link.click();
link.parentNode?.removeChild(link);
window.URL.revokeObjectURL(url);
}
} catch (error: unknown) {
const errorMessage = error instanceof Error ? error.message : "Unknown error occurred";
toast.error(errorMessage);
}
};
return (
<button
className="p-3 border border-gray-700 rounded-lg hover:bg-[#233241] hover:cursor-pointer"
onClick={handleDownloadClick}
>
<div className="flex flex-row gap-2 items-center">
<span className="font-bold text-xl bg-slate-700 p-1 px-2 rounded-md">
<FontAwesomeIcon icon={faDownload} />
</span>
<p className="text-lg">{"Download Log Files"}</p>
</div>
<p className="text-slate-400 italic text-start">{isLoading ? "Downloading..." : "View logs"}</p>
</button>
);
};
export default DownloadLogButton;

View File

@@ -0,0 +1,48 @@
import { FontAwesomeIcon } from "@fortawesome/react-fontawesome";
import { faChartSimple } from "@fortawesome/free-solid-svg-icons";
type StatusReadsProps = {
reads: {
totalPending: number;
totalActive: number;
totalSent: number;
totalReceived: number;
totalLost: number;
sanityCheck: boolean;
sanityCheckFormula: string;
};
isReadsLoading?: boolean;
};
const StatusReads = ({ reads, isReadsLoading }: StatusReadsProps) => {
const totalPending = reads?.totalPending ?? 0;
const totalActive = reads?.totalActive ?? 0;
const totalSent = reads?.totalSent ?? 0;
const totalLost = reads?.totalLost ?? 0;
const totalReceived = reads?.totalReceived ?? 0;
if (isReadsLoading) {
return <p className="text-slate-400">Loading reads</p>;
}
return (
<div className="p-3 border border-gray-700 rounded-lg hover:bg-[#233241]">
<div className="flex flex-row gap-2 items-center">
<span className="font-bold text-xl bg-slate-700 p-1 px-2 rounded-md">
<FontAwesomeIcon icon={faChartSimple} />
</span>
<p className="text-lg">Reads</p>
</div>
<div className="text-slate-400 mt-1">
Pending: <span className="text-yellow-500">{totalPending}</span> | Active:{" "}
<span className="text-cyan-500">{totalActive}</span> | Lost: <span className="text-red-500">{totalLost}</span>
<br />
Sent / Received: <span className="text-blue-500">{totalSent}</span> |{" "}
<span className="text-green-500">{totalReceived}</span>
</div>
</div>
);
};
export default StatusReads;