department-of-veterans-affairs/vets-website

View on GitHub
src/applications/mhv-medical-records/components/shared/DownloadingRecordsInfo.jsx

Summary

Maintainability
A
1 hr
Test Coverage
import React from 'react';
import PropTypes from 'prop-types';

const DownloadingRecordsInfo = props => {
  const { allowTxtDownloads, description } = props;

  const publicSharedContent = () => {
    return (
      <>
        <span className="vads-u-font-weight--bold">
          If you’re using a public or shared computer,
        </span>{' '}
        remember that downloading saves a copy of your records to the computer
        you’re using.
      </>
    );
  };

  return (
    <va-additional-info
      trigger="What to know before you download"
      class="no-print vads-u-margin-bottom--3"
      data-dd-action-name={`What to know before you print or download - ${description}`}
    >
      {/* Use the "!== false" syntax because checking the inverse causes the component to be resized incorrectly
            when the value changes from undefined to true. */}
      {allowTxtDownloads !== false ? (
        <ul>
          <li>{publicSharedContent()}</li>
          <li>
            <span className="vads-u-font-weight--bold">
              If you’re using assistive technology like a screen reader,
            </span>{' '}
            a text file may work better for you.
          </li>
        </ul>
      ) : (
        <p>{publicSharedContent()}</p>
      )}
    </va-additional-info>
  );
};

DownloadingRecordsInfo.propTypes = {
  allowTxtDownloads: PropTypes.bool,
  description: PropTypes.string,
};

export default DownloadingRecordsInfo;