AccountModerationModal: boilerplate
This commit is contained in:
parent
ce60285c5f
commit
3120cc8453
5 changed files with 61 additions and 5 deletions
|
@ -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'),
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
|
@ -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 {
|
||||||
|
|
|
@ -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;
|
|
@ -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');
|
||||||
}
|
}
|
||||||
|
|
|
@ -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",
|
||||||
|
|
Loading…
Reference in a new issue