import React from 'react'; import { defineMessages, FormattedMessage, useIntl } from 'react-intl'; import { openModal } from 'soapbox/actions/modals'; import { Button } from 'soapbox/components/ui'; import { useAppDispatch } from 'soapbox/hooks'; import { useCancelMembershipRequest, useJoinGroup, useLeaveGroup } from 'soapbox/queries/groups'; import { Group } from 'soapbox/types/entities'; interface IGroupActionButton { group: Group } const messages = defineMessages({ confirmationHeading: { id: 'confirmations.leave_group.heading', defaultMessage: 'Leave group' }, confirmationMessage: { id: 'confirmations.leave_group.message', defaultMessage: 'You are about to leave the group. Do you want to continue?' }, confirmationConfirm: { id: 'confirmations.leave_group.confirm', defaultMessage: 'Leave' }, }); const GroupActionButton = ({ group }: IGroupActionButton) => { const dispatch = useAppDispatch(); const intl = useIntl(); const joinGroup = useJoinGroup(); const leaveGroup = useLeaveGroup(); const cancelRequest = useCancelMembershipRequest(); const isRequested = group.relationship?.requested; const isNonMember = !group.relationship?.member && !isRequested; const isAdmin = group.relationship?.role === 'admin'; const isBlocked = group.relationship?.blocked_by; const onJoinGroup = () => joinGroup.mutate(group); const onLeaveGroup = () => dispatch(openModal('CONFIRM', { heading: intl.formatMessage(messages.confirmationHeading), message: intl.formatMessage(messages.confirmationMessage), confirm: intl.formatMessage(messages.confirmationConfirm), onConfirm: () => leaveGroup.mutate(group), })); const onCancelRequest = () => cancelRequest.mutate(group); if (isBlocked) { return null; } if (isNonMember) { return ( ); } if (isRequested) { return ( ); } if (isAdmin) { return ( ); } return ( ); }; export default GroupActionButton;