diff options
author | Dan Finlay <flyswatter@users.noreply.github.com> | 2017-03-25 05:51:01 +0800 |
---|---|---|
committer | GitHub <noreply@github.com> | 2017-03-25 05:51:01 +0800 |
commit | 1c956bdb6209ba436a0de99a0f4440696935bd99 (patch) | |
tree | 83bfb500916c107ec51611e1c0ca4199bc7570fb /app/scripts | |
parent | fb39539214ca888300eb192e0e137a512cc0d88a (diff) | |
parent | 15d987ccce11bf00c3fe9294d9d96759f1cee172 (diff) | |
download | tangerine-wallet-browser-1c956bdb6209ba436a0de99a0f4440696935bd99.tar tangerine-wallet-browser-1c956bdb6209ba436a0de99a0f4440696935bd99.tar.gz tangerine-wallet-browser-1c956bdb6209ba436a0de99a0f4440696935bd99.tar.bz2 tangerine-wallet-browser-1c956bdb6209ba436a0de99a0f4440696935bd99.tar.lz tangerine-wallet-browser-1c956bdb6209ba436a0de99a0f4440696935bd99.tar.xz tangerine-wallet-browser-1c956bdb6209ba436a0de99a0f4440696935bd99.tar.zst tangerine-wallet-browser-1c956bdb6209ba436a0de99a0f4440696935bd99.zip |
Merge pull request #1253 from MetaMask/i1210-txdisappearance
Fix transactions disappearing on other networks when creating transactions on a network
Diffstat (limited to 'app/scripts')
-rw-r--r-- | app/scripts/transaction-manager.js | 32 |
1 files changed, 22 insertions, 10 deletions
diff --git a/app/scripts/transaction-manager.js b/app/scripts/transaction-manager.js index 31c1c8431..7227bdc87 100644 --- a/app/scripts/transaction-manager.js +++ b/app/scripts/transaction-manager.js @@ -47,27 +47,39 @@ module.exports = class TransactionManager extends EventEmitter { // Returns the tx list getTxList () { let network = this.getNetwork() - let fullTxList = this.store.getState().transactions + let fullTxList = this.getFullTxList() return fullTxList.filter(txMeta => txMeta.metamaskNetworkId === network) } + // Returns the number of txs for the current network. + getTxCount () { + return this.getTxList().length + } + + // Returns the full tx list across all networks + getFullTxList () { + return this.store.getState().transactions + } + // Adds a tx to the txlist addTx (txMeta) { - var txList = this.getTxList() - var txHistoryLimit = this.txHistoryLimit + let txCount = this.getTxCount() + let network = this.getNetwork() + let fullTxList = this.getFullTxList() + let txHistoryLimit = this.txHistoryLimit - // checks if the length of th tx history is + // checks if the length of the tx history is // longer then desired persistence limit // and then if it is removes only confirmed // or rejected tx's. // not tx's that are pending or unapproved - if (txList.length > txHistoryLimit - 1) { - var index = txList.findIndex((metaTx) => metaTx.status === 'confirmed' || metaTx.status === 'rejected') - txList.splice(index, 1) + if (txCount > txHistoryLimit - 1) { + var index = fullTxList.findIndex((metaTx) => ((metaTx.status === 'confirmed' || metaTx.status === 'rejected') && network === txMeta.metamaskNetworkId)) + fullTxList.splice(index, 1) } - txList.push(txMeta) + fullTxList.push(txMeta) - this._saveTxList(txList) + this._saveTxList(fullTxList) this.once(`${txMeta.id}:signed`, function (txId) { this.removeAllListeners(`${txMeta.id}:rejected`) }) @@ -89,7 +101,7 @@ module.exports = class TransactionManager extends EventEmitter { // updateTx (txMeta) { var txId = txMeta.id - var txList = this.getTxList() + var txList = this.getFullTxList() var index = txList.findIndex(txData => txData.id === txId) txList[index] = txMeta this._saveTxList(txList) |