ff-admin/src/stores/admin/unit/equipment/damageReport.ts

44 lines
1.6 KiB
TypeScript
Raw Normal View History

2025-05-14 09:13:47 +02:00
import { defineStore } from "pinia";
import { http } from "@/serverCom";
import { useEquipmentStore } from "./equipment";
2025-06-04 12:49:42 +02:00
import type { DamageReportViewModel } from "@/viewmodels/admin/unit/damageReport.models";
2025-05-14 09:13:47 +02:00
export const useEquipmentDamageReportStore = defineStore("equipmentDamageReport", {
state: () => {
return {
damageReports: [] as Array<DamageReportViewModel & { tab_pos: number }>,
totalCount: 0 as number,
loading: "loading" as "loading" | "fetched" | "failed",
};
},
actions: {
fetchDamageReportForEquipment(offset = 0, count = 25, search = "", clear = false) {
const equipmentId = useEquipmentStore().activeEquipment;
if (clear) this.damageReports = [];
this.loading = "loading";
http
.get(
2025-06-04 14:30:41 +02:00
`/admin/damagereport/equipment/${equipmentId}?offset=${offset}&count=${count}${search != "" ? "&search=" + search : ""}`
2025-05-14 09:13:47 +02:00
)
.then((result) => {
this.totalCount = result.data.total;
2025-05-14 14:42:00 +02:00
result.data.reports
2025-05-14 09:13:47 +02:00
.filter((elem: DamageReportViewModel) => this.damageReports.findIndex((m) => m.id == elem.id) == -1)
.map((elem: DamageReportViewModel, index: number): DamageReportViewModel & { tab_pos: number } => {
return {
...elem,
tab_pos: index + offset,
};
})
.forEach((elem: DamageReportViewModel & { tab_pos: number }) => {
this.damageReports.push(elem);
});
this.loading = "fetched";
})
.catch((err) => {
this.loading = "failed";
});
},
},
});