import React, { useContext, useState, useEffect } from 'react'; import PropTypes from 'prop-types'; import { captureException } from '@sentry/browser'; import TransactionDetailItem from '../transaction-detail-item/transaction-detail-item.component'; import fetchEstimatedL1Fee from '../../../helpers/utils/optimism/fetchEstimatedL1Fee'; import { I18nContext } from '../../../contexts/i18n'; import { sumHexes } from '../../../helpers/utils/transactions.util'; import { toBigNumber, toNormalizedDenomination, } from '../../../../shared/modules/conversion.utils'; export default function MultilayerFeeMessage({ transaction, layer2fee }) { const t = useContext(I18nContext); const [fetchedLayer1Total, setLayer1Total] = useState(null); let layer1Total = 'unknown'; if (fetchedLayer1Total !== null) { const layer1TotalBN = toBigNumber.hex(fetchedLayer1Total); layer1Total = `${toNormalizedDenomination .WEI(layer1TotalBN) .toString(10)} ETH`; } const totalInWeiHex = sumHexes( layer2fee || '0x0', fetchedLayer1Total || '0x0', transaction.txParams.value || '0x0', ); const totalBN = toBigNumber.hex(totalInWeiHex); const totalInEth = `${toNormalizedDenomination .WEI(totalBN) .toString(10)} ETH`; useEffect(() => { const getEstimatedL1Fee = async () => { try { const result = await fetchEstimatedL1Fee(global.eth, transaction); setLayer1Total(result); } catch (e) { captureException(e); setLayer1Total(null); } }; getEstimatedL1Fee(); }, [transaction]); return ( <> ); } MultilayerFeeMessage.propTypes = { transaction: PropTypes.object, layer2fee: PropTypes.string, };