AugurProject/augur-ui

View on GitHub
src/modules/markets-list/containers/markets-view-container.js

Summary

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

import MarketsView from "modules/markets-list/components/markets-view";
import { toggleFavorite } from "modules/markets/actions/update-favorites";
import { loadMarketsInfoIfNotLoaded } from "modules/markets/actions/load-markets-info";

import { compose } from "redux";
import { selectMarkets } from "src/modules/markets/selectors/markets-all";
import { getSelectedTagsAndCategoriesFromLocation } from "src/modules/markets/helpers/get-selected-tags-and-categories-from-location";
import { loadMarketsByFilter } from "modules/markets/actions/load-markets";
import { buildSearchString } from "modules/markets/selectors/build-search-string";
import debounce from "utils/debounce";
import { loadDisputing } from "modules/reports/actions/load-disputing";
import { isPastV2Cutoff } from "modules/markets/helpers/is-market-past-v2-cutoff";

const mapStateToProps = (state, { location }) => {
  const markets = selectMarkets(state);
  const {
    selectedCategoryName,
    keywords,
    selectedTagNames
  } = getSelectedTagsAndCategoriesFromLocation(location);

  const searchPhrase = buildSearchString(keywords, selectedTagNames);

  const hasPositionsInCutoffMarkets = markets
    .filter(market => isPastV2Cutoff(market.endTime.timestamp))
    .filter(market => market && market.myPositionOutcomes);

  return {
    isLogged: state.authStatus.isLogged,
    universe: (state.universe || {}).id,
    hasLoadedMarkets: state.appStatus.hasLoadedMarkets,
    search: searchPhrase,
    isMobile: state.appStatus.isMobile,
    markets,
    hasPositionsInCutoffMarkets: hasPositionsInCutoffMarkets.length > 0,
    category: selectedCategoryName,
    defaultFilter: state.filterSortOptions.marketFilter,
    defaultSort: state.filterSortOptions.marketSort,
    defaultMaxFee: state.filterSortOptions.maxFee,
    defaultMaxSpread: state.filterSortOptions.maxSpreadPercent,
    defaultExperimentalInvalid: state.filterSortOptions.experimentalInvalid,
    defaultHideInscureMarkets: state.filterSortOptions.hideInsecureMarkets
  };
};

const mapDispatchToProps = dispatch => ({
  toggleFavorite: marketId => dispatch(toggleFavorite(marketId)),
  loadMarketsInfoIfNotLoaded: marketIds =>
    dispatch(loadMarketsInfoIfNotLoaded(marketIds)),
  loadMarketsByFilter: (filter, cb) =>
    debounce(dispatch(loadMarketsByFilter(filter, cb))),
  loadDisputing: () => dispatch(loadDisputing())
});

const Markets = compose(
  withRouter,
  connect(
    mapStateToProps,
    mapDispatchToProps
  )
)(MarketsView);

export default Markets;