department-of-veterans-affairs/vets-website

View on GitHub
src/applications/find-forms/reducers/findVAFormsReducer.js

Summary

Maintainability
A
2 hrs
Test Coverage
import cloneDeep from 'lodash/cloneDeep';
import { sortTheResults } from '../helpers';
import {
  FETCH_FORMS,
  FETCH_FORMS_FAILURE,
  FETCH_FORMS_SUCCESS,
  INITIAL_SORT_STATE,
  FAF_OPTION_CLOSEST_MATCH,
  UPDATE_HOW_TO_SORT,
  UPDATE_PAGINATION,
  UPDATE_RESULTS,
} from '../constants';

export const initialState = {
  error: '',
  fetching: false,
  page: 1,
  query: '',
  sortByPropertyName: INITIAL_SORT_STATE,
  results: null,
  closestMatchSearchResults: null,
  hasOnlyRetiredForms: false,
  startIndex: 0,
};

export default (state = initialState, action) => {
  switch (action.type) {
    case FETCH_FORMS: {
      return { ...state, error: '', fetching: true, query: action.query };
    }
    case FETCH_FORMS_FAILURE: {
      return { ...state, error: action.error, fetching: false };
    }
    case FETCH_FORMS_SUCCESS: {
      const clonedResults = cloneDeep(action.results);

      return {
        ...state,
        fetching: false,
        hasOnlyRetiredForms: action.hasOnlyRetiredForms,
        closestMatchSearchResults: action.results,
        results:
          state.sortByPropertyName === FAF_OPTION_CLOSEST_MATCH
            ? action.results
            : clonedResults.sort((a, b) =>
                sortTheResults(state.sortByPropertyName, a, b),
              ),
      };
    }
    case UPDATE_HOW_TO_SORT: {
      return { ...state, sortByPropertyName: action.sortByPropertyName };
    }
    case UPDATE_RESULTS: {
      const clonedResults = cloneDeep(action.results);

      return {
        ...state,
        results:
          state.sortByPropertyName === FAF_OPTION_CLOSEST_MATCH
            ? state.closestMatchSearchResults
            : clonedResults.sort((a, b) =>
                sortTheResults(state.sortByPropertyName, a, b),
              ),
      };
    }
    case UPDATE_PAGINATION: {
      return { ...state, page: action.page, startIndex: action.startIndex };
    }
    default: {
      return { ...state };
    }
  }
};