import PropTypes from 'prop-types'; import React from 'react'; import ImmutablePropTypes from 'react-immutable-proptypes'; import ImmutablePureComponent from 'react-immutable-pure-component'; import { connect } from 'react-redux'; import Avatar from 'soapbox/components/avatar'; import DisplayName from 'soapbox/components/display_name'; import Permalink from 'soapbox/components/permalink'; import ActionButton from 'soapbox/features/ui/components/action_button'; import { makeGetAccount } from 'soapbox/selectors'; const makeMapStateToProps = () => { const getAccount = makeGetAccount(); const mapStateToProps = (state, props) => ({ account: getAccount(state, props.id), }); return mapStateToProps; }; const getFirstSentence = str => { const arr = str.split(/(([.?!]+\s)|[.。?!\n•])/); return arr[0]; }; export default @connect(makeMapStateToProps) class Account extends ImmutablePureComponent { static propTypes = { account: ImmutablePropTypes.record.isRequired, intl: PropTypes.object.isRequired, dispatch: PropTypes.func.isRequired, }; render() { const { account } = this.props; return (