aboutsummaryrefslogtreecommitdiffstats
path: root/app
diff options
context:
space:
mode:
authorWhymarrh Whitby <whymarrh.whitby@gmail.com>2018-08-23 02:58:17 +0800
committerGitHub <noreply@github.com>2018-08-23 02:58:17 +0800
commit171f6711d988cdfe04badee6f1b445a3abf513ad (patch)
tree7844a2eb8e5dfa3487f3f204a923600c3ca59456 /app
parent21a6fdc1748424e84d12156552d344c622c03dd1 (diff)
parente803b8e047b5acad9143fe28d99d9e7d65211f46 (diff)
downloadtangerine-wallet-browser-171f6711d988cdfe04badee6f1b445a3abf513ad.tar
tangerine-wallet-browser-171f6711d988cdfe04badee6f1b445a3abf513ad.tar.gz
tangerine-wallet-browser-171f6711d988cdfe04badee6f1b445a3abf513ad.tar.bz2
tangerine-wallet-browser-171f6711d988cdfe04badee6f1b445a3abf513ad.tar.lz
tangerine-wallet-browser-171f6711d988cdfe04badee6f1b445a3abf513ad.tar.xz
tangerine-wallet-browser-171f6711d988cdfe04badee6f1b445a3abf513ad.tar.zst
tangerine-wallet-browser-171f6711d988cdfe04badee6f1b445a3abf513ad.zip
Merge pull request #5066 from whymarrh/fix-key-export
Don't re-render the export modal when the selected identity changes
Diffstat (limited to 'app')
-rw-r--r--app/scripts/metamask-controller.js42
1 files changed, 29 insertions, 13 deletions
diff --git a/app/scripts/metamask-controller.js b/app/scripts/metamask-controller.js
index 29838ad2d..4ee88186a 100644
--- a/app/scripts/metamask-controller.js
+++ b/app/scripts/metamask-controller.js
@@ -137,19 +137,7 @@ module.exports = class MetamaskController extends EventEmitter {
encryptor: opts.encryptor || undefined,
})
- // If only one account exists, make sure it is selected.
- this.keyringController.memStore.subscribe((state) => {
- const addresses = state.keyrings.reduce((res, keyring) => {
- return res.concat(keyring.accounts)
- }, [])
- if (addresses.length === 1) {
- const address = addresses[0]
- this.preferencesController.setSelectedAddress(address)
- }
- // ensure preferences + identities controller know about all addresses
- this.preferencesController.addAddresses(addresses)
- this.accountTracker.syncWithAddresses(addresses)
- })
+ this.keyringController.memStore.subscribe((s) => this._onKeyringControllerUpdate(s))
// detect tokens controller
this.detectTokensController = new DetectTokensController({
@@ -1279,6 +1267,34 @@ module.exports = class MetamaskController extends EventEmitter {
}
/**
+ * Handle a KeyringController update
+ * @param {object} state the KC state
+ * @return {Promise<void>}
+ * @private
+ */
+ async _onKeyringControllerUpdate (state) {
+ const {isUnlocked, keyrings} = state
+ const addresses = keyrings.reduce((acc, {accounts}) => acc.concat(accounts), [])
+
+ if (!addresses.length) {
+ return
+ }
+
+ // Ensure preferences + identities controller know about all addresses
+ this.preferencesController.addAddresses(addresses)
+ this.accountTracker.syncWithAddresses(addresses)
+
+ const wasLocked = !isUnlocked
+ if (wasLocked) {
+ const oldSelectedAddress = this.preferencesController.getSelectedAddress()
+ if (!addresses.includes(oldSelectedAddress)) {
+ const address = addresses[0]
+ await this.preferencesController.setSelectedAddress(address)
+ }
+ }
+ }
+
+ /**
* A method for emitting the full MetaMask state to all registered listeners.
* @private
*/