static-cms/src/reducers/editorialWorkflow.js

100 lines
3.4 KiB
JavaScript
Raw Normal View History

2016-09-06 13:04:17 -03:00
import { Map, List, fromJS } from 'immutable';
import { status, EDITORIAL_WORKFLOW } from '../constants/publishModes';
2016-09-06 13:04:17 -03:00
import {
2016-09-13 16:00:24 -03:00
UNPUBLISHED_ENTRY_REQUEST,
UNPUBLISHED_ENTRY_SUCCESS,
UNPUBLISHED_ENTRIES_REQUEST,
UNPUBLISHED_ENTRIES_SUCCESS,
UNPUBLISHED_ENTRY_PERSIST_REQUEST,
UNPUBLISHED_ENTRY_STATUS_CHANGE_REQUEST,
UNPUBLISHED_ENTRY_PUBLISH_REQUEST,
2016-09-06 13:04:17 -03:00
} from '../actions/editorialWorkflow';
import { CONFIG_SUCCESS } from '../actions/config';
2016-09-06 13:04:17 -03:00
2016-09-08 16:18:38 -03:00
const unpublishedEntries = (state = null, action) => {
const publishMode = action.payload && action.payload.publish_mode;
2016-09-06 13:04:17 -03:00
switch (action.type) {
case CONFIG_SUCCESS:
if (publishMode === EDITORIAL_WORKFLOW) {
// Editorial workflow state is explicetelly initiated after the config.
return Map({ entities: Map(), pages: Map() });
}
return state;
2016-09-13 04:09:52 -03:00
case UNPUBLISHED_ENTRY_REQUEST:
return state.setIn(['entities', `${ action.payload.status }.${ action.payload.slug }`, 'isFetching'], true);
2016-09-13 04:09:52 -03:00
case UNPUBLISHED_ENTRY_SUCCESS:
return state.setIn(
['entities', `${ action.payload.status }.${ action.payload.entry.slug }`],
2016-09-13 04:09:52 -03:00
fromJS(action.payload.entry)
);
2016-09-06 13:04:17 -03:00
case UNPUBLISHED_ENTRIES_REQUEST:
return state.setIn(['pages', 'isFetching'], true);
case UNPUBLISHED_ENTRIES_SUCCESS:
const { entries, pages } = action.payload;
return state.withMutations((map) => {
entries.forEach(entry => (
map.setIn(['entities', `${ entry.metaData.status }.${ entry.slug }`], fromJS(entry).set('isFetching', false))
2016-09-06 13:04:17 -03:00
));
map.set('pages', Map({
...pages,
ids: List(entries.map(entry => entry.slug)),
2016-09-06 13:04:17 -03:00
}));
});
2016-09-13 16:00:24 -03:00
case UNPUBLISHED_ENTRY_PERSIST_REQUEST:
// Update Optimistically
const { collection, entry } = action.payload;
const ownStatus = entry.getIn(['metaData', 'status'], status.first());
return state.withMutations((map) => {
map.setIn(['entities', `${ ownStatus }.${ entry.get('slug') }`], fromJS(entry));
map.updateIn(['pages', 'ids'], List(), list => list.push(entry.get('slug')));
});
case UNPUBLISHED_ENTRY_STATUS_CHANGE_REQUEST:
// Update Optimistically
2016-09-13 16:00:24 -03:00
return state.withMutations((map) => {
let entry = map.getIn(['entities', `${ action.payload.oldStatus }.${ action.payload.slug }`]);
2016-09-14 18:25:45 -03:00
entry = entry.setIn(['metaData', 'status'], action.payload.newStatus);
2016-09-13 16:00:24 -03:00
let entities = map.get('entities').filter((val, key) => (
key !== `${ action.payload.oldStatus }.${ action.payload.slug }`
2016-09-13 16:00:24 -03:00
));
entities = entities.set(`${ action.payload.newStatus }.${ action.payload.slug }`, entry);
2016-09-13 16:00:24 -03:00
map.set('entities', entities);
});
case UNPUBLISHED_ENTRY_PUBLISH_REQUEST:
// Update Optimistically
return state.deleteIn(['entities', `${ action.payload.status }.${ action.payload.slug }`]);
2016-09-14 18:25:45 -03:00
2016-09-06 13:04:17 -03:00
default:
return state;
}
};
export const selectUnpublishedEntry = (state, status, slug) => {
return state && state.getIn(['entities', `${ status }.${ slug }`]);
};
2016-09-06 13:04:17 -03:00
export const selectUnpublishedEntries = (state, status) => {
2016-09-08 16:18:38 -03:00
if (!state) return;
2016-09-06 13:04:17 -03:00
const slugs = state.getIn(['pages', 'ids']);
2016-09-08 19:04:54 -03:00
return slugs && slugs.reduce((acc, slug) => {
const entry = selectUnpublishedEntry(state, status, slug);
if (entry) {
return acc.push(entry);
} else {
return acc;
}
}, List());
2016-09-06 13:04:17 -03:00
};
2016-09-08 19:04:54 -03:00
2016-09-06 13:04:17 -03:00
export default unpublishedEntries;