import ImmutablePureComponent from 'react-immutable-pure-component' import ImmutablePropTypes from 'react-immutable-proptypes' import debounce from 'lodash.debounce' import { defineMessages, injectIntl } from 'react-intl' import { fetchFollowing, expandFollowing, } from '../actions/accounts' import Account from '../components/account' import ScrollableList from '../components/scrollable_list' import Block from '../components/block' import Heading from '../components/heading' const mapStateToProps = (state, { account }) => { const accountId = !!account ? account.get('id') : -1 return { accountId, accountIds: state.getIn(['user_lists', 'following', accountId, 'items']), hasMore: !!state.getIn(['user_lists', 'following', accountId, 'next']), } } const messages = defineMessages({ follows: { id: 'account.follows', defaultMessage: 'Follows' }, empty: { id: 'account.follows.empty', defaultMessage: 'This user doesn\'t follow anyone yet.' }, }) export default @connect(mapStateToProps) @injectIntl class Following extends ImmutablePureComponent { static propTypes = { intl: PropTypes.object.isRequired, params: PropTypes.object.isRequired, dispatch: PropTypes.func.isRequired, accountIds: ImmutablePropTypes.list, account: ImmutablePropTypes.map, accountId: PropTypes.string, hasMore: PropTypes.bool, } componentDidMount() { const { accountId } = this.props if (!!accountId && accountId !== -1) { this.props.dispatch(fetchFollowing(accountId)) } } componentWillReceiveProps(nextProps) { if (!!nextProps.accountId && nextProps.accountId !== -1 && nextProps.accountId !== this.props.accountId) { this.props.dispatch(fetchFollowing(nextProps.accountId)) } } handleLoadMore = debounce(() => { const { accountId } = this.props if (!!accountId && accountId !== -1) { this.props.dispatch(expandFollowing(accountId)) } }, 300, { leading: true }) render() { const { account, accountIds, hasMore, intl, } = this.props if (!account) return null return (
{intl.formatMessage(messages.follows)}
{ !!accountIds && accountIds.map((id) => ( )) }
) } }