unified networks list

This commit is contained in:
hueso 2025-06-22 02:21:46 -03:00
parent 2b707e81c2
commit 3ef1694217
3 changed files with 23 additions and 43 deletions

View File

@ -5,8 +5,8 @@ import SpinnerComponent from "@/components/SpinnerComponent.vue";
import ToasterComponent from "@/components/ToasterComponent.vue"; import ToasterComponent from "@/components/ToasterComponent.vue";
import { init, useOnboard } from "@web3-onboard/vue"; import { init, useOnboard } from "@web3-onboard/vue";
import injectedModule from "@web3-onboard/injected-wallets"; import injectedModule from "@web3-onboard/injected-wallets";
import { Networks } from "./model/Networks"; import { Networks } from "@/model/Networks";
import { NetworkEnum } from "./model/NetworkEnum"; import { NetworkEnum } from "@/model/NetworkEnum";
import { ref } from "vue"; import { ref } from "vue";
const route = useRoute(); const route = useRoute();
@ -15,20 +15,12 @@ const targetNetwork = ref(NetworkEnum.sepolia);
const web3Onboard = init({ const web3Onboard = init({
wallets: [injected], wallets: [injected],
chains: [ chains: Object.entries(Networks).map(([, network]) => ({
{ id: network.chainId,
id: Networks[NetworkEnum.sepolia].chainId, token: network.token,
token: "ETH", label: network.chainName,
label: "Sepolia", rpcUrl: network.rpcUrl,
rpcUrl: import.meta.env.VITE_SEPOLIA_API_URL, })),
},
{
id: Networks[NetworkEnum.rootstock].chainId,
token: "tRBTC",
label: "Rootstock Testnet",
rpcUrl: import.meta.env.VITE_ROOTSTOCK_API_URL,
},
],
connect: { connect: {
autoConnectLastWallet: true, autoConnectLastWallet: true,
}, },

View File

@ -2,7 +2,6 @@ import { ref } from "vue";
import { NetworkEnum, TokenEnum } from "../model/NetworkEnum"; import { NetworkEnum, TokenEnum } from "../model/NetworkEnum";
import type { ValidDeposit } from "@/model/ValidDeposit"; import type { ValidDeposit } from "@/model/ValidDeposit";
import type { Participant } from "../utils/bbPay"; import type { Participant } from "../utils/bbPay";
import { NetworkById } from "@/model/Networks";
import type { Address } from "viem" import type { Address } from "viem"
const walletAddress = ref<Address | null>(null); const walletAddress = ref<Address | null>(null);
@ -33,7 +32,7 @@ export function useUser() {
}; };
const setNetworkId = (network: string | number) => { const setNetworkId = (network: string | number) => {
networkName.value = NetworkById(network) || NetworkEnum.sepolia; networkName.value = Number(network) as NetworkEnum || NetworkEnum.sepolia;
networkId.value = Number(network); networkId.value = Number(network);
}; };

View File

@ -1,37 +1,26 @@
import { NetworkEnum } from "@/model/NetworkEnum"; import { NetworkEnum } from "@/model/NetworkEnum";
export const NetworkById = ( export interface NetworkConfig {
chainId: string | number chainId: string;
): NetworkEnum | undefined => { chainName: string;
const normalizedChainId = token: string;
typeof chainId === "number" ? chainId : Number(chainId); rpcUrl?: string;
blockExplorerUrl?: string;
for (const [network, details] of Object.entries(Networks)) {
if (Number(details.chainId) === normalizedChainId) {
return network as unknown as NetworkEnum;
}
} }
return undefined; export const Networks: { [key in NetworkEnum]: NetworkConfig } = {
};
export const Networks = {
[NetworkEnum.sepolia]: { [NetworkEnum.sepolia]: {
chainId: "0xAA36A7", chainId: "0xAA36A7",
chainName: "Sepolia Testnet", chainName: "Sepolia Testnet",
token: "ETH",
rpcUrl: import.meta.env.VITE_SEPOLIA_API_URL,
blockExplorerUrl: "https://sepolia.etherscan.io",
}, },
[NetworkEnum.rootstock]: { [NetworkEnum.rootstock]: {
chainId: "0x1F", chainId: "0x1F",
chainName: "Rootstock Testnet", chainName: "Rootstock Testnet",
rpcUrls: ["https://public-node.testnet.rsk.co/"], token: "tRBTC",
iconUrls: [ rpcUrl: import.meta.env.VITE_ROOTSTOCK_API_URL,
"", blockExplorerUrl: "https://explorer.testnet.rsk.co",
],
nativeCurrency: {
name: "tRBTC",
symbol: "tRBTC",
decimals: 18,
},
blockExplorerUrls: ["https://explorer.testnet.rootstock.io/"],
}, },
}; };