import { Fragment } from 'react' import { NavLink } from 'react-router-dom' import ImmutablePropTypes from 'react-immutable-proptypes' import { defineMessages, injectIntl } from 'react-intl' import ImmutablePureComponent from 'react-immutable-pure-component' import { me } from '../../initial_state' import Avatar from '../avatar' import DisplayName from '../display_name' import IconButton from '../icon_button' import Icon from '../icon' const messages = defineMessages({ follow: { id: 'account.follow', defaultMessage: 'Follow' }, unfollow: { id: 'account.unfollow', defaultMessage: 'Unfollow' }, requested: { id: 'account.requested', defaultMessage: 'Awaiting approval' }, unblock: { id: 'account.unblock', defaultMessage: 'Unblock @{name}' }, unmute: { id: 'account.unmute', defaultMessage: 'Unmute @{name}' }, mute_notifications: { id: 'account.mute_notifications', defaultMessage: 'Mute notifications from @{name}' }, unmute_notifications: { id: 'account.unmute_notifications', defaultMessage: 'Unmute notifications from @{name}' }, }) export default @injectIntl class Account extends ImmutablePureComponent { static propTypes = { account: ImmutablePropTypes.map.isRequired, onFollow: PropTypes.func.isRequired, onBlock: PropTypes.func.isRequired, onMute: PropTypes.func.isRequired, onMuteNotifications: PropTypes.func, intl: PropTypes.object.isRequired, hidden: PropTypes.bool, actionIcon: PropTypes.string, actionTitle: PropTypes.string, onActionClick: PropTypes.func, } handleFollow = () => { this.props.onFollow(this.props.account) } handleBlock = () => { this.props.onBlock(this.props.account) } handleMute = () => { this.props.onMute(this.props.account) } handleMuteNotifications = () => { this.props.onMuteNotifications(this.props.account, true) } handleUnmuteNotifications = () => { this.props.onMuteNotifications(this.props.account, false) } handleAction = () => { this.props.onActionClick(this.props.account) } render() { const { account, intl, hidden, onActionClick, actionIcon, actionTitle } = this.props if (!account) return null if (hidden) { return ( {account.get('display_name')} {account.get('username')} ) } let buttons if (onActionClick && actionIcon) { buttons = } else if (account.get('id') !== me && account.get('relationship', null) !== null) { const following = account.getIn(['relationship', 'following']) const requested = account.getIn(['relationship', 'requested']) const blocking = account.getIn(['relationship', 'blocking']) const muting = account.getIn(['relationship', 'muting']) if (requested) { buttons = } else if (blocking) { buttons = } else if (muting) { let hidingNotificationsButton if (account.getIn(['relationship', 'muting_notifications'])) { hidingNotificationsButton = } else { hidingNotificationsButton = } buttons = ( {hidingNotificationsButton} ) } else if (!account.get('moved') || following) { buttons = } } return (
) } }