2022-05-02 17:16:57 +00:00
|
|
|
import type { Web3ReactHooks } from '@web3-react/core';
|
2022-03-25 07:44:10 +00:00
|
|
|
import { Web3ReactProvider } from '@web3-react/core';
|
2022-05-02 17:16:57 +00:00
|
|
|
import type { Connector } from '@web3-react/types';
|
2023-04-20 15:20:59 +00:00
|
|
|
import { useMemo } from 'react';
|
2022-03-25 07:44:10 +00:00
|
|
|
|
|
|
|
interface Web3ProviderProps {
|
|
|
|
children: JSX.Element | JSX.Element[];
|
2022-05-02 17:16:57 +00:00
|
|
|
connectors: [Connector, Web3ReactHooks][];
|
2022-03-25 07:44:10 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
export const Web3Provider = ({ children, connectors }: Web3ProviderProps) => {
|
2023-04-20 15:20:59 +00:00
|
|
|
/**
|
|
|
|
* The connectors prop passed to Web3ReactProvider must be referentially static.
|
|
|
|
* https://github.com/Uniswap/web3-react/blob/31742897f9fddb38e00e36c2516029d3df9a9c54/packages/core/src/provider.tsx#L66
|
|
|
|
*/
|
|
|
|
const key = useMemo(
|
|
|
|
() => `WEB3_PROVIDER_${Date.now().toString()}`,
|
|
|
|
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
|
|
[connectors]
|
|
|
|
);
|
|
|
|
|
2022-03-25 07:44:10 +00:00
|
|
|
return (
|
2023-04-20 15:20:59 +00:00
|
|
|
<Web3ReactProvider key={key} connectors={connectors}>
|
|
|
|
{children}
|
|
|
|
</Web3ReactProvider>
|
2022-03-25 07:44:10 +00:00
|
|
|
);
|
|
|
|
};
|