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 an action to fetch token balances
  • Loading branch information
Mikhail Mikheev committed Apr 8, 2019
commit 8108b6bd0113eda7f95627160d2825323ff09505
27 changes: 27 additions & 0 deletions src/logic/tokens/store/actions/fetchTokenBalances.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,27 @@
// @flow
import type { Dispatch as ReduxDispatch } from 'redux'
import { Map, List } from 'immutable'
import { type Token } from '~/logic/tokens/store/model/token'
import { type GlobalState } from '~/store/index'
import { calculateBalanceOf } from './fetchTokens'
import { addTokens } from './saveTokens'

const fetchTokenBalances = (safeAddress: string, tokens: List<Token>) => async (
dispatch: ReduxDispatch<GlobalState>,
) => {
try {
const withBalances = await Promise.all(
tokens.map(async token => token.set('funds', await calculateBalanceOf(token.address, safeAddress))),
)
const tokensMap = Map().withMutations((map) => {
withBalances.forEach(token => map.set(token.address, token))
})

dispatch(addTokens(safeAddress, tokensMap))
} catch (err) {
// eslint-disable-next-line
console.error('Error while loading active tokens from storage:', err)
}
}

export default fetchTokenBalances
2 changes: 1 addition & 1 deletion src/logic/tokens/store/actions/fetchTokens.js
Original file line number Diff line number Diff line change
Expand Up @@ -34,7 +34,7 @@ export const getHumanFriendlyToken = ensureOnce(createHumanFriendlyTokenContract

export const getStandardTokenContract = ensureOnce(createStandardTokenContract)

export const calculateBalanceOf = async (tokenAddress: string, address: string, decimals: number) => {
export const calculateBalanceOf = async (tokenAddress: string, address: string, decimals: number = 18) => {
const erc20Token = await getStandardTokenContract()
let balance = 0

Expand Down
2 changes: 1 addition & 1 deletion src/logic/tokens/store/actions/loadActiveTokens.js
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,7 @@ const loadActiveTokens = (safeAddress: string) => async (dispatch: ReduxDispatch
}
} catch (err) {
// eslint-disable-next-line
console.error('Error while getting safes from storage:', err)
console.error('Error while loading active tokens from storage:', err)
}
}

Expand Down
25 changes: 17 additions & 8 deletions src/logic/tokens/store/selectors/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -6,10 +6,10 @@ import { type GlobalState } from '~/store'
import { TOKEN_REDUCER_ID } from '~/logic/tokens/store/reducer/tokens'
import { type Token } from '~/logic/tokens/store/model/token'

const balancesSelector = (state: GlobalState) => state[TOKEN_REDUCER_ID]
const tokensStateSelector = (state: GlobalState) => state[TOKEN_REDUCER_ID]

export const tokensSelector: Selector<GlobalState, RouterProps, Map<string, Token>> = createSelector(
balancesSelector,
tokensStateSelector,
safeParamAddressSelector,
(tokens: Map<string, Map<string, Token>>, address: string) => {
if (!address) {
Expand All @@ -20,25 +20,34 @@ export const tokensSelector: Selector<GlobalState, RouterProps, Map<string, Toke
},
)

export const tokenListSelector = createSelector(
export const tokenListSelector: Selector<GlobalState, RouterProps, List<Token>> = createSelector(
tokensSelector,
(tokens: Map<string, Token>) => tokens.toList(),
)

export const activeTokensSelector = createSelector(
export const activeTokensSelector: Selector<GlobalState, RouterProps, List<Token>> = createSelector(
tokenListSelector,
(tokens: List<Token>) => tokens.filter((token: Token) => token.get('status')),
)

export const orderedTokenListSelector = createSelector(
export const orderedTokenListSelector: Selector<GlobalState, RouterProps, List<Token>> = createSelector(
tokenListSelector,
(tokens: List<Token>) => tokens.sortBy((token: Token) => token.get('symbol')),
)

export const tokenAddressesSelector = createSelector(
export const tokenAddressesSelector: Selector<GlobalState, RouterProps, List<string>> = createSelector(
tokenListSelector,
(balances: List<Token>) => {
const addresses = List().withMutations(list => balances.map(token => list.push(token.address)))
(tokens: List<Token>) => {
const addresses = List().withMutations(list => tokens.map(token => list.push(token.address)))

return addresses
},
)

export const activeTokenAdressesSelector: Selector<GlobalState, RouterProps, List<string>> = createSelector(
activeTokensSelector,
(tokens: List<Token>) => {
const addresses = List().withMutations(list => tokens.map(token => list.push(token.address)))

return addresses
},
Expand Down
3 changes: 3 additions & 0 deletions src/routes/safe/container/actions.js
Original file line number Diff line number Diff line change
Expand Up @@ -2,15 +2,18 @@
import fetchSafe from '~/routes/safe/store/actions/fetchSafe'
import { fetchTokens } from '~/logic/tokens/store/actions/fetchTokens'
import loadActiveTokens from '~/logic/tokens/store/actions/loadActiveTokens'
import fetchTokenBalances from '~/logic/tokens/store/actions/fetchTokenBalances'

export type Actions = {
fetchSafe: typeof fetchSafe,
fetchTokens: typeof fetchTokens,
loadActiveTokens: typeof loadActiveTokens,
fetchTokenBalances: typeof fetchTokenBalances
}

export default {
fetchSafe,
fetchTokens,
loadActiveTokens,
fetchTokenBalances,
}
18 changes: 13 additions & 5 deletions src/routes/safe/container/index.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -16,21 +16,27 @@ const TIMEOUT = process.env.NODE_ENV === 'test' ? 1500 : 15000
class SafeView extends React.PureComponent<Props> {
componentDidMount() {
const {
safeUrl, fetchTokenBalances, fetchSafe, loadActiveTokens,
safeUrl, fetchTokenBalances, fetchSafe, loadActiveTokens, activeTokens,
} = this.props

fetchSafe(safeUrl)
loadActiveTokens(safeUrl)
// fetchTokens(safeUrl)

if (activeTokens.size) {
fetchTokenBalances(safeUrl, activeTokens)
}

this.intervalId = setInterval(() => {
// fetchTokenBalances(safeUrl)
// eslint-disable-next-line
fetchTokenBalances(safeUrl, this.props.activeTokens)
fetchSafe(safeUrl)
}, TIMEOUT)
}

componentDidUpdate(prevProps) {
const { safe, fetchTokenBalances, loadActiveTokens } = this.props
const {
safe, fetchTokenBalances, loadActiveTokens, activeTokens,
} = this.props

if (prevProps.safe) {
return
Expand All @@ -39,7 +45,9 @@ class SafeView extends React.PureComponent<Props> {
if (safe) {
const safeAddress = safe.get('address')
loadActiveTokens(safeAddress)
// fetchTokenBalances(safeAddress)
if (activeTokens.size) {
fetchTokenBalances(safeAddress, activeTokens)
}
}
}

Expand Down