Skip to content

Commit

Permalink
feat: add BatchTxEditor
Browse files Browse the repository at this point in the history
  • Loading branch information
q20274982 committed Jan 9, 2024
1 parent c3b5d00 commit a7f45f6
Show file tree
Hide file tree
Showing 3 changed files with 109 additions and 1 deletion.
8 changes: 8 additions & 0 deletions src/components/EvmEditor.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -28,6 +28,7 @@ import EvmSignEditor from "./EvmEditors/EvmSignEditor";
import EvmUserOpEditor from "./EvmEditors/EvmUserOpEditor";
import EvmSendEditor from "./EvmEditors/EvmSendEditor";
import EvmContractEditor from "./EvmEditors/EvmContractEditor";
import EvmBatchTxEditor from "./EvmEditors/EvmBatchTxEditor";
import type { EthereumTypes } from "@blocto/sdk";
import { bloctoSDK, useEthereum, supportedChains, web3 } from "../services/evm";
import ReactJson from "react-json-view";
Expand Down Expand Up @@ -233,6 +234,7 @@ const EvmEditor = (): ReactJSXElement => {
<Tab>User Operation</Tab>
<Tab>Send</Tab>
<Tab>Contract</Tab>
<Tab>Batch Transaction</Tab>
</TabList>
<TabPanels>
<TabPanel>
Expand Down Expand Up @@ -266,6 +268,12 @@ const EvmEditor = (): ReactJSXElement => {
chainId={chainId}
/>
</TabPanel>
<TabPanel>
<EvmBatchTxEditor
setRequestObject={setRequestObject}
account={account}
/>
</TabPanel>
</TabPanels>
</Tabs>
</Flex>
Expand Down
95 changes: 95 additions & 0 deletions src/components/EvmEditors/EvmBatchTxEditor.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,95 @@
import React, { useEffect, useState, Dispatch, SetStateAction } from "react";
import {
Box,
Text,
Grid,
Flex,
IconButton,
Radio,
RadioGroup,
} from "@chakra-ui/react";
import { AddIcon, CloseIcon } from "@chakra-ui/icons";
import { ReactJSXElement } from "@emotion/react/types/jsx-namespace";
import type { EthereumTypes } from "@blocto/sdk";
import EvmTxForm from "./EvmTxForm";

interface EvmBatchTxEditorProps {
setRequestObject: Dispatch<
SetStateAction<EthereumTypes.EIP1193RequestPayload | undefined>
>;
account: string | null;
}

const EvmBatchTxEditor = ({
setRequestObject,
account,
}: EvmBatchTxEditorProps): ReactJSXElement => {
const [revert, setRevert] = useState<string>("true");
const [txs, setTxs] = useState<any[]>([{}]);
useEffect(() => {
if (account) {
setRequestObject({
method: "wallet_sendMultiCallTransaction",
params: [txs, revert === "true"],
});
}
}, [account, setRequestObject, revert, txs]);

return (
<>
<Grid templateRows="repeat(4, min-content)" gap="10px">
<Box fontWeight="bold">Revert</Box>
<RadioGroup
value={revert}
onChange={(e) => {
setRevert(e);
}}
>
<Flex gap="15px">
<Radio value="true">true</Radio>
<Radio value="false">false</Radio>
</Flex>
</RadioGroup>

<Flex>
<Box fontWeight="bold">Transaction</Box>
<IconButton
ml={2}
aria-label="Add Transaction"
isRound
icon={<AddIcon />}
size="xs"
colorScheme="blue"
onClick={() => {
setTxs((prev) => [...prev, ""]);
}}
/>
</Flex>
<Flex flexDir="column" mt={2} pl={4}>
{txs.map((value, i) => (
<Box key={i}>
<Text fontWeight="bold" mb={2}>
Transaction {i + 1}
</Text>
<Flex my="5px" alignItems="center">
<EvmTxForm
key={i}
setTransactionObject={(tx) => {
setTxs((prev) => {
const newTxs = [...prev];
newTxs[i] = tx;
return newTxs;
});
}}
account={account}
/>
</Flex>
</Box>
))}
</Flex>
</Grid>
</>
);
};

export default EvmBatchTxEditor;
7 changes: 6 additions & 1 deletion src/components/EvmEditors/EvmTxForm.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -48,7 +48,12 @@ const EvmTxForm = ({
}, [account]);

return (
<Grid templateColumns="min-content 1fr" alignItems="center" gap={6}>
<Grid
templateColumns="min-content 1fr"
alignItems="center"
gap={6}
width="100%"
>
<Box mx="10px">From:</Box>
<Textarea
rows={1}
Expand Down

0 comments on commit a7f45f6

Please sign in to comment.