mirror of
https://github.com/kremalicious/metamask-extension.git
synced 2024-12-12 04:37:13 +01:00
77 lines
2.0 KiB
JavaScript
77 lines
2.0 KiB
JavaScript
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 { getGasFormErrorText } from '../../../helpers/constants/gas';
|
|
import { getNetworkSupportsSettingGasFees } from '../../../selectors';
|
|
|
|
export default function AdvancedGasControls({
|
|
onManualChange,
|
|
gasLimit,
|
|
setGasLimit,
|
|
gasPrice,
|
|
setGasPrice,
|
|
gasErrors,
|
|
minimumGasLimit,
|
|
}) {
|
|
const t = useContext(I18nContext);
|
|
|
|
const networkSupportsSettingGasFees = useSelector(
|
|
getNetworkSupportsSettingGasFees,
|
|
);
|
|
|
|
return (
|
|
<div className="advanced-gas-controls">
|
|
<FormField
|
|
titleText={t('gasLimit')}
|
|
error={
|
|
gasErrors?.gasLimit
|
|
? getGasFormErrorText(gasErrors.gasLimit, t, { minimumGasLimit })
|
|
: null
|
|
}
|
|
onChange={(value) => {
|
|
onManualChange?.();
|
|
setGasLimit(value);
|
|
}}
|
|
tooltipText={t('editGasLimitTooltip')}
|
|
value={gasLimit}
|
|
allowDecimals={false}
|
|
disabled={!networkSupportsSettingGasFees}
|
|
numeric
|
|
/>
|
|
<>
|
|
<FormField
|
|
titleText={t('advancedGasPriceTitle')}
|
|
titleUnit="(GWEI)"
|
|
onChange={(value) => {
|
|
onManualChange?.();
|
|
setGasPrice(value);
|
|
}}
|
|
tooltipText={t('editGasPriceTooltip')}
|
|
value={gasPrice}
|
|
numeric
|
|
allowDecimals
|
|
error={
|
|
gasErrors?.gasPrice
|
|
? getGasFormErrorText(gasErrors.gasPrice, t)
|
|
: null
|
|
}
|
|
disabled={!networkSupportsSettingGasFees}
|
|
/>
|
|
</>
|
|
</div>
|
|
);
|
|
}
|
|
|
|
AdvancedGasControls.propTypes = {
|
|
onManualChange: PropTypes.func,
|
|
gasLimit: PropTypes.number,
|
|
setGasLimit: PropTypes.func,
|
|
gasPrice: PropTypes.string,
|
|
setGasPrice: PropTypes.func,
|
|
minimumGasLimit: PropTypes.string,
|
|
gasErrors: PropTypes.object,
|
|
};
|