|
@ -1,6 +1,7 @@ |
|
|
// @flow
|
|
|
// @flow
|
|
|
import React from 'react' |
|
|
import React from 'react' |
|
|
import { map } from 'rxjs/operators' |
|
|
import { map } from 'rxjs/operators' |
|
|
|
|
|
import type { Account } from '@ledgerhq/live-common/lib/types' |
|
|
import { decodeAccount, encodeAccount } from 'reducers/accounts' |
|
|
import { decodeAccount, encodeAccount } from 'reducers/accounts' |
|
|
import FeesBitcoinKind from 'components/FeesField/BitcoinKind' |
|
|
import FeesBitcoinKind from 'components/FeesField/BitcoinKind' |
|
|
import libcoreScanAccounts from 'commands/libcoreScanAccounts' |
|
|
import libcoreScanAccounts from 'commands/libcoreScanAccounts' |
|
@ -61,15 +62,31 @@ const LibcoreBridge: WalletBridge<Transaction> = { |
|
|
const rawAccount = encodeAccount(account) |
|
|
const rawAccount = encodeAccount(account) |
|
|
const rawSyncedAccount = await libcoreSyncAccount.send({ rawAccount }).toPromise() |
|
|
const rawSyncedAccount = await libcoreSyncAccount.send({ rawAccount }).toPromise() |
|
|
const syncedAccount = decodeAccount(rawSyncedAccount) |
|
|
const syncedAccount = decodeAccount(rawSyncedAccount) |
|
|
next(account => ({ |
|
|
next(account => { |
|
|
...account, |
|
|
const accountOps = account.operations |
|
|
|
|
|
const syncedOps = syncedAccount.operations |
|
|
|
|
|
const patch: $Shape<Account> = { |
|
|
freshAddress: syncedAccount.freshAddress, |
|
|
freshAddress: syncedAccount.freshAddress, |
|
|
freshAddressPath: syncedAccount.freshAddressPath, |
|
|
freshAddressPath: syncedAccount.freshAddressPath, |
|
|
balance: syncedAccount.balance, |
|
|
balance: syncedAccount.balance, |
|
|
blockHeight: syncedAccount.blockHeight, |
|
|
blockHeight: syncedAccount.blockHeight, |
|
|
operations: syncedAccount.operations, // TODO: is a simple replace enough?
|
|
|
|
|
|
lastSyncDate: new Date(), |
|
|
lastSyncDate: new Date(), |
|
|
})) |
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
const hasChanged = |
|
|
|
|
|
accountOps.length !== syncedOps.length || // size change, we do a full refresh for now...
|
|
|
|
|
|
(accountOps.length > 0 && syncedOps.length > 0 && accountOps[0].id !== syncedOps[0].id) // if same size, only check if the last item has changed.
|
|
|
|
|
|
|
|
|
|
|
|
if (hasChanged) { |
|
|
|
|
|
patch.operations = syncedAccount.operations |
|
|
|
|
|
patch.pendingOperations = [] // For now, we assume a change will clean the pendings.
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
return { |
|
|
|
|
|
...account, |
|
|
|
|
|
...patch, |
|
|
|
|
|
} |
|
|
|
|
|
}) |
|
|
complete() |
|
|
complete() |
|
|
} catch (e) { |
|
|
} catch (e) { |
|
|
error(e) |
|
|
error(e) |
|
@ -136,6 +153,11 @@ const LibcoreBridge: WalletBridge<Transaction> = { |
|
|
|
|
|
|
|
|
return op |
|
|
return op |
|
|
}, |
|
|
}, |
|
|
|
|
|
|
|
|
|
|
|
addPendingOperation: (account, operation) => ({ |
|
|
|
|
|
...account, |
|
|
|
|
|
pendingOperations: [operation].concat(account.pendingOperations), |
|
|
|
|
|
}), |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
export default LibcoreBridge |
|
|
export default LibcoreBridge |
|
|