AugurProject/augur-ui

View on GitHub
src/modules/app/containers/app.js

Summary

Maintainability
A
0 mins
Test Coverage
import { compose } from "redux";

import { connect } from "react-redux";
import { withRouter } from "react-router-dom";

import App from "modules/app/components/app/app";
import { sendFinalizeMarket } from "modules/markets/actions/finalize-market";
import { selectInfoNotificationsAndSeenCount } from "modules/notifications/selectors/notifications";
import { selectMarketsHeader } from "modules/markets/selectors/markets-header";
import { selectCoreStats } from "modules/account/selectors/core-stats";
import portfolio from "modules/positions/selectors/portfolio";
import {
  IS_ANIMATING,
  IS_MOBILE,
  IS_MOBILE_SMALL,
  updateAppStatus
} from "modules/app/actions/update-app-status";
import getAllMarkets from "modules/markets/selectors/markets-all";
import { initAugur } from "modules/app/actions/init-augur";
import { updateModal } from "modules/modal/actions/update-modal";
import { isLoading } from "modules/markets/selectors/is-loading";
import {
  selectBlockchainState,
  selectCategoriesState,
  selectConnectionState,
  selectEnvState,
  selectIsLogged,
  selectIsMobile,
  selectIsMobileSmall,
  selectIsAnimating,
  selectLoginAccountState,
  selectModal,
  selectUniverseState,
  selectUrlState
} from "src/select-state";
import { RewriteUrlParams } from "src/modules/app/hocs/rewrite-url-params";
import { windowRef } from "src/utils/window-ref";
import isGlobalWeb3 from "modules/auth/helpers/is-global-web3";
import { logout } from "modules/auth/actions/logout";
import { MARKET_ID_PARAM_NAME } from "modules/routes/constants/param-names";
import parseQuery from "modules/routes/helpers/parse-query";

const mapStateToProps = (state, ownProps) => ({
  blockchain: selectBlockchainState(state),
  categories: selectCategoriesState(state),
  connection: selectConnectionState(state),
  coreStats: selectCoreStats(state),
  isLoading: isLoading(state.marketLoading),
  env: selectEnvState(state),
  isLogged: selectIsLogged(state),
  isMobile: selectIsMobile(state),
  isMobileSmall: selectIsMobileSmall(state),
  isAnimating: selectIsAnimating(state),
  loginAccount: selectLoginAccountState(state),
  markets: getAllMarkets(),
  marketsHeader: selectMarketsHeader(state),
  modal: selectModal(state),
  notifications: selectInfoNotificationsAndSeenCount(state),
  portfolio: portfolio(),
  universe: selectUniverseState(state),
  url: selectUrlState(state),
  useWeb3Transport: isGlobalWeb3(),
  market:
    state.marketsData[
      parseQuery(ownProps.location.search)[MARKET_ID_PARAM_NAME]
    ]
});

const mapDispatchToProps = dispatch => ({
  initAugur: (history, overrides, cb) =>
    dispatch(initAugur(history, overrides, cb)),
  updateIsMobile: isMobile => dispatch(updateAppStatus(IS_MOBILE, isMobile)),
  updateIsMobileSmall: isMobileSmall =>
    dispatch(updateAppStatus(IS_MOBILE_SMALL, isMobileSmall)),
  updateIsAnimating: isAnimating =>
    dispatch(updateAppStatus(IS_ANIMATING, isAnimating)),
  updateModal: modal => dispatch(updateModal(modal)),
  finalizeMarket: marketId => dispatch(sendFinalizeMarket(marketId)),
  logout: () => dispatch(logout())
});

const AppContainer = compose(
  withRouter,
  RewriteUrlParams(windowRef),
  connect(
    mapStateToProps,
    mapDispatchToProps
  )
)(App);

export default AppContainer;