pond: set state once in ConnMgr.getActualState
This commit is contained in:
parent
583f4e02cb
commit
4381448c04
@ -2,8 +2,7 @@ import React from 'react';
|
|||||||
import Cristal from 'react-cristal'
|
import Cristal from 'react-cristal'
|
||||||
|
|
||||||
async function awaitReducer(prev, c) {
|
async function awaitReducer(prev, c) {
|
||||||
await prev
|
return {...await prev, ...await c}
|
||||||
await c
|
|
||||||
}
|
}
|
||||||
|
|
||||||
class ConnMgr extends React.Component {
|
class ConnMgr extends React.Component {
|
||||||
@ -19,29 +18,29 @@ class ConnMgr extends React.Component {
|
|||||||
this.state = {conns: {}, lock: true}
|
this.state = {conns: {}, lock: true}
|
||||||
|
|
||||||
this.getActualState()
|
this.getActualState()
|
||||||
setInterval(this.getActualState, 2000)
|
setInterval(this.getActualState, 500)
|
||||||
}
|
}
|
||||||
|
|
||||||
async getActualState() {
|
async getActualState() {
|
||||||
const nodes = this.props.nodes
|
const nodes = this.props.nodes
|
||||||
let keys = Object.keys(nodes)
|
let keys = Object.keys(nodes)
|
||||||
|
|
||||||
await keys.filter((_, i) => i > 0).map(async (kfrom, i) => {
|
const newConns = await keys.filter((_, i) => i > 0).map(async (kfrom, i) => {
|
||||||
await keys.filter((_, j) => i >= j).map(async kto => {
|
return await keys.filter((_, j) => i >= j).map(async kto => {
|
||||||
|
|
||||||
const fromNd = this.props.nodes[kfrom]
|
const fromNd = this.props.nodes[kfrom]
|
||||||
const toNd = this.props.nodes[kto]
|
const toNd = this.props.nodes[kto]
|
||||||
|
|
||||||
const connectedness = await fromNd.conn.call('Filecoin.NetConnectedness', [toNd.peerid])
|
const connectedness = await fromNd.conn.call('Filecoin.NetConnectedness', [toNd.peerid])
|
||||||
|
|
||||||
this.setState(prev => ({conns: {...prev.conns, [`${kfrom},${kto}`]: connectedness === 1}}))
|
return {[`${kfrom},${kto}`]: connectedness === 1}
|
||||||
}).reduce(awaitReducer)
|
}).reduce(awaitReducer, Promise.resolve({}))
|
||||||
}).reduce(awaitReducer)
|
}).reduce(awaitReducer, Promise.resolve({}))
|
||||||
|
|
||||||
this.setState({lock: false})
|
this.setState({conns: newConns, lock: false})
|
||||||
}
|
}
|
||||||
|
|
||||||
async connect(action, from, to) {
|
async connect(action, from, to, noupdate) {
|
||||||
const fromNd = this.props.nodes[from]
|
const fromNd = this.props.nodes[from]
|
||||||
const toNd = this.props.nodes[to]
|
const toNd = this.props.nodes[to]
|
||||||
|
|
||||||
@ -53,6 +52,7 @@ class ConnMgr extends React.Component {
|
|||||||
await fromNd.conn.call('Filecoin.NetDisconnect', [toNd.peerid])
|
await fromNd.conn.call('Filecoin.NetDisconnect', [toNd.peerid])
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (!noupdate)
|
||||||
this.setState(prev => ({conns: {...prev.conns, [`${from},${to}`]: action}}))
|
this.setState(prev => ({conns: {...prev.conns, [`${from},${to}`]: action}}))
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -63,7 +63,7 @@ class ConnMgr extends React.Component {
|
|||||||
|
|
||||||
keys.filter((_, i) => i > 0).forEach((kfrom, i) => {
|
keys.filter((_, i) => i > 0).forEach((kfrom, i) => {
|
||||||
keys.filter((_, j) => i >= j).forEach((kto, i) => {
|
keys.filter((_, j) => i >= j).forEach((kto, i) => {
|
||||||
this.connect(!discon, kfrom, kto)
|
this.connect(!discon, kfrom, kto, true)
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user