Skip to content

Commit

Permalink
fix: try to fix infinite switch loop
Browse files Browse the repository at this point in the history
  • Loading branch information
belopash committed May 17, 2024
1 parent 88a4723 commit 762829e
Show file tree
Hide file tree
Showing 4 changed files with 40 additions and 35 deletions.
11 changes: 6 additions & 5 deletions src/components/NetworkSwitcher/NetworkSwitcher.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -27,21 +27,22 @@ export function NetworkSwitcher({
color?: string;
hideText?: boolean;
}) {
const { network, switchAndReset: changeAndReset } = useSubsquidNetwork();
const { network, switchAndReset } = useSubsquidNetwork();
const { switchNetworkAsync } = useSwitchNetwork();

const handleAppSwitchAsync = async (network: NetworkName) => {
try {
await switchNetworkAsync?.(getChainId(network));
} catch (e: any) {
if (e.message?.toLowerCase().includes('user rejected the request')) {
return;
} catch (e: unknown) {
if (e instanceof Error) {
if (e.message.toLowerCase().includes('user rejected the request')) return;
if (e.message.toLowerCase().includes('already pending for origin')) return;
}

throw e;
}

changeAndReset(network);
switchAndReset(network);
};

return (
Expand Down
4 changes: 2 additions & 2 deletions src/index.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -119,13 +119,13 @@ export function useAppReload({
navigate(to);
}

// root = createRoot(container);
root = createRoot(container);
root.render(<App />);

await hideLoader();
};
}

const root = createRoot(container);
let root = createRoot(container);
root.render(<App />);
// hideLoader(0);
24 changes: 1 addition & 23 deletions src/layouts/NetworkLayout/NetworkLayout.tsx
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
import '@rainbow-me/rainbowkit/styles.css';

import React, { PropsWithChildren, useEffect, useState } from 'react';
import { PropsWithChildren, useState } from 'react';

import {
AppBar as AppBarMaterial,
Expand All @@ -14,14 +14,11 @@ import {
import { alpha } from '@mui/system/colorManipulator';
import classnames from 'classnames';
import { Outlet } from 'react-router-dom';
import { useDisconnect, useNetwork, useWalletClient } from 'wagmi';

import { Logo } from '@components/Logo';
import { NetworkSwitcher } from '@components/NetworkSwitcher';
import { TopBanner, useBannerHeight } from '@components/TopBanner';
import { MenuIcon } from '@icons/MenuIcon';
import { useAccount } from '@network/useAccount';
import { getChainId, getNetworkName, useSubsquidNetwork } from '@network/useSubsquidNetwork';

import { ColorVariant } from '../../theme';

Expand Down Expand Up @@ -256,25 +253,6 @@ export const NetworkLayout = ({
}: PropsWithChildren<{
stretchContent?: boolean;
}>) => {
const { isConnected } = useAccount();
const { isLoading } = useWalletClient();
const { chain } = useNetwork();
const { disconnect } = useDisconnect();
const { network, switchAndReset } = useSubsquidNetwork();

useEffect(() => {
if (!isConnected || isLoading) return;

if (chain?.id === getChainId(network)) return;

if (!chain?.unsupported) {
switchAndReset(getNetworkName(chain?.id));
return;
}

disconnect();
}, [chain, disconnect, isConnected, network, isLoading, switchAndReset]);

const theme = useTheme();
const narrowLg = useMediaQuery(theme.breakpoints.down('lg'));
const narrowXs = useMediaQuery(theme.breakpoints.down('xs'));
Expand Down
36 changes: 31 additions & 5 deletions src/network/useSubsquidNetwork.ts
Original file line number Diff line number Diff line change
@@ -1,5 +1,8 @@
import { useCallback, useEffect } from 'react';

import { useQueryClient } from '@tanstack/react-query';
import useLocalStorageState from 'use-local-storage-state';
import { useWalletClient, useAccount, useNetwork, useDisconnect } from 'wagmi';
import { arbitrum, arbitrumSepolia } from 'wagmi/chains';

import { localStorageStringSerializer } from '@hooks/useLocalStorageState.ts';
Expand All @@ -16,17 +19,40 @@ function validate(app: NetworkName): NetworkName {
}

export function useSubsquidNetwork() {
const { isLoading } = useWalletClient();
const { isConnected } = useAccount();
const { chain } = useNetwork();
const { disconnect } = useDisconnect();
const [app, changeApp] = useLocalStorageState<NetworkName>('network', {
serializer: localStorageStringSerializer,
defaultValue: defaultApp,
storageSync: false,
});

const queryClient = useQueryClient();

const switchAndReset = (network: NetworkName) => {
changeApp(network);
queryClient.clear();
};
const switchAndReset = useCallback(
(network: NetworkName) => {
changeApp(network);
queryClient.clear();
console.log('switched to ' + network);
},
[changeApp, queryClient],
);

// TODO: reset client when network switched in other window
useEffect(() => {
if (!isConnected || isLoading) return;

if (chain?.id === getChainId(app)) return;

if (chain && !chain.unsupported) {
switchAndReset(getNetworkName(chain?.id));
return;
}

disconnect();
}, [app, chain, disconnect, isConnected, isLoading, switchAndReset]);

return { network: validate(app), switchAndReset };
}
Expand All @@ -35,6 +61,6 @@ export function getChainId(network: NetworkName) {
return network === NetworkName.Mainnet ? arbitrum.id : arbitrumSepolia.id;
}

export function getNetworkName(chainId?: number) {
export function getNetworkName(chainId: number) {
return chainId === arbitrum.id ? NetworkName.Mainnet : NetworkName.Testnet;
}

0 comments on commit 762829e

Please sign in to comment.