From 63d32397ca1bf215a09fa71f516ad8f56183ef76 Mon Sep 17 00:00:00 2001 From: Keith Date: Tue, 11 Oct 2022 02:48:46 +0800 Subject: [PATCH] fix: switch network before calling a write method --- components/ContractInfo/index.tsx | 11 +++++++++++ 1 file changed, 11 insertions(+) diff --git a/components/ContractInfo/index.tsx b/components/ContractInfo/index.tsx index 13e084513..c8c42bd97 100644 --- a/components/ContractInfo/index.tsx +++ b/components/ContractInfo/index.tsx @@ -13,6 +13,7 @@ import { useAccount, useSigner, useNetwork, + useSwitchNetwork, useContract, } from 'wagmi' import Alert from 'components/Alert' @@ -54,9 +55,11 @@ const ContractInfo: React.FC<{ address: string; contract: PolyjuiceContractProps const { address: addr } = useAccount() const { data: signer } = useSigner() const { chain } = useNetwork() + const { switchNetworkAsync } = useSwitchNetwork() const contract = useContract({ addressOrName: address, contractInterface: abi, + // FIXME: remove the provider, or it will break the workflow of `switch to the correct network -> send a request` by one click due to inconsistent chain id signerOrProvider: tabIdx === 2 ? signer : provider, }) @@ -122,6 +125,14 @@ const ContractInfo: React.FC<{ address: string; contract: PolyjuiceContractProps form.setAttribute(LOADING_ATTRIBUTE, 'true') try { + if (tabIdx === 2 && chain?.id !== targetChain.id) { + if (switchNetworkAsync) { + await switchNetworkAsync(targetChain.id) + } else { + connect({ connector, chainId: targetChain.id }) + } + return + } const result = await method(...params) if (tabIdx === 2) { const elm = resInputList[0]