You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
38 lines
1.2 KiB
38 lines
1.2 KiB
4 years ago
|
import { useMemo } from 'react'
|
||
|
import { useSelector } from 'react-redux'
|
||
|
import { getTokenExchangeRates, getConversionRate, getCurrentCurrency } from '../selectors'
|
||
|
import { getFormattedTokenFiatAmount } from '../helpers/utils/token-util'
|
||
|
|
||
|
/**
|
||
|
* Get the token balance converted to fiat and formatted for display
|
||
|
*
|
||
|
* @param {string} tokenAddress - The token address
|
||
|
* @param {string} [tokenAmount] - The token balance
|
||
|
* @param {string} [tokenSymbol] - The token symbol
|
||
|
* @return {string} - The formatted token amount in the user's chosen fiat currency
|
||
|
*/
|
||
|
export function useTokenFiatAmount (tokenAddress, tokenAmount, tokenSymbol) {
|
||
|
const contractExchangeRates = useSelector(getTokenExchangeRates)
|
||
|
const conversionRate = useSelector(getConversionRate)
|
||
|
const currentCurrency = useSelector(getCurrentCurrency)
|
||
|
|
||
|
const tokenExchangeRate = contractExchangeRates[tokenAddress]
|
||
|
|
||
|
const formattedFiat = useMemo(
|
||
|
() => getFormattedTokenFiatAmount(
|
||
|
tokenExchangeRate,
|
||
|
conversionRate,
|
||
|
currentCurrency,
|
||
|
tokenAmount,
|
||
|
tokenSymbol
|
||
|
),
|
||
|
[tokenExchangeRate, conversionRate, currentCurrency, tokenAmount, tokenSymbol]
|
||
|
)
|
||
|
|
||
|
if (currentCurrency.toUpperCase() === tokenSymbol) {
|
||
|
return undefined
|
||
|
}
|
||
|
|
||
|
return formattedFiat
|
||
|
}
|