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 noop from 'lodash/noop'; import StatusContent from 'soapbox/components/status_content'; import DropdownMenu from 'soapbox/containers/dropdown_menu_container'; import { openModal } from 'soapbox/actions/modal'; import { MediaGallery, Video, Audio } from 'soapbox/features/ui/util/async-components'; import Bundle from 'soapbox/features/ui/components/bundle'; import { deleteStatusModal } from 'soapbox/actions/moderation'; const messages = defineMessages({ viewStatus: { id: 'admin.reports.actions.view_status', defaultMessage: 'View post' }, deleteStatus: { id: 'admin.statuses.actions.delete_status', defaultMessage: 'Delete post' }, }); 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')}`, icon: require('@tabler/icons/icons/pencil.svg'), }, { text: intl.formatMessage(messages.deleteStatus, { acct: `@${acct}` }), action: this.handleDeleteStatus, icon: require('@tabler/icons/icons/trash.svg'), destructive: true, }]; } getMedia = () => { const { status } = this.props; if (status.get('media_attachments').size > 0) { if (status.get('media_attachments').some(item => item.get('type') === 'unknown')) { // Do nothing } 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 statusId = status.get('id'); dispatch(deleteStatusModal(intl, statusId)); } render() { const { status } = this.props; const media = this.getMedia(); const menu = this.makeMenu(); return (
{media}
); } }