ff-admin/src/stores/admin/club/member/member.ts

94 lines
3.3 KiB
TypeScript
Raw Normal View History

2024-09-16 19:03:52 +02:00
import { defineStore } from "pinia";
2025-01-02 18:28:13 +01:00
import type { CreateMemberViewModel, UpdateMemberViewModel } from "@/viewmodels/admin/club/member/member.models";
2024-09-17 16:44:02 +02:00
import { http } from "@/serverCom";
2024-09-16 19:03:52 +02:00
import type { AxiosResponse } from "axios";
2025-01-02 18:28:13 +01:00
import type { MemberViewModel } from "@/viewmodels/admin/club/member/member.models";
2024-09-16 19:03:52 +02:00
export const useMemberStore = defineStore("member", {
state: () => {
return {
members: [] as Array<MemberViewModel & { tab_pos: number }>,
totalCount: 0 as number,
loading: "loading" as "loading" | "fetched" | "failed",
2024-09-17 16:44:02 +02:00
activeMember: null as number | null,
activeMemberObj: null as MemberViewModel | null,
loadingActive: "loading" as "loading" | "fetched" | "failed",
2024-09-16 19:03:52 +02:00
};
},
actions: {
2025-01-03 15:20:27 +01:00
fetchMembers(offset = 0, count = 25, search = "", clear = false) {
2024-09-16 19:03:52 +02:00
if (clear) this.members = [];
this.loading = "loading";
http
2025-01-03 15:20:27 +01:00
.get(`/admin/member?offset=${offset}&count=${count}${search != "" ? "&search=" + search : ""}`)
2024-09-16 19:03:52 +02:00
.then((result) => {
this.totalCount = result.data.total;
result.data.members
.filter((elem: MemberViewModel) => this.members.findIndex((m) => m.id == elem.id) == -1)
.map((elem: MemberViewModel, index: number): MemberViewModel & { tab_pos: number } => {
return {
...elem,
tab_pos: index + offset,
};
})
.forEach((elem: MemberViewModel & { tab_pos: number }) => {
this.members.push(elem);
});
this.loading = "fetched";
})
.catch((err) => {
this.loading = "failed";
});
},
2024-09-17 16:44:02 +02:00
fetchMemberByActiveId() {
this.loadingActive = "loading";
http
.get(`/admin/member/${this.activeMember}`)
.then((res) => {
this.activeMemberObj = res.data;
this.loadingActive = "fetched";
})
.catch((err) => {
this.loadingActive = "failed";
});
},
fetchMemberById(id: number) {
return http.get(`/admin/member/${id}`);
},
async createMember(member: CreateMemberViewModel): Promise<AxiosResponse<any, any>> {
const result = await http.post(`/admin/member`, {
salutation: member.salutation,
firstname: member.firstname,
lastname: member.lastname,
nameaffix: member.nameaffix,
birthdate: member.birthdate,
2025-01-02 17:08:43 +01:00
internalId: member.internalId,
2024-09-17 16:44:02 +02:00
});
this.fetchMembers();
return result;
},
async updateActiveMember(member: UpdateMemberViewModel): Promise<AxiosResponse<any, any>> {
const result = await http.patch(`/admin/member/${member.id}`, {
salutation: member.salutation,
firstname: member.firstname,
lastname: member.lastname,
nameaffix: member.nameaffix,
birthdate: member.birthdate,
2025-01-02 17:08:43 +01:00
internalId: member.internalId,
2024-09-17 16:44:02 +02:00
});
this.fetchMembers();
return result;
},
async deleteMember(member: number): Promise<AxiosResponse<any, any>> {
const result = await http.delete(`/admin/member/${member}`);
this.fetchMembers();
return result;
},
2025-01-05 13:43:13 +01:00
async printMemberList(){
return http.get(`/admin/member/print/namelist`, {
responseType: "blob",
});
}
2024-09-16 19:03:52 +02:00
},
});