2023-06-26 14:28:14 +00:00
|
|
|
import type { DefaultWeb3ProviderContextShape } from '@vegaprotocol/web3';
|
2023-02-16 03:52:54 +00:00
|
|
|
import {
|
|
|
|
useEthereumConfig,
|
|
|
|
createConnectors,
|
|
|
|
Web3Provider as Web3ProviderInternal,
|
|
|
|
useWeb3ConnectStore,
|
2023-06-26 14:28:14 +00:00
|
|
|
createDefaultProvider,
|
2023-02-16 03:52:54 +00:00
|
|
|
} from '@vegaprotocol/web3';
|
|
|
|
import { AsyncRenderer } from '@vegaprotocol/ui-toolkit';
|
2023-02-28 18:56:29 +00:00
|
|
|
import { t } from '@vegaprotocol/i18n';
|
2023-02-16 03:52:54 +00:00
|
|
|
import { useEnvironment } from '@vegaprotocol/environment';
|
|
|
|
import type { ReactNode } from 'react';
|
2023-06-26 14:28:14 +00:00
|
|
|
import { useState } from 'react';
|
2023-02-16 03:52:54 +00:00
|
|
|
import { useEffect } from 'react';
|
|
|
|
|
|
|
|
export const Web3Provider = ({ children }: { children: ReactNode }) => {
|
|
|
|
const { config, loading, error } = useEthereumConfig();
|
|
|
|
const { ETHEREUM_PROVIDER_URL, ETH_LOCAL_PROVIDER_URL, ETH_WALLET_MNEMONIC } =
|
|
|
|
useEnvironment();
|
2023-04-20 15:20:59 +00:00
|
|
|
|
|
|
|
const connectors = useWeb3ConnectStore((store) => store.connectors);
|
|
|
|
const initializeConnectors = useWeb3ConnectStore((store) => store.initialize);
|
2023-06-26 14:28:14 +00:00
|
|
|
const [defaultProvider, setDefaultProvider] = useState<
|
|
|
|
DefaultWeb3ProviderContextShape['provider'] | undefined
|
|
|
|
>(undefined);
|
2023-02-16 03:52:54 +00:00
|
|
|
|
|
|
|
useEffect(() => {
|
|
|
|
if (config?.chain_id) {
|
2023-06-26 14:28:14 +00:00
|
|
|
initializeConnectors(
|
2023-02-16 03:52:54 +00:00
|
|
|
createConnectors(
|
|
|
|
ETHEREUM_PROVIDER_URL,
|
|
|
|
Number(config?.chain_id),
|
|
|
|
ETH_LOCAL_PROVIDER_URL,
|
|
|
|
ETH_WALLET_MNEMONIC
|
|
|
|
),
|
|
|
|
Number(config.chain_id)
|
|
|
|
);
|
2023-06-26 14:28:14 +00:00
|
|
|
const defaultProvider = createDefaultProvider(
|
|
|
|
ETHEREUM_PROVIDER_URL,
|
|
|
|
Number(config?.chain_id)
|
|
|
|
);
|
|
|
|
setDefaultProvider(defaultProvider);
|
2023-02-16 03:52:54 +00:00
|
|
|
}
|
|
|
|
}, [
|
|
|
|
config?.chain_id,
|
|
|
|
ETHEREUM_PROVIDER_URL,
|
|
|
|
initializeConnectors,
|
|
|
|
ETH_LOCAL_PROVIDER_URL,
|
|
|
|
ETH_WALLET_MNEMONIC,
|
|
|
|
]);
|
|
|
|
|
|
|
|
return (
|
|
|
|
<AsyncRenderer
|
|
|
|
loading={loading}
|
|
|
|
error={error}
|
|
|
|
data={connectors}
|
|
|
|
noDataCondition={(d) => {
|
|
|
|
if (!d) return true;
|
|
|
|
return d.length < 1;
|
|
|
|
}}
|
|
|
|
noDataMessage={t('Could not fetch Ethereum configuration')}
|
|
|
|
>
|
2023-06-26 14:28:14 +00:00
|
|
|
<Web3ProviderInternal
|
|
|
|
connectors={connectors}
|
|
|
|
defaultProvider={defaultProvider}
|
|
|
|
>
|
2023-02-16 03:52:54 +00:00
|
|
|
<>{children}</>
|
|
|
|
</Web3ProviderInternal>
|
|
|
|
</AsyncRenderer>
|
|
|
|
);
|
|
|
|
};
|