Add indication that you have been blocked in web UI (#10420)
This commit is contained in:
		
							parent
							
								
									1d62b88f8d
								
							
						
					
					
						commit
						bd02ec6daa
					
				
					 5 changed files with 34 additions and 20 deletions
				
			
		|  | @ -14,14 +14,17 @@ import ImmutablePureComponent from 'react-immutable-pure-component'; | |||
| import { FormattedMessage } from 'react-intl'; | ||||
| import { fetchAccountIdentityProofs } from '../../actions/identity_proofs'; | ||||
| 
 | ||||
| const emptyList = ImmutableList(); | ||||
| 
 | ||||
| const mapStateToProps = (state, { params: { accountId }, withReplies = false }) => { | ||||
|   const path = withReplies ? `${accountId}:with_replies` : accountId; | ||||
| 
 | ||||
|   return { | ||||
|     statusIds: state.getIn(['timelines', `account:${path}`, 'items'], ImmutableList()), | ||||
|     featuredStatusIds: withReplies ? ImmutableList() : state.getIn(['timelines', `account:${accountId}:pinned`, 'items'], ImmutableList()), | ||||
|     statusIds: state.getIn(['timelines', `account:${path}`, 'items'], emptyList), | ||||
|     featuredStatusIds: withReplies ? ImmutableList() : state.getIn(['timelines', `account:${accountId}:pinned`, 'items'], emptyList), | ||||
|     isLoading: state.getIn(['timelines', `account:${path}`, 'isLoading']), | ||||
|     hasMore:   state.getIn(['timelines', `account:${path}`, 'hasMore']), | ||||
|     hasMore: state.getIn(['timelines', `account:${path}`, 'hasMore']), | ||||
|     blockedBy: state.getIn(['relationships', accountId, 'blocked_by'], false), | ||||
|   }; | ||||
| }; | ||||
| 
 | ||||
|  | @ -37,6 +40,7 @@ class AccountTimeline extends ImmutablePureComponent { | |||
|     isLoading: PropTypes.bool, | ||||
|     hasMore: PropTypes.bool, | ||||
|     withReplies: PropTypes.bool, | ||||
|     blockedBy: PropTypes.bool, | ||||
|   }; | ||||
| 
 | ||||
|   componentWillMount () { | ||||
|  | @ -44,9 +48,11 @@ class AccountTimeline extends ImmutablePureComponent { | |||
| 
 | ||||
|     this.props.dispatch(fetchAccount(accountId)); | ||||
|     this.props.dispatch(fetchAccountIdentityProofs(accountId)); | ||||
| 
 | ||||
|     if (!withReplies) { | ||||
|       this.props.dispatch(expandAccountFeaturedTimeline(accountId)); | ||||
|     } | ||||
| 
 | ||||
|     this.props.dispatch(expandAccountTimeline(accountId, { withReplies })); | ||||
|   } | ||||
| 
 | ||||
|  | @ -54,9 +60,11 @@ class AccountTimeline extends ImmutablePureComponent { | |||
|     if ((nextProps.params.accountId !== this.props.params.accountId && nextProps.params.accountId) || nextProps.withReplies !== this.props.withReplies) { | ||||
|       this.props.dispatch(fetchAccount(nextProps.params.accountId)); | ||||
|       this.props.dispatch(fetchAccountIdentityProofs(nextProps.params.accountId)); | ||||
| 
 | ||||
|       if (!nextProps.withReplies) { | ||||
|         this.props.dispatch(expandAccountFeaturedTimeline(nextProps.params.accountId)); | ||||
|       } | ||||
| 
 | ||||
|       this.props.dispatch(expandAccountTimeline(nextProps.params.accountId, { withReplies: nextProps.params.withReplies })); | ||||
|     } | ||||
|   } | ||||
|  | @ -66,7 +74,7 @@ class AccountTimeline extends ImmutablePureComponent { | |||
|   } | ||||
| 
 | ||||
|   render () { | ||||
|     const { shouldUpdateScroll, statusIds, featuredStatusIds, isLoading, hasMore } = this.props; | ||||
|     const { shouldUpdateScroll, statusIds, featuredStatusIds, isLoading, hasMore, blockedBy } = this.props; | ||||
| 
 | ||||
|     if (!statusIds && isLoading) { | ||||
|       return ( | ||||
|  | @ -76,6 +84,8 @@ class AccountTimeline extends ImmutablePureComponent { | |||
|       ); | ||||
|     } | ||||
| 
 | ||||
|     const emptyMessage = blockedBy ? <FormattedMessage id='empty_column.account_timeline_blocked' defaultMessage='You are blocked' /> : <FormattedMessage id='empty_column.account_timeline' defaultMessage='No toots here!' />; | ||||
| 
 | ||||
|     return ( | ||||
|       <Column> | ||||
|         <ColumnBackButton /> | ||||
|  | @ -84,13 +94,13 @@ class AccountTimeline extends ImmutablePureComponent { | |||
|           prepend={<HeaderContainer accountId={this.props.params.accountId} />} | ||||
|           alwaysPrepend | ||||
|           scrollKey='account_timeline' | ||||
|           statusIds={statusIds} | ||||
|           statusIds={blockedBy ? emptyList : statusIds} | ||||
|           featuredStatusIds={featuredStatusIds} | ||||
|           isLoading={isLoading} | ||||
|           hasMore={hasMore} | ||||
|           onLoadMore={this.handleLoadMore} | ||||
|           shouldUpdateScroll={shouldUpdateScroll} | ||||
|           emptyMessage={<FormattedMessage id='empty_column.account_timeline' defaultMessage='No toots here!' />} | ||||
|           emptyMessage={emptyMessage} | ||||
|         /> | ||||
|       </Column> | ||||
|     ); | ||||
|  |  | |||
		Reference in a new issue