Gaëtan Renaudeau
7 years ago
committed by
GitHub
4 changed files with 76 additions and 1 deletions
@ -0,0 +1,65 @@ |
|||||
|
// @flow
|
||||
|
// Sync continuously the accounts that have pending operations
|
||||
|
|
||||
|
import React, { Component } from 'react' |
||||
|
import logger from 'logger' |
||||
|
import { createStructuredSelector, createSelector } from 'reselect' |
||||
|
import { connect } from 'react-redux' |
||||
|
import type { Account } from '@ledgerhq/live-common/lib/types' |
||||
|
import { BridgeSyncConsumer } from 'bridge/BridgeSyncContext' |
||||
|
import type { Sync } from 'bridge/BridgeSyncContext' |
||||
|
import { accountsSelector } from 'reducers/accounts' |
||||
|
|
||||
|
const accountsWithPendingOperationsSelector = createSelector(accountsSelector, accounts => |
||||
|
accounts.filter(a => a.pendingOperations.length > 0), |
||||
|
) |
||||
|
|
||||
|
class SyncContPendingOpsConnected extends Component<{ |
||||
|
sync: Sync, |
||||
|
accounts: Account[], |
||||
|
priority: number, |
||||
|
interval: number, |
||||
|
}> { |
||||
|
componentDidMount() { |
||||
|
this.timeout = setTimeout(this.check, this.props.interval) |
||||
|
} |
||||
|
componentWillUnmount() { |
||||
|
clearTimeout(this.timeout) |
||||
|
} |
||||
|
check = () => { |
||||
|
const { sync, accounts, priority, interval } = this.props |
||||
|
setTimeout(this.check, interval) |
||||
|
if (accounts.length > 0) { |
||||
|
logger.log(`SyncContinouslyPendingOperations: found ${accounts.length} accounts`, accounts) |
||||
|
sync({ |
||||
|
type: 'SYNC_SOME_ACCOUNTS', |
||||
|
accountIds: accounts.map(a => a.id), |
||||
|
priority, |
||||
|
}) |
||||
|
} |
||||
|
} |
||||
|
timeout: * |
||||
|
render() { |
||||
|
return null |
||||
|
} |
||||
|
} |
||||
|
|
||||
|
const Effect = connect( |
||||
|
createStructuredSelector({ |
||||
|
accounts: accountsWithPendingOperationsSelector, |
||||
|
}), |
||||
|
)(SyncContPendingOpsConnected) |
||||
|
|
||||
|
const SyncContinuouslyPendingOperations = ({ |
||||
|
priority, |
||||
|
interval, |
||||
|
}: { |
||||
|
priority: number, |
||||
|
interval: number, |
||||
|
}) => ( |
||||
|
<BridgeSyncConsumer> |
||||
|
{sync => <Effect sync={sync} interval={interval} priority={priority} />} |
||||
|
</BridgeSyncConsumer> |
||||
|
) |
||||
|
|
||||
|
export default SyncContinuouslyPendingOperations |
Loading…
Reference in new issue