department-of-veterans-affairs/vets-website

View on GitHub
src/applications/mhv-medications/components/RefillPrescriptions/RefillNotification.jsx

Summary

Maintainability
B
4 hrs
Test Coverage
import React, { useEffect } from 'react';
import { Link } from 'react-router-dom';
import PropTypes from 'prop-types';
import { focusElement } from '@department-of-veterans-affairs/platform-utilities/ui';
import { useSelector } from 'react-redux';
import { dataDogActionNames } from '../../util/dataDogConstants';
import { selectFilterFlag } from '../../util/selectors';
import { SESSION_RX_FILTER_OPEN_BY_DEFAULT } from '../../util/constants';

const RefillNotification = ({ refillStatus }) => {
  // Selectors
  const successfulMeds = useSelector(
    state => state.rx.prescriptions?.refillNotification?.successfulMeds,
  );
  const failedMeds = useSelector(
    state => state.rx.prescriptions?.refillNotification?.failedMeds,
  );

  // Feature flags
  const showFilterContent = useSelector(selectFilterFlag);

  useEffect(
    () => {
      if (refillStatus === 'finished') {
        let elemId = '';
        if (successfulMeds?.length === 0) {
          elemId = 'failed-refill';
        } else if (failedMeds?.length > 0) {
          elemId = 'partial-refill';
        } else {
          elemId = 'success-refill';
        }
        const element = document.getElementById(elemId);
        if (element) {
          focusElement(element);
        }
      }
    },
    [refillStatus, successfulMeds, failedMeds],
  );

  const handleGoToMedicationsListOnSuccess = () => {
    if (!sessionStorage.getItem(SESSION_RX_FILTER_OPEN_BY_DEFAULT)) {
      sessionStorage.setItem(SESSION_RX_FILTER_OPEN_BY_DEFAULT, true);
    }
  };

  const isNotSubmitted =
    refillStatus === 'finished' &&
    successfulMeds?.length === 0 &&
    failedMeds?.length === 0;
  const isPartiallySubmitted = failedMeds?.length > 0;
  const isSuccess = successfulMeds?.length > 0;
  return (
    <>
      <va-alert
        visible={isNotSubmitted}
        id="failed-refill"
        status="error"
        setFocus
        uswds
        class={isNotSubmitted ? 'vads-u-margin-y--1' : ''}
      >
        <h2
          className="vads-u-margin-y--0 vads-u-font-size--h3"
          data-testid="failed-message-title"
        >
          Request not submitted
        </h2>
        <p>We’re sorry. There’s a problem with our system.</p>
        <p>
          To request refills, call the pharmacy number on your prescription
          label.
        </p>
      </va-alert>
      <va-alert
        visible={isPartiallySubmitted}
        id="partial-refill"
        status="error"
        setFocus
        uswds
        class={isPartiallySubmitted ? 'vads-u-margin-y--2' : ''}
      >
        <h2
          className="vads-u-margin-y--0 vads-u-font-size--h3"
          data-testid="failed-message-title"
        >
          Only part of your request was submitted
        </h2>
        <p data-testid="failed-message-description">
          We’re sorry. There’s a problem with our system. We couldn’t submit
          these refill requests:
        </p>
        <ul className="va-list--disc">
          {failedMeds?.map((item, idx) => (
            <li
              className="vads-u-padding-y--0 vads-u-font-weight--bold"
              data-testid="medication-requested-failed"
              key={idx}
            >
              {item?.prescriptionName}
            </li>
          ))}
        </ul>
        <p
          className="vads-u-margin-bottom--0"
          data-testid="success-message-description"
        >
          Try requesting these refills again. If it still doesn’t work, call
          your VA pharmacy.
        </p>
      </va-alert>
      <va-alert
        visible={isSuccess}
        id="success-refill"
        status="success"
        setFocus
        uswds
        class={isSuccess ? 'vads-u-margin-y--2' : ''}
      >
        <h2
          className="vads-u-margin-y--0 vads-u-font-size--h3"
          data-testid="success-message-title"
        >
          Refills requested
        </h2>
        <ul className="va-list--disc">
          {successfulMeds?.map((id, idx) => (
            <li
              className="vads-u-padding-y--0"
              data-testid="medication-requested-successful"
              key={idx}
            >
              {id?.prescriptionName}
            </li>
          ))}
        </ul>
        <div
          className="vads-u-margin-y--0"
          data-testid="success-message-description"
        >
          <p>
            {showFilterContent
              ? 'To check the status of your refill requests, go to your medications list and filter by “recently requested.”'
              : 'For updates on your refill requests, go to your medications list.'}
          </p>
          <Link
            data-testid="back-to-medications-page-link"
            to="/"
            className="hide-visited-link"
            data-dd-action-name={
              dataDogActionNames.refillPage
                .GO_TO_YOUR_MEDICATIONS_LIST_ACTION_LINK
            }
            onClick={handleGoToMedicationsListOnSuccess}
          >
            Go to your medications list
          </Link>
        </div>
      </va-alert>
    </>
  );
};

RefillNotification.propTypes = {
  refillStatus: PropTypes.string,
};

export default RefillNotification;