2020-03-27 13:59:38 -07:00
import React from 'react' ;
import PropTypes from 'prop-types' ;
import ImmutablePropTypes from 'react-immutable-proptypes' ;
import { FormattedMessage } from 'react-intl' ;
import ImmutablePureComponent from 'react-immutable-pure-component' ;
import AvatarOverlay from '../../../components/avatar_overlay' ;
import DisplayName from '../../../components/display_name' ;
2020-05-28 15:52:07 -07:00
import Icon from 'soapbox/components/icon' ;
2020-03-27 13:59:38 -07:00
import { NavLink } from 'react-router-dom' ;
export default class MovedNote extends ImmutablePureComponent {
static contextTypes = {
router : PropTypes . object ,
} ;
static propTypes = {
from : ImmutablePropTypes . map . isRequired ,
to : ImmutablePropTypes . map . isRequired ,
} ;
2020-04-14 14:47:35 -07:00
render ( ) {
2020-03-27 13:59:38 -07:00
const { from , to } = this . props ;
const displayNameHtml = { _ _html : from . get ( 'display_name_html' ) } ;
return (
< div className = 'account__moved-note' >
< div className = 'account__moved-note__message' >
< div className = 'account__moved-note__icon-wrapper' > < Icon id = 'suitcase' className = 'account__moved-note__icon' fixedWidth / > < / d i v >
< FormattedMessage id = 'account.moved_to' defaultMessage = '{name} has moved to:' values = { { name : < bdi > < strong dangerouslySetInnerHTML = { displayNameHtml } / > < /bdi> }} / >
< / d i v >
< NavLink to = { ` /@ ${ this . props . to . get ( 'acct' ) } ` } className = 'detailed-status__display-name' >
< div className = 'detailed-status__display-avatar' > < AvatarOverlay account = { to } friend = { from } / > < / d i v >
< DisplayName account = { to } / >
< / N a v L i n k >
< / d i v >
) ;
}
}