2021-09-29 19:22:35 +00:00
|
|
|
import React, { ReactNode, useState } from "react";
|
2021-09-18 21:18:38 +00:00
|
|
|
import { ParamType } from "@ethersproject/abi";
|
2021-09-29 19:22:35 +00:00
|
|
|
import { Switch } from "@headlessui/react";
|
|
|
|
import { FontAwesomeIcon } from "@fortawesome/react-fontawesome";
|
|
|
|
import { faQuestionCircle } from "@fortawesome/free-regular-svg-icons/faQuestionCircle";
|
|
|
|
import { faQuestionCircle as faQuestionCircleSolid } from "@fortawesome/free-solid-svg-icons/faQuestionCircle";
|
2021-09-25 21:40:00 +00:00
|
|
|
import Uint256Decoder from "./Uint256Decoder";
|
2021-09-25 20:28:49 +00:00
|
|
|
import AddressDecoder from "./AddressDecoder";
|
|
|
|
import BooleanDecoder from "./BooleanDecoder";
|
|
|
|
import BytesDecoder from "./BytesDecoder";
|
2021-09-25 20:19:49 +00:00
|
|
|
import { TransactionData } from "../../types";
|
2021-09-18 21:18:38 +00:00
|
|
|
|
|
|
|
type DecodedParamRowProps = {
|
2021-09-25 18:11:57 +00:00
|
|
|
prefix?: ReactNode;
|
2021-09-18 21:18:38 +00:00
|
|
|
i?: number | undefined;
|
|
|
|
r: any;
|
|
|
|
paramType: ParamType;
|
|
|
|
txData: TransactionData;
|
2021-09-25 18:11:57 +00:00
|
|
|
arrayElem?: number | undefined;
|
2021-09-29 19:22:35 +00:00
|
|
|
help?: string | undefined;
|
2021-09-18 21:18:38 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
const DecodedParamRow: React.FC<DecodedParamRowProps> = ({
|
2021-09-18 21:35:37 +00:00
|
|
|
prefix,
|
2021-09-18 21:18:38 +00:00
|
|
|
i,
|
|
|
|
r,
|
|
|
|
paramType,
|
|
|
|
txData,
|
2021-09-25 18:11:57 +00:00
|
|
|
arrayElem,
|
2021-09-29 19:22:35 +00:00
|
|
|
help,
|
|
|
|
}) => {
|
|
|
|
const [showHelp, setShowHelp] = useState<boolean>(false);
|
|
|
|
|
|
|
|
return (
|
|
|
|
<>
|
|
|
|
<tr className="grid grid-cols-12 gap-x-2 py-2 hover:bg-gray-100">
|
|
|
|
<td className="col-span-3 pl-1">
|
2021-09-29 19:27:36 +00:00
|
|
|
<div className="flex space-x-2 items-baseline">
|
|
|
|
<span>
|
|
|
|
{prefix && <span className="text-gray-300">{prefix}</span>}
|
|
|
|
{arrayElem !== undefined ? (
|
|
|
|
<span className="text-gray-400">
|
|
|
|
{" "}
|
|
|
|
[<span className="text-black">{arrayElem}</span>]
|
|
|
|
</span>
|
|
|
|
) : (
|
|
|
|
<>
|
|
|
|
{paramType.name ?? <span className="italic">param_{i}</span>}{" "}
|
|
|
|
{i !== undefined && (
|
|
|
|
<span className="text-gray-400 text-xs">({i})</span>
|
|
|
|
)}
|
|
|
|
</>
|
|
|
|
)}
|
|
|
|
</span>
|
2021-09-29 19:22:35 +00:00
|
|
|
{help && (
|
2021-09-29 19:27:36 +00:00
|
|
|
<Switch
|
|
|
|
checked={showHelp}
|
|
|
|
onChange={setShowHelp}
|
|
|
|
className="text-gray-500 self-center"
|
|
|
|
>
|
|
|
|
<FontAwesomeIcon
|
|
|
|
icon={showHelp ? faQuestionCircleSolid : faQuestionCircle}
|
|
|
|
size="1x"
|
|
|
|
/>
|
|
|
|
</Switch>
|
2021-09-29 19:22:35 +00:00
|
|
|
)}
|
|
|
|
</div>
|
|
|
|
{help && showHelp && <div className="mt-2 text-gray-400">{help}</div>}
|
|
|
|
</td>
|
|
|
|
<td className="col-span-1 text-gray-500">{paramType.type}</td>
|
|
|
|
<td className="col-span-8 pr-1 font-code break-all">
|
|
|
|
{paramType.baseType === "uint256" ? (
|
|
|
|
<Uint256Decoder r={r} />
|
|
|
|
) : paramType.baseType === "address" ? (
|
|
|
|
<AddressDecoder r={r} txData={txData} />
|
|
|
|
) : paramType.baseType === "bool" ? (
|
|
|
|
<BooleanDecoder r={r} />
|
|
|
|
) : paramType.baseType === "bytes" ? (
|
|
|
|
<BytesDecoder r={r} />
|
|
|
|
) : paramType.baseType === "tuple" ||
|
|
|
|
paramType.baseType === "array" ? (
|
|
|
|
<></>
|
|
|
|
) : (
|
|
|
|
r.toString()
|
|
|
|
)}
|
|
|
|
</td>
|
|
|
|
</tr>
|
|
|
|
{paramType.baseType === "tuple" &&
|
|
|
|
r.map((e: any, idx: number) => (
|
|
|
|
<DecodedParamRow
|
|
|
|
key={idx}
|
|
|
|
prefix={
|
|
|
|
paramType.name ? (
|
|
|
|
paramType.name + "."
|
|
|
|
) : (
|
|
|
|
<span className="italic">param_{i}.</span>
|
|
|
|
)
|
|
|
|
}
|
|
|
|
i={idx}
|
|
|
|
r={e}
|
|
|
|
paramType={paramType.components[idx]}
|
|
|
|
txData={txData}
|
|
|
|
/>
|
|
|
|
))}
|
|
|
|
{paramType.baseType === "array" &&
|
|
|
|
r.map((e: any, idx: number) => (
|
|
|
|
<DecodedParamRow
|
|
|
|
key={idx}
|
|
|
|
prefix={paramType.name ?? <span className="italic">param_{i}</span>}
|
|
|
|
r={e}
|
|
|
|
paramType={paramType.arrayChildren}
|
|
|
|
txData={txData}
|
|
|
|
arrayElem={idx}
|
|
|
|
/>
|
|
|
|
))}
|
|
|
|
</>
|
|
|
|
);
|
|
|
|
};
|
2021-09-18 21:18:38 +00:00
|
|
|
|
|
|
|
export default React.memo(DecodedParamRow);
|