Allow to leave directly from the group

- Also handle error when you are the last admin
- Also change order from the dropdown menu

Signed-off-by: Thomas Citharel <tcit@tcit.fr>
This commit is contained in:
Thomas Citharel 2021-05-25 18:36:11 +02:00
parent 6e59c2cb95
commit 7e1409100f
No known key found for this signature in database
GPG key ID: A061B9DDE0CA0773
2 changed files with 66 additions and 21 deletions

View file

@ -102,8 +102,18 @@
@click="isReportModalActive = true" @click="isReportModalActive = true"
> >
<span> <span>
{{ $t("Report") }}
<b-icon icon="flag" /> <b-icon icon="flag" />
{{ $t("Report") }}
</span>
</b-dropdown-item>
<b-dropdown-item
aria-role="listitem"
v-if="isCurrentActorAGroupMember"
@click="leaveGroup"
>
<span>
<b-icon icon="exit-to-app" />
{{ $t("Leave") }}
</span> </span>
</b-dropdown-item> </b-dropdown-item>
<hr class="dropdown-divider" /> <hr class="dropdown-divider" />
@ -112,8 +122,8 @@
:href="`@${preferredUsername}/feed/atom`" :href="`@${preferredUsername}/feed/atom`"
:title="$t('Atom feed for events and posts')" :title="$t('Atom feed for events and posts')"
> >
{{ $t("RSS/Atom Feed") }}
<b-icon icon="rss" /> <b-icon icon="rss" />
{{ $t("RSS/Atom Feed") }}
</a> </a>
</b-dropdown-item> </b-dropdown-item>
<b-dropdown-item has-link aria-role="listitem"> <b-dropdown-item has-link aria-role="listitem">
@ -121,8 +131,8 @@
:href="`@${preferredUsername}/feed/ics`" :href="`@${preferredUsername}/feed/ics`"
:title="$t('ICS feed for events')" :title="$t('ICS feed for events')"
> >
{{ $t("ICS/WebCal Feed") }}
<b-icon icon="calendar-sync" /> <b-icon icon="calendar-sync" />
{{ $t("ICS/WebCal Feed") }}
</a> </a>
</b-dropdown-item> </b-dropdown-item>
</b-dropdown> </b-dropdown>
@ -222,8 +232,8 @@
@click="isReportModalActive = true" @click="isReportModalActive = true"
> >
<span> <span>
{{ $t("Report") }}
<b-icon icon="flag" /> <b-icon icon="flag" />
{{ $t("Report") }}
</span> </span>
</b-dropdown-item> </b-dropdown-item>
<hr class="dropdown-divider" /> <hr class="dropdown-divider" />
@ -232,8 +242,8 @@
:href="`@${preferredUsername}/feed/atom`" :href="`@${preferredUsername}/feed/atom`"
:title="$t('Atom feed for events and posts')" :title="$t('Atom feed for events and posts')"
> >
{{ $t("RSS/Atom Feed") }}
<b-icon icon="rss" /> <b-icon icon="rss" />
{{ $t("RSS/Atom Feed") }}
</a> </a>
</b-dropdown-item> </b-dropdown-item>
<b-dropdown-item has-link aria-role="listitem"> <b-dropdown-item has-link aria-role="listitem">
@ -241,8 +251,8 @@
:href="`@${preferredUsername}/feed/ics`" :href="`@${preferredUsername}/feed/ics`"
:title="$t('ICS feed for events')" :title="$t('ICS feed for events')"
> >
{{ $t("ICS/WebCal Feed") }}
<b-icon icon="calendar-sync" /> <b-icon icon="calendar-sync" />
{{ $t("ICS/WebCal Feed") }}
</a> </a>
</b-dropdown-item> </b-dropdown-item>
</b-dropdown> </b-dropdown>
@ -546,6 +556,7 @@ import RouteName from "../../router/name";
import GroupSection from "../../components/Group/GroupSection.vue"; import GroupSection from "../../components/Group/GroupSection.vue";
import ReportModal from "../../components/Report/ReportModal.vue"; import ReportModal from "../../components/Report/ReportModal.vue";
import { PERSON_MEMBERSHIP_GROUP } from "@/graphql/actor"; import { PERSON_MEMBERSHIP_GROUP } from "@/graphql/actor";
import { LEAVE_GROUP } from "@/graphql/group";
@Component({ @Component({
apollo: { apollo: {
@ -625,6 +636,34 @@ export default class Group extends mixins(GroupMixin) {
}); });
} }
async leaveGroup(): Promise<void> {
try {
const [group, currentActorId] = [
usernameWithDomain(this.group),
this.currentActor.id,
];
await this.$apollo.mutate({
mutation: LEAVE_GROUP,
variables: {
groupId: this.group.id,
},
refetchQueries: [
{
query: PERSON_MEMBERSHIP_GROUP,
variables: {
id: currentActorId,
group,
},
},
],
});
} catch (error) {
if (error.graphQLErrors && error.graphQLErrors.length > 0) {
this.$notifier.error(error.graphQLErrors[0].message);
}
}
}
acceptInvitation(): void { acceptInvitation(): void {
if (this.groupMember) { if (this.groupMember) {
const index = this.person.memberships.elements.findIndex( const index = this.person.memberships.elements.findIndex(

View file

@ -139,22 +139,28 @@ export default class MyGroups extends Vue {
} }
async leaveGroup(group: IGroup): Promise<void> { async leaveGroup(group: IGroup): Promise<void> {
const { page, limit } = this; try {
await this.$apollo.mutate({ const { page, limit } = this;
mutation: LEAVE_GROUP, await this.$apollo.mutate({
variables: { mutation: LEAVE_GROUP,
groupId: group.id, variables: {
}, groupId: group.id,
refetchQueries: [
{
query: LOGGED_USER_MEMBERSHIPS,
variables: {
page,
limit,
},
}, },
], refetchQueries: [
}); {
query: LOGGED_USER_MEMBERSHIPS,
variables: {
page,
limit,
},
},
],
});
} catch (error) {
if (error.graphQLErrors && error.graphQLErrors.length > 0) {
this.$notifier.error(error.graphQLErrors[0].message);
}
}
} }
get invitations(): IMember[] { get invitations(): IMember[] {