import BigNumber from 'bignumber.js'
import React from 'react'
import { useTranslation } from 'react-i18next'
import { StyleSheet, Text, TouchableOpacity } from 'react-native'
import HorizontalLine from 'src/components/HorizontalLine'
import TokenTotalLineItem from 'src/components/TokenTotalLineItem'
import { navigate } from 'src/navigator/NavigationService'
import { Screens } from 'src/navigator/Screens'
import { getRecipientFromAddress } from 'src/recipients/recipient'
import { recipientInfoSelector } from 'src/recipients/reducer'
import { useSelector } from 'src/redux/hooks'
import colors from 'src/styles/colors'
import { typeScale } from 'src/styles/fonts'
import TransferAvatars from 'src/transactions/TransferAvatars'
import UserSection from 'src/transactions/UserSection'
import { TokenTransfer } from 'src/transactions/types'
import networkConfig from 'src/web3/networkConfig'
// Note that this is tested from TransactionDetailsScreen.test.tsx
function TransferReceivedContent({ transfer }: { transfer: TokenTransfer }) {
const { amount, metadata, address } = transfer
const { t } = useTranslation()
const info = useSelector(recipientInfoSelector)
const celoTokenId = networkConfig.celoTokenId
const celoEducationUri = useSelector((state) => state.app.celoEducationUri)
const isCeloTx = amount.tokenId === celoTokenId
const recipient = getRecipientFromAddress(address, info, metadata.title, metadata.image)
const openLearnMore = () => {
navigate(Screens.WebViewScreen, { uri: celoEducationUri! })
}
return (
<>
}
testID="TransferReceived"
/>
{isCeloTx && !!celoEducationUri && (
{t('learnMore')}
)}
>
)
}
const styles = StyleSheet.create({
learnMore: {
...typeScale.bodySmall,
color: colors.textLink,
textDecorationLine: 'underline',
},
})
export default TransferReceivedContent