From 3a5f9f3c9306123f2e5454ed2364998cb6d8f1d8 Mon Sep 17 00:00:00 2001 From: Chewbacca Date: Wed, 26 Apr 2023 14:27:36 -0400 Subject: [PATCH] Update GroupRelationship state after join/leave group --- .../features/group/components/group-action-button.tsx | 7 +++++-- 1 file changed, 5 insertions(+), 2 deletions(-) diff --git a/app/soapbox/features/group/components/group-action-button.tsx b/app/soapbox/features/group/components/group-action-button.tsx index 28f860a46..e9a47a962 100644 --- a/app/soapbox/features/group/components/group-action-button.tsx +++ b/app/soapbox/features/group/components/group-action-button.tsx @@ -1,6 +1,7 @@ import React from 'react'; import { defineMessages, FormattedMessage, useIntl } from 'react-intl'; +import { fetchGroupRelationshipsSuccess } from 'soapbox/actions/groups'; import { openModal } from 'soapbox/actions/modals'; import { Button } from 'soapbox/components/ui'; import { importEntities } from 'soapbox/entity-store/actions'; @@ -43,8 +44,9 @@ const GroupActionButton = ({ group }: IGroupActionButton) => { const isBlocked = group.relationship?.blocked_by; const onJoinGroup = () => joinGroup.mutate({}, { - onSuccess() { + onSuccess(entity) { joinGroup.invalidate(); + dispatch(fetchGroupRelationshipsSuccess([entity])); queryClient.invalidateQueries(GroupKeys.pendingGroups(account?.id as string)); toast.success( @@ -61,8 +63,9 @@ const GroupActionButton = ({ group }: IGroupActionButton) => { message: intl.formatMessage(messages.confirmationMessage), confirm: intl.formatMessage(messages.confirmationConfirm), onConfirm: () => leaveGroup.mutate(group.relationship?.id as string, { - onSuccess() { + onSuccess(entity) { leaveGroup.invalidate(); + dispatch(fetchGroupRelationshipsSuccess([entity])); toast.success(intl.formatMessage(messages.leaveSuccess)); }, }),