import { gql } from '@apollo/client'; import type { NetworkParamsQuery } from './__generated__/NetworkParamsQuery'; import { Button, Splash } from '@vegaprotocol/ui-toolkit'; import { Web3Provider, Web3ConnectDialog } from '@vegaprotocol/web3'; import { useWeb3React } from '@web3-react/core'; import type { ReactNode } from 'react'; import { useEffect, useState } from 'react'; import { Connectors } from '../../lib/web3-connectors'; import { PageQueryContainer } from '../page-query-container'; import { t } from '@vegaprotocol/react-helpers'; export interface EthereumConfig { network_id: string; chain_id: string; confirmations: number; collateral_bridge_contract: { address: string; }; multisig_control_contract: { address: string; deployment_block_height: number; }; staking_bridge_contract: { address: string; deployment_block_height: number; }; token_vesting_contract: { address: string; deployment_block_height: number; }; } export const NETWORK_PARAMS_QUERY = gql` query NetworkParamsQuery { networkParameters { key value } } `; interface Web3ContainerProps { render: (params: { ethereumConfig: EthereumConfig }) => ReactNode; } export const Web3Container = ({ render }: Web3ContainerProps) => { const [dialogOpen, setDialogOpen] = useState(false); return ( query={NETWORK_PARAMS_QUERY} render={(data) => { const ethereumConfigParam = data.networkParameters?.find( (np) => np.key === 'blockchains.ethereumConfig' ); if (!ethereumConfigParam) { return (

{t('No ethereum config found')}

); } let ethereumConfig: EthereumConfig; try { ethereumConfig = JSON.parse(ethereumConfigParam.value); } catch { return (

{t('Could not parse config')}

); } return ( {render({ ethereumConfig })} ); }} /> ); }; interface Web3ContentProps { children: ReactNode; appChainId: number; setDialogOpen: (isOpen: boolean) => void; } export const Web3Content = ({ children, appChainId, setDialogOpen, }: Web3ContentProps) => { const { isActive, error, connector, chainId } = useWeb3React(); useEffect(() => { if ( connector?.connectEagerly && // Dont eager connect if this is a cypress test run 'Cypress' in window ) { connector.connectEagerly(); } }, [connector]); if (error) { return (

{t(`Something went wrong: ${error.message}`)}

); } if (!isActive) { return (

{t('Connect your Ethereum wallet')}

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

{t(`This app only works on chain ID: ${appChainId}`)}

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