import PropTypes from 'prop-types'; import React from 'react'; import ImmutablePropTypes from 'react-immutable-proptypes'; import { connect } from 'react-redux'; import HoverRefWrapper from 'soapbox/components/hover_ref_wrapper'; import { isVerified } from 'soapbox/utils/accounts'; import { displayFqn } from 'soapbox/utils/state'; import { getAcct } from '../utils/accounts'; import Icon from './icon'; import RelativeTimestamp from './relative_timestamp'; import VerificationBadge from './verification_badge'; 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 ? (
) : null; if (others?.size > 1) { displayName = others.take(2).map(a => ( {verified && } {withDate && joinedAt} )).reduce((prev, cur) => [prev, ', ', cur]); if (others.size - 2 > 0) { suffix = `+${others.size - 2}`; } } else { displayName = ( {verified && } {withDate && joinedAt} ); suffix = @{getAcct(account, displayFqn)}; } return ( {displayName} {suffix} {children} ); } }