aboutsummaryrefslogtreecommitdiffstats
path: root/app
diff options
context:
space:
mode:
authorKevin Serrano <kevgagser@gmail.com>2017-09-30 02:31:18 +0800
committerGitHub <noreply@github.com>2017-09-30 02:31:18 +0800
commitd61f36808a6cad8e770cc66701eb09f40160ab4d (patch)
treee8947c07f7e4f38bbb64b9b2e72daec1230f1967 /app
parentcdf41c28573822c7c4d50efe7dfa34a062825d7f (diff)
parent861bd877f3bf1c0c71a00f1b90048e93dec03488 (diff)
downloadtangerine-wallet-browser-d61f36808a6cad8e770cc66701eb09f40160ab4d.tar
tangerine-wallet-browser-d61f36808a6cad8e770cc66701eb09f40160ab4d.tar.gz
tangerine-wallet-browser-d61f36808a6cad8e770cc66701eb09f40160ab4d.tar.bz2
tangerine-wallet-browser-d61f36808a6cad8e770cc66701eb09f40160ab4d.tar.lz
tangerine-wallet-browser-d61f36808a6cad8e770cc66701eb09f40160ab4d.tar.xz
tangerine-wallet-browser-d61f36808a6cad8e770cc66701eb09f40160ab4d.tar.zst
tangerine-wallet-browser-d61f36808a6cad8e770cc66701eb09f40160ab4d.zip
Merge pull request #2228 from MetaMask/i2218-SelectAccountBugFix
Ensure selected account is always set if possible
Diffstat (limited to 'app')
-rw-r--r--app/scripts/metamask-controller.js9
1 files changed, 9 insertions, 0 deletions
diff --git a/app/scripts/metamask-controller.js b/app/scripts/metamask-controller.js
index 5b3161bc6..b28f2738a 100644
--- a/app/scripts/metamask-controller.js
+++ b/app/scripts/metamask-controller.js
@@ -100,6 +100,14 @@ module.exports = class MetamaskController extends EventEmitter {
encryptor: opts.encryptor || undefined,
})
+ // If only one account exists, make sure it is selected.
+ this.keyringController.store.subscribe((state) => {
+ const addresses = Object.keys(state.walletNicknames || {})
+ if (addresses.length === 1) {
+ const address = addresses[0]
+ this.preferencesController.setSelectedAddress(address)
+ }
+ })
this.keyringController.on('newAccount', (address) => {
this.preferencesController.setSelectedAddress(address)
this.accountTracker.addAccount(address)
@@ -222,6 +230,7 @@ module.exports = class MetamaskController extends EventEmitter {
const isUnlocked = this.keyringController.memStore.getState().isUnlocked
const result = []
const selectedAddress = this.preferencesController.getSelectedAddress()
+
// only show address if account is unlocked
if (isUnlocked && selectedAddress) {
result.push(selectedAddress)