mirror of
https://github.com/kremalicious/metamask-extension.git
synced 2024-12-23 09:52:26 +01:00
235 lines
7.2 KiB
JavaScript
235 lines
7.2 KiB
JavaScript
import React, { useState, useContext } from 'react';
|
|
import PropTypes from 'prop-types';
|
|
|
|
import { GAS_RECOMMENDATIONS } from '../../../../shared/constants/gas';
|
|
|
|
import Button from '../../ui/button';
|
|
import Typography from '../../ui/typography/typography';
|
|
import {
|
|
COLORS,
|
|
TYPOGRAPHY,
|
|
FONT_WEIGHT,
|
|
TEXT_ALIGN,
|
|
} from '../../../helpers/constants/design-system';
|
|
|
|
import InfoTooltip from '../../ui/info-tooltip';
|
|
import TransactionTotalBanner from '../transaction-total-banner/transaction-total-banner.component';
|
|
import RadioGroup from '../../ui/radio-group/radio-group.component';
|
|
import AdvancedGasControls from '../advanced-gas-controls/advanced-gas-controls.component';
|
|
import ActionableMessage from '../../ui/actionable-message/actionable-message';
|
|
|
|
import { I18nContext } from '../../../contexts/i18n';
|
|
import { useGasFeeInputs } from '../../../hooks/useGasFeeInputs';
|
|
|
|
export default function EditGasDisplay({
|
|
alwaysShowForm,
|
|
type,
|
|
showEducationButton,
|
|
onEducationClick,
|
|
dappSuggestedGasFee,
|
|
dappOrigin,
|
|
defaultEstimateToUse = 'medium',
|
|
}) {
|
|
const t = useContext(I18nContext);
|
|
|
|
const [warning] = useState(null);
|
|
|
|
const [showAdvancedForm, setShowAdvancedForm] = useState(false);
|
|
const [
|
|
dappSuggestedGasFeeAcknowledged,
|
|
setDappSuggestedGasFeeAcknowledged,
|
|
] = useState(false);
|
|
|
|
const requireDappAcknowledgement = Boolean(
|
|
dappSuggestedGasFee && !dappSuggestedGasFeeAcknowledged,
|
|
);
|
|
|
|
const {
|
|
maxPriorityFeePerGas,
|
|
setMaxPriorityFeePerGas,
|
|
maxPriorityFeePerGasFiat,
|
|
maxFeePerGas,
|
|
setMaxFeePerGas,
|
|
maxFeePerGasFiat,
|
|
estimatedMaximumNative,
|
|
isGasEstimatesLoading,
|
|
gasFeeEstimates,
|
|
gasEstimateType,
|
|
gasPrice,
|
|
setGasPrice,
|
|
gasLimit,
|
|
setGasLimit,
|
|
estimateToUse,
|
|
setEstimateToUse,
|
|
estimatedMinimumFiat,
|
|
estimatedMaximumFiat,
|
|
isMaxFeeError,
|
|
isMaxPriorityFeeError,
|
|
isGasTooLow,
|
|
} = useGasFeeInputs(defaultEstimateToUse);
|
|
|
|
return (
|
|
<div className="edit-gas-display">
|
|
<div className="edit-gas-display__content">
|
|
{warning && (
|
|
<div className="edit-gas-display__warning">
|
|
<ActionableMessage
|
|
className="actionable-message--warning"
|
|
message={warning}
|
|
/>
|
|
</div>
|
|
)}
|
|
{requireDappAcknowledgement && (
|
|
<div className="edit-gas-display__dapp-acknowledgement-warning">
|
|
<ActionableMessage
|
|
className="actionable-message--warning"
|
|
message={t('gasDisplayDappWarning', [dappOrigin])}
|
|
useIcon
|
|
/>
|
|
</div>
|
|
)}
|
|
{type === 'speed-up' && (
|
|
<div className="edit-gas-display__top-tooltip">
|
|
<Typography
|
|
color={COLORS.BLACK}
|
|
variant={TYPOGRAPHY.H8}
|
|
fontWeight={FONT_WEIGHT.BOLD}
|
|
>
|
|
{t('speedUpTooltipText')}{' '}
|
|
<InfoTooltip
|
|
position="top"
|
|
contentText={t('speedUpExplanation')}
|
|
/>
|
|
</Typography>
|
|
</div>
|
|
)}
|
|
<TransactionTotalBanner
|
|
total={estimatedMinimumFiat}
|
|
detail={
|
|
process.env.SHOW_EIP_1559_UI &&
|
|
t('editGasTotalBannerSubtitle', [
|
|
<Typography
|
|
fontWeight={FONT_WEIGHT.BOLD}
|
|
tag="span"
|
|
key="secondary"
|
|
>
|
|
{estimatedMaximumFiat}
|
|
</Typography>,
|
|
<Typography tag="span" key="primary">
|
|
{estimatedMaximumNative}
|
|
</Typography>,
|
|
])
|
|
}
|
|
timing=""
|
|
/>
|
|
{requireDappAcknowledgement && (
|
|
<Button
|
|
className="edit-gas-display__dapp-acknowledgement-button"
|
|
onClick={() => setDappSuggestedGasFeeAcknowledged(true)}
|
|
>
|
|
{t('gasDisplayAcknowledgeDappButtonText')}
|
|
</Button>
|
|
)}
|
|
{isGasTooLow && (
|
|
<div className="edit-gas-display__error">
|
|
<Typography
|
|
color={COLORS.ERROR1}
|
|
variant={TYPOGRAPHY.H7}
|
|
align={TEXT_ALIGN.CENTER}
|
|
>
|
|
{t('editGasTooLow')}
|
|
</Typography>
|
|
</div>
|
|
)}
|
|
{!requireDappAcknowledgement && (
|
|
<RadioGroup
|
|
name="gas-recommendation"
|
|
options={[
|
|
{
|
|
value: GAS_RECOMMENDATIONS.LOW,
|
|
label: t('editGasLow'),
|
|
recommended: defaultEstimateToUse === GAS_RECOMMENDATIONS.LOW,
|
|
},
|
|
{
|
|
value: GAS_RECOMMENDATIONS.MEDIUM,
|
|
label: t('editGasMedium'),
|
|
recommended:
|
|
defaultEstimateToUse === GAS_RECOMMENDATIONS.MEDIUM,
|
|
},
|
|
{
|
|
value: GAS_RECOMMENDATIONS.HIGH,
|
|
label: t('editGasHigh'),
|
|
recommended: defaultEstimateToUse === GAS_RECOMMENDATIONS.HIGH,
|
|
},
|
|
]}
|
|
selectedValue={estimateToUse}
|
|
onChange={setEstimateToUse}
|
|
/>
|
|
)}
|
|
{!alwaysShowForm && (
|
|
<button
|
|
className="edit-gas-display__advanced-button"
|
|
onClick={() => setShowAdvancedForm(!showAdvancedForm)}
|
|
>
|
|
{t('advancedOptions')}{' '}
|
|
{showAdvancedForm ? (
|
|
<i className="fa fa-caret-up"></i>
|
|
) : (
|
|
<i className="fa fa-caret-down"></i>
|
|
)}
|
|
</button>
|
|
)}
|
|
{!requireDappAcknowledgement &&
|
|
(alwaysShowForm || showAdvancedForm) && (
|
|
<AdvancedGasControls
|
|
gasFeeEstimates={gasFeeEstimates}
|
|
gasEstimateType={gasEstimateType}
|
|
estimateToUse={estimateToUse}
|
|
isGasEstimatesLoading={isGasEstimatesLoading}
|
|
gasLimit={gasLimit}
|
|
setGasLimit={setGasLimit}
|
|
maxPriorityFee={maxPriorityFeePerGas}
|
|
setMaxPriorityFee={setMaxPriorityFeePerGas}
|
|
maxFee={maxFeePerGas}
|
|
setMaxFee={setMaxFeePerGas}
|
|
gasPrice={gasPrice}
|
|
setGasPrice={setGasPrice}
|
|
maxPriorityFeeFiat={maxPriorityFeePerGasFiat}
|
|
maxFeeFiat={maxFeePerGasFiat}
|
|
maxPriorityFeeError={
|
|
isMaxPriorityFeeError ? t('editGasMaxPriorityFeeLow') : null
|
|
}
|
|
maxFeeError={isMaxFeeError ? t('editGasMaxFeeLow') : null}
|
|
/>
|
|
)}
|
|
</div>
|
|
{!requireDappAcknowledgement && showEducationButton && (
|
|
<div className="edit-gas-display__education">
|
|
<button onClick={onEducationClick}>
|
|
{t('editGasEducationButtonText')}
|
|
</button>
|
|
</div>
|
|
)}
|
|
</div>
|
|
);
|
|
}
|
|
|
|
EditGasDisplay.propTypes = {
|
|
alwaysShowForm: PropTypes.bool,
|
|
type: PropTypes.oneOf(['customize-gas', 'speed-up']),
|
|
showEducationButton: PropTypes.bool,
|
|
onEducationClick: PropTypes.func,
|
|
dappSuggestedGasFee: PropTypes.number,
|
|
dappOrigin: PropTypes.string,
|
|
defaultEstimateToUse: PropTypes.oneOf(Object.values(GAS_RECOMMENDATIONS)),
|
|
};
|
|
|
|
EditGasDisplay.defaultProps = {
|
|
alwaysShowForm: false,
|
|
type: 'customize-gas',
|
|
showEducationButton: false,
|
|
onEducationClick: undefined,
|
|
dappSuggestedGasFee: 0,
|
|
dappOrigin: '',
|
|
};
|