diff --git a/ui/pages/confirm-transaction/confirm-transaction.component.js b/ui/pages/confirm-transaction/confirm-transaction.component.js index cfa563c5d..066fef15b 100644 --- a/ui/pages/confirm-transaction/confirm-transaction.component.js +++ b/ui/pages/confirm-transaction/confirm-transaction.component.js @@ -1,13 +1,14 @@ import React, { useCallback, useEffect, useMemo, useState } from 'react'; import { useDispatch, useSelector } from 'react-redux'; import { Switch, Route, useHistory, useParams } from 'react-router-dom'; + import Loading from '../../components/ui/loading-screen'; -import ConfirmTransactionSwitch from '../confirm-transaction-switch'; import ConfirmContractInteraction from '../confirm-contract-interaction'; -import ConfirmSendEther from '../confirm-send-ether'; import ConfirmDeployContract from '../confirm-deploy-contract'; import ConfirmDecryptMessage from '../confirm-decrypt-message'; import ConfirmEncryptionPublicKey from '../confirm-encryption-public-key'; +import ConfirmSendEther from '../confirm-send-ether'; +import ConfirmTransactionSwitch from '../confirm-transaction-switch'; import { ORIGIN_METAMASK } from '../../../shared/constants/app'; @@ -18,14 +19,14 @@ import { import { getMostRecentOverviewPage } from '../../ducks/history/history'; import { getSendTo } from '../../ducks/send'; import { - CONFIRM_TRANSACTION_ROUTE, CONFIRM_DEPLOY_CONTRACT_PATH, CONFIRM_SEND_ETHER_PATH, CONFIRM_TOKEN_METHOD_PATH, - SIGNATURE_REQUEST_PATH, + CONFIRM_TRANSACTION_ROUTE, DECRYPT_MESSAGE_REQUEST_PATH, - ENCRYPTION_PUBLIC_KEY_REQUEST_PATH, DEFAULT_ROUTE, + ENCRYPTION_PUBLIC_KEY_REQUEST_PATH, + SIGNATURE_REQUEST_PATH, } from '../../helpers/constants/routes'; import { isTokenMethodAction } from '../../helpers/utils/transactions.util'; import { usePrevious } from '../../hooks/usePrevious'; @@ -56,29 +57,31 @@ const ConfirmTransaction = () => { const mostRecentOverviewPage = useSelector(getMostRecentOverviewPage); const sendTo = useSelector(getSendTo); const unapprovedTxs = useSelector(getUnapprovedTransactions); - const unconfirmedTransactions = useSelector( - unconfirmedTransactionsListSelector, - ); + const unconfirmedTxs = useSelector(unconfirmedTransactionsListSelector); const unconfirmedMessages = useSelector(unconfirmedTransactionsHashSelector); - const totalUnapprovedCount = unconfirmedTransactions.length || 0; + const totalUnapproved = unconfirmedTxs.length || 0; + const transaction = useMemo(() => { - return totalUnapprovedCount + return totalUnapproved ? unapprovedTxs[paramsTransactionId] || unconfirmedMessages[paramsTransactionId] || - unconfirmedTransactions[0] + unconfirmedTxs[0] : {}; }, [ paramsTransactionId, - totalUnapprovedCount, + totalUnapproved, unapprovedTxs, unconfirmedMessages, - unconfirmedTransactions, + unconfirmedTxs, ]); const { id, type } = transaction; const transactionId = id && String(id); const isValidERC20TokenMethod = isTokenMethodAction(type); + const isValidTransactionId = + transactionId && + (!paramsTransactionId || paramsTransactionId === transactionId); const prevParamsTransactionId = usePrevious(paramsTransactionId); const prevTransactionId = usePrevious(transactionId); @@ -95,8 +98,6 @@ const ConfirmTransaction = () => { useEffect(() => { setIsMounted(true); - const { txParams: { data } = {}, origin } = transaction; - getGasFeeEstimatesAndStartPolling().then((_pollingToken) => { if (isMounted) { setPollingToken(_pollingToken); @@ -109,9 +110,11 @@ const ConfirmTransaction = () => { window.addEventListener('beforeunload', _beforeUnload); - if (!totalUnapprovedCount && !sendTo) { + if (!totalUnapproved && !sendTo) { history.replace(mostRecentOverviewPage); } else { + const { txParams: { data } = {}, origin } = transaction; + if (origin !== ORIGIN_METAMASK) { dispatch(getContractMethodData(data)); } @@ -130,19 +133,19 @@ const ConfirmTransaction = () => { }, []); useEffect(() => { - const { txData: { txParams: { data } = {}, origin } = {} } = transaction; - if ( paramsTransactionId && transactionId && prevParamsTransactionId !== paramsTransactionId ) { + const { txData: { txParams: { data } = {}, origin } = {} } = transaction; + dispatch(clearConfirmTransaction()); dispatch(setTransactionToConfirm(paramsTransactionId)); if (origin !== ORIGIN_METAMASK) { dispatch(getContractMethodData(data)); } - } else if (prevTransactionId && !transactionId && !totalUnapprovedCount) { + } else if (prevTransactionId && !transactionId && !totalUnapproved) { dispatch(setDefaultHomeActiveTabName('activity')).then(() => { history.replace(DEFAULT_ROUTE); }); @@ -155,27 +158,23 @@ const ConfirmTransaction = () => { } }, [ dispatch, - transaction, - paramsTransactionId, - transactionId, history, mostRecentOverviewPage, + paramsTransactionId, prevParamsTransactionId, prevTransactionId, - totalUnapprovedCount, + totalUnapproved, + transaction, + transactionId, ]); - const validTransactionId = - transactionId && - (!paramsTransactionId || paramsTransactionId === transactionId); - - if (isValidERC20TokenMethod && validTransactionId) { + if (isValidERC20TokenMethod && isValidTransactionId) { return ; } // Show routes when state.confirmTransaction has been set and when either the ID in the params // isn't specified or is specified and matches the ID in state.confirmTransaction in order to // support URLs of /confirm-transaction or /confirm-transaction/ - return validTransactionId ? ( + return isValidTransactionId ? (