From 7c0d06dd8f5bdb3005dd0a5cd4d3ab0dc210cd13 Mon Sep 17 00:00:00 2001 From: Willian Mitsuda Date: Mon, 22 Aug 2022 19:57:19 -0300 Subject: [PATCH] Fix error handling --- src/AddressMainPage.tsx | 3 +-- src/AddressTransactionByNonce.tsx | 26 ++++++++++++++++++++------ 2 files changed, 21 insertions(+), 8 deletions(-) diff --git a/src/AddressMainPage.tsx b/src/AddressMainPage.tsx index f1c796c..77a3e80 100644 --- a/src/AddressMainPage.tsx +++ b/src/AddressMainPage.tsx @@ -30,8 +30,6 @@ import { ChecksummedAddress } from "./types"; type AddressMainPageProps = {}; const AddressMainPage: React.FC = ({}) => { - const { provider } = useContext(RuntimeContext); - const { addressOrName, direction } = useParams(); if (addressOrName === undefined) { throw new Error("addressOrName couldn't be undefined here"); @@ -55,6 +53,7 @@ const AddressMainPage: React.FC = ({}) => { urlFixer ); + const { provider } = useContext(RuntimeContext); const hasCode = useHasCode(provider, checksummedAddress, "latest"); const addressMetadata = useSourcifyMetadata( hasCode ? checksummedAddress : undefined, diff --git a/src/AddressTransactionByNonce.tsx b/src/AddressTransactionByNonce.tsx index a8ac654..8e4cc2e 100644 --- a/src/AddressTransactionByNonce.tsx +++ b/src/AddressTransactionByNonce.tsx @@ -1,6 +1,7 @@ import React, { useCallback, useContext, useEffect, useState } from "react"; import { useNavigate, useParams, useSearchParams } from "react-router-dom"; import StandardFrame from "./StandardFrame"; +import AddressOrENSNameNotFound from "./components/AddressOrENSNameNotFound"; import AddressOrENSNameInvalidNonce from "./components/AddressOrENSNameInvalidNonce"; import AddressOrENSNameNoTx from "./components/AddressOrENSNameNoTx"; import { useTransactionBySenderAndNonce } from "./useErigonHooks"; @@ -36,7 +37,7 @@ const AddressTransactionByNonce: React.FC = ({ }, [navigate, direction, searchParams] ); - const [checksummedAddress, isENS, error] = useAddressOrENS( + const [checksummedAddress, , ensError] = useAddressOrENS( addressOrName, urlFixer ); @@ -77,12 +78,20 @@ const AddressTransactionByNonce: React.FC = ({ nonce !== undefined && isNaN(nonce) ? undefined : nonce ); + // Invalid ENS + if (ensError) { + return ( + + + + ); + } + // Loading... - if ( - checksummedAddress === undefined || - nonce === undefined || - txHash === undefined - ) { + if (checksummedAddress === undefined || nonce === undefined) { return ; } @@ -107,6 +116,11 @@ const AddressTransactionByNonce: React.FC = ({ ); } + // Valid nonce, waiting tx load + if (txHash === undefined) { + return ; + } + // Valid nonce, but no tx found if (txHash === null) { return (