2022-03-11 19:59:58 +01:00
|
|
|
import React, { useContext } from 'react';
|
2021-11-29 18:40:48 +01:00
|
|
|
import PropTypes from 'prop-types';
|
|
|
|
|
2022-03-11 19:59:58 +01:00
|
|
|
import { isNullish } from '../../../../helpers/utils/util';
|
|
|
|
import { formatGasFeeOrFeeRange } from '../../../../helpers/utils/gas';
|
|
|
|
import { I18nContext } from '../../../../contexts/i18n';
|
2021-11-29 18:40:48 +01:00
|
|
|
import Box from '../../../ui/box';
|
2021-12-10 01:50:38 +01:00
|
|
|
import LoadingHeartBeat from '../../../ui/loading-heartbeat';
|
2021-11-29 18:40:48 +01:00
|
|
|
|
2022-03-11 19:59:58 +01:00
|
|
|
function determineTrendInfo(trend, t) {
|
|
|
|
switch (trend) {
|
|
|
|
case 'up':
|
|
|
|
return {
|
|
|
|
className: 'advanced-gas-fee-input-subtext__up',
|
|
|
|
imageSrc: '/images/up-arrow.svg',
|
|
|
|
imageAlt: t('upArrow'),
|
|
|
|
};
|
|
|
|
case 'down':
|
|
|
|
return {
|
|
|
|
className: 'advanced-gas-fee-input-subtext__down',
|
|
|
|
imageSrc: '/images/down-arrow.svg',
|
|
|
|
imageAlt: t('downArrow'),
|
|
|
|
};
|
|
|
|
case 'level':
|
|
|
|
return {
|
|
|
|
className: 'advanced-gas-fee-input-subtext__level',
|
|
|
|
imageSrc: '/images/level-arrow.svg',
|
|
|
|
imageAlt: t('levelArrow'),
|
|
|
|
};
|
|
|
|
default:
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
const AdvancedGasFeeInputSubtext = ({ latest, historical, trend }) => {
|
|
|
|
const t = useContext(I18nContext);
|
|
|
|
const trendInfo = determineTrendInfo(trend, t);
|
2021-11-29 18:40:48 +01:00
|
|
|
return (
|
2022-03-11 19:59:58 +01:00
|
|
|
<Box
|
|
|
|
display="flex"
|
|
|
|
alignItems="center"
|
|
|
|
gap={4}
|
|
|
|
className="advanced-gas-fee-input-subtext"
|
|
|
|
>
|
|
|
|
{isNullish(latest) ? null : (
|
|
|
|
<Box display="flex" alignItems="center" data-testid="latest">
|
|
|
|
<span className="advanced-gas-fee-input-subtext__label">
|
|
|
|
{t('currentTitle')}
|
|
|
|
</span>
|
|
|
|
<span className="advanced-gas-fee-input-subtext__value">
|
|
|
|
<LoadingHeartBeat />
|
|
|
|
{formatGasFeeOrFeeRange(latest)}
|
|
|
|
</span>
|
|
|
|
{trendInfo === null ? null : (
|
|
|
|
<span className={trendInfo.className}>
|
|
|
|
<img
|
|
|
|
src={trendInfo.imageSrc}
|
|
|
|
alt={trendInfo.imageAlt}
|
|
|
|
data-testid="fee-arrow"
|
|
|
|
/>
|
|
|
|
</span>
|
|
|
|
)}
|
|
|
|
</Box>
|
|
|
|
)}
|
|
|
|
{isNullish(historical) ? null : (
|
|
|
|
<Box>
|
|
|
|
<span
|
|
|
|
className="advanced-gas-fee-input-subtext__label"
|
|
|
|
data-testid="historical"
|
|
|
|
>
|
|
|
|
{t('twelveHrTitle')}
|
|
|
|
</span>
|
|
|
|
<span className="advanced-gas-fee-input-subtext__value">
|
|
|
|
<LoadingHeartBeat />
|
|
|
|
{formatGasFeeOrFeeRange(historical)}
|
|
|
|
</span>
|
|
|
|
</Box>
|
|
|
|
)}
|
2021-11-29 18:40:48 +01:00
|
|
|
</Box>
|
|
|
|
);
|
|
|
|
};
|
|
|
|
|
|
|
|
AdvancedGasFeeInputSubtext.propTypes = {
|
2022-03-11 19:59:58 +01:00
|
|
|
latest: PropTypes.oneOfType([
|
|
|
|
PropTypes.string,
|
|
|
|
PropTypes.arrayOf(PropTypes.string),
|
|
|
|
]),
|
|
|
|
historical: PropTypes.oneOfType([
|
|
|
|
PropTypes.string,
|
|
|
|
PropTypes.arrayOf(PropTypes.string),
|
|
|
|
]),
|
|
|
|
trend: PropTypes.oneOf(['up', 'down', 'level']),
|
2021-11-29 18:40:48 +01:00
|
|
|
};
|
|
|
|
|
|
|
|
export default AdvancedGasFeeInputSubtext;
|