import React, { useContext } from 'react'; import PropTypes from 'prop-types'; import { useSelector } from 'react-redux'; import { I18nContext } from '../../../contexts/i18n'; import FormField from '../../ui/form-field'; import { GAS_ESTIMATE_TYPES } from '../../../../shared/constants/gas'; import { getGasFormErrorText } from '../../../helpers/constants/gas'; import { checkNetworkAndAccountSupports1559 } from '../../../selectors'; import { getIsGasEstimatesLoading } from '../../../ducks/metamask/metamask'; import { getGasLoadingAnimationIsShowing } from '../../../ducks/app/app'; export default function AdvancedGasControls({ gasEstimateType, maxPriorityFee, maxFee, setMaxPriorityFee, setMaxFee, onManualChange, gasLimit, setGasLimit, gasPrice, setGasPrice, maxPriorityFeeFiat, maxFeeFiat, gasErrors, minimumGasLimit, estimateToUse, }) { const t = useContext(I18nContext); const networkAndAccountSupport1559 = useSelector( checkNetworkAndAccountSupports1559, ); const isGasEstimatesLoading = useSelector(getIsGasEstimatesLoading); const isGasLoadingAnimationIsShowing = useSelector( getGasLoadingAnimationIsShowing, ); const disableFormFields = estimateToUse !== 'custom' && (isGasEstimatesLoading || isGasLoadingAnimationIsShowing); const showFeeMarketFields = networkAndAccountSupport1559 && (gasEstimateType === GAS_ESTIMATE_TYPES.FEE_MARKET || gasEstimateType === GAS_ESTIMATE_TYPES.ETH_GASPRICE || isGasEstimatesLoading); return (
{ onManualChange?.(); setGasLimit(value); }} tooltipText={t('editGasLimitTooltip')} value={gasLimit} allowDecimals={false} numeric autoFocus /> {showFeeMarketFields ? ( <> { onManualChange?.(); setMaxPriorityFee(value); }} value={maxPriorityFee} detailText={maxPriorityFeeFiat} numeric error={ gasErrors?.maxPriorityFee ? getGasFormErrorText(gasErrors.maxPriorityFee, t) : null } disabled={disableFormFields} /> { onManualChange?.(); setMaxFee(value); }} value={maxFee} numeric detailText={maxFeeFiat} error={ gasErrors?.maxFee ? getGasFormErrorText(gasErrors.maxFee, t) : null } disabled={disableFormFields} /> ) : ( <> { onManualChange?.(); setGasPrice(value); }} tooltipText={t('editGasPriceTooltip')} value={gasPrice} numeric error={ gasErrors?.gasPrice ? getGasFormErrorText(gasErrors.gasPrice, t) : null } disabled={disableFormFields} /> )}
); } AdvancedGasControls.propTypes = { gasEstimateType: PropTypes.oneOf(Object.values(GAS_ESTIMATE_TYPES)), setMaxPriorityFee: PropTypes.func, setMaxFee: PropTypes.func, maxPriorityFee: PropTypes.number, maxFee: PropTypes.number, onManualChange: PropTypes.func, gasLimit: PropTypes.number, setGasLimit: PropTypes.func, gasPrice: PropTypes.number, setGasPrice: PropTypes.func, maxPriorityFeeFiat: PropTypes.string, maxFeeFiat: PropTypes.string, gasErrors: PropTypes.object, minimumGasLimit: PropTypes.number, estimateToUse: PropTypes.bool, };