import React, { useMemo } from "react"; import { Interface } from "@ethersproject/abi"; import ContentFrame from "../ContentFrame"; import LogEntry from "./LogEntry"; import { TransactionData } from "../types"; import { useAppConfigContext } from "../useAppConfig"; import { Metadata, useMultipleMetadata } from "../useSourcify"; import { ResolvedAddresses } from "../api/address-resolver"; type LogsProps = { txData: TransactionData; metadata: Metadata | null | undefined; resolvedAddresses: ResolvedAddresses | undefined; }; const Logs: React.FC = ({ txData, metadata, resolvedAddresses }) => { const baseMetadatas = useMemo((): Record => { if (!txData.to || metadata === undefined) { return {}; } const md: Record = {}; md[txData.to] = metadata; return md; }, [txData.to, metadata]); const { sourcifySource } = useAppConfigContext(); const logAddresses = useMemo( () => txData.confirmedData?.logs.map((l) => l.address) ?? [], [txData] ); const metadatas = useMultipleMetadata( baseMetadatas, logAddresses, 1, sourcifySource ); const logDescs = useMemo(() => { if (!txData) { return undefined; } return txData.confirmedData?.logs.map((l) => { const mt = metadatas[l.address]; if (!mt) { return mt; } const abi = mt.output.abi; const intf = new Interface(abi as any); try { return intf.parseLog({ topics: l.topics, data: l.data, }); } catch (err) { console.warn("Couldn't find function signature", err); return null; } }); }, [metadatas, txData]); return ( {txData.confirmedData && ( <> {txData.confirmedData.logs.length > 0 ? ( <> {txData.confirmedData.logs.map((l, i) => ( ))} ) : (
Transaction didn't emit any logs
)} )}
); }; export default React.memo(Logs);