import { List as ImmutableList, Record as ImmutableRecord } from 'immutable'; import { AnyAction } from 'redux'; import { LIST_ADDER_RESET, LIST_ADDER_SETUP, LIST_ADDER_LISTS_FETCH_REQUEST, LIST_ADDER_LISTS_FETCH_SUCCESS, LIST_ADDER_LISTS_FETCH_FAIL, LIST_EDITOR_ADD_SUCCESS, LIST_EDITOR_REMOVE_SUCCESS, } from '../actions/lists'; const ListsRecord = ImmutableRecord({ items: ImmutableList(), loaded: false, isLoading: false, }); const ReducerRecord = ImmutableRecord({ accountId: null as string | null, lists: ListsRecord(), }); type State = ReturnType; export default function listAdderReducer(state: State = ReducerRecord(), action: AnyAction) { switch (action.type) { case LIST_ADDER_RESET: return ReducerRecord(); case LIST_ADDER_SETUP: return state.withMutations(map => { map.set('accountId', action.account.get('id')); }); case LIST_ADDER_LISTS_FETCH_REQUEST: return state.setIn(['lists', 'isLoading'], true); case LIST_ADDER_LISTS_FETCH_FAIL: return state.setIn(['lists', 'isLoading'], false); case LIST_ADDER_LISTS_FETCH_SUCCESS: return state.update('lists', lists => lists.withMutations(map => { map.set('isLoading', false); map.set('loaded', true); map.set('items', ImmutableList(action.lists.map((item: { id: string }) => item.id))); })); case LIST_EDITOR_ADD_SUCCESS: return state.updateIn(['lists', 'items'], list => (list as ImmutableList).unshift(action.listId)); case LIST_EDITOR_REMOVE_SUCCESS: return state.updateIn(['lists', 'items'], list => (list as ImmutableList).filterNot(item => item === action.listId)); default: return state; } }