aboutsummaryrefslogtreecommitdiffstats
path: root/app/scripts/transaction-manager.js
diff options
context:
space:
mode:
authorFrances Pangilinan <frankie.diamond@gmail.com>2016-12-15 07:04:33 +0800
committerFrances Pangilinan <frankie.diamond@gmail.com>2016-12-15 07:04:33 +0800
commitda9349fe63de70d29a13b6c7d94eb40dc5fcb127 (patch)
tree204f87bc51d11c6d718841c1f7cb11c4b7781d3c /app/scripts/transaction-manager.js
parent5a292cc39781824ecd57535972cfa7c985d7824d (diff)
downloadtangerine-wallet-browser-da9349fe63de70d29a13b6c7d94eb40dc5fcb127.tar
tangerine-wallet-browser-da9349fe63de70d29a13b6c7d94eb40dc5fcb127.tar.gz
tangerine-wallet-browser-da9349fe63de70d29a13b6c7d94eb40dc5fcb127.tar.bz2
tangerine-wallet-browser-da9349fe63de70d29a13b6c7d94eb40dc5fcb127.tar.lz
tangerine-wallet-browser-da9349fe63de70d29a13b6c7d94eb40dc5fcb127.tar.xz
tangerine-wallet-browser-da9349fe63de70d29a13b6c7d94eb40dc5fcb127.tar.zst
tangerine-wallet-browser-da9349fe63de70d29a13b6c7d94eb40dc5fcb127.zip
Clean up and comment functions
Diffstat (limited to 'app/scripts/transaction-manager.js')
-rw-r--r--app/scripts/transaction-manager.js30
1 files changed, 29 insertions, 1 deletions
diff --git a/app/scripts/transaction-manager.js b/app/scripts/transaction-manager.js
index 07e588679..d0226a600 100644
--- a/app/scripts/transaction-manager.js
+++ b/app/scripts/transaction-manager.js
@@ -38,12 +38,14 @@ module.exports = class TransactionManager extends EventEmitter {
this.emit('update')
}
+ // gets tx by Id and returns it
getTx (txId, cb) {
var txList = this.getTxList()
var tx = txList.find((tx) => tx.id === txId)
return cb ? cb(tx) : tx
}
+ //
updateTx (txData) {
var txId = txData.id
var txList = this.getTxList()
@@ -75,6 +77,21 @@ module.exports = class TransactionManager extends EventEmitter {
}, {})
}
+ /*
+ Takes an object of fields to search for eg:
+ var thingsToLookFor = {
+ to: '0x0..',
+ from: '0x0..',
+ status: 'signed',
+ }
+ and returns a list of tx with all
+ options matching
+
+ this is for things like filtering a the tx list
+ for only tx's from 1 account
+ or for filltering for all txs from one account
+ and that have been 'confirmed'
+ */
getFilterdTxList (opts) {
var filteredTxList
Object.keys(opts).forEach((key) => {
@@ -93,10 +110,19 @@ module.exports = class TransactionManager extends EventEmitter {
})
}
+// keeps around the txCbs for later
addOnTxDoneCb (txId, cb) {
this._unconfTxCbs[txId] = cb || noop
}
+ execOnTxDoneCb (txId, conf) {
+ var approvalCb = this._unconfTxCbs[txId]
+
+ approvalCb(null, conf)
+ // clean up
+ delete this._unconfTxCbs[txId]
+ }
+
// should return the tx
// Should find the tx in the tx list and
@@ -136,7 +162,6 @@ module.exports = class TransactionManager extends EventEmitter {
setTxStatusConfirmed (txId) {
this.setTxStatus(txId, 'confirmed')
- // this.removeListener(`check${txId}`, this.checkForTxInBlock)
}
// merges txParams obj onto txData.txParams
@@ -147,12 +172,15 @@ module.exports = class TransactionManager extends EventEmitter {
this.updateTx(txData)
}
+ // sets provider for provider utils and event listener
setProvider (provider) {
this.provider = provider
this.txProviderUtils = new TxProviderUtil(provider)
this.provider.on('block', this.checkForTxInBlock.bind(this))
}
+ // checks if a signed tx is in a block and
+ // if included sets the tx status as 'confirmed'
checkForTxInBlock () {
var signedTxList = this.getFilterdTxList({status: 'signed'})
if (!signedTxList.length) return