import React, { useMemo } from 'react'; import PropTypes from 'prop-types'; import { EditGasModes, PriorityLevels, } from '../../../../../shared/constants/gas'; import { FONT_WEIGHT, TextColor, TypographyVariant, } from '../../../../helpers/constants/design-system'; import { isMetamaskSuggestedGasEstimate } from '../../../../helpers/utils/gas'; import { roundToDecimalPlacesRemovingExtraZeroes } from '../../../../helpers/utils/util'; import Typography from '../../../ui/typography'; const EditGasToolTip = ({ editGasMode, estimateGreaterThanGasUse, gasLimit, priorityLevel, // maxFeePerGas & maxPriorityFeePerGas are derived from conditional logic // related to the source of the estimates. We pass these values from the // the parent component (edit-gas-item) rather than recalculate them maxFeePerGas, maxPriorityFeePerGas, transaction, t, }) => { const toolTipMessage = useMemo(() => { switch (priorityLevel) { case PriorityLevels.low: return t('lowGasSettingToolTipMessage', [ {t('low')} , ]); case PriorityLevels.medium: if (estimateGreaterThanGasUse) { return t('disabledGasOptionToolTipMessage', [ {t(priorityLevel)} , ]); } return t('mediumGasSettingToolTipMessage', [ {t('medium')} , ]); case PriorityLevels.high: if (estimateGreaterThanGasUse) { return t('disabledGasOptionToolTipMessage', [ {t(priorityLevel)} , ]); } if (editGasMode === EditGasModes.swaps) { return t('swapSuggestedGasSettingToolTipMessage'); } return t('highGasSettingToolTipMessage', [ {t('high')} , ]); case PriorityLevels.custom: return t('customGasSettingToolTipMessage', [ {t('custom')} , ]); case PriorityLevels.dAppSuggested: return transaction?.origin ? t('dappSuggestedGasSettingToolTipMessage', [ {transaction?.origin}, ]) : null; default: return ''; } }, [editGasMode, estimateGreaterThanGasUse, priorityLevel, transaction, t]); let imgAltText; if (priorityLevel === PriorityLevels.low) { imgAltText = t('curveLowGasEstimate'); } else if (priorityLevel === PriorityLevels.medium) { imgAltText = t('curveMediumGasEstimate'); } else if (priorityLevel === PriorityLevels.high) { imgAltText = t('curveHighGasEstimate'); } // Gas estimate curve is visible for low/medium/high gas estimates // the curve is not visible for high estimates for swaps // also it is not visible in case of cancel/speedup if the medium/high option is disabled const showGasEstimateCurve = isMetamaskSuggestedGasEstimate(priorityLevel) && !( priorityLevel === PriorityLevels.high && editGasMode === EditGasModes.swaps ) && !estimateGreaterThanGasUse; return (