Browse Source

feature(contacts): add channelNodes selector

renovate/lint-staged-8.x
Jack Mallers 7 years ago
parent
commit
15d7ec33ff
  1. 14
      app/components/Contacts/ContactModal.js
  2. 11
      app/components/Contacts/ContactModal.scss
  3. 12
      app/reducers/channels.js
  4. 4
      app/routes/contacts/containers/ContactsContainer.js

14
app/components/Contacts/ContactModal.js

@ -1,6 +1,6 @@
import React from 'react' import React from 'react'
import PropTypes from 'prop-types' import PropTypes from 'prop-types'
import find from 'lodash/find'
import ReactModal from 'react-modal' import ReactModal from 'react-modal'
import { FaClose, FaCircle } from 'react-icons/lib/fa' import { FaClose, FaCircle } from 'react-icons/lib/fa'
@ -8,8 +8,9 @@ import { btc } from 'utils'
import styles from './ContactModal.scss' import styles from './ContactModal.scss'
const ContactModal = ({ isOpen, channel, closeContactModal }) => { const ContactModal = ({ isOpen, channel, closeContactModal, channelNodes }) => {
console.log('channel: ', channel) if (!channel) { return <span /> }
const customStyles = { const customStyles = {
overlay: { overlay: {
cursor: 'pointer', cursor: 'pointer',
@ -27,6 +28,9 @@ const ContactModal = ({ isOpen, channel, closeContactModal }) => {
} }
} }
// the remote node for the channel
const node = find(channelNodes, { pub_key: channel.remote_pubkey })
return ( return (
<ReactModal <ReactModal
isOpen={isOpen} isOpen={isOpen}
@ -60,6 +64,10 @@ const ContactModal = ({ isOpen, channel, closeContactModal }) => {
</header> </header>
<section className={styles.title}> <section className={styles.title}>
{
node &&
<h1>{node.alias}</h1>
}
<h2>{channel.remote_pubkey}</h2> <h2>{channel.remote_pubkey}</h2>
</section> </section>

11
app/components/Contacts/ContactModal.scss

@ -43,11 +43,18 @@
} }
.title { .title {
h1 {
h2 {
color: $secondary; color: $secondary;
font-weight: bold; font-weight: bold;
font-size: 16px;
letter-spacing: 1.1px;
margin-bottom: 10px;
}
h2 {
font-size: 12px; font-size: 12px;
color: $darkestgrey;
font-weight: 100;
} }
} }

12
app/reducers/channels.js

@ -1,5 +1,6 @@
import { createSelector } from 'reselect' import { createSelector } from 'reselect'
import { ipcRenderer } from 'electron' import { ipcRenderer } from 'electron'
import filter from 'lodash/filter'
import { btc } from 'utils' import { btc } from 'utils'
import { showNotification } from 'notifications' import { showNotification } from 'notifications'
import { closeChannelForm, resetChannelForm } from './channelform' import { closeChannelForm, resetChannelForm } from './channelform'
@ -328,6 +329,7 @@ const pendingForceClosedChannelsSelector = state => state.channels.pendingChanne
const channelSearchQuerySelector = state => state.channels.searchQuery const channelSearchQuerySelector = state => state.channels.searchQuery
const filtersSelector = state => state.channels.filters const filtersSelector = state => state.channels.filters
const filterSelector = state => state.channels.filter const filterSelector = state => state.channels.filter
const nodesSelector = state => state.network.nodes
channelsSelectors.channelModalOpen = createSelector( channelsSelectors.channelModalOpen = createSelector(
channelSelector, channelSelector,
@ -381,6 +383,16 @@ channelsSelectors.nonActiveFilters = createSelector(
(filters, filter) => filters.filter(f => f.key !== filter.key) (filters, filter) => filters.filter(f => f.key !== filter.key)
) )
channelsSelectors.channelNodes = createSelector(
channelsSelector,
nodesSelector,
(channels, nodes) => {
const chanPubkeys = channels.map(channel => channel.remote_pubkey)
return filter(nodes, node => chanPubkeys.includes(node.pub_key))
}
)
const allChannels = createSelector( const allChannels = createSelector(
channelsSelectors.activeChannels, channelsSelectors.activeChannels,
channelsSelectors.nonActiveChannels, channelsSelectors.nonActiveChannels,

4
app/routes/contacts/containers/ContactsContainer.js

@ -61,6 +61,7 @@ const mapStateToProps = state => ({
pendingOpenChannelPubkeys: channelsSelectors.pendingOpenChannelPubkeys(state), pendingOpenChannelPubkeys: channelsSelectors.pendingOpenChannelPubkeys(state),
closingPendingChannels: channelsSelectors.closingPendingChannels(state), closingPendingChannels: channelsSelectors.closingPendingChannels(state),
nonActiveFilters: channelsSelectors.nonActiveFilters(state), nonActiveFilters: channelsSelectors.nonActiveFilters(state),
channelNodes: channelsSelectors.channelNodes(state),
filteredNetworkNodes: contactFormSelectors.filteredNetworkNodes(state), filteredNetworkNodes: contactFormSelectors.filteredNetworkNodes(state),
showManualForm: contactFormSelectors.showManualForm(state) showManualForm: contactFormSelectors.showManualForm(state)
@ -71,7 +72,8 @@ const mergeProps = (stateProps, dispatchProps, ownProps) => {
closeContactModal: dispatchProps.closeContactModal, closeContactModal: dispatchProps.closeContactModal,
isOpen: stateProps.channels.contactModal.isOpen, isOpen: stateProps.channels.contactModal.isOpen,
channel: stateProps.channels.contactModal.channel channel: stateProps.channels.contactModal.channel,
channelNodes: stateProps.channelNodes
} }
const contactsFormProps = { const contactsFormProps = {

Loading…
Cancel
Save