header_container.js (2970B)
- import React from 'react';
- import { connect } from 'react-redux';
- import { makeGetAccount } from '../../../selectors';
- import Header from '../components/header';
- import {
- followAccount,
- unfollowAccount,
- blockAccount,
- unblockAccount,
- unmuteAccount,
- } from '../../../actions/accounts';
- import {
- mentionCompose,
- directCompose,
- } from '../../../actions/compose';
- import { initMuteModal } from '../../../actions/mutes';
- import { openModal } from '../../../actions/modal';
- import { defineMessages, injectIntl, FormattedMessage } from 'react-intl';
- import { unfollowModal } from '../../../initial_state';
- const messages = defineMessages({
- unfollowConfirm: { id: 'confirmations.unfollow.confirm', defaultMessage: 'Unfollow' },
- blockConfirm: { id: 'confirmations.block.confirm', defaultMessage: 'Block' },
- });
- const makeMapStateToProps = () => {
- const getAccount = makeGetAccount();
- const mapStateToProps = (state, { accountId }) => ({
- account: getAccount(state, accountId),
- });
- return mapStateToProps;
- };
- const mapDispatchToProps = (dispatch, { intl }) => ({
- onFollow (account) {
- if (account.getIn(['relationship', 'following']) || account.getIn(['relationship', 'requested'])) {
- if (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')));
- }
- } else {
- dispatch(followAccount(account.get('id')));
- }
- },
- onBlock (account) {
- if (account.getIn(['relationship', 'blocking'])) {
- dispatch(unblockAccount(account.get('id')));
- } else {
- 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),
- onConfirm: () => dispatch(blockAccount(account.get('id'))),
- }));
- }
- },
- onMention (account, router) {
- dispatch(mentionCompose(account, router));
- },
- onDirect (account, router) {
- dispatch(directCompose(account, router));
- },
- onReblogToggle (account) {
- if (account.getIn(['relationship', 'showing_reblogs'])) {
- dispatch(followAccount(account.get('id'), false));
- } else {
- dispatch(followAccount(account.get('id'), true));
- }
- },
- onMute (account) {
- if (account.getIn(['relationship', 'muting'])) {
- dispatch(unmuteAccount(account.get('id')));
- } else {
- dispatch(initMuteModal(account));
- }
- }
- });
- export default injectIntl(connect(makeMapStateToProps, mapDispatchToProps)(Header));