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.
Tag:
Branch:
Tree:
434249f171
develop
feature/default_network_editable
v10.22.3
${ noResults }
61 lines
1.8 KiB
61 lines
1.8 KiB
import React, { useMemo } from 'react';
|
|||
import PropTypes from 'prop-types';
|
|||
import { PRIMARY, SECONDARY, ETH } from '../../../helpers/constants/common';
|
|||
import CurrencyDisplay from '../../ui/currency-display';
|
|||
import { useUserPreferencedCurrency } from '../../../hooks/useUserPreferencedCurrency';
|
|||
|
|||
|
export default function UserPreferencedCurrencyDisplay({
|
||
'data-testid': dataTestId,
|
|||
ethLogoHeight = 12,
|
|||
ethNumberOfDecimals,
|
|||
fiatNumberOfDecimals,
|
|||
'numberOfDecimals': propsNumberOfDecimals,
|
|||
showEthLogo,
|
|||
type,
|
|||
...restProps
|
|||
}) {
|
|||
|
const { currency, numberOfDecimals } = useUserPreferencedCurrency(type, {
|
||
ethNumberOfDecimals,
|
|||
fiatNumberOfDecimals,
|
|||
numberOfDecimals: propsNumberOfDecimals,
|
|||
});
|
|||
const prefixComponent = useMemo(() => {
|
|||
|
return (
|
||
currency === ETH &&
|
|||
showEthLogo && <img src="/images/eth.svg" height={ethLogoHeight} alt="" />
|
|||
);
|
|||
}, [currency, showEthLogo, ethLogoHeight]);
|
|||
|
|||
return (
|
|||
<CurrencyDisplay
|
|||
{...restProps}
|
|||
currency={currency}
|
|||
data-testid={dataTestId}
|
|||
numberOfDecimals={numberOfDecimals}
|
|||
prefixComponent={prefixComponent}
|
|||
/>
|
|||
);
|
|||
}
|
|||
|
|||
UserPreferencedCurrencyDisplay.propTypes = {
|
|||
'className': PropTypes.string,
|
|||
'data-testid': PropTypes.string,
|
|||
'prefix': PropTypes.string,
|
|||
'value': PropTypes.string,
|
|||
'numberOfDecimals': PropTypes.oneOfType([PropTypes.string, PropTypes.number]),
|
|||
'hideLabel': PropTypes.bool,
|
|||
'hideTitle': PropTypes.bool,
|
|||
'style': PropTypes.object,
|
|||
'showEthLogo': PropTypes.bool,
|
|||
'ethLogoHeight': PropTypes.oneOfType([PropTypes.string, PropTypes.number]),
|
|||
'type': PropTypes.oneOf([PRIMARY, SECONDARY]),
|
|||
'ethNumberOfDecimals': PropTypes.oneOfType([
|
|||
|
PropTypes.string,
|
||
PropTypes.number,
|
|||
]),
|
|||
'fiatNumberOfDecimals': PropTypes.oneOfType([
|
|||
|
PropTypes.string,
|
||
PropTypes.number,
|
|||
]),
|
|||
};
|