2022-05-09 19:47:06 +02:00
|
|
|
import React, { useEffect, useState } from 'react';
|
2022-04-01 17:52:22 +02:00
|
|
|
import PropTypes from 'prop-types';
|
2023-01-17 16:23:04 +01:00
|
|
|
import { useSelector } from 'react-redux';
|
2022-04-01 17:52:22 +02:00
|
|
|
|
|
|
|
import {
|
2023-07-12 18:42:24 +02:00
|
|
|
Display,
|
2023-02-02 21:15:26 +01:00
|
|
|
TextColor,
|
2023-05-03 15:17:49 +02:00
|
|
|
TextVariant,
|
2022-04-01 17:52:22 +02:00
|
|
|
} from '../../../../helpers/constants/design-system';
|
|
|
|
import { useTokenTracker } from '../../../../hooks/useTokenTracker';
|
|
|
|
import { useTokenFiatAmount } from '../../../../hooks/useTokenFiatAmount';
|
2023-01-17 16:23:04 +01:00
|
|
|
import { getUseCurrencyRateCheck } from '../../../../selectors';
|
2023-08-26 17:27:10 +02:00
|
|
|
import { Box, Checkbox, Text } from '../../../component-library';
|
2022-04-01 17:52:22 +02:00
|
|
|
|
2022-05-09 19:47:06 +02:00
|
|
|
const DetectedTokenValues = ({
|
|
|
|
token,
|
|
|
|
handleTokenSelection,
|
|
|
|
tokensListDetected,
|
|
|
|
}) => {
|
|
|
|
const [tokenSelection, setTokenSelection] = useState(() => {
|
|
|
|
return tokensListDetected[token.address]?.selected;
|
|
|
|
});
|
|
|
|
|
2022-04-01 17:52:22 +02:00
|
|
|
const { tokensWithBalances } = useTokenTracker([token]);
|
2022-05-09 19:47:06 +02:00
|
|
|
const balanceString = tokensWithBalances[0]?.string;
|
2022-04-01 17:52:22 +02:00
|
|
|
const formattedFiatBalance = useTokenFiatAmount(
|
|
|
|
token.address,
|
2022-05-09 19:47:06 +02:00
|
|
|
balanceString,
|
2022-04-01 17:52:22 +02:00
|
|
|
token.symbol,
|
|
|
|
);
|
|
|
|
|
2023-01-17 16:23:04 +01:00
|
|
|
const useCurrencyRateCheck = useSelector(getUseCurrencyRateCheck);
|
|
|
|
|
2022-05-09 19:47:06 +02:00
|
|
|
useEffect(() => {
|
|
|
|
setTokenSelection(tokensListDetected[token.address]?.selected);
|
|
|
|
}, [tokensListDetected, token.address, tokenSelection, setTokenSelection]);
|
|
|
|
|
|
|
|
const handleCheckBoxSelection = () => {
|
|
|
|
setTokenSelection(!tokenSelection);
|
|
|
|
handleTokenSelection(token);
|
|
|
|
};
|
|
|
|
|
2022-04-01 17:52:22 +02:00
|
|
|
return (
|
2023-07-12 18:42:24 +02:00
|
|
|
<Box display={Display.InlineFlex} className="detected-token-values">
|
2022-04-01 17:52:22 +02:00
|
|
|
<Box marginBottom={1}>
|
2023-05-03 15:17:49 +02:00
|
|
|
<Text variant={TextVariant.bodyLgMedium} as="h4">
|
2022-05-09 19:47:06 +02:00
|
|
|
{`${balanceString || '0'} ${token.symbol}`}
|
2023-05-03 15:17:49 +02:00
|
|
|
</Text>
|
|
|
|
<Text
|
|
|
|
variant={TextVariant.bodySm}
|
|
|
|
as="h6"
|
2023-02-02 21:15:26 +01:00
|
|
|
color={TextColor.textAlternative}
|
|
|
|
>
|
2023-01-17 16:23:04 +01:00
|
|
|
{useCurrencyRateCheck
|
2023-08-26 17:27:10 +02:00
|
|
|
? formattedFiatBalance || '$0' // since formattedFiatBalance will be when the conversion rate is not obtained, should replace the `$0` with `N/A`
|
2023-01-17 16:23:04 +01:00
|
|
|
: formattedFiatBalance}
|
2023-05-03 15:17:49 +02:00
|
|
|
</Text>
|
2022-04-01 17:52:22 +02:00
|
|
|
</Box>
|
|
|
|
<Box className="detected-token-values__checkbox">
|
2023-08-26 17:27:10 +02:00
|
|
|
<Checkbox
|
|
|
|
isChecked={tokenSelection}
|
|
|
|
onClick={handleCheckBoxSelection}
|
|
|
|
/>
|
2022-04-01 17:52:22 +02:00
|
|
|
</Box>
|
|
|
|
</Box>
|
|
|
|
);
|
|
|
|
};
|
|
|
|
|
|
|
|
DetectedTokenValues.propTypes = {
|
|
|
|
token: PropTypes.shape({
|
|
|
|
address: PropTypes.string.isRequired,
|
|
|
|
decimals: PropTypes.number,
|
|
|
|
symbol: PropTypes.string,
|
|
|
|
iconUrl: PropTypes.string,
|
|
|
|
aggregators: PropTypes.array,
|
|
|
|
}),
|
2022-05-09 19:47:06 +02:00
|
|
|
handleTokenSelection: PropTypes.func.isRequired,
|
|
|
|
tokensListDetected: PropTypes.object,
|
2022-04-01 17:52:22 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
export default DetectedTokenValues;
|