Skip to content
This repository has been archived by the owner on Nov 10, 2023. It is now read-only.

#99 Refactor redux store #103

Merged
merged 52 commits into from
Apr 22, 2019
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
52 commits
Select commit Hold shift + click to select a range
6e9799b
remove cookie store and session storage
Apr 8, 2019
0f7d68b
eslint fix
Apr 8, 2019
6003d8d
display all safes and not owners only in safe list
Apr 8, 2019
3b27729
load active tokens from localstorage when visiting safe view
Apr 8, 2019
8108b6b
add an action to fetch token balances
Apr 8, 2019
8a8b297
action for fetching active token balances wip
Apr 9, 2019
4f59865
reducer fix, fetching balances and updating balances fixes
Apr 9, 2019
1125536
tokens fetch fixes, disable eth switch in tokens modal
Apr 9, 2019
56c6892
split fetching tokens function
Apr 9, 2019
f598344
fix token fetch
Apr 10, 2019
93cf045
update safe and token models
Apr 10, 2019
a158fe4
add extended token selector
Apr 10, 2019
78883ea
extended token selector fix, dep bump
Apr 11, 2019
fe35b81
refactor tokens reducer
Apr 11, 2019
f94e598
balance fetch fixes
Apr 11, 2019
be295d1
tokens balance refactor wip
Apr 11, 2019
5f142bc
add eth balance to safe model
Apr 11, 2019
3530d2f
remove eth from list of active tokens
Apr 11, 2019
50a315b
show eth balance in balance tab
Apr 12, 2019
f797e2d
use addSafe instead updateSafe while adding a new safe
Apr 12, 2019
a6249de
add SafeToken record
Apr 12, 2019
49f0004
update readme
Apr 12, 2019
f8d1e68
Update safe tokens wip
Apr 12, 2019
413cfa3
reducer fix
Apr 12, 2019
595731d
fix displaying active tokens
Apr 12, 2019
910382c
Active tokens WIP, needs debugging: tokens get washed after safe update
Apr 12, 2019
f486068
rewrite fetchSafe function to support updates
mmv08 Apr 15, 2019
3c5d7fc
fix token balance updating
mmv08 Apr 15, 2019
fc3e1e4
eslint fix
mmv08 Apr 15, 2019
400a19f
fix token balance updating
mmv08 Apr 15, 2019
d7127fb
rewrite active tokens logic to use updateSafe action
mmv08 Apr 15, 2019
81e05c1
remove unused vars, add comment for generateProps func
mmv08 Apr 15, 2019
0b6be00
fix checkbox displaying in manage tokens modal
mmv08 Apr 15, 2019
2c8a79e
remove cdu, otherwise it will fail on many token updates because of i…
Apr 15, 2019
7df11f3
update fix
Apr 15, 2019
b9b936d
activeTokens refactor (again)
mmv08 Apr 16, 2019
d8fbdd3
conflict ifx
mmv08 Apr 16, 2019
76b41a4
merge fixes
mmv08 Apr 16, 2019
4c1197a
fix token balance selector
mmv08 Apr 16, 2019
3373b83
storage middleware wip, add optimization comment
Apr 16, 2019
7e49f8d
fix storing safe in localstorage
Apr 16, 2019
dc185e8
fix safe loading from storage wip
mmv08 Apr 17, 2019
e3d7984
fix safe loading from storage
mmv08 Apr 17, 2019
81fbb3b
add selector for all active tokens
mmv08 Apr 17, 2019
cdaa6c8
fix loading tokens from storage
mmv08 Apr 17, 2019
289f5f6
token redux-related stuff cleanup after refactor
mmv08 Apr 17, 2019
43e8521
eslint fix
mmv08 Apr 17, 2019
c633165
rename setActiveTokens to saveActiveTokens
mmv08 Apr 17, 2019
84af7ae
eslint fixes
mmv08 Apr 17, 2019
8f9eadb
fix updateActiveTokens action call inside Tokens modal
mmv08 Apr 18, 2019
1c95804
fix loading active tokens error
Apr 22, 2019
24b51ba
fix eslint disable statement duplication
Apr 22, 2019
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
add extended token selector
  • Loading branch information
Mikhail Mikheev committed Apr 10, 2019
commit a158fe4a1599d15121b990d24e058c4fbbaff6bd
4 changes: 4 additions & 0 deletions src/logic/tokens/store/model/token.js
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,7 @@ export type TokenProps = {
symbol: string,
decimals: number,
logoUri: string,
balance: string
}

export const makeToken: RecordFactory<TokenProps> = Record({
Expand All @@ -16,6 +17,9 @@ export const makeToken: RecordFactory<TokenProps> = Record({
symbol: '',
decimals: 0,
logoUri: '',
balance: undefined,
})

// balance is only set in extendedSafeTokensSelector when we display user's token balances

export type Token = RecordOf<TokenProps>
28 changes: 24 additions & 4 deletions src/routes/safe/container/selector.js
Original file line number Diff line number Diff line change
@@ -1,13 +1,18 @@
// @flow
import { List } from 'immutable'
import { List, Map } from 'immutable'
import { createSelector, createStructuredSelector, type Selector } from 'reselect'
import { safeSelector, type RouterProps, type SafeSelectorProps } from '~/routes/safe/store/selectors'
import {
safeSelector,
safeTokensSelector,
type RouterProps,
type SafeSelectorProps,
} from '~/routes/safe/store/selectors'
import { providerNameSelector, userAccountSelector, networkSelector } from '~/logic/wallets/store/selectors'
import { type Safe } from '~/routes/safe/store/model/safe'
import { type Owner } from '~/routes/safe/store/model/owner'
import { type GlobalState } from '~/store'
import { sameAddress } from '~/logic/wallets/ethAddresses'
import { activeTokensSelector, orderedTokenListSelector } from '~/logic/tokens/store/selectors'
import { activeTokensSelector, orderedTokenListSelector, tokensSelector } from '~/logic/tokens/store/selectors'
import { type Token } from '~/logic/tokens/store/model/token'
import { safeParamAddressSelector } from '../store/selectors'

Expand Down Expand Up @@ -42,10 +47,25 @@ export const grantedSelector: Selector<GlobalState, RouterProps, boolean> = crea
},
)

const extendedSafeTokensSelector: Selector<GlobalState, RouterProps, List<Token>> = createSelector(
safeTokensSelector,
tokensSelector,
(safeTokens: Map<string, string>, tokensList: Map<string, Token>) => {
// const extendedTokens = safeTokens.map(token => tokensList.get(token.address).set('balance', token.balance))
const extendedTokens = Map().withMutations((map) => {
safeTokens.forEach(({ address, balance }: { address: string, balance: string }) => {
map.set(address, tokensList.get(address).set(balance))
})
})

return extendedTokens
},
)

export default createStructuredSelector<Object, *>({
safe: safeSelector,
provider: providerNameSelector,
tokens: orderedTokenListSelector,
tokens: extendedSafeTokensSelector,
activeTokens: activeTokensSelector,
granted: grantedSelector,
userAddress: userAccountSelector,
Expand Down
12 changes: 10 additions & 2 deletions src/routes/safe/store/model/safe.js
Original file line number Diff line number Diff line change
Expand Up @@ -2,23 +2,31 @@
import { List, Record, Map } from 'immutable'
import type { RecordFactory, RecordOf } from 'immutable'
import type { Owner } from '~/routes/safe/store/model/owner'
import { ETH_ADDRESS } from '~/logic/tokens/utils/tokenHelpers'

export type SafeProps = {
name: string,
address: string,
threshold: number,
owners: List<Owner>,
activeTokensBalances: Map<String, String>,
tokens: List<Map<string, string>>,
}

const SafeRecord: RecordFactory<SafeProps> = Record({
name: '',
address: '',
threshold: 0,
owners: List([]),
activeTokensBalances: Map([]),
tokens: List([
{
address: ETH_ADDRESS,
balance: '0',
},
]),
})

// Tokens is a list of currently enabled tokens for the safe with balances

export type Safe = RecordOf<SafeProps>

export default SafeRecord
16 changes: 15 additions & 1 deletion src/routes/safe/store/selectors/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -78,6 +78,20 @@ export const safeSelector: Selector<GlobalState, RouterProps, SafeSelectorProps>
},
)

export default createStructuredSelector({
export const safeTokensSelector: Selector<GlobalState, RouterProps, Map<string, string>> = createSelector(
safeSelector,
(safe: Safe) => {
if (!safe) {
return Map()
}

const tokens = safe.get('tokens')

return tokens
},
)

export default createStructuredSelector<Object, *>({
safe: safeSelector,
tokens: safeTokensSelector,
})