|
|
@ -17,6 +17,8 @@ import { fetchAccountIdentityProofs } from '../../actions/identity_proofs'; |
|
|
|
import MissingIndicator from 'flavours/glitch/components/missing_indicator'; |
|
|
|
import MissingIndicator from 'flavours/glitch/components/missing_indicator'; |
|
|
|
import TimelineHint from 'flavours/glitch/components/timeline_hint'; |
|
|
|
import TimelineHint from 'flavours/glitch/components/timeline_hint'; |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
const emptyList = ImmutableList(); |
|
|
|
|
|
|
|
|
|
|
|
const mapStateToProps = (state, { params: { accountId }, withReplies = false }) => { |
|
|
|
const mapStateToProps = (state, { params: { accountId }, withReplies = false }) => { |
|
|
|
const path = withReplies ? `${accountId}:with_replies` : accountId; |
|
|
|
const path = withReplies ? `${accountId}:with_replies` : accountId; |
|
|
|
|
|
|
|
|
|
|
@ -28,6 +30,7 @@ const mapStateToProps = (state, { params: { accountId }, withReplies = false }) |
|
|
|
featuredStatusIds: withReplies ? ImmutableList() : state.getIn(['timelines', `account:${accountId}:pinned`, 'items'], ImmutableList()), |
|
|
|
featuredStatusIds: withReplies ? ImmutableList() : state.getIn(['timelines', `account:${accountId}:pinned`, 'items'], ImmutableList()), |
|
|
|
isLoading: state.getIn(['timelines', `account:${path}`, 'isLoading']), |
|
|
|
isLoading: state.getIn(['timelines', `account:${path}`, 'isLoading']), |
|
|
|
hasMore: state.getIn(['timelines', `account:${path}`, 'hasMore']), |
|
|
|
hasMore: state.getIn(['timelines', `account:${path}`, 'hasMore']), |
|
|
|
|
|
|
|
suspended: state.getIn(['accounts', accountId, 'suspended'], false), |
|
|
|
}; |
|
|
|
}; |
|
|
|
}; |
|
|
|
}; |
|
|
|
|
|
|
|
|
|
|
@ -51,6 +54,7 @@ class AccountTimeline extends ImmutablePureComponent { |
|
|
|
hasMore: PropTypes.bool, |
|
|
|
hasMore: PropTypes.bool, |
|
|
|
withReplies: PropTypes.bool, |
|
|
|
withReplies: PropTypes.bool, |
|
|
|
isAccount: PropTypes.bool, |
|
|
|
isAccount: PropTypes.bool, |
|
|
|
|
|
|
|
suspended: PropTypes.bool, |
|
|
|
remote: PropTypes.bool, |
|
|
|
remote: PropTypes.bool, |
|
|
|
remoteUrl: PropTypes.string, |
|
|
|
remoteUrl: PropTypes.string, |
|
|
|
multiColumn: PropTypes.bool, |
|
|
|
multiColumn: PropTypes.bool, |
|
|
@ -91,7 +95,7 @@ class AccountTimeline extends ImmutablePureComponent { |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
render () { |
|
|
|
render () { |
|
|
|
const { statusIds, featuredStatusIds, isLoading, hasMore, isAccount, multiColumn, remote, remoteUrl } = this.props; |
|
|
|
const { statusIds, featuredStatusIds, isLoading, hasMore, suspended, isAccount, multiColumn, remote, remoteUrl } = this.props; |
|
|
|
|
|
|
|
|
|
|
|
if (!isAccount) { |
|
|
|
if (!isAccount) { |
|
|
|
return ( |
|
|
|
return ( |
|
|
@ -112,7 +116,9 @@ class AccountTimeline extends ImmutablePureComponent { |
|
|
|
|
|
|
|
|
|
|
|
let emptyMessage; |
|
|
|
let emptyMessage; |
|
|
|
|
|
|
|
|
|
|
|
if (remote && statusIds.isEmpty()) { |
|
|
|
if (suspended) { |
|
|
|
|
|
|
|
emptyMessage = <FormattedMessage id='empty_column.account_unavailable' defaultMessage='Profile unavailable' />; |
|
|
|
|
|
|
|
} else if (remote && statusIds.isEmpty()) { |
|
|
|
emptyMessage = <RemoteHint url={remoteUrl} />; |
|
|
|
emptyMessage = <RemoteHint url={remoteUrl} />; |
|
|
|
} else { |
|
|
|
} else { |
|
|
|
emptyMessage = <FormattedMessage id='empty_column.account_timeline' defaultMessage='No toots here!' />; |
|
|
|
emptyMessage = <FormattedMessage id='empty_column.account_timeline' defaultMessage='No toots here!' />; |
|
|
@ -129,7 +135,7 @@ class AccountTimeline extends ImmutablePureComponent { |
|
|
|
alwaysPrepend |
|
|
|
alwaysPrepend |
|
|
|
append={remoteMessage} |
|
|
|
append={remoteMessage} |
|
|
|
scrollKey='account_timeline' |
|
|
|
scrollKey='account_timeline' |
|
|
|
statusIds={statusIds} |
|
|
|
statusIds={suspended ? emptyList : statusIds} |
|
|
|
featuredStatusIds={featuredStatusIds} |
|
|
|
featuredStatusIds={featuredStatusIds} |
|
|
|
isLoading={isLoading} |
|
|
|
isLoading={isLoading} |
|
|
|
hasMore={hasMore} |
|
|
|
hasMore={hasMore} |
|
|
|