import { connect } from 'react-redux' import { setLocale } from 'reducers/locale' import { setCurrency, setFiatTicker, tickerSelectors } from 'reducers/ticker' import { fetchBalance } from 'reducers/balance' import { fetchChannels } from 'reducers/channels' import { fetchInvoices, setInvoice, invoiceSelectors } from 'reducers/invoice' import { setPayment, fetchPayments, paymentSelectors } from 'reducers/payment' import { fetchTransactions } from 'reducers/transaction' import { showActivityModal, hideActivityModal, changeFilter, toggleFilterPulldown, toggleExpiredRequests, activitySelectors, updateSearchActive, updateSearchText } from 'reducers/activity' import { walletAddress, openWalletModal } from 'reducers/address' import { setFormType } from 'reducers/form' import { setSettingsOpen, setActiveSubMenu, disableSubMenu } from 'reducers/settings' import { setTheme, themeSelectors } from 'reducers/theme' import Activity from 'components/Activity' const mapDispatchToProps = { setLocale, setCurrency, setFiatTicker, setPayment, setInvoice, fetchPayments, fetchInvoices, fetchTransactions, showActivityModal, hideActivityModal, changeFilter, toggleFilterPulldown, toggleExpiredRequests, walletAddress, openWalletModal, fetchBalance, fetchChannels, updateSearchActive, updateSearchText, setFormType, setSettingsOpen, setActiveSubMenu, disableSubMenu, setTheme } const mapStateToProps = state => ({ activity: state.activity, balance: state.balance, address: state.address, info: state.info, payment: state.payment, transaction: state.transaction, invoice: state.invoice, invoices: invoiceSelectors.invoices(state), ticker: state.ticker, network: state.network, settings: state.settings, currentLocale: state.intl.locale, locales: state.locale, currentTheme: themeSelectors.currentTheme(state), themes: themeSelectors.themes(state), paymentModalOpen: paymentSelectors.paymentModalOpen(state), invoiceModalOpen: invoiceSelectors.invoiceModalOpen(state), currentTicker: tickerSelectors.currentTicker(state), currencyFilters: tickerSelectors.currencyFilters(state), currencyName: tickerSelectors.currencyName(state), currentActivity: activitySelectors.currentActivity(state)(state), nonActiveFilters: activitySelectors.nonActiveFilters(state), showExpiredToggle: activitySelectors.showExpiredToggle(state), showPayLoadingScreen: paymentSelectors.showPayLoadingScreen(state) }) const mergeProps = (stateProps, dispatchProps, ownProps) => ({ ...stateProps, ...dispatchProps, ...ownProps, walletProps: { balance: stateProps.balance, address: stateProps.address.address, info: stateProps.info, ticker: stateProps.ticker, currentTicker: stateProps.currentTicker, showPayLoadingScreen: stateProps.showPayLoadingScreen, showSuccessPayScreen: stateProps.payment.showSuccessPayScreen, successTransactionScreen: stateProps.transaction.successTransactionScreen, currencyFilters: stateProps.currencyFilters, currencyName: stateProps.currencyName, network: stateProps.info.network, paymentTimeout: stateProps.payment.paymentTimeout, theme: stateProps.currentTheme, setCurrency: dispatchProps.setCurrency, walletAddress: dispatchProps.walletAddress, openReceiveModal: dispatchProps.openWalletModal, openPayForm: () => dispatchProps.setFormType('PAY_FORM'), openRequestForm: () => dispatchProps.setFormType('REQUEST_FORM'), settingsProps: { settings: stateProps.settings, toggleSettings: () => { if (stateProps.settings.settingsOpen) { dispatchProps.setSettingsOpen(false) } else { dispatchProps.setSettingsOpen(true) } return }, setActiveSubMenu: dispatchProps.setActiveSubMenu, fiatProps: { fiatTicker: stateProps.ticker.fiatTicker, fiatTickers: stateProps.ticker.fiatTickers, disableSubMenu: dispatchProps.disableSubMenu, setFiatTicker: dispatchProps.setFiatTicker }, localeProps: { locales: stateProps.locales, currentLocale: stateProps.currentLocale, disableSubMenu: dispatchProps.disableSubMenu, setLocale: dispatchProps.setLocale }, themeProps: { themes: stateProps.themes, currentTheme: stateProps.currentTheme, setTheme: dispatchProps.setTheme, disableSubMenu: dispatchProps.disableSubMenu } } } }) export default connect( mapStateToProps, mapDispatchToProps, mergeProps )(Activity)