Add listener to listen chain change and update store network name state, also start refactor with getProvider function
Co-authored-by: brunoedcf <brest.dallacosta@outlook.com>
This commit is contained in:
parent
62dd4349b2
commit
8b0a212b78
15
src/blockchain/provider.ts
Normal file
15
src/blockchain/provider.ts
Normal file
@ -0,0 +1,15 @@
|
|||||||
|
import { ethers } from "ethers";
|
||||||
|
import { useEtherStore } from "@/store/ether";
|
||||||
|
|
||||||
|
const getProvider = (): ethers.providers.Web3Provider | null => {
|
||||||
|
const etherStore = useEtherStore();
|
||||||
|
|
||||||
|
const window_ = window as any;
|
||||||
|
const connection = window_.ethereum;
|
||||||
|
|
||||||
|
if (!connection) return null;
|
||||||
|
|
||||||
|
return new ethers.providers.Web3Provider(connection);
|
||||||
|
};
|
||||||
|
|
||||||
|
export { getProvider }
|
@ -7,6 +7,8 @@ import p2pix from "./smart_contract_files/P2PIX.json";
|
|||||||
import addresses from "./smart_contract_files/localhost.json";
|
import addresses from "./smart_contract_files/localhost.json";
|
||||||
// Mock wallets import
|
// Mock wallets import
|
||||||
import { wallets } from "./smart_contract_files/wallets.json";
|
import { wallets } from "./smart_contract_files/wallets.json";
|
||||||
|
import { getProvider } from "../blockchain/provider";
|
||||||
|
import { NetworkEnum } from "@/model/NetworkEnum";
|
||||||
|
|
||||||
// Wallet methods
|
// Wallet methods
|
||||||
// Update wallet state (balance and address)
|
// Update wallet state (balance and address)
|
||||||
@ -272,20 +274,28 @@ const connectProvider = async () => {
|
|||||||
await updateDepositAddedEvents();
|
await updateDepositAddedEvents();
|
||||||
await updateLockAddedEvents();
|
await updateLockAddedEvents();
|
||||||
await updateLockReleasedEvents();
|
await updateLockReleasedEvents();
|
||||||
|
listenToNetworkChange(connection);
|
||||||
|
|
||||||
connection.on("accountsChanged", async () => {
|
connection.on("accountsChanged", async () => {
|
||||||
await updateWalletStatus();
|
await updateWalletStatus();
|
||||||
});
|
});
|
||||||
};
|
};
|
||||||
|
|
||||||
const getProvider = (): ethers.providers.Web3Provider | null => {
|
const listenToNetworkChange = (connection: any) => {
|
||||||
const window_ = window as any;
|
const etherStore = useEtherStore();
|
||||||
const connection = window_.ethereum;
|
|
||||||
|
|
||||||
if (!connection) return null;
|
const possibleNetworks: {[key: string]: NetworkEnum} = {
|
||||||
|
"0x5": NetworkEnum.ethereum,
|
||||||
|
"0x13881": NetworkEnum.polygon,
|
||||||
|
"0x7a69": NetworkEnum.localhost,
|
||||||
|
}
|
||||||
|
|
||||||
return new ethers.providers.Web3Provider(connection);
|
connection.on("chainChanged", (networkChain: string) => {
|
||||||
};
|
if (Object.keys(possibleNetworks).includes(networkChain)){
|
||||||
|
etherStore.setNetworkName(possibleNetworks[networkChain]);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
// Deposit methods
|
// Deposit methods
|
||||||
const approveTokens = async (tokenQty: Number) => {
|
const approveTokens = async (tokenQty: Number) => {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user