From d4dc0a400fb43afd6deaa8d31a013fb049909b11 Mon Sep 17 00:00:00 2001 From: banklesss <105349292+banklesss@users.noreply.github.com> Date: Thu, 19 Dec 2024 18:04:30 +0100 Subject: [PATCH] refactor(wallet-mobile): tx review (#3772) --- .../common/hooks/useFormattedMetadata.tsx | 2 +- .../ReviewTx/common/hooks/useFormattedTx.tsx | 17 --- .../src/features/ReviewTx/common/mocks.ts | 138 ------------------ .../src/features/ReviewTx/common/types.ts | 9 -- .../ReviewTx/Overview/OverviewTab.tsx | 26 +++- .../ReviewTx/UTxOs/UTxOsTab.tsx | 38 +++-- 6 files changed, 44 insertions(+), 186 deletions(-) diff --git a/apps/wallet-mobile/src/features/ReviewTx/common/hooks/useFormattedMetadata.tsx b/apps/wallet-mobile/src/features/ReviewTx/common/hooks/useFormattedMetadata.tsx index baee85c3d2..aa6fe59e65 100644 --- a/apps/wallet-mobile/src/features/ReviewTx/common/hooks/useFormattedMetadata.tsx +++ b/apps/wallet-mobile/src/features/ReviewTx/common/hooks/useFormattedMetadata.tsx @@ -21,7 +21,7 @@ export const formatMetadata = async ( if (unsignedTx != null && unsignedTx.unsignedTx.auxiliaryData && hash != null) { generalTransactionMetadata = await unsignedTx.unsignedTx.auxiliaryData?.metadata() } else if (cbor != null && hash != null) { - const tx = await csl.Transaction.fromBytes(Buffer.from(cbor, 'hex')) + const tx = await csl.Transaction.fromHex(cbor) const auxiliaryData = await tx.auxiliaryData() generalTransactionMetadata = await auxiliaryData?.metadata() } diff --git a/apps/wallet-mobile/src/features/ReviewTx/common/hooks/useFormattedTx.tsx b/apps/wallet-mobile/src/features/ReviewTx/common/hooks/useFormattedTx.tsx index f4b0420786..7a28175139 100644 --- a/apps/wallet-mobile/src/features/ReviewTx/common/hooks/useFormattedTx.tsx +++ b/apps/wallet-mobile/src/features/ReviewTx/common/hooks/useFormattedTx.tsx @@ -1,6 +1,5 @@ import {CredKind} from '@emurgo/cross-csl-core' import {isNonNullable} from '@yoroi/common' -import {infoExtractName} from '@yoroi/portfolio' import {ApiUtxoData, Portfolio} from '@yoroi/types' import {NetworkApi} from '@yoroi/types/lib/typescript/network/manager' import _ from 'lodash' @@ -9,7 +8,6 @@ import {useQuery} from 'react-query' import {YoroiWallet} from '../../../../yoroi-wallets/cardano/types' import {deriveRewardAddressFromAddress} from '../../../../yoroi-wallets/cardano/utils' import {wrappedCsl} from '../../../../yoroi-wallets/cardano/wrappedCsl' -import {formatTokenWithText} from '../../../../yoroi-wallets/utils/format' import {asQuantity} from '../../../../yoroi-wallets/utils/utils' import {usePortfolioTokenInfos} from '../../../Portfolio/common/hooks/usePortfolioTokenInfos' import {useSelectedNetwork} from '../../../WalletManager/common/hooks/useSelectedNetwork' @@ -138,10 +136,7 @@ const formatInputs = async ( ? [ { tokenInfo: wallet.portfolioPrimaryTokenInfo, - name: wallet.portfolioPrimaryTokenInfo.name, - label: formatTokenWithText(coin, wallet.portfolioPrimaryTokenInfo), quantity: coin, - isPrimary: true, }, ] : [] @@ -155,10 +150,7 @@ const formatInputs = async ( return { tokenInfo, - name: infoExtractName(tokenInfo), - label: formatTokenWithText(quantity, tokenInfo), quantity: quantity, - isPrimary: false, } }) .filter(Boolean) ?? [] @@ -193,10 +185,7 @@ const formatOutputs = async ( const primaryAssets = [ { tokenInfo: wallet.portfolioPrimaryTokenInfo, - name: wallet.portfolioPrimaryTokenInfo.name, - label: formatTokenWithText(coin, wallet.portfolioPrimaryTokenInfo), quantity: coin, - isPrimary: true, }, ] @@ -209,10 +198,7 @@ const formatOutputs = async ( return { tokenInfo, - name: infoExtractName(tokenInfo), - label: formatTokenWithText(quantity, tokenInfo), quantity, - isPrimary: false, } }) }) @@ -236,10 +222,7 @@ export const formatFee = (wallet: YoroiWallet, data: TransactionBody): Formatted return { tokenInfo: wallet.portfolioPrimaryTokenInfo, - name: wallet.portfolioPrimaryTokenInfo.name, - label: formatTokenWithText(fee, wallet.portfolioPrimaryTokenInfo), quantity: fee, - isPrimary: true, } } diff --git a/apps/wallet-mobile/src/features/ReviewTx/common/mocks.ts b/apps/wallet-mobile/src/features/ReviewTx/common/mocks.ts index b11b4e9128..7aa71594f5 100644 --- a/apps/wallet-mobile/src/features/ReviewTx/common/mocks.ts +++ b/apps/wallet-mobile/src/features/ReviewTx/common/mocks.ts @@ -24,10 +24,7 @@ export const onlyAdaOneReceiver: FormattedTx = { originalImage: '', description: 'Cardano', }, - name: 'ADA', - label: '10.618074 ADA', quantity: '10618074', - isPrimary: true, }, ], address: @@ -58,10 +55,7 @@ export const onlyAdaOneReceiver: FormattedTx = { originalImage: '', description: 'Cardano', }, - name: 'ADA', - label: '2.000000 ADA', quantity: '2000000', - isPrimary: true, }, ], address: @@ -94,10 +88,7 @@ export const onlyAdaOneReceiver: FormattedTx = { originalImage: '', description: 'Cardano', }, - name: 'ADA', - label: '10.000000 ADA', quantity: '10000000', - isPrimary: true, }, ], address: @@ -126,10 +117,7 @@ export const onlyAdaOneReceiver: FormattedTx = { originalImage: '', description: 'Cardano', }, - name: 'ADA', - label: '2.443465 ADA', quantity: '2443465', - isPrimary: true, }, ], address: @@ -157,10 +145,7 @@ export const onlyAdaOneReceiver: FormattedTx = { originalImage: '', description: 'Cardano', }, - name: 'ADA', - label: '0.174609 ADA', quantity: '174609', - isPrimary: true, }, certificates: null, mint: null, @@ -189,10 +174,7 @@ export const onlyAdaOneReceiverReferenceInputs: FormattedTx = { originalImage: '', description: 'Cardano', }, - name: 'ADA', - label: '10.618074 ADA', quantity: '10618074', - isPrimary: true, }, ], address: @@ -223,10 +205,7 @@ export const onlyAdaOneReceiverReferenceInputs: FormattedTx = { originalImage: '', description: 'Cardano', }, - name: 'ADA', - label: '2.000000 ADA', quantity: '2000000', - isPrimary: true, }, ], address: @@ -259,10 +238,7 @@ export const onlyAdaOneReceiverReferenceInputs: FormattedTx = { originalImage: '', description: 'Cardano', }, - name: 'ADA', - label: '10.000000 ADA', quantity: '10000000', - isPrimary: true, }, ], address: @@ -291,10 +267,7 @@ export const onlyAdaOneReceiverReferenceInputs: FormattedTx = { originalImage: '', description: 'Cardano', }, - name: 'ADA', - label: '2.443465 ADA', quantity: '2443465', - isPrimary: true, }, ], address: @@ -322,10 +295,7 @@ export const onlyAdaOneReceiverReferenceInputs: FormattedTx = { originalImage: '', description: 'Cardano', }, - name: 'ADA', - label: '0.174609 ADA', quantity: '174609', - isPrimary: true, }, certificates: null, mint: null, @@ -350,10 +320,7 @@ export const onlyAdaOneReceiverReferenceInputs: FormattedTx = { originalImage: '', description: 'Cardano', }, - name: 'ADA', - label: '10.618074 ADA', quantity: '10618074', - isPrimary: true, }, ], address: @@ -389,10 +356,7 @@ export const onlyAdaOneReceiverMint: FormattedTx = { originalImage: '', description: 'Cardano', }, - name: 'ADA', - label: '10.618074 ADA', quantity: '10618074', - isPrimary: true, }, ], address: @@ -423,10 +387,7 @@ export const onlyAdaOneReceiverMint: FormattedTx = { originalImage: '', description: 'Cardano', }, - name: 'ADA', - label: '2.000000 ADA', quantity: '2000000', - isPrimary: true, }, ], address: @@ -459,10 +420,7 @@ export const onlyAdaOneReceiverMint: FormattedTx = { originalImage: '', description: 'Cardano', }, - name: 'ADA', - label: '10.000000 ADA', quantity: '10000000', - isPrimary: true, }, ], address: @@ -491,10 +449,7 @@ export const onlyAdaOneReceiverMint: FormattedTx = { originalImage: '', description: 'Cardano', }, - name: 'ADA', - label: '2.443465 ADA', quantity: '2443465', - isPrimary: true, }, ], address: @@ -522,10 +477,7 @@ export const onlyAdaOneReceiverMint: FormattedTx = { originalImage: '', description: 'Cardano', }, - name: 'ADA', - label: '0.174609 ADA', quantity: '174609', - isPrimary: true, }, certificates: null, mint: [ @@ -595,10 +547,7 @@ export const multiAssetOneReceiver: FormattedTx = { originalImage: '', description: 'Cardano', }, - name: 'ADA', - label: '2.000000 ADA', quantity: '2000000', - isPrimary: true, }, { tokenInfo: { @@ -620,10 +569,7 @@ export const multiAssetOneReceiver: FormattedTx = { originalImage: '', }, - name: 'ADAMOON', - label: '20 ADAMOON', quantity: '20', - isPrimary: false, }, { tokenInfo: { @@ -643,10 +589,7 @@ export const multiAssetOneReceiver: FormattedTx = { description: '', originalImage: 'https://ipfs.io/ipfs/QmNbZQLBoqNdsmmVJ42Yip5wcbRiqTbwgFAi3ChWQX74nm', }, - name: 'javibueno.ada', - label: '1 javibueno.ada', quantity: '1', - isPrimary: false, }, ], address: @@ -677,10 +620,7 @@ export const multiAssetOneReceiver: FormattedTx = { originalImage: '', description: 'Cardano', }, - name: 'ADA', - label: '2.482465 ADA', quantity: '2482465', - isPrimary: true, }, ], address: @@ -713,10 +653,7 @@ export const multiAssetOneReceiver: FormattedTx = { originalImage: '', description: 'Cardano', }, - name: 'ADA', - label: '2.000000 ADA', quantity: '2000000', - isPrimary: true, }, { tokenInfo: { @@ -738,10 +675,7 @@ export const multiAssetOneReceiver: FormattedTx = { originalImage: '', }, - name: 'ADAMOON', - label: '10 ADAMOON', quantity: '10', - isPrimary: false, }, { tokenInfo: { @@ -761,10 +695,7 @@ export const multiAssetOneReceiver: FormattedTx = { description: '', originalImage: 'https://ipfs.io/ipfs/QmNbZQLBoqNdsmmVJ42Yip5wcbRiqTbwgFAi3ChWQX74nm', }, - name: 'javibueno.ada', - label: '1 javibueno.ada', quantity: '1', - isPrimary: false, }, ], address: @@ -793,10 +724,7 @@ export const multiAssetOneReceiver: FormattedTx = { originalImage: '', description: 'Cardano', }, - name: 'ADA', - label: '1.150770 ADA', quantity: '1150770', - isPrimary: true, }, { tokenInfo: { @@ -818,10 +746,7 @@ export const multiAssetOneReceiver: FormattedTx = { originalImage: '', }, - name: 'ADAMOON', - label: '10 ADAMOON', quantity: '10', - isPrimary: false, }, ], address: @@ -850,10 +775,7 @@ export const multiAssetOneReceiver: FormattedTx = { originalImage: '', description: 'Cardano', }, - name: 'ADA', - label: '1.153126 ADA', quantity: '1153126', - isPrimary: true, }, ], address: @@ -881,10 +803,7 @@ export const multiAssetOneReceiver: FormattedTx = { originalImage: '', description: 'Cardano', }, - name: 'ADA', - label: '0.178569 ADA', quantity: '178569', - isPrimary: true, }, certificates: null, mint: null, @@ -913,10 +832,7 @@ const onlyAdaMultiReceiver: FormattedTx = { originalImage: '', description: 'Cardano', }, - name: 'ADA', - label: '10.618074 ADA', quantity: '10618074', - isPrimary: true, }, ], address: @@ -947,10 +863,7 @@ const onlyAdaMultiReceiver: FormattedTx = { originalImage: '', description: 'Cardano', }, - name: 'ADA', - label: '2.000000 ADA', quantity: '2000000', - isPrimary: true, }, { tokenInfo: { @@ -970,10 +883,7 @@ const onlyAdaMultiReceiver: FormattedTx = { description: '', originalImage: 'https://ipfs.io/ipfs/QmNbZQLBoqNdsmmVJ42Yip5wcbRiqTbwgFAi3ChWQX74nm', }, - name: 'javibueno.ada', - label: '1 javibueno.ada', quantity: '1', - isPrimary: false, }, ], address: @@ -1006,10 +916,7 @@ const onlyAdaMultiReceiver: FormattedTx = { originalImage: '', description: 'Cardano', }, - name: 'ADA', - label: '5.000000 ADA', quantity: '5000000', - isPrimary: true, }, ], address: @@ -1038,10 +945,7 @@ const onlyAdaMultiReceiver: FormattedTx = { originalImage: '', description: 'Cardano', }, - name: 'ADA', - label: '5.000000 ADA', quantity: '5000000', - isPrimary: true, }, ], address: @@ -1070,10 +974,7 @@ const onlyAdaMultiReceiver: FormattedTx = { originalImage: '', description: 'Cardano', }, - name: 'ADA', - label: '2.443465 ADA', quantity: '2443465', - isPrimary: true, }, ], address: @@ -1101,10 +1002,7 @@ const onlyAdaMultiReceiver: FormattedTx = { originalImage: '', description: 'Cardano', }, - name: 'ADA', - label: '0.174609 ADA', quantity: '174609', - isPrimary: true, }, certificates: null, mint: null, @@ -1133,10 +1031,7 @@ const multiAssetMultiReceiver: FormattedTx = { originalImage: '', description: 'Cardano', }, - name: 'ADA', - label: '10.618074 ADA', quantity: '10618074', - isPrimary: true, }, ], address: @@ -1167,10 +1062,7 @@ const multiAssetMultiReceiver: FormattedTx = { originalImage: '', description: 'Cardano', }, - name: 'ADA', - label: '2.000000 ADA', quantity: '2000000', - isPrimary: true, }, { tokenInfo: { @@ -1190,10 +1082,7 @@ const multiAssetMultiReceiver: FormattedTx = { description: '', originalImage: 'https://ipfs.io/ipfs/QmNbZQLBoqNdsmmVJ42Yip5wcbRiqTbwgFAi3ChWQX74nm', }, - name: 'javibueno.ada', - label: '1 javibueno.ada', quantity: '1', - isPrimary: false, }, ], address: @@ -1226,10 +1115,7 @@ const multiAssetMultiReceiver: FormattedTx = { originalImage: '', description: 'Cardano', }, - name: 'ADA', - label: '5.000000 ADA', quantity: '5000000', - isPrimary: true, }, ], address: @@ -1258,10 +1144,7 @@ const multiAssetMultiReceiver: FormattedTx = { originalImage: '', description: 'Cardano', }, - name: 'ADA', - label: '5.000000 ADA', quantity: '5000000', - isPrimary: true, }, { tokenInfo: { @@ -1281,10 +1164,7 @@ const multiAssetMultiReceiver: FormattedTx = { description: '', originalImage: 'https://ipfs.io/ipfs/QmNbZQLBoqNdsmmVJ42Yip5wcbRiqTbwgFAi3ChWQX74nm', }, - name: 'javibueno.ada', - label: '1 javibueno.ada', quantity: '1', - isPrimary: false, }, ], address: @@ -1313,10 +1193,7 @@ const multiAssetMultiReceiver: FormattedTx = { originalImage: '', description: 'Cardano', }, - name: 'ADA', - label: '2.443465 ADA', quantity: '2443465', - isPrimary: true, }, ], address: @@ -1344,10 +1221,7 @@ const multiAssetMultiReceiver: FormattedTx = { originalImage: '', description: 'Cardano', }, - name: 'ADA', - label: '0.174609 ADA', quantity: '174609', - isPrimary: true, }, certificates: null, mint: null, @@ -1376,10 +1250,7 @@ const operationsWarning: FormattedTx = { originalImage: '', description: 'Cardano', }, - name: 'ADA', - label: '8.221903 ADA', quantity: '8221903', - isPrimary: true, }, ], address: @@ -1412,10 +1283,7 @@ const operationsWarning: FormattedTx = { originalImage: '', description: 'Cardano', }, - name: 'ADA', - label: '8.048702 ADA', quantity: '8048702', - isPrimary: true, }, ], address: @@ -1443,10 +1311,7 @@ const operationsWarning: FormattedTx = { originalImage: '', description: 'Cardano', }, - name: 'ADA', - label: '0.173201 ADA', quantity: '173201', - isPrimary: true, }, certificates: [ { @@ -1571,10 +1436,7 @@ const operationsWarning: FormattedTx = { originalImage: '', description: 'Cardano', }, - name: 'ADA', - label: '8.221903 ADA', quantity: '8221903', - isPrimary: true, }, ], address: diff --git a/apps/wallet-mobile/src/features/ReviewTx/common/types.ts b/apps/wallet-mobile/src/features/ReviewTx/common/types.ts index f36e49c878..e99a7e08b2 100644 --- a/apps/wallet-mobile/src/features/ReviewTx/common/types.ts +++ b/apps/wallet-mobile/src/features/ReviewTx/common/types.ts @@ -14,10 +14,7 @@ export type TransactionOutputs = TransactionOutputsJSON export type FormattedInput = { assets: Array<{ tokenInfo: Portfolio.Token.Info - name: string - label: string quantity: Balance.Quantity - isPrimary: boolean }> address: string | undefined addressKind: CredKind | null @@ -32,10 +29,7 @@ export type FormattedInputs = Array export type FormattedOutput = { assets: Array<{ tokenInfo: Portfolio.Token.Info - name: string - label: string quantity: Balance.Quantity - isPrimary: boolean }> address: string addressKind: CredKind | null @@ -47,10 +41,7 @@ export type FormattedOutputs = Array export type FormattedFee = { tokenInfo: Portfolio.Token.Info - name: string - label: string quantity: Balance.Quantity - isPrimary: boolean } export type FormattedTx = { diff --git a/apps/wallet-mobile/src/features/ReviewTx/useCases/ReviewTxScreen/ReviewTx/Overview/OverviewTab.tsx b/apps/wallet-mobile/src/features/ReviewTx/useCases/ReviewTxScreen/ReviewTx/Overview/OverviewTab.tsx index cbc4e5c979..1d42b47eb4 100644 --- a/apps/wallet-mobile/src/features/ReviewTx/useCases/ReviewTxScreen/ReviewTx/Overview/OverviewTab.tsx +++ b/apps/wallet-mobile/src/features/ReviewTx/useCases/ReviewTxScreen/ReviewTx/Overview/OverviewTab.tsx @@ -2,7 +2,7 @@ import {CredKind} from '@emurgo/cross-csl-core' import {parseBoolean, useAsyncStorage, useMutationWithInvalidations} from '@yoroi/common' import {Blockies} from '@yoroi/identicon' import {useTheme} from '@yoroi/theme' -import {Balance} from '@yoroi/types' +import {Balance, Portfolio} from '@yoroi/types' import {Image} from 'expo-image' import * as React from 'react' import {Linking, ScrollView, StyleSheet, Text, TouchableOpacity, useWindowDimensions, View} from 'react-native' @@ -134,7 +134,7 @@ const WalletInfoSection = ({tx, createdBy}: {tx: FormattedTx; createdBy?: React. )} - + ) } @@ -202,7 +202,7 @@ const MyWalletTokens = ({ const totalPrimaryTokenSent = React.useMemo( () => notOwnedOutputs - .flatMap((output) => output.assets.filter((asset) => asset.isPrimary)) + .flatMap((output) => output.assets.filter((asset) => asset.tokenInfo.nature === Portfolio.Token.Nature.Primary)) .reduce((previous, current) => Quantities.sum([previous, current.quantity]), Quantities.zero), [notOwnedOutputs], ) @@ -213,7 +213,10 @@ const MyWalletTokens = ({ const totalPrimaryTokenSpentLabel = formatTokenWithText(totalPrimaryTokenSpent, wallet.portfolioPrimaryTokenInfo) const notPrimaryTokenSent = React.useMemo( - () => notOwnedOutputs.flatMap((output) => output.assets.filter((asset) => !asset.isPrimary)), + () => + notOwnedOutputs.flatMap((output) => + output.assets.filter((asset) => asset.tokenInfo.nature !== Portfolio.Token.Nature.Primary), + ), [notOwnedOutputs], ) @@ -227,7 +230,12 @@ const MyWalletTokens = ({ {notPrimaryTokenSent.map((token, index) => ( - + ))} @@ -296,9 +304,11 @@ const MultiExternalPartiesSection = ({outputs}: {outputs: FormattedOutputs}) => const strings = useStrings() const receivers = outputs.map((output, index) => { - const totalPrimaryToken = output.assets.filter((asset) => asset.isPrimary)[0]?.quantity ?? Quantities.zero + const totalPrimaryToken = + output.assets.filter((asset) => asset.tokenInfo.nature === Portfolio.Token.Nature.Primary)[0]?.quantity ?? + Quantities.zero const totalPrimaryTokenLabel = formatTokenWithText(totalPrimaryToken, wallet.portfolioPrimaryTokenInfo) - const notPrimaryToken = output.assets.filter((asset) => !asset.isPrimary) + const notPrimaryToken = output.assets.filter((asset) => asset.tokenInfo.nature !== Portfolio.Token.Nature.Primary) const address = output?.rewardAddress ?? output?.address ?? '-' return ( @@ -327,7 +337,7 @@ const MultiExternalPartiesSection = ({outputs}: {outputs: FormattedOutputs}) => diff --git a/apps/wallet-mobile/src/features/ReviewTx/useCases/ReviewTxScreen/ReviewTx/UTxOs/UTxOsTab.tsx b/apps/wallet-mobile/src/features/ReviewTx/useCases/ReviewTxScreen/ReviewTx/UTxOs/UTxOsTab.tsx index 1b7529e0b9..41a0cf74b2 100644 --- a/apps/wallet-mobile/src/features/ReviewTx/useCases/ReviewTxScreen/ReviewTx/UTxOs/UTxOsTab.tsx +++ b/apps/wallet-mobile/src/features/ReviewTx/useCases/ReviewTxScreen/ReviewTx/UTxOs/UTxOsTab.tsx @@ -1,9 +1,12 @@ import {useTheme} from '@yoroi/theme' +import {Portfolio} from '@yoroi/types' import * as React from 'react' import {StyleSheet, Text, View} from 'react-native' import {Divider} from '../../../../../../components/Divider/Divider' import {Space} from '../../../../../../components/Space/Space' +import {formatTokenWithText} from '../../../../../../yoroi-wallets/utils/format' +import {useSelectedWallet} from '../../../../../WalletManager/common/hooks/useSelectedWallet' import {Accordion} from '../../../../common/Accordion' import {CopiableText} from '../../../../common/CopiableText' import {useStrings} from '../../../../common/hooks/useStrings' @@ -13,6 +16,7 @@ import {FormattedInput, FormattedInputs, FormattedOutput, FormattedOutputs, Form export const UTxOsTab = ({tx}: {tx: FormattedTx}) => { const {styles} = useStyles() const strings = useStrings() + const {wallet} = useSelectedWallet() return ( @@ -22,7 +26,7 @@ export const UTxOsTab = ({tx}: {tx: FormattedTx}) => { - + @@ -67,9 +71,12 @@ const Input = ({input}: {input: FormattedInput}) => { - {input.assets.map((asset, index) => ( - - ))} + {input.assets.map((asset, index) => { + const isPrimary = asset.tokenInfo.nature === Portfolio.Token.Nature.Primary + const label = formatTokenWithText(asset.quantity, asset.tokenInfo) + + return + })} ) @@ -98,15 +105,20 @@ const Output = ({output}: {output: FormattedOutput}) => { - {output.assets.map((asset, index) => ( - - ))} + {output.assets.map((asset, index) => { + const isPrimary = asset.tokenInfo.nature === Portfolio.Token.Nature.Primary + const label = formatTokenWithText(asset.quantity, asset.tokenInfo) + + return ( + + ) + })} )