diff options
author | Whymarrh Whitby <whymarrh.whitby@gmail.com> | 2018-08-23 02:58:17 +0800 |
---|---|---|
committer | GitHub <noreply@github.com> | 2018-08-23 02:58:17 +0800 |
commit | 171f6711d988cdfe04badee6f1b445a3abf513ad (patch) | |
tree | 7844a2eb8e5dfa3487f3f204a923600c3ca59456 /app | |
parent | 21a6fdc1748424e84d12156552d344c622c03dd1 (diff) | |
parent | e803b8e047b5acad9143fe28d99d9e7d65211f46 (diff) | |
download | tangerine-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.js | 42 |
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 */ |