aboutsummaryrefslogtreecommitdiffstats
path: root/app/scripts
diff options
context:
space:
mode:
authorDan Finlay <542863+danfinlay@users.noreply.github.com>2018-07-21 06:50:45 +0800
committerGitHub <noreply@github.com>2018-07-21 06:50:45 +0800
commite094d4ad1fb84a9bc663c328d0650bd9d8bf8716 (patch)
tree41e2c3df2b8146dc85ec144a1d58c5d7bac5d4e2 /app/scripts
parent5db00c766abdb701b824e336c8a76a9dd4911d50 (diff)
parentc11dea9afc9f4215529abda11a0d5a7e4fdd10d4 (diff)
downloadtangerine-wallet-browser-e094d4ad1fb84a9bc663c328d0650bd9d8bf8716.tar
tangerine-wallet-browser-e094d4ad1fb84a9bc663c328d0650bd9d8bf8716.tar.gz
tangerine-wallet-browser-e094d4ad1fb84a9bc663c328d0650bd9d8bf8716.tar.bz2
tangerine-wallet-browser-e094d4ad1fb84a9bc663c328d0650bd9d8bf8716.tar.lz
tangerine-wallet-browser-e094d4ad1fb84a9bc663c328d0650bd9d8bf8716.tar.xz
tangerine-wallet-browser-e094d4ad1fb84a9bc663c328d0650bd9d8bf8716.tar.zst
tangerine-wallet-browser-e094d4ad1fb84a9bc663c328d0650bd9d8bf8716.zip
Merge pull request #4840 from scsaba/transaction-notifications
Transaction notifications
Diffstat (limited to 'app/scripts')
-rw-r--r--app/scripts/metamask-controller.js7
-rw-r--r--app/scripts/platforms/extension.js54
2 files changed, 61 insertions, 0 deletions
diff --git a/app/scripts/metamask-controller.js b/app/scripts/metamask-controller.js
index 6f5908414..e629d1359 100644
--- a/app/scripts/metamask-controller.js
+++ b/app/scripts/metamask-controller.js
@@ -175,6 +175,13 @@ module.exports = class MetamaskController extends EventEmitter {
})
this.txController.on('newUnapprovedTx', opts.showUnapprovedTx.bind(opts))
+ this.txController.on(`tx:status-update`, (txId, status) => {
+ if (status === 'confirmed' || status === 'failed') {
+ const txMeta = this.txController.txStateManager.getTx(txId)
+ this.platform.showTransactionNotification(txMeta)
+ }
+ })
+
// computed balances (accounting for pending transactions)
this.balancesController = new BalancesController({
accountTracker: this.accountTracker,
diff --git a/app/scripts/platforms/extension.js b/app/scripts/platforms/extension.js
index f8dd767dc..901c26cab 100644
--- a/app/scripts/platforms/extension.js
+++ b/app/scripts/platforms/extension.js
@@ -1,4 +1,5 @@
const extension = require('extensionizer')
+const explorerLink = require('etherscan-link').createExplorerLink
class ExtensionPlatform {
@@ -34,6 +35,59 @@ class ExtensionPlatform {
cb(e)
}
}
+
+ showTransactionNotification (txMeta) {
+
+ const status = txMeta.status
+ if (status === 'confirmed') {
+ this._showConfirmedTransaction(txMeta)
+ } else if (status === 'failed') {
+ this._showFailedTransaction(txMeta)
+ }
+ }
+
+ _showConfirmedTransaction (txMeta) {
+
+ this._subscribeToNotificationClicked()
+
+ const url = explorerLink(txMeta.hash, parseInt(txMeta.metamaskNetworkId))
+ const nonce = parseInt(txMeta.txParams.nonce, 16)
+
+ const title = 'Confirmed transaction'
+ const message = `Transaction ${nonce} confirmed! View on EtherScan`
+ this._showNotification(title, message, url)
+ }
+
+ _showFailedTransaction (txMeta) {
+
+ const nonce = parseInt(txMeta.txParams.nonce, 16)
+ const title = 'Failed transaction'
+ const message = `Transaction ${nonce} failed! ${txMeta.err.message}`
+ this._showNotification(title, message)
+ }
+
+ _showNotification (title, message, url) {
+ extension.notifications.create(
+ url,
+ {
+ 'type': 'basic',
+ 'title': title,
+ 'iconUrl': extension.extension.getURL('../../images/icon-64.png'),
+ 'message': message,
+ })
+ }
+
+ _subscribeToNotificationClicked () {
+ if (!extension.notifications.onClicked.hasListener(this._viewOnEtherScan)) {
+ extension.notifications.onClicked.addListener(this._viewOnEtherScan)
+ }
+ }
+
+ _viewOnEtherScan (txId) {
+ if (txId.startsWith('http://')) {
+ global.metamaskController.platform.openWindow({ url: txId })
+ }
+ }
}
module.exports = ExtensionPlatform