chinwagsocial/app/assets/javascripts/components/features/ui/containers/status_list_container.jsx

41 lines
1.1 KiB
React
Raw Normal View History

import { connect } from 'react-redux';
import StatusList from '../../../components/status_list';
import { replyCompose } from '../../../actions/compose';
import { reblog, favourite } from '../../../actions/interactions';
2016-09-22 09:08:35 +10:00
import { expandTimeline } from '../../../actions/timelines';
import { selectStatus } from '../../../reducers/timelines';
2016-09-30 08:00:45 +10:00
import { deleteStatus } from '../../../actions/statuses';
const mapStateToProps = function (state, props) {
return {
2016-09-30 08:00:45 +10:00
statuses: state.getIn(['timelines', props.type]).map(id => selectStatus(state, id)),
me: state.getIn(['timelines', 'me'])
};
};
2016-09-22 09:08:35 +10:00
const mapDispatchToProps = function (dispatch, props) {
2016-09-01 06:58:10 +10:00
return {
2016-09-30 08:00:45 +10:00
onReply (status) {
2016-09-01 06:58:10 +10:00
dispatch(replyCompose(status));
},
2016-09-30 08:00:45 +10:00
onFavourite (status) {
dispatch(favourite(status));
},
2016-09-30 08:00:45 +10:00
onReblog (status) {
dispatch(reblog(status));
2016-09-22 09:08:35 +10:00
},
2016-09-30 08:00:45 +10:00
onScrollToBottom () {
2016-09-22 09:08:35 +10:00
dispatch(expandTimeline(props.type));
2016-09-30 08:00:45 +10:00
},
onDelete (status) {
dispatch(deleteStatus(status.get('id')));
2016-09-01 06:58:10 +10:00
}
};
};
export default connect(mapStateToProps, mapDispatchToProps)(StatusList);