bigbuffet-rw/app/soapbox/features/admin/components/report.js

125 lines
4.8 KiB
JavaScript
Raw Normal View History

import React from 'react';
2020-12-31 15:54:08 -08:00
import { connect } from 'react-redux';
2020-12-31 20:56:17 -08:00
import { Link } from 'react-router-dom';
import ImmutablePureComponent from 'react-immutable-pure-component';
import ImmutablePropTypes from 'react-immutable-proptypes';
2020-12-31 15:54:08 -08:00
import { injectIntl, FormattedMessage, defineMessages } from 'react-intl';
import Avatar from 'soapbox/components/avatar';
2020-12-31 16:24:52 -08:00
import Button from 'soapbox/components/button';
2020-12-31 15:54:08 -08:00
import DropdownMenu from 'soapbox/containers/dropdown_menu_container';
2020-12-31 18:47:15 -08:00
import Accordion from 'soapbox/features/ui/components/accordion';
2021-01-18 12:59:02 -08:00
import { closeReports } from 'soapbox/actions/admin';
2020-12-31 15:54:08 -08:00
import snackbar from 'soapbox/actions/snackbar';
2021-01-18 12:59:02 -08:00
import { deactivateUserModal, deleteUserModal } from 'soapbox/actions/moderation';
2022-01-10 14:01:24 -08:00
import ReportStatus from './report_status';
2020-12-31 15:54:08 -08:00
const messages = defineMessages({
reportClosed: { id: 'admin.reports.report_closed_message', defaultMessage: 'Report on @{name} was closed' },
deactivateUser: { id: 'admin.users.actions.deactivate_user', defaultMessage: 'Deactivate @{name}' },
deleteUser: { id: 'admin.users.actions.delete_user', defaultMessage: 'Delete @{name}' },
2020-12-31 15:54:08 -08:00
});
export default @connect()
@injectIntl
class Report extends ImmutablePureComponent {
static propTypes = {
report: ImmutablePropTypes.map.isRequired,
};
2020-12-31 18:47:15 -08:00
state = {
accordionExpanded: false,
};
2020-12-31 15:54:08 -08:00
makeMenu = () => {
const { intl, report } = this.props;
return [{
text: intl.formatMessage(messages.deactivateUser, { name: report.getIn(['account', 'username']) }),
2020-12-31 15:54:08 -08:00
action: this.handleDeactivateUser,
icon: require('@tabler/icons/icons/user-off.svg'),
2020-12-31 16:59:10 -08:00
}, {
text: intl.formatMessage(messages.deleteUser, { name: report.getIn(['account', 'username']) }),
2020-12-31 16:59:10 -08:00
action: this.handleDeleteUser,
icon: require('@tabler/icons/icons/user-minus.svg'),
2020-12-31 15:54:08 -08:00
}];
}
2020-12-31 16:24:52 -08:00
handleCloseReport = () => {
const { intl, dispatch, report } = this.props;
dispatch(closeReports([report.get('id')])).then(() => {
const message = intl.formatMessage(messages.reportClosed, { name: report.getIn(['account', 'username']) });
2020-12-31 16:24:52 -08:00
dispatch(snackbar.success(message));
}).catch(() => {});
}
2020-12-31 15:54:08 -08:00
handleDeactivateUser = () => {
const { intl, dispatch, report } = this.props;
2021-01-18 12:59:02 -08:00
const accountId = report.getIn(['account', 'id']);
dispatch(deactivateUserModal(intl, accountId, () => this.handleCloseReport()));
2020-12-31 15:54:08 -08:00
}
2020-12-31 16:59:10 -08:00
handleDeleteUser = () => {
const { intl, dispatch, report } = this.props;
2021-01-18 12:59:02 -08:00
const accountId = report.getIn(['account', 'id']);
dispatch(deleteUserModal(intl, accountId, () => this.handleCloseReport()));
2020-12-31 16:59:10 -08:00
}
2020-12-31 18:47:15 -08:00
handleAccordionToggle = setting => {
this.setState({ accordionExpanded: setting });
}
render() {
const { report } = this.props;
2020-12-31 18:47:15 -08:00
const { accordionExpanded } = this.state;
2020-12-31 15:54:08 -08:00
const menu = this.makeMenu();
const statuses = report.get('statuses');
const statusCount = statuses.count();
2020-12-31 20:56:17 -08:00
const acct = report.getIn(['account', 'acct']);
const reporterAcct = report.getIn(['actor', 'acct']);
return (
<div className='admin-report' key={report.get('id')}>
2020-12-31 15:54:08 -08:00
<div className='admin-report__avatar'>
2020-12-31 20:56:17 -08:00
<Link to={`/@${acct}`} title={acct}>
<Avatar account={report.get('account')} size={32} />
</Link>
2020-12-31 15:54:08 -08:00
</div>
<div className='admin-report__content'>
<h4 className='admin-report__title'>
<FormattedMessage
id='admin.reports.report_title'
defaultMessage='Report on {acct}'
2020-12-31 20:56:17 -08:00
values={{ acct: <Link to={`/@${acct}`} title={acct}>@{acct}</Link> }}
/>
</h4>
2020-12-31 18:47:15 -08:00
<div className='admin-report__statuses'>
{statusCount > 0 && (
<Accordion
headline={`Reported posts (${statusCount})`}
expanded={accordionExpanded}
onToggle={this.handleAccordionToggle}
>
2020-12-31 21:16:50 -08:00
{statuses.map(status => <ReportStatus report={report} status={status} key={status.get('id')} />)}
</Accordion>
)}
2020-12-31 18:47:15 -08:00
</div>
<div className='admin-report__quote'>
2020-12-31 20:46:21 -08:00
{report.get('content', '').length > 0 &&
<blockquote className='md' dangerouslySetInnerHTML={{ __html: report.get('content') }} />
}
2020-12-31 20:56:17 -08:00
<span className='byline'>&mdash; <Link to={`/@${reporterAcct}`} title={reporterAcct}>@{reporterAcct}</Link></span>
</div>
</div>
2020-12-31 15:54:08 -08:00
<div className='admin-report__actions'>
2020-12-31 16:24:52 -08:00
<Button className='button-alternative' size={30} onClick={this.handleCloseReport}>
<FormattedMessage id='admin.reports.actions.close' defaultMessage='Close' />
</Button>
<DropdownMenu className='admin-report__dropdown' items={menu} src={require('@tabler/icons/icons/dots-vertical.svg')} direction='right' />
2020-12-31 15:54:08 -08:00
</div>
</div>
);
}
}