aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorbitpshr <mail@bitpshr.net>2018-10-18 06:29:40 +0800
committerDan Finlay <542863+danfinlay@users.noreply.github.com>2018-11-06 07:07:09 +0800
commit573139b9357ccd97eb6b866721fafc93ceb080b6 (patch)
treef34a8dd34fb3914a3e80b055dbe2b31e1e09c259
parent3a2ade4e8490fa754b66e8f342a8308879e2f9ed (diff)
downloadtangerine-wallet-browser-573139b9357ccd97eb6b866721fafc93ceb080b6.tar
tangerine-wallet-browser-573139b9357ccd97eb6b866721fafc93ceb080b6.tar.gz
tangerine-wallet-browser-573139b9357ccd97eb6b866721fafc93ceb080b6.tar.bz2
tangerine-wallet-browser-573139b9357ccd97eb6b866721fafc93ceb080b6.tar.lz
tangerine-wallet-browser-573139b9357ccd97eb6b866721fafc93ceb080b6.tar.xz
tangerine-wallet-browser-573139b9357ccd97eb6b866721fafc93ceb080b6.tar.zst
tangerine-wallet-browser-573139b9357ccd97eb6b866721fafc93ceb080b6.zip
Differentiate isEnabled and isApproved hook
-rw-r--r--app/scripts/inpage.js15
1 files changed, 12 insertions, 3 deletions
diff --git a/app/scripts/inpage.js b/app/scripts/inpage.js
index bfafc255d..88831c0cc 100644
--- a/app/scripts/inpage.js
+++ b/app/scripts/inpage.js
@@ -27,9 +27,10 @@ var metamaskStream = new LocalMessageDuplexStream({
// compose the inpage provider
var inpageProvider = new MetamaskInpageProvider(metamaskStream)
+
// set a high max listener count to avoid unnecesary warnings
inpageProvider.setMaxListeners(100)
-var originApproved = false
+var isEnabled = false
// Augment the provider with its enable method
inpageProvider.enable = function () {
@@ -38,11 +39,11 @@ inpageProvider.enable = function () {
if (typeof detail.error !== 'undefined') {
reject(detail.error)
} else {
- originApproved = true
inpageProvider.sendAsync({ method: 'eth_accounts', params: [] }, (error, response) => {
if (error) {
reject(error)
} else {
+ isEnabled = true
resolve(response.result)
}
})
@@ -53,18 +54,26 @@ inpageProvider.enable = function () {
}
inpageProvider.isEnabled = function () {
+ return isEnabled
+}
+
+inpageProvider.isApproved = function () {
return new Promise((resolve, reject) => {
window.addEventListener('ethereumproviderstatus', ({ detail }) => {
if (typeof detail.error !== 'undefined') {
reject(detail.error)
} else {
- resolve(originApproved && !!detail.isEnabled)
+ resolve(!!detail.isEnabled)
}
})
window.postMessage({ type: 'ETHEREUM_QUERY_STATUS' }, '*')
})
}
+inpageProvider.isUnlocked = function () {
+
+}
+
// Work around for web3@1.0 deleting the bound `sendAsync` but not the unbound
// `sendAsync` method on the prototype, causing `this` reference issues with drizzle
const proxiedInpageProvider = new Proxy(inpageProvider, {