aboutsummaryrefslogtreecommitdiffstats
path: root/app/scripts
diff options
context:
space:
mode:
authorEsteban MIno <efmino@uc.cl>2018-07-26 04:14:10 +0800
committerEsteban MIno <efmino@uc.cl>2018-07-26 04:14:10 +0800
commit2770df80e3cdd4d539b88c6d018108cb07211748 (patch)
tree65ffb8964b1d0e8115cb771632561512cad564e0 /app/scripts
parent3667f3cb8556d55ad893ec8c1a0f84447273906f (diff)
downloadtangerine-wallet-browser-2770df80e3cdd4d539b88c6d018108cb07211748.tar
tangerine-wallet-browser-2770df80e3cdd4d539b88c6d018108cb07211748.tar.gz
tangerine-wallet-browser-2770df80e3cdd4d539b88c6d018108cb07211748.tar.bz2
tangerine-wallet-browser-2770df80e3cdd4d539b88c6d018108cb07211748.tar.lz
tangerine-wallet-browser-2770df80e3cdd4d539b88c6d018108cb07211748.tar.xz
tangerine-wallet-browser-2770df80e3cdd4d539b88c6d018108cb07211748.tar.zst
tangerine-wallet-browser-2770df80e3cdd4d539b88c6d018108cb07211748.zip
add & delete tokens per account
Diffstat (limited to 'app/scripts')
-rw-r--r--app/scripts/controllers/detect-tokens.js2
-rw-r--r--app/scripts/controllers/preferences.js33
2 files changed, 27 insertions, 8 deletions
diff --git a/app/scripts/controllers/detect-tokens.js b/app/scripts/controllers/detect-tokens.js
index 195ec918a..62e639795 100644
--- a/app/scripts/controllers/detect-tokens.js
+++ b/app/scripts/controllers/detect-tokens.js
@@ -85,7 +85,7 @@ class DetectTokensController {
set preferences (preferences) {
if (!preferences) { return }
this._preferences = preferences
- preferences.store.subscribe(({ tokens }) => { this.tokenAddresses = tokens.map((obj) => { return obj.address }) })
+ preferences.store.subscribe(({ tokens = [] }) => { this.tokenAddresses = tokens.map((obj) => { return obj.address }) })
preferences.store.subscribe(({ selectedAddress }) => {
if (this.selectedAddress !== selectedAddress) {
this.selectedAddress = selectedAddress
diff --git a/app/scripts/controllers/preferences.js b/app/scripts/controllers/preferences.js
index f6250dc16..878333481 100644
--- a/app/scripts/controllers/preferences.js
+++ b/app/scripts/controllers/preferences.js
@@ -24,6 +24,7 @@ class PreferencesController {
const initState = extend({
frequentRpcList: [],
currentAccountTab: 'history',
+ addressTokens: {},
tokens: [],
useBlockie: false,
featureFlags: {},
@@ -35,6 +36,16 @@ class PreferencesController {
this.diagnostics = opts.diagnostics
this.store = new ObservableStore(initState)
+
+ Object.defineProperty(this.store._state, 'tokens', {
+ get: () => {
+ const selectedAddress = this.store.getState().selectedAddress
+ const tokens = this.store.getState().addressTokens
+ // TODO when create vault
+ if (!(selectedAddress in tokens)) return []
+ return tokens[selectedAddress]
+ },
+ })
}
// PUBLIC METHODS
@@ -117,14 +128,16 @@ class PreferencesController {
*/
addAddresses (addresses) {
const identities = this.store.getState().identities
+ const addressTokens = this.store.getState().addressTokens
addresses.forEach((address) => {
// skip if already exists
if (identities[address]) return
// add missing identity
const identityCount = Object.keys(identities).length
+ if (!(address in addressTokens)) addressTokens[address] = []
identities[address] = { name: `Account ${identityCount + 1}`, address }
})
- this.store.updateState({ identities })
+ this.store.updateState({ identities, addressTokens })
}
/*
@@ -181,7 +194,8 @@ class PreferencesController {
setSelectedAddress (_address) {
return new Promise((resolve, reject) => {
const address = normalizeAddress(_address)
- this.store.updateState({ selectedAddress: address })
+ const tokens = this.store.getState().addressTokens[_address]
+ this.store.updateState({ selectedAddress: address, tokens: tokens })
resolve()
})
}
@@ -233,7 +247,10 @@ class PreferencesController {
tokens.push(newEntry)
}
- this.store.updateState({ tokens })
+ const selectedAddress = this.store.getState().selectedAddress
+ const addressTokens = this.store.getState().addressTokens
+ addressTokens[selectedAddress] = tokens
+ this.store.updateState({ addressTokens })
return Promise.resolve(tokens)
}
@@ -246,11 +263,13 @@ class PreferencesController {
*
*/
removeToken (rawAddress) {
- const tokens = this.store.getState().tokens
-
- const updatedTokens = tokens.filter(token => token.address !== rawAddress)
+ const addressTokens = this.store.getState().addressTokens
+ const selectedAddress = this.store.getState().selectedAddress
+
+ const updatedTokens = addressTokens[selectedAddress].filter(token => token.address !== rawAddress)
+ addressTokens[selectedAddress] = updatedTokens
+ this.store.updateState({ addressTokens, tokens: updatedTokens })
- this.store.updateState({ tokens: updatedTokens })
return Promise.resolve(updatedTokens)
}