import type { InMemoryCacheConfig } from '@apollo/client'; import { AppLoader, NetworkLoader, useEnvironment, useNodeSwitcherStore, } from '@vegaprotocol/environment'; import { useEffect, type ReactNode, useState } from 'react'; import { Web3Provider } from './web3-provider'; import { useT } from '../../lib/use-t'; import { DataLoader } from './data-loader'; import { WalletProvider } from '@vegaprotocol/wallet-react'; import { useVegaWalletConfig } from '../../lib/hooks/use-vega-wallet-config'; import { Trans } from 'react-i18next'; import { Button, Loader, Splash, VLogo } from '@vegaprotocol/ui-toolkit'; const Failure = ({ reason }: { reason?: ReactNode }) => { const t = useT(); const setNodeSwitcher = useNodeSwitcherStore((store) => store.setDialogOpen); return (
{t('Failed to initialize the app')}

{reason}

); }; const Loading = () => { const [showSlowNotification, setShowSlowNotification] = useState(false); const t = useT(); const setNodeSwitcher = useNodeSwitcherStore((store) => store.setDialogOpen); useEffect(() => { const to = setTimeout(() => { if (!showSlowNotification) setShowSlowNotification(true); }, 5000); return () => { clearTimeout(to); }; }, [showSlowNotification]); return (
{showSlowNotification && ( <>

{t( "It looks like you're connection is slow, try switching to another node." )}

)}
); }; export const Bootstrapper = ({ children }: { children: ReactNode }) => { const t = useT(); const { error, VEGA_URL } = useEnvironment((state) => ({ error: state.error, VEGA_URL: state.VEGA_URL, })); const config = useVegaWalletConfig(); if (!config) { return ; } const ERR_DATA_LOADER = ( {VEGA_URL} , ]} values={{ VEGA_URL, }} /> ); return ( } failure={} > } failure={} > } failure={} > {children} ); }; const cacheConfig: InMemoryCacheConfig = { typePolicies: { Statistics: { merge: true, }, Account: { keyFields: false, fields: { balanceFormatted: {}, }, }, Instrument: { keyFields: false, }, TradableInstrument: { keyFields: false, }, Product: { keyFields: ['settlementAsset', ['id']], }, MarketData: { keyFields: ['market', ['id']], }, Node: { keyFields: false, }, Withdrawal: { fields: { pendingOnForeignChain: { read: (isPending = false) => isPending, }, }, }, ERC20: { keyFields: ['contractAddress'], }, Party: { keyFields: false, }, Position: { keyFields: ['market', ['id'], 'party', ['id']], }, Fees: { keyFields: false, }, // The folling types are cached by the data provider and not by apollo PositionUpdate: { keyFields: false, }, TradeUpdate: { keyFields: false, }, AccountUpdate: { keyFields: false, }, OrderUpdate: { keyFields: false, }, Game: { keyFields: false, }, }, };