department-of-veterans-affairs/vets-website

View on GitHub
src/applications/verify-your-enrollment/containers/ChangeOfDirectDepositWrapper.jsx

Summary

Maintainability
D
2 days
Test Coverage
import React, { useState, useEffect, useCallback } from 'react';
import PropTypes from 'prop-types';
import '../sass/change-of-direct-deposit-wrapper.scss';
import { useDispatch, useSelector } from 'react-redux';
import LoadingButton from '~/platform/site-wide/loading-button/LoadingButton';
import ChangeOfDirectDepositForm from '../components/ChangeOfDirectDepositForm';

import { hasFormChanged, scrollToElement } from '../helpers';
import {
  CHANGE_OF_DIRECT_DEPOSIT_TITLE,
  DIRECT_DEPOSIT_BUTTON_TEXT,
} from '../constants/index';
import { updateBankInfo } from '../actions';
import Alert from '../components/Alert';
import Loader from '../components/Loader';
import AlertModal from '../components/AlertModal';

const ChangeOfDirectDepositWrapper = ({ applicantName }) => {
  const prefix = 'GI-Bill-Chapters-';
  const [toggleDirectDepositForm, setToggleDirectDepositForm] = useState(false);
  const [formData, setFormData] = useState();
  const [showModal, setShowModal] = useState(false);
  const dispatch = useDispatch();
  const { loading, error, data: response } = useSelector(
    state => state.bankInfo,
  );

  const scrollToTopOfForm = () => {
    scrollToElement('Direct deposit information');
  };

  const handleCloseForm = useCallback(() => {
    setFormData({}); // clear form data
    setToggleDirectDepositForm(false);
    setShowModal(false);
    scrollToTopOfForm();
  }, []);

  const onCancelButtonClick = () => {
    if (hasFormChanged(formData, applicantName)) {
      setShowModal(true);
    } else {
      handleCloseForm();
    }
  };
  // called when submitting form
  const saveBankInfo = () => {
    // commented out until tied in with redu
    const fields = {
      phone: formData[`${prefix}phone`],
      // phone2: formData[`${prefix}phone`],
      fullName: applicantName,
      email: formData[`${prefix}email`],
      acctType: formData[`${prefix}AccountType`].toLowerCase(),
      routingNo: formData[`${prefix}RoutingNumber`],
      acctNo: formData[`${prefix}AccountNumber`],
      bankName: formData[`${prefix}BankName`],
      bankPhone: formData[`${prefix}BankPhone`],
    };
    dispatch(updateBankInfo(fields));
  };

  useEffect(
    () => {
      if (!loading && (response || error)) {
        handleCloseForm();
      } else {
        window.scrollTo(0, 0);
      }
    },
    [error, handleCloseForm, loading, response],
  );
  const directDepositDescription = (
    <div className="vads-u-margin-top--2 vads-u-margin-bottom--2">
      <p>
        Please enter your bank’s routing and account numbers and your account
        type.
      </p>
      <img
        src="/img/direct-deposit-check-guide.svg"
        alt="On a personal check, find your bank’s 9-digit routing number listed along the bottom-left edge, and your account number listed beside that."
      />
    </div>
  );

  const gaBankInfoHelpText = () => {
    window.dataLayer.push({
      event: 'VYE-change-of-direct-deposit-help-text-clicked',
      'help-text-label': 'What if I don’t have a bank account?',
    });
  };

  const bankInfoHelpText = (
    <va-additional-info
      trigger="What if I don’t have a bank account?"
      onClick={gaBankInfoHelpText}
    >
      <span>
        <p>
          The{' '}
          <a href="https://veteransbenefitsbanking.org/">
            Veterans Benefits Banking Program (VBBP)
          </a>{' '}
          provides a list of Veteran-friendly banks and credit unions. They’ll
          work with you to set up an account, or help you qualify for an
          account, so you can use direct deposit. To get started, call one of
          the participating banks or credit unions listed on the VBBP website.
          Be sure to mention the Veterans Benefits Banking Program.
        </p>
        <p>
          Note: Federal regulation, found in 31 C.F.R. § 208.3 provides that,
          subject to section 208.4, “all Federal payments made by an agency
          shall be made by electronic funds transfer” (EFT).
        </p>
      </span>
    </va-additional-info>
  );

  const handleAddNewClick = () => {
    // toggle show form true
    setToggleDirectDepositForm(true);
    scrollToTopOfForm();
  };

  return (
    <div id={CHANGE_OF_DIRECT_DEPOSIT_TITLE}>
      <h2 className="vads-u-font-family--serif vads-u-margin-y--4">
        {CHANGE_OF_DIRECT_DEPOSIT_TITLE}
      </h2>
      <div
        className="vads-u-border-color--gray-lighter
            vads-u-color-gray-dark
            vads-u-display--flex
            vads-u-flex-direction--column
            vads-u-padding-x--2
            vads-u-padding-y--1p5
            medium-screen:vads-u-padding--4
            vads-u-border--1px"
      >
        {!toggleDirectDepositForm && (
          <>
            {error && (
              <Alert
                status="error"
                message="Sorry, something went wrong. Please try again Later"
              />
            )}
            {response?.ok && (
              <Alert
                status="success"
                title="New account added"
                message="We’ve updated your direct deposit information for Montgomery GI Bill benefits."
              />
            )}
            <va-button
              id="VYE-add-new-account-button"
              onClick={handleAddNewClick}
              text={DIRECT_DEPOSIT_BUTTON_TEXT}
            />
            <div>
              <p>
                <span className="vads-u-font-weight--bold">Note: </span>
                Any updates you make here will affect your Montgomery GI Bill
                benefits only.{' '}
              </p>
              <va-link
                href="/change-direct-deposit/"
                text="Learn how to update your direct deposit account for other VA benefits"
              />
              <div className="vads-u-margin-top--3">{bankInfoHelpText}</div>
            </div>
          </>
        )}
        {toggleDirectDepositForm && (
          <div className="direct-deposit-form-container">
            <h3 className="vads-u-line-height--4 vads-u-font-size--base vads-u-font-family--serif vads-u-margin-y--0">
              Add new account
            </h3>
            {directDepositDescription}
            {loading && <Loader className="loader" />}
            <ChangeOfDirectDepositForm
              defaultName={applicantName}
              formData={formData ?? {}}
              formChange={data => setFormData(data)}
              formPrefix={prefix}
              formSubmit={saveBankInfo}
            >
              <AlertModal
                showModal={showModal}
                setShowModal={setShowModal}
                cancelEditClick={handleCloseForm}
                formType="direct deposit"
              />
              <div className="button-container">
                <LoadingButton
                  aria-label="save your bank information for GI Bill® benefits"
                  type="submit"
                  loadingText="saving bank information"
                  className="usa-button-primary vads-u-margin-top--0 ach-submit-btn-auto-width"
                >
                  Save
                </LoadingButton>
                <va-button
                  text="Cancel"
                  secondary
                  label="cancel updating your bank information for GI Bill® benefits"
                  onClick={onCancelButtonClick}
                  data-qa="cancel-button"
                  data-testid={`${prefix}form-cancel-button`}
                />
              </div>
            </ChangeOfDirectDepositForm>
          </div>
        )}
      </div>
    </div>
  );
};
ChangeOfDirectDepositWrapper.propTypes = {
  applicantName: PropTypes.string,
};
export default ChangeOfDirectDepositWrapper;