department-of-veterans-affairs/vets-website

View on GitHub
src/applications/personalization/view-dependents/manage-dependents/redux/reducers.js

Summary

Maintainability
B
5 hrs
Test Coverage
import { updateSchemasAndData } from 'platform/forms-system/src/js/state/helpers';

import {
  FORM_DATA_UPDATED,
  FORM_DATA_CLEANUP,
  FORM_DATA_SUBMIT_FAILED,
  FORM_DATA_SUBMIT_SUCCESS,
  FORM_DATA_SUBMIT_START,
} from './actions';

const initialState = {
  dependentsState: null,
  openFormlett: null,
  submittedDependents: [],
};

export function removeDependents(state = initialState, action) {
  // schema, uiSchema, and formData are already extracted based on index (stateKey) here.
  if (action.type === FORM_DATA_UPDATED) {
    const {
      data: newFormData,
      schema: newFormSchema,
      uiSchema: newUiSchema,
    } = updateSchemasAndData(
      action.formSchema,
      action.uiSchema,
      action.formData,
      true,
    );

    return {
      ...state,
      openFormlett: true,
      dependentsState: {
        ...state.dependentsState,
        [action.stateKey]: {
          uiSchema: newUiSchema,
          formSchema: newFormSchema,
          formData: newFormData,
        },
      },
    };
  }

  if (action.type === FORM_DATA_CLEANUP) {
    const nextDependentsState = state.dependentsState;
    delete nextDependentsState[action.stateKey];
    return {
      ...state,
      openFormlett: null,
      dependentsState: nextDependentsState,
    };
  }

  if (action.type === FORM_DATA_SUBMIT_START) {
    return {
      ...state,
      dependentsState: {
        ...state.dependentsState,
        [action.stateKey]: {
          ...state.dependentsState[action.stateKey],
          status: action.status,
        },
      },
    };
  }

  // we want to clean up the data but also keep track of
  // which dependents have been submitted. We need to
  // switch off openFormlett and include a way to track
  // which indexes have been submitted
  if (action.type === FORM_DATA_SUBMIT_SUCCESS) {
    return {
      ...state,
      openFormlett: null,
      submittedDependents: [...state.submittedDependents, action.stateKey],
      dependentsState: {
        ...state.dependentsState,
        [action.stateKey]: {
          ...state.dependentsState[action.stateKey],
          status: action.status,
        },
      },
    };
  }

  if (action.type === FORM_DATA_SUBMIT_FAILED) {
    return {
      ...state,
      dependentsState: {
        ...state.dependentsState,
        [action.stateKey]: {
          ...state.dependentsState[action.stateKey],
          status: action.status,
          error: action.error.errors[0],
        },
      },
    };
  }

  return state;
}