mirror of
https://github.com/kremalicious/metamask-extension.git
synced 2024-12-23 09:52:26 +01:00
189 lines
5.9 KiB
JavaScript
189 lines
5.9 KiB
JavaScript
import React from 'react';
|
|
import { useSelector } from 'react-redux';
|
|
|
|
import { useI18nContext } from '../../../../hooks/useI18nContext';
|
|
import {
|
|
getIsMainnet,
|
|
getIsMultiLayerFeeNetwork,
|
|
getPreferences,
|
|
getUnapprovedTransactions,
|
|
getUseCurrencyRateCheck,
|
|
transactionFeeSelector,
|
|
txDataSelector,
|
|
} from '../../../../selectors';
|
|
import { PRIMARY, SECONDARY } from '../../../../helpers/constants/common';
|
|
|
|
import TransactionDetailItem from '../../transaction-detail-item';
|
|
import UserPreferencedCurrencyDisplay from '../../user-preferenced-currency-display';
|
|
import InfoTooltip from '../../../ui/info-tooltip';
|
|
import LoadingHeartBeat from '../../../ui/loading-heartbeat';
|
|
import { Text } from '../../../component-library/text';
|
|
import {
|
|
FONT_STYLE,
|
|
TextVariant,
|
|
TextColor,
|
|
} from '../../../../helpers/constants/design-system';
|
|
import { useDraftTransactionGasValues } from '../../../../hooks/useDraftTransactionGasValues';
|
|
import { getNativeCurrency } from '../../../../ducks/metamask/metamask';
|
|
import MultilayerFeeMessage from '../../multilayer-fee-message/multi-layer-fee-message';
|
|
|
|
const renderHeartBeatIfNotInTest = () =>
|
|
process.env.IN_TEST ? null : <LoadingHeartBeat />;
|
|
|
|
const ConfirmLegacyGasDisplay = () => {
|
|
const t = useI18nContext();
|
|
|
|
// state selectors
|
|
const isMainnet = useSelector(getIsMainnet);
|
|
const isMultiLayerFeeNetwork = useSelector(getIsMultiLayerFeeNetwork);
|
|
const useCurrencyRateCheck = useSelector(getUseCurrencyRateCheck);
|
|
const { useNativeCurrencyAsPrimaryCurrency } = useSelector(getPreferences);
|
|
const nativeCurrency = useSelector(getNativeCurrency);
|
|
const unapprovedTxs = useSelector(getUnapprovedTransactions);
|
|
const { transactionData } = useDraftTransactionGasValues();
|
|
const txData = useSelector((state) => txDataSelector(state));
|
|
const { id: transactionId, dappSuggestedGasFees } = txData;
|
|
const transaction = Object.keys(transactionData).length
|
|
? transactionData
|
|
: unapprovedTxs[transactionId] || {};
|
|
const { hexMinimumTransactionFee, hexMaximumTransactionFee } = useSelector(
|
|
(state) => transactionFeeSelector(state, transaction),
|
|
);
|
|
|
|
if (isMultiLayerFeeNetwork) {
|
|
return [
|
|
<TransactionDetailItem
|
|
key="total-item"
|
|
detailTitle={t('transactionDetailLayer2GasHeading')}
|
|
detailTotal={
|
|
<UserPreferencedCurrencyDisplay
|
|
type={PRIMARY}
|
|
value={hexMinimumTransactionFee}
|
|
hideLabel={!useNativeCurrencyAsPrimaryCurrency}
|
|
numberOfDecimals={18}
|
|
/>
|
|
}
|
|
detailText={
|
|
useCurrencyRateCheck && (
|
|
<UserPreferencedCurrencyDisplay
|
|
type={SECONDARY}
|
|
value={hexMinimumTransactionFee}
|
|
hideLabel={Boolean(useNativeCurrencyAsPrimaryCurrency)}
|
|
/>
|
|
)
|
|
}
|
|
noBold
|
|
flexWidthValues
|
|
/>,
|
|
<MultilayerFeeMessage
|
|
key="confirm-layer-1"
|
|
transaction={txData}
|
|
layer2fee={hexMinimumTransactionFee}
|
|
nativeCurrency={nativeCurrency}
|
|
/>,
|
|
];
|
|
}
|
|
|
|
return (
|
|
<TransactionDetailItem
|
|
key="legacy-gas-details"
|
|
detailTitle={
|
|
dappSuggestedGasFees ? (
|
|
<>
|
|
{t('transactionDetailGasHeading')}
|
|
<InfoTooltip
|
|
contentText={t('transactionDetailDappGasTooltip')}
|
|
position="top"
|
|
>
|
|
<i className="fa fa-info-circle" />
|
|
</InfoTooltip>
|
|
</>
|
|
) : (
|
|
<>
|
|
{t('transactionDetailGasHeading')}
|
|
<InfoTooltip
|
|
contentText={
|
|
<>
|
|
<p>
|
|
{t('transactionDetailGasTooltipIntro', [
|
|
isMainnet ? t('networkNameEthereum') : '',
|
|
])}
|
|
</p>
|
|
<p>{t('transactionDetailGasTooltipExplanation')}</p>
|
|
<p>
|
|
<a
|
|
href="https://community.metamask.io/t/what-is-gas-why-do-transactions-take-so-long/3172"
|
|
target="_blank"
|
|
rel="noopener noreferrer"
|
|
>
|
|
{t('transactionDetailGasTooltipConversion')}
|
|
</a>
|
|
</p>
|
|
</>
|
|
}
|
|
position="top"
|
|
>
|
|
<i className="fa fa-info-circle" />
|
|
</InfoTooltip>
|
|
</>
|
|
)
|
|
}
|
|
detailText={
|
|
useCurrencyRateCheck && (
|
|
<div>
|
|
{renderHeartBeatIfNotInTest()}
|
|
<UserPreferencedCurrencyDisplay
|
|
type={SECONDARY}
|
|
value={hexMinimumTransactionFee}
|
|
hideLabel={Boolean(useNativeCurrencyAsPrimaryCurrency)}
|
|
/>
|
|
</div>
|
|
)
|
|
}
|
|
detailTotal={
|
|
<div>
|
|
{renderHeartBeatIfNotInTest()}
|
|
<UserPreferencedCurrencyDisplay
|
|
type={PRIMARY}
|
|
value={hexMinimumTransactionFee}
|
|
hideLabel={!useNativeCurrencyAsPrimaryCurrency}
|
|
numberOfDecimals={6}
|
|
/>
|
|
</div>
|
|
}
|
|
subText={
|
|
<>
|
|
<strong key="editGasSubTextFeeLabel">
|
|
{t('editGasSubTextFeeLabel')}
|
|
</strong>
|
|
<div key="editGasSubTextFeeValue">
|
|
{renderHeartBeatIfNotInTest()}
|
|
<UserPreferencedCurrencyDisplay
|
|
key="editGasSubTextFeeAmount"
|
|
type={PRIMARY}
|
|
value={hexMaximumTransactionFee}
|
|
hideLabel={!useNativeCurrencyAsPrimaryCurrency}
|
|
/>
|
|
</div>
|
|
</>
|
|
}
|
|
subTitle={
|
|
<>
|
|
{dappSuggestedGasFees && (
|
|
<Text
|
|
variant={TextVariant.bodySm}
|
|
fontStyle={FONT_STYLE.ITALIC}
|
|
color={TextColor.textAlternative}
|
|
as="h6"
|
|
>
|
|
{t('transactionDetailDappGasMoreInfo')}
|
|
</Text>
|
|
)}
|
|
</>
|
|
}
|
|
/>
|
|
);
|
|
};
|
|
|
|
export default ConfirmLegacyGasDisplay;
|