Merge pull request #404 from ThibG/glitch-soc/features/moved-note
[Untested] [Glitch] Profile redirect notesmaster
commit
1bd12cf8eb
@ -0,0 +1,48 @@ |
||||
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'; |
||||
|
||||
export default class MovedNote extends ImmutablePureComponent { |
||||
|
||||
static contextTypes = { |
||||
router: PropTypes.object, |
||||
}; |
||||
|
||||
static propTypes = { |
||||
from: ImmutablePropTypes.map.isRequired, |
||||
to: ImmutablePropTypes.map.isRequired, |
||||
}; |
||||
|
||||
handleAccountClick = e => { |
||||
if (e.button === 0) { |
||||
e.preventDefault(); |
||||
this.context.router.history.push(`/accounts/${this.props.to.get('id')}`); |
||||
} |
||||
|
||||
e.stopPropagation(); |
||||
} |
||||
|
||||
render () { |
||||
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'><i className='fa fa-fw fa-suitcase account__moved-note__icon' /></div> |
||||
<FormattedMessage id='account.moved_to' defaultMessage='{name} has moved to:' values={{ name: <strong dangerouslySetInnerHTML={displayNameHtml} /> }} /> |
||||
</div> |
||||
|
||||
<a href={to.get('url')} onClick={this.handleAccountClick} className='detailed-status__display-name'> |
||||
<div className='detailed-status__display-avatar'><AvatarOverlay account={to} friend={from} /></div> |
||||
<DisplayName account={to} /> |
||||
</a> |
||||
</div> |
||||
); |
||||
} |
||||
|
||||
} |
Loading…
Reference in new issue