import React, { useState } from 'react'; import { useIntl, FormattedMessage, defineMessages } from 'react-intl'; import { Link } from 'react-router-dom'; import { closeReports } from 'soapbox/actions/admin'; import { deactivateUserModal, deleteUserModal } from 'soapbox/actions/moderation'; import snackbar from 'soapbox/actions/snackbar'; import Avatar from 'soapbox/components/avatar'; import { Button } from 'soapbox/components/ui'; import DropdownMenu from 'soapbox/containers/dropdown_menu_container'; import Accordion from 'soapbox/features/ui/components/accordion'; import { useAppDispatch } from 'soapbox/hooks'; import ReportStatus from './report_status'; import type { Map as ImmutableMap, List as ImmutableList } from 'immutable'; import type { Status } from 'soapbox/types/entities'; 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}' }, }); interface IReport { report: ImmutableMap; } const Report: React.FC = ({ report }) => { const intl = useIntl(); const dispatch = useAppDispatch(); const [accordionExpanded, setAccordionExpanded] = useState(false); const makeMenu = () => { return [{ text: intl.formatMessage(messages.deactivateUser, { name: report.getIn(['account', 'username']) as string }), action: handleDeactivateUser, icon: require('@tabler/icons/icons/user-off.svg'), }, { text: intl.formatMessage(messages.deleteUser, { name: report.getIn(['account', 'username']) as string }), action: handleDeleteUser, icon: require('@tabler/icons/icons/user-minus.svg'), }]; }; const handleCloseReport = () => { dispatch(closeReports([report.get('id')])).then(() => { const message = intl.formatMessage(messages.reportClosed, { name: report.getIn(['account', 'username']) as string }); dispatch(snackbar.success(message)); }).catch(() => {}); }; const handleDeactivateUser = () => { const accountId = report.getIn(['account', 'id']); dispatch(deactivateUserModal(intl, accountId, () => handleCloseReport())); }; const handleDeleteUser = () => { const accountId = report.getIn(['account', 'id']) as string; dispatch(deleteUserModal(intl, accountId, () => handleCloseReport())); }; const handleAccordionToggle = (setting: boolean) => { setAccordionExpanded(setting); }; const menu = makeMenu(); const statuses = report.get('statuses') as ImmutableList; const statusCount = statuses.count(); const acct = report.getIn(['account', 'acct']) as string; const reporterAcct = report.getIn(['actor', 'acct']) as string; return (

@{acct} }} />

{statusCount > 0 && ( {statuses.map(status => )} )}
{report.get('content', '').length > 0 &&
} @{reporterAcct}
); }; export default Report;