aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorkumavis <kumavis@users.noreply.github.com>2018-05-01 01:42:27 +0800
committerGitHub <noreply@github.com>2018-05-01 01:42:27 +0800
commit099fc0917dd5d281b60e2879bd1f555fe0988981 (patch)
tree854d2e5993629d6a276b9596bd51a6cf18327834
parentaa3dc83bf046d4c84d83976238c032dfeb953014 (diff)
parent98ae853b6c67bce137df00c2527e5ece25f1129e (diff)
downloadtangerine-wallet-browser-099fc0917dd5d281b60e2879bd1f555fe0988981.tar.gz
tangerine-wallet-browser-099fc0917dd5d281b60e2879bd1f555fe0988981.tar.zst
tangerine-wallet-browser-099fc0917dd5d281b60e2879bd1f555fe0988981.zip
Merge pull request #4131 from MetaMask/emitter-cleanup
transactions - run event emitters outside context of _setTxStatus
-rw-r--r--app/scripts/controllers/transactions/tx-state-manager.js21
1 files changed, 14 insertions, 7 deletions
diff --git a/app/scripts/controllers/transactions/tx-state-manager.js b/app/scripts/controllers/transactions/tx-state-manager.js
index 53428c333..f05c7d095 100644
--- a/app/scripts/controllers/transactions/tx-state-manager.js
+++ b/app/scripts/controllers/transactions/tx-state-manager.js
@@ -2,6 +2,7 @@ const extend = require('xtend')
const EventEmitter = require('events')
const ObservableStore = require('obs-store')
const ethUtil = require('ethereumjs-util')
+const log = require('loglevel')
const txStateHistoryHelper = require('./lib/tx-state-history-helper')
const createId = require('../../lib/random-id')
const { getFinalStates } = require('./lib/util')
@@ -398,13 +399,19 @@ class TransactionStateManager extends EventEmitter {
_setTxStatus (txId, status) {
const txMeta = this.getTx(txId)
txMeta.status = status
- this.emit(`${txMeta.id}:${status}`, txId)
- this.emit(`tx:status-update`, txId, status)
- if (['submitted', 'rejected', 'failed'].includes(status)) {
- this.emit(`${txMeta.id}:finished`, txMeta)
- }
- this.updateTx(txMeta, `txStateManager: setting status to ${status}`)
- this.emit('update:badge')
+ setTimeout(() => {
+ try {
+ this.updateTx(txMeta, `txStateManager: setting status to ${status}`)
+ this.emit(`${txMeta.id}:${status}`, txId)
+ this.emit(`tx:status-update`, txId, status)
+ if (['submitted', 'rejected', 'failed'].includes(status)) {
+ this.emit(`${txMeta.id}:finished`, txMeta)
+ }
+ this.emit('update:badge')
+ } catch (error) {
+ log.error(error)
+ }
+ })
}
/**