From 96529917c961e821ab22d777e6a0daa1eecfc8ef Mon Sep 17 00:00:00 2001
From: casperiv0 <53900565+casperiv0@users.noreply.github.com>
Date: Wed, 11 Oct 2023 07:24:17 +0200
Subject: [PATCH] feat: show stats for record (closes #1835)
---
apps/client/locales/en/leo.json | 3 +-
.../leo/citizen-logs/arrest-reports-tab.tsx | 3 ++
.../components/leo/records-stats-column.tsx | 45 +++++++++++++++++++
.../supervisor/citizen-logs/[citizenId].tsx | 3 ++
4 files changed, 53 insertions(+), 1 deletion(-)
create mode 100644 apps/client/src/components/leo/records-stats-column.tsx
diff --git a/apps/client/locales/en/leo.json b/apps/client/locales/en/leo.json
index a9f5cb8fb..5ef9306af 100644
--- a/apps/client/locales/en/leo.json
+++ b/apps/client/locales/en/leo.json
@@ -385,7 +385,8 @@
"arrestReportLogs": "Arrest report logs",
"all": "All",
"ungrouped": "Ungrouped",
- "counts": "Counts"
+ "counts": "Counts",
+ "stats": "Stats"
},
"Bolos": {
"activeBolos": "Active Bolos",
diff --git a/apps/client/src/components/leo/citizen-logs/arrest-reports-tab.tsx b/apps/client/src/components/leo/citizen-logs/arrest-reports-tab.tsx
index 48bf4454e..a587dfa90 100644
--- a/apps/client/src/components/leo/citizen-logs/arrest-reports-tab.tsx
+++ b/apps/client/src/components/leo/citizen-logs/arrest-reports-tab.tsx
@@ -24,6 +24,7 @@ import type {
} from "@snailycad/types/api";
import { useQuery } from "@tanstack/react-query";
import { RecordsCaseNumberColumn } from "../records-case-number-column";
+import { RecordsStatsColumn } from "../records-stats-column";
interface Props {
arrestReports: GetManagePendingArrestReports;
@@ -134,6 +135,7 @@ export function PendingCitizenRecordsTab({ arrestReports }: Props) {
{record.notes}
),
+ stats: ,
violations: ,
createdAt: createdAt ? {createdAt} : "—",
status: {record.status},
@@ -172,6 +174,7 @@ export function PendingCitizenRecordsTab({ arrestReports }: Props) {
{ header: t("postal"), accessorKey: "postal" },
{ header: t("status"), accessorKey: "status" },
{ header: t("notes"), accessorKey: "notes" },
+ { header: t("notes"), accessorKey: "stats" },
{ header: t("violations"), accessorKey: "violations" },
{ header: common("createdAt"), accessorKey: "createdAt" },
{ header: common("actions"), accessorKey: "actions" },
diff --git a/apps/client/src/components/leo/records-stats-column.tsx b/apps/client/src/components/leo/records-stats-column.tsx
new file mode 100644
index 000000000..ddd348b69
--- /dev/null
+++ b/apps/client/src/components/leo/records-stats-column.tsx
@@ -0,0 +1,45 @@
+import { Record, Violation } from "@snailycad/types";
+import { useTranslations } from "use-intl";
+
+interface Props {
+ record: Record;
+}
+
+function sumOf(violations: Violation[], type: "fine" | "jailTime" | "bail"): number {
+ let sum = 0;
+
+ for (const violation of violations) {
+ const counts = violation.counts || 1;
+ const fine = violation[type];
+
+ if (fine) {
+ sum += fine * counts;
+ }
+ }
+
+ return sum;
+}
+
+function formatSum(sum: number) {
+ return Intl.NumberFormat().format(sum);
+}
+
+export function RecordsStatsColumn(props: Props) {
+ const totalBail = formatSum(sumOf(props.record.violations, "bail"));
+ const totalJail = formatSum(sumOf(props.record.violations, "jailTime"));
+ const totalFines = formatSum(sumOf(props.record.violations, "fine"));
+ const t = useTranslations("Leo");
+ const common = useTranslations("Common");
+
+ return (
+ <>
+ {t("fines")}: {common("currency")}
+ {totalFines}
+
+ {t("jail")}: {totalJail}
+
+ {t("bail")}: {common("currency")}
+ {totalBail}
+ >
+ );
+}
diff --git a/apps/client/src/pages/officer/supervisor/citizen-logs/[citizenId].tsx b/apps/client/src/pages/officer/supervisor/citizen-logs/[citizenId].tsx
index 40bd4e4d2..0138d386e 100644
--- a/apps/client/src/pages/officer/supervisor/citizen-logs/[citizenId].tsx
+++ b/apps/client/src/pages/officer/supervisor/citizen-logs/[citizenId].tsx
@@ -16,6 +16,7 @@ import Link from "next/link";
import { FullDate, Status, buttonVariants } from "@snailycad/ui";
import { ArrowLeft } from "react-bootstrap-icons";
import { RecordsCaseNumberColumn } from "components/leo/records-case-number-column";
+import { RecordsStatsColumn } from "components/leo/records-stats-column";
export type CitizenLog = RecordLog & { citizen: Citizen };
interface Props {
@@ -79,6 +80,7 @@ export default function CitizenLogs(props: Props) {
status: {item.records.status},
postal: item.records.postal || common("none"),
notes: item.records.notes || common("none"),
+ stats: ,
violations: ,
paymentStatus: {item.records.paymentStatus},
}
@@ -107,6 +109,7 @@ export default function CitizenLogs(props: Props) {
{ header: t("postal"), accessorKey: "postal" },
{ header: t("status"), accessorKey: "status" },
{ header: t("paymentStatus"), accessorKey: "paymentStatus" },
+ { header: t("stats"), accessorKey: "stats" },
{ header: t("notes"), accessorKey: "notes" },
{ header: t("violations"), accessorKey: "violations" },
{ header: common("createdAt"), accessorKey: "createdAt" },