2017-05-03 03:04:16 +03:00
import React from 'react' ;
2017-01-30 22:40:55 +02:00
import { connect } from 'react-redux' ;
import { makeGetAccount } from '../../../selectors' ;
import Header from '../components/header' ;
import {
followAccount ,
unfollowAccount ,
blockAccount ,
2017-02-06 03:51:56 +02:00
unblockAccount ,
2017-05-20 18:31:47 +03:00
unmuteAccount ,
2017-01-30 22:40:55 +02:00
} from '../../../actions/accounts' ;
import { mentionCompose } from '../../../actions/compose' ;
2017-08-07 01:43:58 +03:00
import { initMuteModal } from '../../../actions/mutes' ;
2017-02-14 21:59:26 +02:00
import { initReport } from '../../../actions/reports' ;
2017-04-23 05:39:50 +03:00
import { openModal } from '../../../actions/modal' ;
2017-05-19 22:05:32 +03:00
import { blockDomain , unblockDomain } from '../../../actions/domain_blocks' ;
2017-04-23 05:39:50 +03:00
import { defineMessages , injectIntl , FormattedMessage } from 'react-intl' ;
const messages = defineMessages ( {
2017-07-18 18:14:43 +03:00
unfollowConfirm : { id : 'confirmations.unfollow.confirm' , defaultMessage : 'Unfollow' } ,
2017-04-23 05:39:50 +03:00
blockConfirm : { id : 'confirmations.block.confirm' , defaultMessage : 'Block' } ,
2017-05-19 22:05:32 +03:00
blockDomainConfirm : { id : 'confirmations.domain_block.confirm' , defaultMessage : 'Hide entire domain' } ,
2017-04-23 05:39:50 +03:00
} ) ;
2017-01-30 22:40:55 +02:00
const makeMapStateToProps = ( ) => {
const getAccount = makeGetAccount ( ) ;
const mapStateToProps = ( state , { accountId } ) => ( {
account : getAccount ( state , Number ( accountId ) ) ,
2017-05-20 18:31:47 +03:00
me : state . getIn ( [ 'meta' , 'me' ] ) ,
2017-07-18 18:14:43 +03:00
unfollowModal : state . getIn ( [ 'meta' , 'unfollow_modal' ] ) ,
2017-01-30 22:40:55 +02:00
} ) ;
return mapStateToProps ;
} ;
2017-04-23 05:39:50 +03:00
const mapDispatchToProps = ( dispatch , { intl } ) => ( {
2017-07-18 18:14:43 +03:00
2017-01-30 22:40:55 +02:00
onFollow ( account ) {
2017-09-02 21:44:41 +03:00
if ( account . getIn ( [ 'relationship' , 'following' ] ) || account . getIn ( [ 'relationship' , 'requested' ] ) ) {
2017-07-18 18:14:43 +03:00
if ( this . unfollowModal ) {
dispatch ( openModal ( 'CONFIRM' , {
message : < FormattedMessage id = 'confirmations.unfollow.message' defaultMessage = 'Are you sure you want to unfollow {name}?' values = { { name : < strong > @ { account . get ( 'acct' ) } < /strong> }} / > ,
confirm : intl . formatMessage ( messages . unfollowConfirm ) ,
onConfirm : ( ) => dispatch ( unfollowAccount ( account . get ( 'id' ) ) ) ,
} ) ) ;
} else {
dispatch ( unfollowAccount ( account . get ( 'id' ) ) ) ;
}
2017-01-30 22:40:55 +02:00
} else {
dispatch ( followAccount ( account . get ( 'id' ) ) ) ;
}
} ,
onBlock ( account ) {
if ( account . getIn ( [ 'relationship' , 'blocking' ] ) ) {
dispatch ( unblockAccount ( account . get ( 'id' ) ) ) ;
} else {
2017-04-23 05:39:50 +03:00
dispatch ( openModal ( 'CONFIRM' , {
message : < FormattedMessage id = 'confirmations.block.message' defaultMessage = 'Are you sure you want to block {name}?' values = { { name : < strong > @ { account . get ( 'acct' ) } < /strong> }} / > ,
confirm : intl . formatMessage ( messages . blockConfirm ) ,
2017-05-20 18:31:47 +03:00
onConfirm : ( ) => dispatch ( blockAccount ( account . get ( 'id' ) ) ) ,
2017-04-23 05:39:50 +03:00
} ) ) ;
2017-01-30 22:40:55 +02:00
}
} ,
onMention ( account , router ) {
dispatch ( mentionCompose ( account , router ) ) ;
2017-02-14 21:59:26 +02:00
} ,
onReport ( account ) {
dispatch ( initReport ( account ) ) ;
2017-02-06 03:51:56 +02:00
} ,
onMute ( account ) {
if ( account . getIn ( [ 'relationship' , 'muting' ] ) ) {
dispatch ( unmuteAccount ( account . get ( 'id' ) ) ) ;
} else {
2017-08-07 01:43:58 +03:00
dispatch ( initMuteModal ( account ) ) ;
2017-02-06 03:51:56 +02:00
}
2017-05-19 22:05:32 +03:00
} ,
onBlockDomain ( domain , accountId ) {
dispatch ( openModal ( 'CONFIRM' , {
message : < FormattedMessage id = 'confirmations.domain_block.message' defaultMessage = 'Are you really, really sure you want to block the entire {domain}? In most cases a few targeted blocks or mutes are sufficient and preferable.' values = { { domain : < strong > { domain } < /strong> }} / > ,
confirm : intl . formatMessage ( messages . blockDomainConfirm ) ,
2017-05-20 18:31:47 +03:00
onConfirm : ( ) => dispatch ( blockDomain ( domain , accountId ) ) ,
2017-05-19 22:05:32 +03:00
} ) ) ;
} ,
onUnblockDomain ( domain , accountId ) {
dispatch ( unblockDomain ( domain , accountId ) ) ;
2017-05-20 18:31:47 +03:00
} ,
2017-07-18 18:14:43 +03:00
2017-01-30 22:40:55 +02:00
} ) ;
2017-04-23 05:39:50 +03:00
export default injectIntl ( connect ( makeMapStateToProps , mapDispatchToProps ) ( Header ) ) ;