AugurProject/augur-ui

View on GitHub
src/modules/market-charts/containers/market-outcomes-chart.js

Summary

Maintainability
A
1 hr
Test Coverage
import { connect } from "react-redux";

import MarketOutcomesChart from "modules/market-charts/components/market-outcomes-chart/market-outcomes-chart";

import { selectMarket } from "modules/markets/selectors/market";
import { selectCurrentTimestamp } from "src/select-state";
import { selectBucketedPriceTimeSeries } from "modules/markets/selectors/select-bucketed-price-time-series";
import { createBigNumber } from "src/utils/create-big-number";

const mapStateToProps = (state, ownProps) => {
  const {
    creationTime = {},
    maxPrice = createBigNumber(1),
    minPrice = createBigNumber(0),
    outcomes = [],
    volume = { formatted: "0" }
  } = selectMarket(ownProps.marketId);

  // (minPrice + ((maxPrice - minPrice) / outcomes.length)
  const adjusted = createBigNumber(maxPrice)
    .minus(minPrice)
    .div(outcomes.length);
  const estimatedInitialPrice = createBigNumber(minPrice)
    .plus(adjusted)
    .toNumber();

  const creationTimestamp = creationTime.value.getTime();
  const currentTimestamp = selectCurrentTimestamp(state);
  const hasPriceHistory = volume.formatted !== "0";
  const bucketedPriceTimeSeries = selectBucketedPriceTimeSeries(
    creationTimestamp,
    currentTimestamp,
    outcomes
  );

  return {
    isMobileSmall: state.appStatus.isMobileSmall,
    creationTime: creationTimestamp,
    currentTimestamp,
    estimatedInitialPrice,
    maxPrice: maxPrice.toNumber(),
    minPrice: minPrice.toNumber(),
    outcomes,
    hasPriceHistory,
    bucketedPriceTimeSeries
  };
};

export default connect(mapStateToProps)(MarketOutcomesChart);