import React from 'react' import PropTypes from 'prop-types' import { connect } from 'react-redux' import { injectIntl, defineMessages } from 'react-intl' import { makeGetAccount } from '../../selectors' import { muteAccount } from '../../actions/accounts' import ConfirmationModal from './confirmation_modal' const messages = defineMessages({ title: { id: 'mute_title', defaultMessage: 'Mute {name}' }, muteMessage: { id: 'confirmations.mute.message', defaultMessage: 'Are you sure you want to mute {name}?' }, mute: { id: 'confirmations.mute.confirm', defaultMessage: 'Mute' }, }) const mapStateToProps = (state, { accountId }) => { const getAccount = makeGetAccount() return { account: getAccount(state, accountId), } } const mapDispatchToProps = (dispatch) => ({ onConfirm(account, notifications) { dispatch(muteAccount(account.get('id'), notifications)) }, }) export default @connect(mapStateToProps, mapDispatchToProps) @injectIntl class MuteModal extends React.PureComponent { static propTypes = { account: PropTypes.object.isRequired, onConfirm: PropTypes.func.isRequired, intl: PropTypes.object.isRequired, onClose: PropTypes.func.isRequired, } handleClick = () => { this.props.onConfirm(this.props.account) } render() { const { account, intl, onClose } = this.props const title = intl.formatMessage(messages.title, { name: !!account ? account.get('acct') : '', }) const message = intl.formatMessage(messages.muteMessage, { name: !!account ? account.get('acct') : '', }) return ( ) } }