From 33fec1ca58b02c8495223f4be58d7e03915607b8 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Rodrigo=20Santana=20Gon=C3=A7alves?= Date: Mon, 25 Sep 2023 03:25:15 -0300 Subject: [PATCH] fix sending jesse and usdrif tokens (#747) --- .../ReviewTransactionContainer.tsx | 33 ++++++++++++++----- 1 file changed, 25 insertions(+), 8 deletions(-) diff --git a/src/ux/requestsModal/ReviewRelayTransaction/ReviewTransactionContainer.tsx b/src/ux/requestsModal/ReviewRelayTransaction/ReviewTransactionContainer.tsx index 353c3a93a..fa5a46747 100644 --- a/src/ux/requestsModal/ReviewRelayTransaction/ReviewTransactionContainer.tsx +++ b/src/ux/requestsModal/ReviewRelayTransaction/ReviewTransactionContainer.tsx @@ -80,19 +80,38 @@ export const ReviewTransactionContainer = ({ const feeSymbol = isMainnet ? TokenSymbol.RIF : TokenSymbol.TRIF const feeContract = getTokenAddress(feeSymbol, chainTypesById[chainId]) + const getTokenBySymbol = useCallback( + (symb: string) => { + const result = Object.values(balances).find( + token => token.symbol.toUpperCase() === symb.toUpperCase(), + ) + if (!result) { + throw new Error( + `Token with the symbol ${symb} not found on ${chainId}.`, + ) + } + return result + }, + [balances, chainId], + ) + const tokenContract = useMemo(() => { const rbtcAddress = constants.AddressZero if (symbol === rbtcSymbol) { return rbtcAddress } if (symbol) { - return getTokenAddress(symbol, chainTypesById[chainId]) + try { + return getTokenAddress(symbol, chainTypesById[chainId]) + } catch { + return getTokenBySymbol(symbol).contractAddress + } } return feeContract - }, [symbol, rbtcSymbol, feeContract, chainId]) + }, [symbol, rbtcSymbol, feeContract, chainId, getTokenBySymbol]) - const tokenQuote = tokenPrices[tokenContract].price - const feeQuote = tokenPrices[feeContract].price + const tokenQuote = tokenPrices[tokenContract]?.price + const feeQuote = tokenPrices[feeContract]?.price useEffect(() => { if (txRequest.to && !isAddress(txRequest.to)) { @@ -146,12 +165,10 @@ export const ReviewTransactionContainer = ({ }, [onCancel, request]) const data: TransactionSummaryScreenProps = useMemo(() => { - const convertToUSD = (tokenValue: number, quote: number) => + const convertToUSD = (tokenValue: number, quote = 0) => convertTokenToUSD(tokenValue, quote, true).toFixed(2) - const feeValue = txCostInRif - ? `${balanceToDisplay(txCostInRif, 18, 0)}` - : '0' + const feeValue = txCostInRif ? balanceToDisplay(txCostInRif, 18, 0) : '0' let insufficientFunds = false