/* @flow */ 'use strict'; import React, { Component, PropTypes } from 'react'; import { bindActionCreators } from 'redux'; import { connect } from 'react-redux'; import Summary from './Summary'; import { default as AbstractAccountActions } from '~/js/actions/AbstractAccountActions'; import * as SummaryActions from '~/js/actions/SummaryActions'; import * as TokenActions from '~/js/actions/TokenActions'; import type { MapStateToProps, MapDispatchToProps } from 'react-redux'; import type { State, Dispatch } from '~/flowtype'; import type { StateProps as BaseStateProps, DispatchProps as BaseDispatchProps } from '../AbstractAccount'; type OwnProps = { } type StateProps = BaseStateProps & { tokens: $ElementType, summary: $ElementType, fiat: $ElementType, localStorage: $ElementType, } type DispatchProps = BaseDispatchProps & { onDetailsToggle: typeof SummaryActions.onDetailsToggle, addToken: typeof TokenActions.add, loadTokens: typeof TokenActions.load, removeToken: typeof TokenActions.remove, } export type Props = StateProps & DispatchProps; const mapStateToProps: MapStateToProps = (state: State, own: OwnProps): StateProps => { return { abstractAccount: state.abstractAccount, devices: state.connect.devices, accounts: state.accounts, discovery: state.discovery, tokens: state.tokens, summary: state.summary, fiat: state.fiat, localStorage: state.localStorage, }; } const mapDispatchToProps: MapDispatchToProps = (dispatch: Dispatch): DispatchProps => { return { abstractAccountActions: bindActionCreators(AbstractAccountActions, dispatch), initAccount: bindActionCreators(SummaryActions.init, dispatch), disposeAccount: bindActionCreators(SummaryActions.dispose, dispatch), onDetailsToggle: bindActionCreators(SummaryActions.onDetailsToggle, dispatch), addToken: bindActionCreators(TokenActions.add, dispatch), loadTokens: bindActionCreators(TokenActions.load, dispatch), removeToken: bindActionCreators(TokenActions.remove, dispatch), }; } export default connect(mapStateToProps, mapDispatchToProps)(Summary)