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 { connect } from 'react-redux'; import Avatar from 'soapbox/components/avatar'; import DisplayName from 'soapbox/components/display_name'; import Icon from 'soapbox/components/icon'; import Permalink from 'soapbox/components/permalink'; import { makeGetAccount } from 'soapbox/selectors'; const messages = defineMessages({ birthDate: { id: 'account.birth_date', defaultMessage: 'Birth date: {date}' }, }); const makeMapStateToProps = () => { const getAccount = makeGetAccount(); const mapStateToProps = (state, { accountId }) => { const account = getAccount(state, accountId); return { account, }; }; return mapStateToProps; }; export default @connect(makeMapStateToProps) @injectIntl class Account extends ImmutablePureComponent { static propTypes = { accountId: PropTypes.string.isRequired, intl: PropTypes.object.isRequired, account: ImmutablePropTypes.map, }; static defaultProps = { added: false, }; componentDidMount() { const { account, accountId } = this.props; if (accountId && !account) { this.props.fetchAccount(accountId); } } render() { const { account, intl } = this.props; if (!account) return null; const birthDate = account.getIn(['pleroma', 'birth_date']); if (!birthDate) return null; const formattedBirthDate = intl.formatDate(birthDate, { day: 'numeric', month: 'short', year: 'numeric' }); return (