From 33839eb5efc8b2f113f74bdd45baa8833efc75d3 Mon Sep 17 00:00:00 2001 From: Willian Mitsuda Date: Fri, 18 Feb 2022 03:39:37 -0300 Subject: [PATCH 1/2] Hide ENS label when network does not support it --- src/Header.tsx | 4 +++- src/Home.tsx | 4 +++- 2 files changed, 6 insertions(+), 2 deletions(-) diff --git a/src/Header.tsx b/src/Header.tsx index 251e584..7feec16 100644 --- a/src/Header.tsx +++ b/src/Header.tsx @@ -44,7 +44,9 @@ const Header: React.FC = () => { className="w-full border-t border-b border-l rounded-l focus:outline-none px-2 py-1 text-sm" type="text" size={60} - placeholder='Type "/" to search by address / txn hash / block number / ENS name' + placeholder={`Type "/" to search by address / txn hash / block number${ + provider?.network.ensAddress ? " / ENS name" : "" + }`} onChange={handleChange} ref={searchRef} /> diff --git a/src/Home.tsx b/src/Home.tsx index 8781549..2bcb23d 100644 --- a/src/Home.tsx +++ b/src/Home.tsx @@ -39,7 +39,9 @@ const Home: React.FC = () => { className="w-full border-l border-t border-b rounded-l focus:outline-none px-2 py-1" type="text" size={50} - placeholder="Search by address / txn hash / block number / ENS name" + placeholder={`Search by address / txn hash / block number${ + provider?.network.ensAddress ? " / ENS name" : "" + }`} onChange={handleChange} ref={searchRef} autoFocus From 488f267d480c79247d39b1f949e268e335fc44bc Mon Sep 17 00:00:00 2001 From: Willian Mitsuda Date: Fri, 18 Feb 2022 03:46:37 -0300 Subject: [PATCH 2/2] Disable search by ENS name if network does not support it --- src/Address.tsx | 5 +++- src/components/AddressOrENSNameNotFound.tsx | 5 +++- src/useResolvedAddresses.ts | 32 ++++++++++++--------- 3 files changed, 27 insertions(+), 15 deletions(-) diff --git a/src/Address.tsx b/src/Address.tsx index 3b9b62d..f739e7b 100644 --- a/src/Address.tsx +++ b/src/Address.tsx @@ -100,7 +100,10 @@ const Address: React.FC = () => { return ( {error ? ( - + ) : ( checksummedAddress && ( <> diff --git a/src/components/AddressOrENSNameNotFound.tsx b/src/components/AddressOrENSNameNotFound.tsx index 437aa6c..8cc5059 100644 --- a/src/components/AddressOrENSNameNotFound.tsx +++ b/src/components/AddressOrENSNameNotFound.tsx @@ -4,16 +4,19 @@ import ContentFrame from "../ContentFrame"; type AddressOrENSNameNotFoundProps = { addressOrENSName: string; + supportsENS: boolean; }; const AddressOrENSNameNotFound: React.FC = ({ addressOrENSName, + supportsENS, }) => ( <> Transaction Details
- "{addressOrENSName}" is not an ETH address or ENS name. + "{addressOrENSName}" is not an ETH address + {supportsENS && " or ENS name"}.
diff --git a/src/useResolvedAddresses.ts b/src/useResolvedAddresses.ts index 4870072..93db361 100644 --- a/src/useResolvedAddresses.ts +++ b/src/useResolvedAddresses.ts @@ -48,19 +48,25 @@ export const useAddressOrENS = ( if (!provider) { return; } - const resolveName = async () => { - const resolvedAddress = await provider.resolveName(addressOrName); - if (resolvedAddress !== null) { - setENS(true); - setError(false); - setChecksummedAddress(resolvedAddress); - } else { - setENS(false); - setError(true); - setChecksummedAddress(undefined); - } - }; - resolveName(); + if (provider.network.ensAddress) { + const resolveName = async () => { + const resolvedAddress = await provider.resolveName(addressOrName); + if (resolvedAddress !== null) { + setENS(true); + setError(false); + setChecksummedAddress(resolvedAddress); + } else { + setENS(false); + setError(true); + setChecksummedAddress(undefined); + } + }; + resolveName(); + } else { + setENS(false); + setError(true); + setChecksummedAddress(undefined); + } }, [provider, addressOrName, urlFixer]); return [checksummedAddress, isENS, error];