125 lines
4.5 KiB
TypeScript
125 lines
4.5 KiB
TypeScript
import React from 'react';
|
|
import { defineMessages, useIntl } from 'react-intl';
|
|
import { useHistory } from 'react-router-dom';
|
|
|
|
import { editGroup } from 'soapbox/actions/groups';
|
|
import { openModal } from 'soapbox/actions/modals';
|
|
import List, { ListItem } from 'soapbox/components/list';
|
|
import { CardBody, CardHeader, CardTitle, Column, Spinner, Text } from 'soapbox/components/ui';
|
|
import { useAppDispatch, useGroup, useGroupsPath } from 'soapbox/hooks';
|
|
import { useDeleteGroup } from 'soapbox/hooks/api';
|
|
import { GroupRoles } from 'soapbox/schemas/group-member';
|
|
import toast from 'soapbox/toast';
|
|
|
|
import ColumnForbidden from '../ui/components/column-forbidden';
|
|
|
|
type RouteParams = { id: string };
|
|
|
|
const messages = defineMessages({
|
|
heading: { id: 'column.manage_group', defaultMessage: 'Manage group' },
|
|
editGroup: { id: 'manage_group.edit_group', defaultMessage: 'Edit group' },
|
|
pendingRequests: { id: 'manage_group.pending_requests', defaultMessage: 'Pending requests' },
|
|
blockedMembers: { id: 'manage_group.blocked_members', defaultMessage: 'Banned members' },
|
|
deleteGroup: { id: 'manage_group.delete_group', defaultMessage: 'Delete group' },
|
|
deleteConfirm: { id: 'confirmations.delete_group.confirm', defaultMessage: 'Delete' },
|
|
deleteHeading: { id: 'confirmations.delete_group.heading', defaultMessage: 'Delete group' },
|
|
deleteMessage: { id: 'confirmations.delete_group.message', defaultMessage: 'Are you sure you want to delete this group? This is a permanent action that cannot be undone.' },
|
|
members: { id: 'group.tabs.members', defaultMessage: 'Members' },
|
|
other: { id: 'settings.other', defaultMessage: 'Other options' },
|
|
deleteSuccess: { id: 'group.delete.success', defaultMessage: 'Group successfully deleted' },
|
|
});
|
|
|
|
interface IManageGroup {
|
|
params: RouteParams
|
|
}
|
|
|
|
const ManageGroup: React.FC<IManageGroup> = ({ params }) => {
|
|
const { id } = params;
|
|
const intl = useIntl();
|
|
const history = useHistory();
|
|
const dispatch = useAppDispatch();
|
|
const groupsPath = useGroupsPath();
|
|
|
|
const { group } = useGroup(id);
|
|
|
|
const deleteGroup = useDeleteGroup();
|
|
|
|
const isOwner = group?.relationship?.role === GroupRoles.OWNER;
|
|
|
|
if (!group || !group.relationship) {
|
|
return (
|
|
<Column label={intl.formatMessage(messages.heading)}>
|
|
<Spinner />
|
|
</Column>
|
|
);
|
|
}
|
|
|
|
if (!group.relationship.role || !['owner', 'admin', 'moderator'].includes(group.relationship.role)) {
|
|
return (<ColumnForbidden />);
|
|
}
|
|
|
|
const onEditGroup = () =>
|
|
dispatch(editGroup(group));
|
|
|
|
const onDeleteGroup = () =>
|
|
dispatch(openModal('CONFIRM', {
|
|
icon: require('@tabler/icons/trash.svg'),
|
|
heading: intl.formatMessage(messages.deleteHeading),
|
|
message: intl.formatMessage(messages.deleteMessage),
|
|
confirm: intl.formatMessage(messages.deleteConfirm),
|
|
onConfirm: () => {
|
|
deleteGroup.mutate(group.id, {
|
|
onSuccess() {
|
|
toast.success(intl.formatMessage(messages.deleteSuccess));
|
|
history.push(groupsPath);
|
|
},
|
|
});
|
|
},
|
|
}));
|
|
|
|
const navigateToPending = () => history.push(`/groups/${id}/manage/requests`);
|
|
const navigateToBlocks = () => history.push(`/groups/${id}/manage/blocks`);
|
|
|
|
return (
|
|
<Column label={intl.formatMessage(messages.heading)} backHref={`/groups/${id}`}>
|
|
<CardBody className='space-y-4'>
|
|
{isOwner && (
|
|
<>
|
|
<CardHeader>
|
|
<CardTitle title={intl.formatMessage(messages.editGroup)} />
|
|
</CardHeader>
|
|
|
|
<List>
|
|
<ListItem label={intl.formatMessage(messages.editGroup)} onClick={onEditGroup}>
|
|
<span dangerouslySetInnerHTML={{ __html: group.display_name_html }} />
|
|
</ListItem>
|
|
</List>
|
|
</>
|
|
)}
|
|
|
|
<CardHeader>
|
|
<CardTitle title={intl.formatMessage(messages.members)} />
|
|
</CardHeader>
|
|
|
|
<List>
|
|
<ListItem label={intl.formatMessage(messages.pendingRequests)} onClick={navigateToPending} />
|
|
<ListItem label={intl.formatMessage(messages.blockedMembers)} onClick={navigateToBlocks} />
|
|
</List>
|
|
|
|
{isOwner && (
|
|
<>
|
|
<CardHeader>
|
|
<CardTitle title={intl.formatMessage(messages.other)} />
|
|
</CardHeader>
|
|
|
|
<List>
|
|
<ListItem label={<Text theme='danger'>{intl.formatMessage(messages.deleteGroup)}</Text>} onClick={onDeleteGroup} />
|
|
</List>
|
|
</>
|
|
)}
|
|
</CardBody>
|
|
</Column>
|
|
);
|
|
};
|
|
|
|
export default ManageGroup;
|