otterscan/src/address/DecodedFragment.tsx

63 lines
1.7 KiB
TypeScript
Raw Normal View History

2021-10-25 04:29:50 +00:00
import React from "react";
import {
ConstructorFragment,
EventFragment,
Fragment,
FunctionFragment,
Interface,
} from "@ethersproject/abi";
2021-10-25 04:44:24 +00:00
import { FontAwesomeIcon } from "@fortawesome/react-fontawesome";
import { faCaretRight } from "@fortawesome/free-solid-svg-icons/faCaretRight";
2021-10-25 04:29:50 +00:00
type DecodedFragmentProps = {
intf: Interface;
fragment: Fragment;
};
const DecodedFragment: React.FC<DecodedFragmentProps> = ({
intf,
fragment,
}) => {
let sig: string | undefined;
let letter: string | undefined;
let letterBg: string | undefined;
if (FunctionFragment.isFunctionFragment(fragment)) {
sig = intf.getSighash(fragment);
letter = "F";
letterBg = "bg-purple-500";
} else if (EventFragment.isEventFragment(fragment)) {
sig = intf.getEventTopic(fragment);
letter = "E";
letterBg = "bg-green-300";
} else if (ConstructorFragment.isConstructorFragment(fragment)) {
letter = "C";
letterBg = "bg-blue-500";
}
return (
2021-10-25 04:44:24 +00:00
<div className="flex items-baseline space-x-2 px-2 py-1 hover:bg-gray-100">
<span className="text-gray-500">
<FontAwesomeIcon icon={faCaretRight} size="1x" />
</span>
2021-10-25 04:29:50 +00:00
{letter && (
<span
className={`flex-shrink-0 text-xs font-code border border-gray-300 rounded-full w-5 h-5 self-center flex items-center justify-center text-white font-bold ${letterBg}`}
>
{letter}
</span>
)}
<span className="text-sm font-code whitespace-nowrap">
{fragment.format("full")}
</span>
{sig && (
<span className="text-xs border rounded-xl px-2 pt-1 font-code">
{sig}
</span>
)}
</div>
);
};
export default React.memo(DecodedFragment);