2020-10-09 15:26:37 +02:00
|
|
|
import { PERSON_MEMBERSHIPS, CURRENT_ACTOR_CLIENT } from "@/graphql/actor";
|
|
|
|
import { FETCH_GROUP } from "@/graphql/group";
|
2020-10-12 12:16:36 +02:00
|
|
|
import RouteName from "@/router/name";
|
2020-10-09 15:26:37 +02:00
|
|
|
import { Group, IActor, IGroup, IPerson, MemberRole } from "@/types/actor";
|
|
|
|
import { Component, Vue } from "vue-property-decorator";
|
|
|
|
|
|
|
|
@Component({
|
|
|
|
apollo: {
|
|
|
|
group: {
|
|
|
|
query: FETCH_GROUP,
|
|
|
|
fetchPolicy: "cache-and-network",
|
|
|
|
variables() {
|
|
|
|
return {
|
|
|
|
name: this.$route.params.preferredUsername,
|
|
|
|
};
|
|
|
|
},
|
|
|
|
skip() {
|
|
|
|
return !this.$route.params.preferredUsername;
|
|
|
|
},
|
2020-10-12 12:16:36 +02:00
|
|
|
error({ graphQLErrors }) {
|
|
|
|
this.handleErrors(graphQLErrors);
|
|
|
|
},
|
2020-10-09 15:26:37 +02:00
|
|
|
},
|
|
|
|
person: {
|
|
|
|
query: PERSON_MEMBERSHIPS,
|
|
|
|
fetchPolicy: "cache-and-network",
|
|
|
|
variables() {
|
|
|
|
return {
|
|
|
|
id: this.currentActor.id,
|
|
|
|
};
|
|
|
|
},
|
|
|
|
skip() {
|
|
|
|
return !this.currentActor || !this.currentActor.id;
|
|
|
|
},
|
|
|
|
},
|
|
|
|
currentActor: CURRENT_ACTOR_CLIENT,
|
|
|
|
},
|
|
|
|
})
|
|
|
|
export default class GroupMixin extends Vue {
|
|
|
|
group: IGroup = new Group();
|
2020-10-15 14:23:55 +02:00
|
|
|
|
2020-10-09 15:26:37 +02:00
|
|
|
currentActor!: IActor;
|
|
|
|
|
|
|
|
person!: IPerson;
|
|
|
|
|
|
|
|
get isCurrentActorAGroupAdmin(): boolean {
|
2020-10-22 09:37:30 +02:00
|
|
|
return this.hasCurrentActorThisRole(MemberRole.ADMINISTRATOR);
|
|
|
|
}
|
|
|
|
|
|
|
|
get isCurrentActorAGroupModerator(): boolean {
|
|
|
|
return this.hasCurrentActorThisRole([MemberRole.MODERATOR, MemberRole.ADMINISTRATOR]);
|
|
|
|
}
|
|
|
|
|
|
|
|
hasCurrentActorThisRole(givenRole: string | string[]): boolean {
|
|
|
|
const roles = Array.isArray(givenRole) ? givenRole : [givenRole];
|
2020-10-09 15:26:37 +02:00
|
|
|
return (
|
|
|
|
this.person &&
|
|
|
|
this.person.memberships.elements.some(
|
2020-10-22 09:37:30 +02:00
|
|
|
({ parent: { id }, role }) => id === this.group.id && roles.includes(role)
|
2020-10-09 15:26:37 +02:00
|
|
|
)
|
|
|
|
);
|
|
|
|
}
|
2020-10-12 12:16:36 +02:00
|
|
|
|
2020-10-15 14:23:55 +02:00
|
|
|
handleErrors(errors: any[]): void {
|
2020-10-12 12:16:36 +02:00
|
|
|
if (
|
|
|
|
errors.some((error) => error.status_code === 404) ||
|
|
|
|
errors.some(({ message }) => message.includes("has invalid value $uuid"))
|
|
|
|
) {
|
|
|
|
this.$router.replace({ name: RouteName.PAGE_NOT_FOUND });
|
|
|
|
}
|
|
|
|
}
|
2020-10-09 15:26:37 +02:00
|
|
|
}
|