import React from 'react'; import { connect } from 'react-redux'; import ImmutablePureComponent from 'react-immutable-pure-component'; import ImmutablePropTypes from 'react-immutable-proptypes'; import { injectIntl, defineMessages } from 'react-intl'; import StatusContent from 'soapbox/components/status_content'; import DropdownMenu from 'soapbox/containers/dropdown_menu_container'; import { deleteStatus } from 'soapbox/actions/admin'; import snackbar from 'soapbox/actions/snackbar'; import { openModal } from 'soapbox/actions/modal'; import noop from 'lodash/noop'; import { MediaGallery, Video, Audio } from 'soapbox/features/ui/util/async-components'; import Bundle from 'soapbox/features/ui/components/bundle'; const messages = defineMessages({ viewStatus: { id: 'admin.reports.actions.view_status', defaultMessage: 'View post' }, deleteStatus: { id: 'admin.reports.actions.delete_status', defaultMessage: 'Delete post' }, deleteStatusPrompt: { id: 'confirmations.admin.delete_status.message', defaultMessage: 'You are about to delete a post by {acct}. This action cannot be undone.' }, deleteStatusConfirm: { id: 'confirmations.admin.delete_status.confirm', defaultMessage: 'Delete post' }, statusDeleted: { id: 'admin.reports.status_deleted_message', defaultMessage: 'Post by {acct} was deleted' }, }); export default @connect() @injectIntl class ReportStatus extends ImmutablePureComponent { static propTypes = { status: ImmutablePropTypes.map.isRequired, report: ImmutablePropTypes.map, }; makeMenu = () => { const { intl, status } = this.props; const acct = status.getIn(['account', 'acct']); return [{ text: intl.formatMessage(messages.viewStatus, { acct: `@${acct}` }), to: `/@${acct}/posts/${status.get('id')}`, }, { text: intl.formatMessage(messages.deleteStatus, { acct: `@${acct}` }), action: this.handleDeleteStatus, }]; } getMedia = () => { const { status } = this.props; if (status.get('media_attachments').size > 0) { if (status.get('media_attachments').some(item => item.get('type') === 'unknown')) { } else if (status.getIn(['media_attachments', 0, 'type']) === 'video') { const video = status.getIn(['media_attachments', 0]); return ( {Component => ( )} ); } else if (status.getIn(['media_attachments', 0, 'type']) === 'audio') { const audio = status.getIn(['media_attachments', 0]); return ( {Component => ( )} ); } else { return ( {Component => } ); } } return null; } handleOpenMedia = (media, index) => { const { dispatch } = this.props; dispatch(openModal('MEDIA', { media, index })); } handleDeleteStatus = () => { const { intl, dispatch, status } = this.props; const nickname = status.getIn(['account', 'acct']); const statusId = status.get('id'); dispatch(openModal('CONFIRM', { message: intl.formatMessage(messages.deleteStatusPrompt, { acct: `@${nickname}` }), confirm: intl.formatMessage(messages.deleteStatusConfirm), onConfirm: () => { dispatch(deleteStatus(statusId)).then(() => { const message = intl.formatMessage(messages.statusDeleted, { acct: `@${nickname}` }); dispatch(snackbar.success(message)); }).catch(() => {}); this.handleCloseReport(); }, })); } render() { const { status } = this.props; const media = this.getMedia(); const menu = this.makeMenu(); return (
{media}
); } }