aboutsummaryrefslogtreecommitdiffstats
path: root/app/scripts/transaction-manager.js
diff options
context:
space:
mode:
authorDan Finlay <flyswatter@users.noreply.github.com>2017-03-25 05:51:01 +0800
committerGitHub <noreply@github.com>2017-03-25 05:51:01 +0800
commit1c956bdb6209ba436a0de99a0f4440696935bd99 (patch)
tree83bfb500916c107ec51611e1c0ca4199bc7570fb /app/scripts/transaction-manager.js
parentfb39539214ca888300eb192e0e137a512cc0d88a (diff)
parent15d987ccce11bf00c3fe9294d9d96759f1cee172 (diff)
downloadtangerine-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/transaction-manager.js')
-rw-r--r--app/scripts/transaction-manager.js32
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)