AugurProject/augur-ui

View on GitHub
src/modules/modal/components/modal-view.jsx

Summary

Maintainability
A
2 hrs
Test Coverage
import React, { Component } from "react";
import PropTypes from "prop-types";
import classNames from "classnames";

import ModalSignTransaction from "modules/modal/containers/modal-sign-transaction";
import ModalConfirm from "modules/modal/components/modal-confirm";
import ModalReview from "modules/modal/components/modal-review";
import ModalNetworkDisabled from "modules/modal/containers/modal-network-disabled";
import ModalNetworkMismatch from "modules/modal/containers/modal-mismatch";
import ModalNetworkDisconnected from "modules/modal/containers/modal-network-disconnected";
import ModalApproval from "modules/modal/containers/modal-approval";
import ModalClaimReportingFeesForkedMarket from "modules/modal/containers/modal-claim-reporting-fees-forked-market";
import ModalClaimReportingFeesNonforkedMarkets from "modules/modal/containers/modal-claim-reporting-fees-nonforked-markets";
import ModalParticipate from "modules/modal/containers/modal-participate";
import ModalMigrateMarket from "modules/modal/containers/modal-migrate-market";
import ModalNetworkConnect from "modules/modal/containers/modal-network-connect";
import ModalDisclaimer from "modules/modal/containers/modal-disclaimer";
import ModalMarketsV2Alert from "modules/modal/containers/modal-v2-markets-alert";
import ModalMarketReview from "modules/modal/containers/modal-market-review";
import ModalGasPrice from "modules/modal/containers/modal-gas-price";
import ModalClaimTradingProceeds from "modules/modal/containers/modal-claim-trading-proceeds";

import * as TYPES from "modules/modal/constants/modal-types";

import Styles from "modules/modal/components/common/common.styles";

export default class ModalView extends Component {
  static propTypes = {
    modal: PropTypes.object.isRequired,
    closeModal: PropTypes.func.isRequired
  };

  componentDidMount() {
    window.onpopstate = () => {
      this.props.closeModal();
    };
  }

  render() {
    const { closeModal, modal } = this.props;

    return (
      <section className={Styles.ModalView}>
        <div
          className={classNames(Styles.ModalView__content, {
            [`${Styles["ModalView__content--taller"]}`]:
              modal.type === TYPES.MODAL_DISCLAIMER
          })}
        >
          {modal.type === TYPES.MODAL_CLAIM_TRADING_PROCEEDS && (
            <ModalClaimTradingProceeds {...this.props} />
          )}
          {modal.type === TYPES.MODAL_GAS_PRICE && (
            <ModalGasPrice {...this.props} />
          )}
          {modal.type === TYPES.MODAL_CONFIRM && (
            <ModalConfirm {...modal} closeModal={closeModal} />
          )}
          {modal.type === TYPES.MODAL_REVIEW && <ModalReview {...modal} />}
          {modal.type === TYPES.MODAL_LEDGER ||
            (modal.type === TYPES.MODAL_TREZOR && (
              <ModalSignTransaction {...modal} />
            ))}
          {modal.type === TYPES.MODAL_PARTICIPATE && <ModalParticipate />}
          {modal.type === TYPES.MODAL_NETWORK_MISMATCH && (
            <ModalNetworkMismatch {...modal} />
          )}
          {modal.type === TYPES.MODAL_NETWORK_DISABLED && (
            <ModalNetworkDisabled {...modal} />
          )}
          {modal.type === TYPES.MODAL_NETWORK_CONNECT && (
            <ModalNetworkConnect />
          )}
          {modal.type === TYPES.MODAL_NETWORK_DISCONNECTED && (
            <ModalNetworkDisconnected {...this.props} />
          )}
          {modal.type === TYPES.MODAL_ACCOUNT_APPROVAL && <ModalApproval />}
          {modal.type === TYPES.MODAL_CLAIM_REPORTING_FEES_FORKED_MARKET && (
            <ModalClaimReportingFeesForkedMarket {...modal} />
          )}
          {modal.type ===
            TYPES.MODAL_CLAIM_REPORTING_FEES_NONFORKED_MARKETS && (
            <ModalClaimReportingFeesNonforkedMarkets {...modal} />
          )}
          {modal.type === TYPES.MODAL_MIGRATE_MARKET && (
            <ModalMigrateMarket {...modal} closeModal={closeModal} />
          )}
          {modal.type === TYPES.MODAL_DISCLAIMER && (
            <ModalDisclaimer {...modal} />
          )}
          {modal.type === TYPES.MODAL_V2_MARKETS_ALERT && (
            <ModalMarketsV2Alert {...modal} />
          )}
          {modal.type === TYPES.MODAL_MARKET_REVIEW && (
            <ModalMarketReview {...modal} />
          )}
          {modal.type === TYPES.MODAL_MARKET_CUTOFF_NOTICE && (
            <ModalConfirm {...modal} closeModal={closeModal} />
          )}
        </div>
      </section>
    );
  }
}