diff options
author | frankiebee <frankie.diamond@gmail.com> | 2017-05-25 10:13:35 +0800 |
---|---|---|
committer | frankiebee <frankie.diamond@gmail.com> | 2017-05-25 11:00:58 +0800 |
commit | 473b88f399478b47bfa53d44ef9981aeb6d9960b (patch) | |
tree | 20d0c190aa52728b80a9babc51cd7e954c89a7f3 /app/scripts/lib/auto-reload.js | |
parent | d06a812004a5acc0a26fcdd5c29254b17fca25a0 (diff) | |
download | tangerine-wallet-browser-473b88f399478b47bfa53d44ef9981aeb6d9960b.tar tangerine-wallet-browser-473b88f399478b47bfa53d44ef9981aeb6d9960b.tar.gz tangerine-wallet-browser-473b88f399478b47bfa53d44ef9981aeb6d9960b.tar.bz2 tangerine-wallet-browser-473b88f399478b47bfa53d44ef9981aeb6d9960b.tar.lz tangerine-wallet-browser-473b88f399478b47bfa53d44ef9981aeb6d9960b.tar.xz tangerine-wallet-browser-473b88f399478b47bfa53d44ef9981aeb6d9960b.tar.zst tangerine-wallet-browser-473b88f399478b47bfa53d44ef9981aeb6d9960b.zip |
Reload the page when switching networks for sites that use web3
Diffstat (limited to 'app/scripts/lib/auto-reload.js')
-rw-r--r-- | app/scripts/lib/auto-reload.js | 47 |
1 files changed, 25 insertions, 22 deletions
diff --git a/app/scripts/lib/auto-reload.js b/app/scripts/lib/auto-reload.js index 1302df35f..30ddd2395 100644 --- a/app/scripts/lib/auto-reload.js +++ b/app/scripts/lib/auto-reload.js @@ -1,30 +1,33 @@ -const once = require('once') -const ensnare = require('ensnare') - module.exports = setupDappAutoReload -function setupDappAutoReload (web3) { +function setupDappAutoReload (web3, observable) { // export web3 as a global, checking for usage - var pageIsUsingWeb3 = false - var resetWasRequested = false - global.web3 = ensnare(web3, once(function () { - // if web3 usage happened after a reset request, trigger reset late - if (resetWasRequested) return triggerReset() - // mark web3 as used - pageIsUsingWeb3 = true - // reset web3 reference - global.web3 = web3 - })) + global.web3 = new Proxy(web3, { + get: (_web3, name) => { + // get the time of use + if (name !== '_used') _web3._used = Date.now() + return _web3[name] + }, + set: (_web3, name, value) => { + _web3[name] = value + }, + }) + var networkVersion - return handleResetRequest + observable.subscribe(function (state) { + // get the initial network + const curentNetVersion = state.networkVersion + if (!networkVersion) networkVersion = curentNetVersion - function handleResetRequest () { - resetWasRequested = true - // ignore if web3 was not used - if (!pageIsUsingWeb3) return - // reload after short timeout - setTimeout(triggerReset, 500) - } + if (curentNetVersion !== networkVersion && web3._used) { + const timeSenseUse = Date.now() - web3._used + // if web3 was recently used then delay the reloading of the page + timeSenseUse > 500 ? triggerReset() : setTimeout(triggerReset, 500) + // prevent reentry into if statement if state updates again before + // reload + networkVersion = curentNetVersion + } + }) } // reload the page |