Browse Source

fix(channels): filter channel list on node alias

Update channel filter handlers to correctly consider the node alias.

Fix #396
renovate/lint-staged-8.x
Tom Kirkpatrick 7 years ago
parent
commit
e8e6e9fe6b
No known key found for this signature in database GPG Key ID: 72203A8EC5967EA8
  1. 49
      app/reducers/channels.js

49
app/reducers/channels.js

@ -386,6 +386,17 @@ const filtersSelector = state => state.channels.filters
const filterSelector = state => state.channels.filter const filterSelector = state => state.channels.filter
const nodesSelector = state => state.network.nodes const nodesSelector = state => state.network.nodes
const channelMatchesQuery = (channel, nodes, searchQuery) => {
const node = nodes.find(n => channel.remote_pubkey === n.pub_key)
const query = searchQuery.toLowerCase()
const remoteNodePub = (channel.remote_node_pub || '').toLowerCase()
const remotePubkey = (channel.remote_pubkey || '').toLowerCase()
const displayName = (node ? node.alias : '' || '').toLowerCase()
return remoteNodePub.includes(query) || remotePubkey.includes(query) || displayName.includes(query)
}
channelsSelectors.channelModalOpen = createSelector( channelsSelectors.channelModalOpen = createSelector(
channelSelector, channelSelector,
channel => (!!channel) channel => (!!channel)
@ -456,15 +467,23 @@ const allChannels = createSelector(
pendingForceClosedChannelsSelector, pendingForceClosedChannelsSelector,
waitingCloseChannelsSelector, waitingCloseChannelsSelector,
channelSearchQuerySelector, channelSearchQuerySelector,
(activeChannels, nonActiveChannels, pendingOpenChannels, pendingClosedChannels, pendingForcedClosedChannels, waitingCloseChannels, searchQuery) => { nodesSelector,
const filterChannel = channel => (
channel.remote_pubkey.includes(searchQuery) || channel.channel_point.includes(searchQuery) activeChannels,
nonActiveChannels,
pendingOpenChannels,
pendingClosedChannels,
pendingForcedClosedChannels,
waitingCloseChannels,
searchQuery,
nodes
) => {
const filterChannel = channel => channelMatchesQuery(channel.channel || channel, nodes, searchQuery)
const filteredActiveChannels = activeChannels.filter(filterChannel) const filteredActiveChannels = activeChannels.filter(filterChannel)
const filteredNonActiveChannels = nonActiveChannels.filter(filterChannel) const filteredNonActiveChannels = nonActiveChannels.filter(filterChannel)
const filterPendingChannel = channel => const filterPendingChannel = channel => channelMatchesQuery(channel.channel || channel, nodes, searchQuery)
channel.channel.remote_node_pub.includes(searchQuery) || channel.channel.channel_point.includes(searchQuery)
const filteredPendingOpenChannels = pendingOpenChannels.filter(filterPendingChannel) const filteredPendingOpenChannels = pendingOpenChannels.filter(filterPendingChannel)
const filteredPendingClosedChannels = pendingClosedChannels.filter(filterPendingChannel) const filteredPendingClosedChannels = pendingClosedChannels.filter(filterPendingChannel)
@ -491,7 +510,18 @@ export const currentChannels = createSelector(
channelsSelectors.closingPendingChannels, channelsSelectors.closingPendingChannels,
filterSelector, filterSelector,
channelSearchQuerySelector, channelSearchQuerySelector,
(allChannelsArr, activeChannelsArr, nonActiveChannelsArr, openChannels, pendingOpenChannels, pendingClosedChannels, channelFilter, searchQuery) => { nodesSelector,
(
allChannelsArr,
activeChannelsArr,
nonActiveChannelsArr,
openChannels,
pendingOpenChannels,
pendingClosedChannels,
channelFilter,
searchQuery,
nodes
) => {
// Helper function to deliver correct channel array based on filter // Helper function to deliver correct channel array based on filter
const filteredArray = (filterKey) => { const filteredArray = (filterKey) => {
switch (filterKey) { switch (filterKey) {
@ -512,13 +542,8 @@ export const currentChannels = createSelector(
} }
} }
const channelArray = filteredArray(channelFilter.key) const channelArray = filteredArray(channelFilter.key)
return channelArray.filter(channel => channelMatchesQuery(channel.channel || channel, nodes, searchQuery))
return channelArray.filter(channel => (Object.prototype.hasOwnProperty.call(channel, 'channel') ?
channel.channel.remote_node_pub.includes(searchQuery) || channel.channel.channel_point.includes(searchQuery)
:
channel.remote_pubkey.includes(searchQuery) || channel.channel_point.includes(searchQuery)))
} }
) )

Loading…
Cancel
Save