2022-03-11 19:59:58 +01:00
|
|
|
import React, { useContext } from 'react';
|
2021-12-06 17:02:23 +01:00
|
|
|
import {
|
2023-04-25 15:28:22 +02:00
|
|
|
FontWeight,
|
2023-02-02 21:15:26 +01:00
|
|
|
TextColor,
|
2023-04-25 15:28:22 +02:00
|
|
|
TextVariant,
|
2021-12-06 17:02:23 +01:00
|
|
|
} from '../../../../helpers/constants/design-system';
|
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-12-06 17:02:23 +01:00
|
|
|
import { useGasFeeContext } from '../../../../contexts/gasFee';
|
2023-04-25 15:28:22 +02:00
|
|
|
import { Text } from '../../../component-library';
|
2022-03-11 19:59:58 +01:00
|
|
|
import { BaseFeeTooltip, PriorityFeeTooltip } from './tooltips';
|
2021-12-06 17:02:23 +01:00
|
|
|
import StatusSlider from './status-slider';
|
|
|
|
|
|
|
|
const NetworkStatistics = () => {
|
2022-03-11 19:59:58 +01:00
|
|
|
const t = useContext(I18nContext);
|
2021-12-06 17:02:23 +01:00
|
|
|
const { gasFeeEstimates } = useGasFeeContext();
|
2022-03-11 19:59:58 +01:00
|
|
|
const formattedLatestBaseFee = formatGasFeeOrFeeRange(
|
|
|
|
gasFeeEstimates?.estimatedBaseFee,
|
|
|
|
{
|
|
|
|
precision: 0,
|
|
|
|
},
|
|
|
|
);
|
|
|
|
const formattedLatestPriorityFeeRange = formatGasFeeOrFeeRange(
|
|
|
|
gasFeeEstimates?.latestPriorityFeeRange,
|
|
|
|
{ precision: [1, 0] },
|
|
|
|
);
|
|
|
|
const networkCongestion = gasFeeEstimates?.networkCongestion;
|
2021-12-06 17:02:23 +01:00
|
|
|
|
|
|
|
return (
|
|
|
|
<div className="network-statistics">
|
2023-04-25 15:28:22 +02:00
|
|
|
<Text
|
2023-02-02 21:15:26 +01:00
|
|
|
color={TextColor.textAlternative}
|
2023-04-25 15:28:22 +02:00
|
|
|
fontWeight={FontWeight.Bold}
|
2022-07-20 22:47:51 +02:00
|
|
|
marginTop={3}
|
|
|
|
marginBottom={3}
|
2023-04-25 15:28:22 +02:00
|
|
|
variant={TextVariant.bodyXs}
|
|
|
|
as="h6"
|
2021-12-06 17:02:23 +01:00
|
|
|
>
|
2022-03-11 19:59:58 +01:00
|
|
|
{t('networkStatus')}
|
2023-04-25 15:28:22 +02:00
|
|
|
</Text>
|
2021-12-06 17:02:23 +01:00
|
|
|
<div className="network-statistics__info">
|
2022-03-11 19:59:58 +01:00
|
|
|
{isNullish(formattedLatestBaseFee) ? null : (
|
|
|
|
<div
|
|
|
|
className="network-statistics__field"
|
|
|
|
data-testid="formatted-latest-base-fee"
|
|
|
|
>
|
|
|
|
<BaseFeeTooltip>
|
|
|
|
<span className="network-statistics__field-data">
|
|
|
|
{formattedLatestBaseFee}
|
|
|
|
</span>
|
|
|
|
<span className="network-statistics__field-label">
|
|
|
|
{t('baseFee')}
|
|
|
|
</span>
|
|
|
|
</BaseFeeTooltip>
|
|
|
|
</div>
|
|
|
|
)}
|
|
|
|
{isNullish(formattedLatestPriorityFeeRange) ? null : (
|
|
|
|
<div
|
|
|
|
className="network-statistics__field"
|
|
|
|
data-testid="formatted-latest-priority-fee-range"
|
|
|
|
>
|
|
|
|
<PriorityFeeTooltip>
|
|
|
|
<span className="network-statistics__field-data">
|
|
|
|
{formattedLatestPriorityFeeRange}
|
|
|
|
</span>
|
|
|
|
<span className="network-statistics__field-label">
|
|
|
|
{t('priorityFee')}
|
|
|
|
</span>
|
|
|
|
</PriorityFeeTooltip>
|
|
|
|
</div>
|
|
|
|
)}
|
|
|
|
{isNullish(networkCongestion) ? null : (
|
|
|
|
<div className="network-statistics__field">
|
|
|
|
<StatusSlider />
|
|
|
|
</div>
|
|
|
|
)}
|
2021-12-06 17:02:23 +01:00
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
);
|
|
|
|
};
|
|
|
|
|
|
|
|
export default NetworkStatistics;
|