2016-05-23 00:23:16 +02:00
module . exports = setupDappAutoReload
2017-05-25 04:13:35 +02:00
function setupDappAutoReload ( web3 , observable ) {
2016-05-23 00:23:16 +02:00
// export web3 as a global, checking for usage
2017-08-24 01:26:55 +02:00
let hasBeenWarned = false
2017-08-24 01:44:57 +02:00
let reloadInProgress = false
let lastTimeUsed
let lastSeenNetwork
2017-05-25 04:13:35 +02:00
global . web3 = new Proxy ( web3 , {
2017-08-24 01:26:55 +02:00
get : ( _web3 , key ) => {
// show warning once on web3 access
if ( ! hasBeenWarned && key !== 'currentProvider' ) {
2017-09-05 20:35:33 +02:00
c onsole . warn ( 'MetaMask: web3 will be deprecated in the near future in favor of the ethereumProvider \nhttps://github.com/MetaMask/faq/blob/master/detecting_metamask.md#web3-deprecation' )
2017-08-24 01:26:55 +02:00
hasBeenWarned = true
}
// get the time of use
2017-08-24 01:44:57 +02:00
lastTimeUsed = Date . now ( )
// return value normally
2017-08-24 01:26:55 +02:00
return _web3 [ key ]
2017-05-25 04:13:35 +02:00
} ,
2017-08-24 01:26:55 +02:00
set : ( _web3 , key , value ) => {
2017-08-24 01:44:57 +02:00
// set value normally
2017-08-24 01:26:55 +02:00
_web3 [ key ] = value
2017-05-25 04:13:35 +02:00
} ,
} )
2016-05-23 00:23:16 +02:00
2017-05-25 04:13:35 +02:00
observable . subscribe ( function ( state ) {
2017-08-24 01:44:57 +02:00
// if reload in progress, no need to check reload logic
if ( reloadInProgress ) return
const currentNetwork = state . networkVersion
// set the initial network
if ( ! lastSeenNetwork ) {
lastSeenNetwork = currentNetwork
return
}
// skip reload logic if web3 not used
if ( ! lastTimeUsed ) return
// if network did not change, exit
if ( currentNetwork === lastSeenNetwork ) return
// initiate page reload
reloadInProgress = true
const timeSinceUse = Date . now ( ) - lastTimeUsed
// if web3 was recently used then delay the reloading of the page
if ( timeSinceUse > 500 ) {
triggerReset ( )
} else {
setTimeout ( triggerReset , 500 )
2017-05-25 04:13:35 +02:00
}
} )
2016-06-21 22:18:32 +02:00
}
2016-10-12 21:35:55 +02:00
// reload the page
function triggerReset ( ) {
global . location . reload ( )
2016-11-11 19:26:12 +01:00
}