mirror of
https://github.com/status-im/safe-react.git
synced 2025-01-15 20:44:07 +00:00
WA-232 Using custom fetch and active tokens extractor
This commit is contained in:
parent
0f4d5cb33a
commit
be9bfe0df9
19
src/utils/fetch.js
Normal file
19
src/utils/fetch.js
Normal file
@ -0,0 +1,19 @@
|
|||||||
|
// @flow
|
||||||
|
|
||||||
|
export const enhancedFetch = async (url: string, errMsg: string) => {
|
||||||
|
const header = new Headers({
|
||||||
|
'Access-Control-Allow-Origin': '*',
|
||||||
|
})
|
||||||
|
|
||||||
|
const sentData = {
|
||||||
|
mode: 'cors',
|
||||||
|
header,
|
||||||
|
}
|
||||||
|
|
||||||
|
const response = await fetch(url, sentData)
|
||||||
|
if (!response.ok) {
|
||||||
|
throw new Error(errMsg)
|
||||||
|
}
|
||||||
|
|
||||||
|
return response.json()
|
||||||
|
}
|
@ -1,2 +1,39 @@
|
|||||||
// @flow
|
// @flow
|
||||||
|
import { List } from 'immutable'
|
||||||
|
import logo from '~/assets/icons/icon_etherTokens.svg'
|
||||||
|
import { getBalanceInEtherOf } from '~/wallets/getWeb3'
|
||||||
|
import { makeToken, type Token } from '~/routes/tokens/store/model/token'
|
||||||
|
|
||||||
export const isEther = (symbol: string) => symbol === 'ETH'
|
export const isEther = (symbol: string) => symbol === 'ETH'
|
||||||
|
|
||||||
|
export const getSafeEthToken = async (safeAddress: string) => {
|
||||||
|
const balance = await getBalanceInEtherOf(safeAddress)
|
||||||
|
|
||||||
|
const ethBalance = makeToken({
|
||||||
|
address: '0',
|
||||||
|
name: 'Ether',
|
||||||
|
symbol: 'ETH',
|
||||||
|
decimals: 18,
|
||||||
|
logoUrl: logo,
|
||||||
|
funds: balance,
|
||||||
|
})
|
||||||
|
|
||||||
|
return ethBalance
|
||||||
|
}
|
||||||
|
|
||||||
|
export const calculateActiveErc20TokensFrom = (tokens: List<Token>) => {
|
||||||
|
const addresses = List().withMutations(list =>
|
||||||
|
tokens.forEach((token: Token) => {
|
||||||
|
if (isEther(token.get('symbol'))) {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!token.get('status')) {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
list.push(token.address)
|
||||||
|
}))
|
||||||
|
|
||||||
|
return addresses
|
||||||
|
}
|
||||||
|
@ -2,6 +2,7 @@
|
|||||||
import { BigNumber } from 'bignumber.js'
|
import { BigNumber } from 'bignumber.js'
|
||||||
import { getWeb3 } from '~/wallets/getWeb3'
|
import { getWeb3 } from '~/wallets/getWeb3'
|
||||||
import { promisify } from '~/utils/promisify'
|
import { promisify } from '~/utils/promisify'
|
||||||
|
import { enhancedFetch } from '~/utils/fetch'
|
||||||
|
|
||||||
// const MAINNET_NETWORK = 1
|
// const MAINNET_NETWORK = 1
|
||||||
export const EMPTY_DATA = '0x'
|
export const EMPTY_DATA = '0x'
|
||||||
@ -40,21 +41,9 @@ export const calculateGasPrice = async () => {
|
|||||||
return '20000000000'
|
return '20000000000'
|
||||||
}
|
}
|
||||||
|
|
||||||
const header = new Headers({
|
const url = 'https://ethgasstation.info/json/ethgasAPI.json'
|
||||||
'Access-Control-Allow-Origin': '*',
|
const errMsg = 'Error querying gas station'
|
||||||
})
|
const json = await enhancedFetch(url, errMsg)
|
||||||
|
|
||||||
const sentData = {
|
|
||||||
mode: 'cors',
|
|
||||||
header,
|
|
||||||
}
|
|
||||||
|
|
||||||
const response = await fetch('https://ethgasstation.info/json/ethgasAPI.json', sentData)
|
|
||||||
if (!response.ok) {
|
|
||||||
throw new Error('Error querying gast station')
|
|
||||||
}
|
|
||||||
|
|
||||||
const json = await response.json()
|
|
||||||
|
|
||||||
return new BigNumber(json.average).multipliedBy(1e8).toString()
|
return new BigNumber(json.average).multipliedBy(1e8).toString()
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user