import { withRouter } from 'react-router' import { connect } from 'react-redux' import { fetchChannels, openChannel, updateChannelSearchQuery, toggleFilterPulldown, changeFilter, openContactModal, closeContactModal, currentChannels, channelsSelectors } from 'reducers/channels' import { fetchPeers } from 'reducers/peers' import { fetchDescribeNetwork } from 'reducers/network' import { openContactsForm, closeContactsForm, updateContactFormSearchQuery, updateContactCapacity, contactFormSelectors } from 'reducers/contactsform' import Contacts from '../components/Contacts' const mapDispatchToProps = { openContactsForm, closeContactsForm, openContactModal, closeContactModal, updateContactFormSearchQuery, updateContactCapacity, openChannel, updateChannelSearchQuery, toggleFilterPulldown, changeFilter, fetchChannels, fetchPeers, fetchDescribeNetwork } const mapStateToProps = state => ({ channels: state.channels, peers: state.peers, network: state.network, contactsform: state.contactsform, currentChannels: currentChannels(state), activeChannels: channelsSelectors.activeChannels(state), activeChannelPubkeys: channelsSelectors.activeChannelPubkeys(state), nonActiveChannels: channelsSelectors.nonActiveChannels(state), nonActiveChannelPubkeys: channelsSelectors.nonActiveChannelPubkeys(state), pendingOpenChannels: channelsSelectors.pendingOpenChannels(state), pendingOpenChannelPubkeys: channelsSelectors.pendingOpenChannelPubkeys(state), closingPendingChannels: channelsSelectors.closingPendingChannels(state), nonActiveFilters: channelsSelectors.nonActiveFilters(state), filteredNetworkNodes: contactFormSelectors.filteredNetworkNodes(state), showManualForm: contactFormSelectors.showManualForm(state) }) const mergeProps = (stateProps, dispatchProps, ownProps) => { const contactModalProps = { closeContactModal: dispatchProps.closeContactModal, isOpen: stateProps.channels.contactModal.isOpen, channel: stateProps.channels.contactModal.channel } const contactsFormProps = { closeContactsForm: dispatchProps.closeContactsForm, updateContactFormSearchQuery: dispatchProps.updateContactFormSearchQuery, updateContactCapacity: dispatchProps.updateContactCapacity, openChannel: dispatchProps.openChannel, contactsform: stateProps.contactsform, filteredNetworkNodes: stateProps.filteredNetworkNodes, loadingChannelPubkeys: stateProps.channels.loadingChannelPubkeys, showManualForm: stateProps.showManualForm, activeChannelPubkeys: stateProps.activeChannelPubkeys, nonActiveChannelPubkeys: stateProps.nonActiveChannelPubkeys, pendingOpenChannelPubkeys: stateProps.pendingOpenChannelPubkeys } return { ...stateProps, ...dispatchProps, ...ownProps, contactModalProps, contactsFormProps } } export default withRouter(connect(mapStateToProps, mapDispatchToProps, mergeProps)(Contacts))