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(() => {
if (typeof connector?.connectEagerly === 'function') {
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}
);
};