2020-03-27 13:59:38 -07:00
import React from 'react' ;
import { defineMessages , injectIntl , FormattedMessage } from 'react-intl' ;
2022-01-10 14:17:52 -08:00
import { connect } from 'react-redux' ;
2022-01-10 14:01:24 -08:00
import { blockDomain , unblockDomain } from '../actions/domain_blocks' ;
2020-03-27 13:59:38 -07:00
import { openModal } from '../actions/modal' ;
2022-01-10 14:17:52 -08:00
import Domain from '../components/domain' ;
2020-03-27 13:59:38 -07:00
const messages = defineMessages ( {
blockDomainConfirm : { id : 'confirmations.domain_block.confirm' , defaultMessage : 'Hide entire domain' } ,
} ) ;
const makeMapStateToProps = ( ) => {
const mapStateToProps = ( ) => ( { } ) ;
return mapStateToProps ;
} ;
const mapDispatchToProps = ( dispatch , { intl } ) => ( {
2020-04-14 14:47:35 -07:00
onBlockDomain ( domain ) {
2020-03-27 13:59:38 -07:00
dispatch ( openModal ( 'CONFIRM' , {
2021-12-30 08:38:57 -08:00
icon : require ( '@tabler/icons/icons/ban.svg' ) ,
heading : < FormattedMessage id = 'confirmations.domain_block.heading' defaultMessage = 'Block {domain}' values = { { domain } } / > ,
2020-03-27 13:59:38 -07:00
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 ) ,
onConfirm : ( ) => dispatch ( blockDomain ( domain ) ) ,
} ) ) ;
} ,
2020-04-14 14:47:35 -07:00
onUnblockDomain ( domain ) {
2020-03-27 13:59:38 -07:00
dispatch ( unblockDomain ( domain ) ) ;
} ,
} ) ;
export default injectIntl ( connect ( makeMapStateToProps , mapDispatchToProps ) ( Domain ) ) ;