forked from fedi/mastodon
cf845fed38
Hide some components rather than unmounting them to allow to show again quickly and keep the view state such as the scrolled offset.
87 lines
2.7 KiB
JavaScript
87 lines
2.7 KiB
JavaScript
import { connect } from 'react-redux';
|
|
import ImmutablePropTypes from 'react-immutable-proptypes';
|
|
import PropTypes from 'prop-types';
|
|
import {
|
|
fetchAccount,
|
|
fetchAccountTimeline,
|
|
expandAccountTimeline
|
|
} from '../../actions/accounts';
|
|
import StatusList from '../../components/status_list';
|
|
import LoadingIndicator from '../../components/loading_indicator';
|
|
import Column from '../ui/components/column';
|
|
import HeaderContainer from './containers/header_container';
|
|
import ColumnBackButton from '../../components/column_back_button';
|
|
import Immutable from 'immutable';
|
|
|
|
const mapStateToProps = (state, props) => ({
|
|
statusIds: state.getIn(['timelines', 'accounts_timelines', Number(props.params.accountId), 'items'], Immutable.List()),
|
|
isLoading: state.getIn(['timelines', 'accounts_timelines', Number(props.params.accountId), 'isLoading']),
|
|
hasMore: !!state.getIn(['timelines', 'accounts_timelines', Number(props.params.accountId), 'next']),
|
|
me: state.getIn(['meta', 'me'])
|
|
});
|
|
|
|
class AccountTimeline extends React.PureComponent {
|
|
|
|
constructor (props, context) {
|
|
super(props, context);
|
|
this.handleScrollToBottom = this.handleScrollToBottom.bind(this);
|
|
}
|
|
|
|
componentWillMount () {
|
|
this.props.dispatch(fetchAccount(Number(this.props.params.accountId)));
|
|
this.props.dispatch(fetchAccountTimeline(Number(this.props.params.accountId)));
|
|
}
|
|
|
|
componentWillReceiveProps(nextProps) {
|
|
if (nextProps.params.accountId !== this.props.params.accountId && nextProps.params.accountId) {
|
|
this.props.dispatch(fetchAccount(Number(nextProps.params.accountId)));
|
|
this.props.dispatch(fetchAccountTimeline(Number(nextProps.params.accountId)));
|
|
}
|
|
}
|
|
|
|
handleScrollToBottom () {
|
|
if (!this.props.isLoading && this.props.hasMore) {
|
|
this.props.dispatch(expandAccountTimeline(Number(this.props.params.accountId)));
|
|
}
|
|
}
|
|
|
|
render () {
|
|
const { statusIds, isLoading, hasMore, me } = this.props;
|
|
|
|
if (!statusIds && isLoading) {
|
|
return (
|
|
<Column>
|
|
<LoadingIndicator />
|
|
</Column>
|
|
);
|
|
}
|
|
|
|
return (
|
|
<Column>
|
|
<ColumnBackButton />
|
|
|
|
<StatusList
|
|
prepend={<HeaderContainer accountId={this.props.params.accountId} />}
|
|
scrollKey='account_timeline'
|
|
statusIds={statusIds}
|
|
isLoading={isLoading}
|
|
hasMore={hasMore}
|
|
me={me}
|
|
onScrollToBottom={this.handleScrollToBottom}
|
|
/>
|
|
</Column>
|
|
);
|
|
}
|
|
|
|
}
|
|
|
|
AccountTimeline.propTypes = {
|
|
params: PropTypes.object.isRequired,
|
|
dispatch: PropTypes.func.isRequired,
|
|
statusIds: ImmutablePropTypes.list,
|
|
isLoading: PropTypes.bool,
|
|
hasMore: PropTypes.bool,
|
|
me: PropTypes.number.isRequired
|
|
};
|
|
|
|
export default connect(mapStateToProps)(AccountTimeline);
|