Show boosted user's avatar (#2518)
* Show boosted user's avatar * add .status__avatar-boost * margin * apply to notifications too. * account__avatar-boost * Add inline prop to Avatar component * Add AvatarOverlay component * rename mixins.scss * move files for latest master * fixed for webpack
This commit is contained in:
		
					parent
					
						
							
								bf8031e984
							
						
					
				
			
			
				commit
				
					
						383c0b7802
					
				
			
		
					 7 changed files with 97 additions and 15 deletions
				
			
		|  | @ -2,6 +2,7 @@ import React from 'react'; | |||
| import ImmutablePropTypes from 'react-immutable-proptypes'; | ||||
| import PropTypes from 'prop-types'; | ||||
| import Avatar from './avatar'; | ||||
| import AvatarOverlay from './avatar_overlay'; | ||||
| import RelativeTimestamp from './relative_timestamp'; | ||||
| import DisplayName from './display_name'; | ||||
| import MediaGallery from './media_gallery'; | ||||
|  | @ -36,7 +37,8 @@ class Status extends ImmutablePureComponent { | |||
| 
 | ||||
|   render () { | ||||
|     let media = ''; | ||||
|     const { status, ...other } = this.props; | ||||
|     let statusAvatar; | ||||
|     const { status, account, ...other } = this.props; | ||||
| 
 | ||||
|     if (status === null) { | ||||
|       return <div />; | ||||
|  | @ -58,7 +60,7 @@ class Status extends ImmutablePureComponent { | |||
|             <FormattedMessage id='status.reblogged_by' defaultMessage='{name} boosted' values={{ name: <a onClick={this.handleAccountClick.bind(this, status.getIn(['account', 'id']))} href={status.getIn(['account', 'url'])} className='status__display-name muted'><strong dangerouslySetInnerHTML={displayNameHTML} /></a> }} /> | ||||
|           </div> | ||||
| 
 | ||||
|           <Status {...other} wrapped={true} status={status.get('reblog')} /> | ||||
|           <Status {...other} wrapped={true} status={status.get('reblog')} account={status.get('account')} /> | ||||
|         </div> | ||||
|       ); | ||||
|     } | ||||
|  | @ -73,6 +75,12 @@ class Status extends ImmutablePureComponent { | |||
|       } | ||||
|     } | ||||
| 
 | ||||
|     if (account === undefined || account === null) { | ||||
|       statusAvatar = <Avatar src={status.getIn(['account', 'avatar'])} staticSrc={status.getIn(['account', 'avatar_static'])} size={48}/>; | ||||
|     }else{ | ||||
|       statusAvatar = <AvatarOverlay staticSrc={status.getIn(['account', 'avatar_static'])} overlaySrc={account.get('avatar_static')} />; | ||||
|     } | ||||
| 
 | ||||
|     return ( | ||||
|       <div className={this.props.muted ? 'status muted' : 'status'}> | ||||
|         <div className='status__info'> | ||||
|  | @ -82,7 +90,7 @@ class Status extends ImmutablePureComponent { | |||
| 
 | ||||
|           <a onClick={this.handleAccountClick.bind(this, status.getIn(['account', 'id']))} href={status.getIn(['account', 'url'])} className='status__display-name'> | ||||
|             <div className='status__avatar'> | ||||
|               <Avatar src={status.getIn(['account', 'avatar'])} staticSrc={status.getIn(['account', 'avatar_static'])} size={48} /> | ||||
|               {statusAvatar} | ||||
|             </div> | ||||
| 
 | ||||
|             <DisplayName account={status.get('account')} /> | ||||
|  | @ -106,6 +114,7 @@ Status.contextTypes = { | |||
| 
 | ||||
| Status.propTypes = { | ||||
|   status: ImmutablePropTypes.map, | ||||
|   account: ImmutablePropTypes.map, | ||||
|   wrapped: PropTypes.bool, | ||||
|   onReply: PropTypes.func, | ||||
|   onFavourite: PropTypes.func, | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue