AugurProject/augur-ui

View on GitHub
src/modules/reporting/containers/reporting-dispute.js

Summary

Maintainability
A
2 hrs
Test Coverage
import { connect } from "react-redux";
import { withRouter } from "react-router-dom";

import ReportingDispute from "modules/reporting/components/reporting-dispute/reporting-dispute";
import { loadFullMarket } from "modules/markets/actions/load-full-market";
import {
  MARKET_ID_PARAM_NAME,
  RETURN_PARAM_NAME
} from "modules/routes/constants/param-names";
import { selectMarket } from "modules/markets/selectors/market";
import parseQuery from "modules/routes/helpers/parse-query";
import getValue from "utils/get-value";
import { getGasPrice } from "modules/auth/selectors/get-gas-price";
import { submitMarketContribute } from "modules/reports/actions/submit-market-contribute";

const mapStateToProps = state => ({
  isLogged: state.authStatus.isLogged,
  // might need to call get market cost breakdown, it's on market from augur-node
  isConnected: state.connection.isConnected,
  universe: state.universe.id,
  marketsData: state.marketsData,
  isMobile: state.appStatus.isMobile,
  availableRep: getValue(state, "loginAccount.rep") || "0",
  gasPrice: getGasPrice(state)
});

const mapDispatchToProps = dispatch => ({
  loadFullMarket: marketId => dispatch(loadFullMarket(marketId)),
  submitMarketContribute: ({
    estimateGas,
    marketId,
    selectedOutcome,
    invalid,
    amount,
    history,
    returnPath,
    callback
  }) =>
    dispatch(
      submitMarketContribute({
        estimateGas,
        marketId,
        selectedOutcome,
        invalid,
        amount,
        history,
        returnPath,
        callback
      })
    )
});

const mergeProps = (sP, dP, oP) => {
  const marketId = parseQuery(oP.location.search)[MARKET_ID_PARAM_NAME];
  let returnPath = parseQuery(oP.location.search)[RETURN_PARAM_NAME];
  const market = selectMarket(marketId);

  if (returnPath && returnPath.substring(0, 3) === "#!/") {
    // need to get rid of this
    returnPath = returnPath.substring(3, returnPath.length);
  }

  return {
    ...oP,
    ...sP,
    marketId,
    isLogged: sP.isLogged,
    isConnected: sP.isConnected && getValue(sP, "universe.id") != null,
    isMarketLoaded: sP.marketsData[marketId] != null,
    market,
    loadFullMarket: () => dP.loadFullMarket(marketId),
    submitMarketContribute: ({
      estimateGas,
      marketId,
      selectedOutcome,
      invalid,
      amount,
      history,
      callback
    }) =>
      dP.submitMarketContribute({
        estimateGas,
        marketId,
        selectedOutcome,
        invalid,
        amount,
        history,
        returnPath,
        callback
      })
  };
};

const Reporting = withRouter(
  connect(
    mapStateToProps,
    mapDispatchToProps,
    mergeProps
  )(ReportingDispute)
);

export default Reporting;