import React from 'react'; import PropTypes from 'prop-types'; import { connect } from 'react-redux'; import ImmutablePropTypes from 'react-immutable-proptypes'; import HoverRefWrapper from 'soapbox/components/hover_ref_wrapper'; import { displayFqn } from 'soapbox/utils/state'; import { isVerified } from 'soapbox/utils/accounts'; import { getAcct } from '../utils/accounts'; import VerificationBadge from './verification_badge'; import Icon from './icon'; import RelativeTimestamp from './relative_timestamp'; const mapStateToProps = state => { return { displayFqn: displayFqn(state), }; }; export default @connect(mapStateToProps) class DisplayName extends React.PureComponent { static propTypes = { account: ImmutablePropTypes.map.isRequired, displayFqn: PropTypes.bool, others: ImmutablePropTypes.list, children: PropTypes.node, withDate: PropTypes.bool, }; static defaultProps = { withDate: false, } render() { const { account, displayFqn, others, children, withDate } = this.props; let displayName, suffix; const verified = isVerified(account); const createdAt = account.get('created_at'); const joinedAt = createdAt ? (