import PropTypes from 'prop-types'; import React from 'react'; import ImmutablePropTypes from 'react-immutable-proptypes'; import ImmutablePureComponent from 'react-immutable-pure-component'; import { defineMessages, injectIntl } from 'react-intl'; import { NavLink } from 'react-router-dom'; import Button from 'soapbox/components/button'; import DropdownMenuContainer from '../../../../containers/dropdown_menu_container'; const messages = defineMessages({ join: { id: 'groups.join', defaultMessage: 'Join group' }, leave: { id: 'groups.leave', defaultMessage: 'Leave group' }, removed_accounts: { id: 'groups.removed_accounts', defaultMessage: 'Removed Accounts' }, edit: { id: 'groups.edit', defaultMessage: 'Edit' }, }); export default @injectIntl class Header extends ImmutablePureComponent { static propTypes = { group: ImmutablePropTypes.map, relationships: ImmutablePropTypes.map, toggleMembership: PropTypes.func.isRequired, }; toggle = () => { const { group, relationships, toggleMembership } = this.props; toggleMembership(group, relationships); } getActionButton() { const { group, relationships, intl } = this.props; if (!relationships) { return ''; } else if (!relationships.get('member')) { return