basic member pagination
This commit is contained in:
parent
6f13cdc297
commit
c1a6c0040d
12 changed files with 302 additions and 5 deletions
43
src/stores/admin/member.ts
Normal file
43
src/stores/admin/member.ts
Normal file
|
@ -0,0 +1,43 @@
|
|||
import { defineStore } from "pinia";
|
||||
import type { CreateAwardViewModel, UpdateAwardViewModel, AwardViewModel } from "../../viewmodels/admin/award.models";
|
||||
import { http } from "../../serverCom";
|
||||
import type { AxiosResponse } from "axios";
|
||||
import type { MemberViewModel } from "../../viewmodels/admin/member.models";
|
||||
|
||||
export const useMemberStore = defineStore("member", {
|
||||
state: () => {
|
||||
return {
|
||||
members: [] as Array<MemberViewModel & { tab_pos: number }>,
|
||||
totalCount: 0 as number,
|
||||
loading: "loading" as "loading" | "fetched" | "failed",
|
||||
activeMember: null as null | MemberViewModel,
|
||||
};
|
||||
},
|
||||
actions: {
|
||||
fetchMembers(offset = 0, count = 25, clear = false) {
|
||||
if (clear) this.members = [];
|
||||
this.loading = "loading";
|
||||
http
|
||||
.get(`/admin/member?offset=${offset}&count=${count}`)
|
||||
.then((result) => {
|
||||
this.members = result.data.members;
|
||||
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";
|
||||
});
|
||||
},
|
||||
},
|
||||
});
|
|
@ -54,7 +54,7 @@ export const useNavigationStore = defineStore("navigation", {
|
|||
{
|
||||
key: "club",
|
||||
title: "Verein",
|
||||
levelDefault: "members",
|
||||
levelDefault: "member",
|
||||
} as topLevelNavigationModel,
|
||||
]
|
||||
: []),
|
||||
|
@ -86,7 +86,7 @@ export const useNavigationStore = defineStore("navigation", {
|
|||
club: {
|
||||
mainTitle: "Verein",
|
||||
main: [
|
||||
...(abilityStore.can("read", "club", "members") ? [{ key: "members", title: "Mitglieder" }] : []),
|
||||
...(abilityStore.can("read", "club", "member") ? [{ key: "member", title: "Mitglieder" }] : []),
|
||||
...(abilityStore.can("read", "club", "calendar") ? [{ key: "calendar", title: "Termine" }] : []),
|
||||
...(abilityStore.can("read", "club", "newsletter") ? [{ key: "newsletter", title: "Newsletter" }] : []),
|
||||
...(abilityStore.can("read", "club", "protocoll") ? [{ key: "protocol", title: "Protokolle" }] : []),
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue