Home Reference Source

app/reducers/commentReducer.jsx

import moment from 'moment';
import _ from 'lodash';

// - Import action types
import * as types from 'actionTypes';

// Default state
let defaultState = {
    postComments: {},
    loaded: false
};

/**
 * Comment actions
 * @param {object} state 
 * @param {object} action 
 */
export let commentReducer = (state = defaultState, action) => {
    let { payload } = action;
    switch (action.type) {
        /* _____________ CRUD _____________ */
        case types.ADD_COMMENT:
            return {
                ...state,
                postComments: {
                    ...state.postComments,
                    [payload.postId]: {
                        ...state.postComments[payload.postId],
                        [payload.id]: {
                            ...payload.comment,
                            editorStatus: false
                        }
                    }
                }
            };
        case types.ADD_COMMENT_LIST:
            return {
                ...state,
                postComments: {
                    ...payload
                },
                loaded: true
            };
        case types.UPDATE_COMMENT:
            return {
                ...state,
                postComments: {
                    ...state.postComments,
                    [payload.postId]: {
                        ...state.postComments[payload.postId],
                        [payload.id]: {
                            ...state.postComments[payload.postId][payload.id],
                            text: payload.text,
                            editorStatus: payload.editorStatus
                        }
                    }
                }
            };
        case types.DELETE_COMMENT:
            let parsedComments = {};

            if (!state.postComments[payload.postId]) {
                return state;
            }

            Object.keys(state.postComments[payload.postId]).map((id) => {
                if (id !== payload.id) {
                    _.merge(parsedComments, { [id]: { ...state.postComments[payload.postId][id] } })
                }
            });

            return {
                ...state,
                postComments: {
                    ...state.postComments,
                    [payload.postId]: {
                        ...parsedComments
                    }
                }
            };
        case types.CLOSE_COMMENT_EDITOR:
            return {
                ...state,
                postComments: {
                    ...state.postComments,
                    [payload.postId]: {
                        ...state.postComments[payload.postId],
                        [payload.id]: {
                            ...state.postComments[payload.postId][payload.id],
                            editorStatus: false
                        }
                    }
                }
            };
        case types.OPEN_COMMENT_EDITOR:
            return {
                ...state,
                postComments: {
                    ...state.postComments,
                    [payload.postId]: {
                        ...state.postComments[payload.postId],
                        [payload.id]: {
                            ...state.postComments[payload.postId][payload.id],
                            editorStatus: true
                        }
                    }
                }
            };
        case types.CLEAR_ALL_DATA_COMMENT:
            return defaultState;
        default:
            return state;
    }
}