Fixed some reactivity for network selected.

This commit is contained in:
Filipe Soccol
2025-04-15 17:56:32 -03:00
parent 0186afe971
commit 1ec4780e14
5 changed files with 52 additions and 45 deletions

View File

@@ -2,42 +2,19 @@
import { ref, computed, watch, onMounted } from "vue";
import { useOnboard } from "@web3-onboard/vue";
import { Networks } from "../model/Networks";
import { NetworkEnum } from "../model/NetworkEnum";
import type { PropType } from "vue";
import { useUser } from "@/composables/useUser";
const props = defineProps({
targetNetwork: {
type: Object as PropType<NetworkEnum>,
default: NetworkEnum.sepolia,
},
});
const { connectedWallet } = useOnboard();
const user = useUser();
const { networkName } = user;
const { networkId, networkName } = user;
const isWrongNetwork = ref(false);
const currentNetworkName = ref("");
const targetNetworkName = computed(
() => Networks[props.targetNetwork as keyof typeof Networks].chainName
);
const targetNetworkName = computed(() => Networks[networkName.value].chainName);
const checkNetwork = () => {
if (connectedWallet.value) {
const chainId = connectedWallet.value.chains[0].id;
const targetChainId =
Networks[props.targetNetwork as keyof typeof Networks].chainId;
isWrongNetwork.value =
chainId.toLowerCase() !== targetChainId.toLowerCase();
// Find current network name
Object.entries(Networks).forEach(([key, network]) => {
if (network.chainId === chainId) {
currentNetworkName.value = network.chainName;
}
});
isWrongNetwork.value = Number(chainId) !== networkId.value;
} else {
isWrongNetwork.value = false; // No wallet connected yet
}
@@ -46,11 +23,13 @@ const checkNetwork = () => {
const switchNetwork = async () => {
try {
if (connectedWallet.value && connectedWallet.value.provider) {
const targetChainId =
Networks[props.targetNetwork as keyof typeof Networks].chainId;
await connectedWallet.value.provider.request({
method: "wallet_switchEthereumChain",
params: [{ chainId: targetChainId }],
params: [
{
chainId: Networks[networkName.value].chainId,
},
],
});
}
} catch (error) {
@@ -59,8 +38,8 @@ const switchNetwork = async () => {
};
onMounted(checkNetwork);
watch(connectedWallet, checkNetwork, { immediate: true });
watch(networkName, checkNetwork, { immediate: true });
watch(connectedWallet, checkNetwork);
watch(networkId, checkNetwork, { immediate: true });
</script>
<template>
@@ -71,9 +50,6 @@ watch(networkName, checkNetwork, { immediate: true });
>
<div>
<span class="font-bold">Wrong network!</span>
<span v-if="currentNetworkName"
>You are connected to {{ currentNetworkName }}.</span
>
<span> Please switch to {{ targetNetworkName }}.</span>
</div>
<button

View File

@@ -16,7 +16,7 @@ import { connectProvider } from "@/blockchain/provider";
// Use the new composable
const user = useUser();
const { walletAddress, sellerView } = user;
const { walletAddress, sellerView, networkId } = user;
const menuOpenToggle = ref<boolean>(false);
const infoMenuOpenToggle = ref<boolean>(false);
@@ -40,6 +40,19 @@ watch(connectedWallet, async (newVal: any) => {
});
watch(connectedChain, (newVal: any) => {
// Check if connected chain is valid, otherwise default to Sepolia (NetworkEnum.SEPOLIA)
if (
!newVal ||
!Object.values(Networks).some(
(network) => Number(network.chainId) === Number(newVal.id)
)
) {
console.log(
"Invalid or unsupported network detected, defaulting to Sepolia"
);
user.setNetworkId(user.networkId.value);
return;
}
user.setNetworkId(newVal?.id);
});