From fd1c0e47bb99f01c3ade7cbe3c59675fed047d59 Mon Sep 17 00:00:00 2001 From: Matthew Foyle Date: Tue, 9 Jul 2024 17:36:41 +0200 Subject: [PATCH] fix: check and change network for safe --- packages/nextjs/app/safe/page.tsx | 32 +++++++++++++++++++++++++++---- 1 file changed, 28 insertions(+), 4 deletions(-) diff --git a/packages/nextjs/app/safe/page.tsx b/packages/nextjs/app/safe/page.tsx index 8b99b6e..e0d2636 100644 --- a/packages/nextjs/app/safe/page.tsx +++ b/packages/nextjs/app/safe/page.tsx @@ -1,7 +1,7 @@ "use client"; import { useState } from "react"; -import { ExternalLinkIcon, useDynamicContext } from "@dynamic-labs/sdk-react-core"; +import { ExternalLinkIcon, getNetwork, useDynamicContext, useSwitchNetwork } from "@dynamic-labs/sdk-react-core"; import { createWalletClientFromWallet } from "@dynamic-labs/viem-utils"; import { formatUnits } from "viem"; import { baseSepolia } from "viem/chains"; @@ -26,6 +26,7 @@ import { const SafePage = () => { const { address, chain, isConnected } = useAccount(); const { primaryWallet, isAuthenticated } = useDynamicContext(); + const switchNetwork = useSwitchNetwork(); const [safeDeployed, setSafeDeployed] = useState(false); const [safeAddress, setSafeAddress] = useState(""); @@ -57,8 +58,16 @@ const SafePage = () => { setLoading(true); setError(null); try { + if (!primaryWallet) return; + const network = await getNetwork(primaryWallet.connector); + + if (network !== baseSepolia.id) { + switchNetwork({ wallet: primaryWallet, network: baseSepolia.id }); + } const userAddress = address as `0x${string}`; - if (!primaryWallet || !chain) return; + console.log(chain); + if (!chain) return; + const walletClient = await createWalletClientFromWallet(primaryWallet); const { account } = await getPimlicoSmartAccountClient(userAddress, chain, walletClient); setSafeAddress(account.address); @@ -77,8 +86,16 @@ const SafePage = () => { setLoading(true); setError(null); try { + if (!primaryWallet) return; + const network = await getNetwork(primaryWallet.connector); + + if (network !== baseSepolia.id) { + switchNetwork({ wallet: primaryWallet, network: baseSepolia.id }); + } + const userAddress = address as `0x${string}`; - if (!primaryWallet || !chain) return; + if (!chain) return; + const walletClient = await createWalletClientFromWallet(primaryWallet); const smartAccountClient = await getPimlicoSmartAccountClient(userAddress, chain, walletClient); const txHash = await transferERC20( @@ -114,8 +131,15 @@ const SafePage = () => { setLoading(true); setError(null); try { + if (!primaryWallet) return; + const network = await getNetwork(primaryWallet.connector); + + if (network !== baseSepolia.id) { + switchNetwork({ wallet: primaryWallet, network: baseSepolia.id }); + } + const userAddress = address as `0x${string}`; - if (!primaryWallet || !chain) return; + if (!chain) return; const walletClient = await createWalletClientFromWallet(primaryWallet); const smartAccountClient = await getPimlicoSmartAccountClient(userAddress, chain, walletClient); const approveHash = await approveERC20(