import PropTypes from 'prop-types'; import { FormattedMessage } from 'react-intl'; import { NavLink, withRouter } from 'react-router-dom'; import ImmutablePropTypes from 'react-immutable-proptypes'; import ImmutablePureComponent from 'react-immutable-pure-component'; import { WithRouterPropTypes } from 'mastodon/utils/react_router'; import InnerHeader from '../../account/components/header'; import MemorialNote from './memorial_note'; import MovedNote from './moved_note'; class Header extends ImmutablePureComponent { static propTypes = { account: ImmutablePropTypes.record, onFollow: PropTypes.func.isRequired, onBlock: PropTypes.func.isRequired, onMention: PropTypes.func.isRequired, onDirect: PropTypes.func.isRequired, onReblogToggle: PropTypes.func.isRequired, onReport: PropTypes.func.isRequired, onMute: PropTypes.func.isRequired, onBlockDomain: PropTypes.func.isRequired, onUnblockDomain: PropTypes.func.isRequired, onEndorseToggle: PropTypes.func.isRequired, onAddToList: PropTypes.func.isRequired, onChangeLanguages: PropTypes.func.isRequired, onInteractionModal: PropTypes.func.isRequired, onOpenAvatar: PropTypes.func.isRequired, onOpenURL: PropTypes.func.isRequired, hideTabs: PropTypes.bool, domain: PropTypes.string.isRequired, hidden: PropTypes.bool, ...WithRouterPropTypes, }; handleFollow = () => { this.props.onFollow(this.props.account); }; handleBlock = () => { this.props.onBlock(this.props.account); }; handleMention = () => { this.props.onMention(this.props.account, this.props.history); }; handleDirect = () => { this.props.onDirect(this.props.account, this.props.history); }; handleReport = () => { this.props.onReport(this.props.account); }; handleReblogToggle = () => { this.props.onReblogToggle(this.props.account); }; handleNotifyToggle = () => { this.props.onNotifyToggle(this.props.account); }; handleMute = () => { this.props.onMute(this.props.account); }; handleBlockDomain = () => { const domain = this.props.account.get('acct').split('@')[1]; if (!domain) return; this.props.onBlockDomain(domain); }; handleUnblockDomain = () => { const domain = this.props.account.get('acct').split('@')[1]; if (!domain) return; this.props.onUnblockDomain(domain); }; handleEndorseToggle = () => { this.props.onEndorseToggle(this.props.account); }; handleAddToList = () => { this.props.onAddToList(this.props.account); }; handleEditAccountNote = () => { this.props.onEditAccountNote(this.props.account); }; handleChangeLanguages = () => { this.props.onChangeLanguages(this.props.account); }; handleInteractionModal = () => { this.props.onInteractionModal(this.props.account); }; handleOpenAvatar = () => { this.props.onOpenAvatar(this.props.account); }; render () { const { account, hidden, hideTabs } = this.props; if (account === null) { return null; } return (