AccountModerationModal: boilerplate

This commit is contained in:
Alex Gleason 2022-09-11 11:25:48 -05:00
parent ce60285c5f
commit 3120cc8453
No known key found for this signature in database
GPG key ID: 7211D1F99744FBB7
5 changed files with 61 additions and 5 deletions

View file

@ -59,7 +59,7 @@ const messages = defineMessages({
endorse: { id: 'account.endorse', defaultMessage: 'Feature on profile' }, endorse: { id: 'account.endorse', defaultMessage: 'Feature on profile' },
unendorse: { id: 'account.unendorse', defaultMessage: 'Don\'t feature on profile' }, unendorse: { id: 'account.unendorse', defaultMessage: 'Don\'t feature on profile' },
removeFromFollowers: { id: 'account.remove_from_followers', defaultMessage: 'Remove this follower' }, removeFromFollowers: { id: 'account.remove_from_followers', defaultMessage: 'Remove this follower' },
admin_account: { id: 'status.admin_account', defaultMessage: 'Open moderation interface for @{name}' }, adminAccount: { id: 'status.admin_account', defaultMessage: 'Moderate @{name}' },
add_or_remove_from_list: { id: 'account.add_or_remove_from_list', defaultMessage: 'Add or Remove from lists' }, add_or_remove_from_list: { id: 'account.add_or_remove_from_list', defaultMessage: 'Add or Remove from lists' },
deactivateUser: { id: 'admin.users.actions.deactivate_user', defaultMessage: 'Deactivate @{name}' }, deactivateUser: { id: 'admin.users.actions.deactivate_user', defaultMessage: 'Deactivate @{name}' },
deleteUser: { id: 'admin.users.actions.delete_user', defaultMessage: 'Delete @{name}' }, deleteUser: { id: 'admin.users.actions.delete_user', defaultMessage: 'Delete @{name}' },
@ -287,6 +287,10 @@ const Header: React.FC<IHeader> = ({ account }) => {
.catch(() => {}); .catch(() => {});
}; };
const onModerate = () => {
dispatch(openModal('ACCOUNT_MODERATION', { accountId: account.id }));
};
const onRemoveFromFollowers = () => { const onRemoveFromFollowers = () => {
dispatch((_, getState) => { dispatch((_, getState) => {
const unfollowModal = getSettings(getState()).get('unfollowModal'); const unfollowModal = getSettings(getState()).get('unfollowModal');
@ -534,9 +538,8 @@ const Header: React.FC<IHeader> = ({ account }) => {
if (ownAccount?.admin) { if (ownAccount?.admin) {
menu.push({ menu.push({
text: intl.formatMessage(messages.admin_account, { name: account.username }), text: intl.formatMessage(messages.adminAccount, { name: account.username }),
to: `/pleroma/admin/#/users/${account.id}/`, action: onModerate,
newTab: true,
icon: require('@tabler/icons/gavel.svg'), icon: require('@tabler/icons/gavel.svg'),
}); });
} }

View file

@ -32,6 +32,7 @@ import {
CompareHistoryModal, CompareHistoryModal,
VerifySmsModal, VerifySmsModal,
FamiliarFollowersModal, FamiliarFollowersModal,
AccountModerationModal,
} from 'soapbox/features/ui/util/async-components'; } from 'soapbox/features/ui/util/async-components';
import BundleContainer from '../containers/bundle_container'; import BundleContainer from '../containers/bundle_container';
@ -69,6 +70,7 @@ const MODAL_COMPONENTS = {
'COMPARE_HISTORY': CompareHistoryModal, 'COMPARE_HISTORY': CompareHistoryModal,
'VERIFY_SMS': VerifySmsModal, 'VERIFY_SMS': VerifySmsModal,
'FAMILIAR_FOLLOWERS': FamiliarFollowersModal, 'FAMILIAR_FOLLOWERS': FamiliarFollowersModal,
'ACCOUNT_MODERATION': AccountModerationModal,
}; };
export default class ModalRoot extends React.PureComponent { export default class ModalRoot extends React.PureComponent {

View file

@ -0,0 +1,47 @@
import React from 'react';
import { defineMessages, useIntl } from 'react-intl';
import MissingIndicator from 'soapbox/components/missing_indicator';
import { Modal } from 'soapbox/components/ui';
import { useAppSelector } from 'soapbox/hooks';
import { makeGetAccount } from 'soapbox/selectors';
const messages = defineMessages({
title: { id: 'account_moderation_modal.title', defaultMessage: 'Moderate @{acct}' },
});
const getAccount = makeGetAccount();
interface IAccountModerationModal {
/** Action to close the modal. */
onClose: (type: string) => void,
/** ID of the account to moderate. */
accountId: string,
}
/** Moderator actions against accounts. */
const AccountModerationModal: React.FC<IAccountModerationModal> = ({ onClose, accountId }) => {
const intl = useIntl();
const account = useAppSelector(state => getAccount(state, accountId));
const handleClose = () => onClose('ACCOUNT_MODERATION');
if (!account) {
return (
<Modal onClose={handleClose}>
<MissingIndicator />
</Modal>
);
}
return (
<Modal
title={intl.formatMessage(messages.title, { acct: account.acct })}
onClose={handleClose}
>
<div>TODO</div>
</Modal>
);
};
export default AccountModerationModal;

View file

@ -106,6 +106,10 @@ export function ReportModal() {
return import(/* webpackChunkName: "modals/report-modal/report-modal" */'../components/modals/report-modal/report-modal'); return import(/* webpackChunkName: "modals/report-modal/report-modal" */'../components/modals/report-modal/report-modal');
} }
export function AccountModerationModal() {
return import(/* webpackChunkName: "modals/account-moderation-modal" */'../components/modals/account-moderation-modal');
}
export function MediaGallery() { export function MediaGallery() {
return import(/* webpackChunkName: "status/media_gallery" */'../../../components/media_gallery'); return import(/* webpackChunkName: "status/media_gallery" */'../../../components/media_gallery');
} }

View file

@ -974,7 +974,7 @@
"soapbox_config.single_user_mode_profile_label": "Main user handle", "soapbox_config.single_user_mode_profile_label": "Main user handle",
"soapbox_config.verified_can_edit_name_label": "Allow verified users to edit their own display name.", "soapbox_config.verified_can_edit_name_label": "Allow verified users to edit their own display name.",
"status.actions.more": "More", "status.actions.more": "More",
"status.admin_account": "Open moderation interface for @{name}", "status.admin_account": "Moderate @{name}",
"status.admin_status": "Open this post in the moderation interface", "status.admin_status": "Open this post in the moderation interface",
"status.block": "Block @{name}", "status.block": "Block @{name}",
"status.bookmark": "Bookmark", "status.bookmark": "Bookmark",