import React from 'react' import PropTypes from 'prop-types' import { connect } from 'react-redux' import ImmutablePureComponent from 'react-immutable-pure-component' import ImmutablePropTypes from 'react-immutable-proptypes' import { FormattedMessage } from 'react-intl' import { fetchLikes } from '../actions/interactions' import { fetchStatus } from '../actions/statuses' import { makeGetStatus } from '../selectors' import Account from '../components/account' import ColumnIndicator from '../components/column_indicator' import ScrollableList from '../components/scrollable_list' class StatusLikes extends ImmutablePureComponent { componentWillMount () { this.props.dispatch(fetchLikes(this.props.statusId)) this.props.dispatch(fetchStatus(this.props.statusId)) } componentWillReceiveProps(nextProps) { if (nextProps.statusId !== this.props.statusId && nextProps.statusId) { this.props.dispatch(fetchLikes(nextProps.statusId)) this.props.dispatch(fetchStatus(nextProps.statusId)) } } render () { const { accountIds, status } = this.props if (!accountIds) { return } else if (!status) { return } return ( } > { accountIds.map(id => ) } ) } } const mapStateToProps = (state, props) => { const statusId = props.params ? props.params.statusId : props.statusId const getStatus = makeGetStatus() const status = getStatus(state, { id: statusId }) return { status, statusId, accountIds: state.getIn(['user_lists', 'liked_by', statusId]), } } StatusLikes.propTypes = { accountIds: ImmutablePropTypes.list, dispatch: PropTypes.func.isRequired, status: ImmutablePropTypes.map, statusId: PropTypes.string.isRequired, } export default connect(mapStateToProps)(StatusLikes)