diff --git a/src/AddressMainPage.tsx b/src/AddressMainPage.tsx index 77a3e80..a00263a 100644 --- a/src/AddressMainPage.tsx +++ b/src/AddressMainPage.tsx @@ -55,7 +55,7 @@ const AddressMainPage: React.FC = ({}) => { const { provider } = useContext(RuntimeContext); const hasCode = useHasCode(provider, checksummedAddress, "latest"); - const addressMetadata = useSourcifyMetadata( + const match = useSourcifyMetadata( hasCode ? checksummedAddress : undefined, provider?.network.chainId ); @@ -110,18 +110,18 @@ const AddressMainPage: React.FC = ({}) => { Contract - {addressMetadata === undefined ? ( + {match === undefined ? ( - ) : addressMetadata === null ? ( + ) : match === null ? ( @@ -153,7 +153,7 @@ const AddressMainPage: React.FC = ({}) => { element={ } /> diff --git a/src/Main.tsx b/src/Main.tsx index 1fe30e5..344e34c 100644 --- a/src/Main.tsx +++ b/src/Main.tsx @@ -2,7 +2,7 @@ import React, { useMemo, useState } from "react"; import { Outlet } from "react-router-dom"; import Header from "./Header"; import { AppConfig, AppConfigContext } from "./useAppConfig"; -import { SourcifySource } from "./url"; +import { SourcifySource } from "./sourcify/useSourcify"; const Main: React.FC = () => { const [sourcifySource, setSourcifySource] = useState( diff --git a/src/SourcifyMenu.tsx b/src/SourcifyMenu.tsx index ce23472..c4b60dd 100644 --- a/src/SourcifyMenu.tsx +++ b/src/SourcifyMenu.tsx @@ -2,8 +2,8 @@ import React, { PropsWithChildren } from "react"; import { Menu } from "@headlessui/react"; import { FontAwesomeIcon } from "@fortawesome/react-fontawesome"; import { faBars } from "@fortawesome/free-solid-svg-icons/faBars"; -import { SourcifySource } from "./url"; import { useAppConfigContext } from "./useAppConfig"; +import { SourcifySource } from "./sourcify/useSourcify"; const SourcifyMenu: React.FC = () => { const { sourcifySource, setSourcifySource } = useAppConfigContext(); diff --git a/src/address/ContractFromRepo.tsx b/src/address/ContractFromRepo.tsx index 568babf..12e0899 100644 --- a/src/address/ContractFromRepo.tsx +++ b/src/address/ContractFromRepo.tsx @@ -1,25 +1,28 @@ import React from "react"; import { SyntaxHighlighter, docco } from "../highlight-init"; -import { useContract } from "../sourcify/useSourcify"; +import { MatchType, useContract } from "../sourcify/useSourcify"; import { useAppConfigContext } from "../useAppConfig"; type ContractFromRepoProps = { checksummedAddress: string; networkId: number; filename: string; + type: MatchType; }; const ContractFromRepo: React.FC = ({ checksummedAddress, networkId, filename, + type, }) => { const { sourcifySource } = useAppConfigContext(); const content = useContract( checksummedAddress, networkId, filename, - sourcifySource + sourcifySource, + type ); return ( diff --git a/src/address/Contracts.tsx b/src/address/Contracts.tsx index d3e4179..e5ba03d 100644 --- a/src/address/Contracts.tsx +++ b/src/address/Contracts.tsx @@ -8,39 +8,39 @@ import InfoRow from "../components/InfoRow"; import Contract from "./Contract"; import ContractFromRepo from "./ContractFromRepo"; import { RuntimeContext } from "../useRuntime"; -import { Metadata } from "../sourcify/useSourcify"; +import { Match, MatchType } from "../sourcify/useSourcify"; import ExternalLink from "../components/ExternalLink"; import { openInRemixURL } from "../url"; import ContractABI from "./ContractABI"; type ContractsProps = { checksummedAddress: string; - rawMetadata: Metadata | null | undefined; + match: Match | null | undefined; }; -const Contracts: React.FC = ({ - checksummedAddress, - rawMetadata, -}) => { +const Contracts: React.FC = ({ checksummedAddress, match }) => { const { provider } = useContext(RuntimeContext); const [selected, setSelected] = useState(); useEffect(() => { - if (rawMetadata) { - setSelected(Object.keys(rawMetadata.sources)[0]); + if (match) { + setSelected(Object.keys(match.metadata.sources)[0]); } - }, [rawMetadata]); - const optimizer = rawMetadata?.settings?.optimizer; + }, [match]); + const optimizer = match?.metadata.settings?.optimizer; return ( - {rawMetadata && ( + {match && ( <> + + {match.type === MatchType.FULL_MATCH ? "Full" : "Partial"} + - {rawMetadata.language} + {match.metadata.language} - {rawMetadata.compiler.version} + {match.metadata.compiler.version} {optimizer?.enabled ? ( @@ -58,19 +58,19 @@ const Contracts: React.FC = ({ )}
- {rawMetadata === undefined && ( + {match === undefined && ( Getting data from Sourcify repository... )} - {rawMetadata === null && ( + {match === null && ( Address is not a contract or couldn't find contract metadata in Sourcify repository. )} - {rawMetadata !== undefined && rawMetadata !== null && ( + {match !== undefined && match !== null && ( <> - {rawMetadata.output.abi && ( - + {match.metadata.output.abi && ( + )}
@@ -96,7 +96,7 @@ const Contracts: React.FC = ({
- {Object.entries(rawMetadata.sources).map(([k]) => ( + {Object.entries(match.metadata.sources).map(([k]) => (