2020-03-27 13:59:38 -07:00
import React from 'react' ;
import { connect } from 'react-redux' ;
2020-05-29 11:05:24 -07:00
import { changeReportComment , changeReportForward , changeReportBlock , submitReport } from '../../../actions/reports' ;
import { blockAccount } from '../../../actions/accounts' ;
2020-03-27 13:59:38 -07:00
import { expandAccountTimeline } from '../../../actions/timelines' ;
import PropTypes from 'prop-types' ;
import ImmutablePropTypes from 'react-immutable-proptypes' ;
import { makeGetAccount } from '../../../selectors' ;
import { defineMessages , FormattedMessage , injectIntl } from 'react-intl' ;
import StatusCheckBox from '../../report/containers/status_check_box_container' ;
import { OrderedSet } from 'immutable' ;
import ImmutablePureComponent from 'react-immutable-pure-component' ;
import Button from '../../../components/button' ;
import Toggle from 'react-toggle' ;
import IconButton from '../../../components/icon_button' ;
const messages = defineMessages ( {
close : { id : 'lightbox.close' , defaultMessage : 'Close' } ,
placeholder : { id : 'report.placeholder' , defaultMessage : 'Additional comments' } ,
submit : { id : 'report.submit' , defaultMessage : 'Submit' } ,
} ) ;
const makeMapStateToProps = ( ) => {
const getAccount = makeGetAccount ( ) ;
const mapStateToProps = state => {
const accountId = state . getIn ( [ 'reports' , 'new' , 'account_id' ] ) ;
return {
isSubmitting : state . getIn ( [ 'reports' , 'new' , 'isSubmitting' ] ) ,
account : getAccount ( state , accountId ) ,
comment : state . getIn ( [ 'reports' , 'new' , 'comment' ] ) ,
forward : state . getIn ( [ 'reports' , 'new' , 'forward' ] ) ,
2020-05-29 11:05:24 -07:00
block : state . getIn ( [ 'reports' , 'new' , 'block' ] ) ,
2020-03-27 13:59:38 -07:00
statusIds : OrderedSet ( state . getIn ( [ 'timelines' , ` account: ${ accountId } :with_replies ` , 'items' ] ) ) . union ( state . getIn ( [ 'reports' , 'new' , 'status_ids' ] ) ) ,
} ;
} ;
return mapStateToProps ;
} ;
export default @ connect ( makeMapStateToProps )
@ injectIntl
class ReportModal extends ImmutablePureComponent {
static propTypes = {
isSubmitting : PropTypes . bool ,
account : ImmutablePropTypes . map ,
statusIds : ImmutablePropTypes . orderedSet . isRequired ,
comment : PropTypes . string . isRequired ,
forward : PropTypes . bool ,
2020-05-29 11:05:24 -07:00
block : PropTypes . bool ,
2020-03-27 13:59:38 -07:00
dispatch : PropTypes . func . isRequired ,
intl : PropTypes . object . isRequired ,
} ;
handleCommentChange = e => {
this . props . dispatch ( changeReportComment ( e . target . value ) ) ;
}
handleForwardChange = e => {
this . props . dispatch ( changeReportForward ( e . target . checked ) ) ;
}
2020-05-29 11:05:24 -07:00
handleBlockChange = e => {
this . props . dispatch ( changeReportBlock ( e . target . checked ) ) ;
}
2020-03-27 13:59:38 -07:00
handleSubmit = ( ) => {
this . props . dispatch ( submitReport ( ) ) ;
2020-05-29 11:05:24 -07:00
if ( this . props . block ) {
this . props . dispatch ( blockAccount ( this . props . account . get ( 'id' ) ) ) ;
}
2020-03-27 13:59:38 -07:00
}
handleKeyDown = e => {
if ( e . keyCode === 13 && ( e . ctrlKey || e . metaKey ) ) {
this . handleSubmit ( ) ;
}
}
2020-04-14 14:47:35 -07:00
componentDidMount ( ) {
2020-03-27 13:59:38 -07:00
this . props . dispatch ( expandAccountTimeline ( this . props . account . get ( 'id' ) , { withReplies : true } ) ) ;
}
2020-07-04 16:41:41 -07:00
componentDidUpdate ( prevProps ) {
const { account } = this . props ;
if ( prevProps . account !== account && account ) {
this . props . dispatch ( expandAccountTimeline ( account . get ( 'id' ) , { withReplies : true } ) ) ;
2020-03-27 13:59:38 -07:00
}
}
2020-04-14 14:47:35 -07:00
render ( ) {
2020-05-29 11:05:24 -07:00
const { account , comment , intl , statusIds , isSubmitting , forward , block , onClose } = this . props ;
2020-03-27 13:59:38 -07:00
if ( ! account ) {
return null ;
}
const domain = account . get ( 'acct' ) . split ( '@' ) [ 1 ] ;
return (
< div className = 'modal-root__modal report-modal' >
< div className = 'report-modal__target' >
< IconButton className = 'media-modal__close' title = { intl . formatMessage ( messages . close ) } icon = 'times' onClick = { onClose } size = { 16 } / >
< FormattedMessage id = 'report.target' defaultMessage = 'Reporting {target}' values = { { target : < strong > { account . get ( 'acct' ) } < /strong> }} / >
< / d i v >
< div className = 'report-modal__container' >
< div className = 'report-modal__comment' >
< p > < FormattedMessage id = 'report.hint' defaultMessage = 'The report will be sent to your server moderators. You can provide an explanation of why you are reporting this account below:' / > < / p >
< textarea
className = 'setting-text light'
placeholder = { intl . formatMessage ( messages . placeholder ) }
value = { comment }
onChange = { this . handleCommentChange }
onKeyDown = { this . handleKeyDown }
disabled = { isSubmitting }
autoFocus
/ >
{ domain && (
< div >
< p > < FormattedMessage id = 'report.forward_hint' defaultMessage = 'The account is from another server. Send an anonymized copy of the report there as well?' / > < / p >
< div className = 'setting-toggle' >
< Toggle id = 'report-forward' checked = { forward } disabled = { isSubmitting } onChange = { this . handleForwardChange } / >
< label htmlFor = 'report-forward' className = 'setting-toggle__label' > < FormattedMessage id = 'report.forward' defaultMessage = 'Forward to {target}' values = { { target : domain } } / > < / l a b e l >
< / d i v >
< / d i v >
) }
2020-05-29 11:05:24 -07:00
< div >
< p > < FormattedMessage id = 'report.block_hint' defaultMessage = 'Do you also want to block this account?' / > < / p >
< div className = 'setting-toggle' >
< Toggle id = 'report-block' checked = { block } disabled = { isSubmitting } onChange = { this . handleBlockChange } / >
< label htmlFor = 'report-block' className = 'setting-toggle__label' > < FormattedMessage id = 'report.block' defaultMessage = 'Block {target}' values = { { target : account . get ( 'acct' ) } } / > < / l a b e l >
< / d i v >
< / d i v >
2020-03-27 13:59:38 -07:00
< Button disabled = { isSubmitting } text = { intl . formatMessage ( messages . submit ) } onClick = { this . handleSubmit } / >
< / d i v >
< div className = 'report-modal__statuses' >
< div >
{ statusIds . map ( statusId => < StatusCheckBox id = { statusId } key = { statusId } disabled = { isSubmitting } / > ) }
< / d i v >
< / d i v >
< / d i v >
< / d i v >
) ;
}
}