|
|
@ -6,9 +6,9 @@ import { createSelector } from 'reselect'; |
|
|
|
import { debounce } from 'lodash'; |
|
|
|
import { me } from '../../../initial_state'; |
|
|
|
|
|
|
|
const makeGetStatusIds = () => createSelector([ |
|
|
|
const makeGetStatusIds = (pending = false) => createSelector([ |
|
|
|
(state, { type }) => state.getIn(['settings', type], ImmutableMap()), |
|
|
|
(state, { type }) => state.getIn(['timelines', type, 'items'], ImmutableList()), |
|
|
|
(state, { type }) => state.getIn(['timelines', type, pending ? 'pendingItems' : 'items'], ImmutableList()), |
|
|
|
(state) => state.get('statuses'), |
|
|
|
], (columnSettings, statusIds, statuses) => { |
|
|
|
return statusIds.filter(id => { |
|
|
@ -31,13 +31,14 @@ const makeGetStatusIds = () => createSelector([ |
|
|
|
|
|
|
|
const makeMapStateToProps = () => { |
|
|
|
const getStatusIds = makeGetStatusIds(); |
|
|
|
const getPendingStatusIds = makeGetStatusIds(true); |
|
|
|
|
|
|
|
const mapStateToProps = (state, { timelineId }) => ({ |
|
|
|
statusIds: getStatusIds(state, { type: timelineId }), |
|
|
|
isLoading: state.getIn(['timelines', timelineId, 'isLoading'], true), |
|
|
|
isPartial: state.getIn(['timelines', timelineId, 'isPartial'], false), |
|
|
|
hasMore: state.getIn(['timelines', timelineId, 'hasMore']), |
|
|
|
numPending: state.getIn(['timelines', timelineId, 'pendingItems'], ImmutableList()).size, |
|
|
|
numPending: getPendingStatusIds(state, { type: timelineId }).size, |
|
|
|
}); |
|
|
|
|
|
|
|
return mapStateToProps; |
|
|
|