import { Button, Splash } from '@vegaprotocol/ui-toolkit'; import { Web3Provider, Web3ConnectDialog } from '@vegaprotocol/web3'; import { useWeb3React } from '@web3-react/core'; import { ReactNode, useEffect, useState } from 'react'; import { Connectors } from '../../lib/web3-connectors'; interface Web3ContainerProps { children: ReactNode; } export const Web3Container = ({ children }: Web3ContainerProps) => { const [dialogOpen, setDialogOpen] = useState(false); return ( {children} ); }; interface Web3ContentProps { children: ReactNode; setDialogOpen: (isOpen: boolean) => void; } export const Web3Content = ({ children, setDialogOpen }: Web3ContentProps) => { const appChainId = Number(process.env['NX_ETHEREUM_CHAIN_ID'] || 3); const { isActive, error, connector, chainId } = useWeb3React(); useEffect(() => { connector?.connectEagerly(); }, [connector]); if (error) { return (

Something went wrong: {error.message}

); } if (!isActive) { return (

Connect your Ethereum wallet

); } if (chainId !== appChainId) { return (

This app only works on chain ID: {appChainId}

); } return <>{children}; }; interface SplashWrapperProps { children: ReactNode; } const SplashWrapper = ({ children }: SplashWrapperProps) => { return (
{children}
); };