department-of-veterans-affairs/vets-website

View on GitHub
src/applications/letters/components/DownloadLetterLink.jsx

Summary

Maintainability
B
4 hrs
Test Coverage
import React from 'react';
import { connect } from 'react-redux';
import PropTypes from 'prop-types';
import { TransitionGroup, CSSTransition } from 'react-transition-group';

import recordEvent from '@department-of-veterans-affairs/platform-monitoring/record-event';
import CallVBACenter from '@department-of-veterans-affairs/platform-static-data/CallVBACenter';
import { VaButton } from '@department-of-veterans-affairs/component-library/dist/react-bindings';

import { getLetterPdf } from '../actions/letters';
import { DOWNLOAD_STATUSES } from '../utils/constants';

export class DownloadLetterLink extends React.Component {
  // Either download the pdf or open it in a new window, depending on the
  // browser. Needs to be manually tested on a variety of
  // vets.gov-supported platforms, particularly iOS/Safari
  downloadLetter = e => {
    e.preventDefault();
    recordEvent({
      event: 'letter-download',
      'letter-type': this.props.letterType,
    });
    this.props.getLetterPdf(
      this.props.letterType,
      this.props.letterTitle,
      this.props.letterOptions,
      this.props.LH_MIGRATION__options,
    );
  };

  render() {
    let buttonText;
    let buttonDisabled; // false causes MS Voice Access to ignore buttons
    let message;
    switch (this.props.downloadStatus) {
      case DOWNLOAD_STATUSES.downloading:
        buttonText = 'Downloading...';
        buttonDisabled = true;
        break;
      case DOWNLOAD_STATUSES.success:
        buttonText = `${this.props.letterTitle} (PDF)`;
        buttonDisabled = undefined;
        message = (
          <va-alert status="success" role="alert">
            <h4 slot="headline">Your letter has successfully downloaded.</h4>
            <p>
              If you want to download your letter again, please press the button
              below.
            </p>
          </va-alert>
        );
        break;
      case DOWNLOAD_STATUSES.failure:
        buttonText = 'Retry download';
        buttonDisabled = undefined;
        message = (
          <va-alert status="error" role="alert">
            <h4 slot="headline">Your letter didn’t download.</h4>
            <p>
              Your letter isn’t available at this time. If you need help with
              accessing your letter, please <CallVBACenter />
            </p>
          </va-alert>
        );
        break;
      default:
        buttonText = `${this.props.letterTitle} (PDF)`;
        buttonDisabled = undefined;
    }

    return (
      <div>
        <div className="form-expanding-group form-expanding-group-open">
          <TransitionGroup>
            {message ? (
              <CSSTransition
                classNames="form-expanding-group-inner"
                appear
                timeout={{
                  appear: 700,
                  enter: 700,
                }}
                exit={false}
              >
                {message}
              </CSSTransition>
            ) : null}
          </TransitionGroup>
        </div>
        <VaButton
          className="vads-u-margin-top--1 vads-u-margin-bottom--3"
          disabled={buttonDisabled}
          text={buttonText}
          onClick={this.downloadLetter}
        />
      </div>
    );
  }
}

function mapStateToProps(state, ownProps) {
  return {
    letterType: ownProps.letterType,
    letterTitle: ownProps.letterTitle,
    downloadStatus: ownProps.downloadStatus,
    letterOptions: state.letters.requestOptions,
    shouldUseLighthouse: state.shouldUseLighthouse,
  };
}

DownloadLetterLink.propTypes = {
  letterTitle: PropTypes.string.isRequired,
  letterType: PropTypes.string.isRequired,
  downloadStatus: PropTypes.string,
};

const mapDispatchToProps = {
  getLetterPdf,
};

export default connect(
  mapStateToProps,
  mapDispatchToProps,
)(DownloadLetterLink);