You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

170 lines
4.7 KiB

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 { payFormSelectors } from 'reducers/payform'
import { setWalletCurrencyFilters } from 'reducers/info'
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,
setWalletCurrencyFilters,
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),
currentCurrencyFilters: tickerSelectors.currentCurrencyFilters(state),
currencyName: tickerSelectors.currencyName(state),
currentActivity: activitySelectors.currentActivity(state)(state),
nonActiveFilters: activitySelectors.nonActiveFilters(state),
showExpiredToggle: activitySelectors.showExpiredToggle(state),
showPayLoadingScreen: payFormSelectors.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,
currentCurrencyFilters: stateProps.currentCurrencyFilters,
currencyName: stateProps.currencyName,
network: stateProps.info.network,
paymentTimeout: stateProps.payment.paymentTimeout,
theme: stateProps.currentTheme,
setCurrency: dispatchProps.setCurrency,
setWalletCurrencyFilters: dispatchProps.setWalletCurrencyFilters,
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)