AugurProject/augur-ui

View on GitHub
src/modules/market/components/market-outcomes-and-positions/market-outcomes-and-positions.jsx

Summary

Maintainability
A
0 mins
Test Coverage
import React from "react";
import PropTypes from "prop-types";

import isPopulated from "utils/is-populated";
import MarketOutcomesList from "modules/market/components/market-outcomes-list/market-outcomes-list";
import MarketPositionsList from "modules/market/components/market-positions-list/market-positions-list";
import MarketPositionsListMobile from "modules/market/components/market-positions-list--mobile/market-positions-list--mobile";

const MarketOutcomesAndPositions = ({
  isMobile,
  marketId,
  outcomes,
  numCompleteSets,
  transactionsStatus,
  positions,
  orphanedOrders,
  openOrders,
  selectedOutcome,
  cancelOrphanedOrder,
  sellCompleteSets,
  updateSelectedOutcome,
  updateSelectedOrderProperties
}) => (
  <section>
    {(!isMobile || !selectedOutcome) && (
      <MarketOutcomesList
        marketId={marketId}
        outcomes={outcomes}
        selectedOutcome={selectedOutcome}
        updateSelectedOutcome={updateSelectedOutcome}
        isMobile={isMobile}
      />
    )}
    {!isMobile && (
      <MarketPositionsList
        positions={positions}
        openOrders={openOrders}
        numCompleteSets={numCompleteSets}
        transactionsStatus={transactionsStatus}
        marketId={marketId}
        sellCompleteSets={sellCompleteSets}
        orphanedOrders={orphanedOrders}
        cancelOrphanedOrder={cancelOrphanedOrder}
        updateSelectedOrderProperties={updateSelectedOrderProperties}
      />
    )}
    {isMobile &&
      selectedOutcome &&
      isPopulated(outcomes) && (
        <MarketPositionsListMobile
          outcome={
            outcomes.filter(outcome => outcome.id === selectedOutcome)[0]
          }
          positions={positions.filter(
            position =>
              parseInt(position.outcomeId, 10) === parseInt(selectedOutcome, 10)
          )}
          openOrders={openOrders.filter(
            order => order.outcomeId === selectedOutcome
          )}
        />
      )}
  </section>
);

MarketOutcomesAndPositions.propTypes = {
  isMobile: PropTypes.bool.isRequired,
  marketId: PropTypes.string.isRequired,
  outcomes: PropTypes.array,
  numCompleteSets: PropTypes.object,
  transactionsStatus: PropTypes.object.isRequired,
  positions: PropTypes.array,
  orphanedOrders: PropTypes.array,
  openOrders: PropTypes.array,
  selectedOutcome: PropTypes.string,
  cancelOrphanedOrder: PropTypes.func.isRequired,
  sellCompleteSets: PropTypes.func.isRequired,
  updateSelectedOutcome: PropTypes.func.isRequired,
  updateSelectedOrderProperties: PropTypes.func
};

MarketOutcomesAndPositions.defaultProps = {
  outcomes: [],
  numCompleteSets: null,
  positions: [],
  orphanedOrders: [],
  openOrders: [],
  selectedOutcome: null,
  updateSelectedOrderProperties: null
};

export default MarketOutcomesAndPositions;