diff options
author | Frances Pangilinan <frankie.diamond@gmail.com> | 2016-12-15 07:04:33 +0800 |
---|---|---|
committer | Frances Pangilinan <frankie.diamond@gmail.com> | 2016-12-15 07:04:33 +0800 |
commit | da9349fe63de70d29a13b6c7d94eb40dc5fcb127 (patch) | |
tree | 204f87bc51d11c6d718841c1f7cb11c4b7781d3c /app/scripts/transaction-manager.js | |
parent | 5a292cc39781824ecd57535972cfa7c985d7824d (diff) | |
download | tangerine-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.js | 30 |
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 |