diff --git a/pages/_app.page.tsx b/pages/_app.page.tsx index 5c7ffa5a97..9059f3f753 100644 --- a/pages/_app.page.tsx +++ b/pages/_app.page.tsx @@ -96,7 +96,10 @@ interface MyAppProps extends AppProps { export default function MyApp(props: MyAppProps) { const { Component, emotionCache = clientSideEmotionCache, pageProps } = props; const getLayout = Component.getLayout ?? ((page: ReactNode) => page); - const initializeMixpanel = useRootStore((store) => store.initializeMixpanel); + const [initializeMixpanel, setWalletType] = useRootStore((store) => [ + store.initializeMixpanel, + store.setWalletType, + ]); const [queryClient] = useState( () => new QueryClient({ @@ -137,7 +140,10 @@ export default function MyApp(props: MyAppProps) { - + setWalletType(connectorId)} + > diff --git a/pages/index.page.tsx b/pages/index.page.tsx index f934df8fbd..1b1c8e2d34 100644 --- a/pages/index.page.tsx +++ b/pages/index.page.tsx @@ -14,7 +14,7 @@ import { DashboardContentWrapper } from '../src/modules/dashboard/DashboardConte import { DashboardTopPanel } from '../src/modules/dashboard/DashboardTopPanel'; export default function Home() { - const { currentAccount, loading: web3Loading } = useWeb3Context(); + const { currentAccount } = useWeb3Context(); const { currentMarket } = useProtocolDataContext(); const trackEvent = useRootStore((store) => store.trackEvent); @@ -63,7 +63,7 @@ export default function Home() { {currentAccount ? ( ) : ( - + )} diff --git a/pages/v3-migration.page.tsx b/pages/v3-migration.page.tsx index e0ecce54ab..01a3bec7a5 100644 --- a/pages/v3-migration.page.tsx +++ b/pages/v3-migration.page.tsx @@ -51,7 +51,7 @@ const selectableMarkets = [ ]; export default function V3Migration() { - const { currentAccount, loading: web3Loading } = useWeb3Context(); + const { currentAccount } = useWeb3Context(); const router = useRouter(); const [fromMarketData, setFromMarketData] = useState(() => { if (router.query.market) { @@ -255,7 +255,6 @@ export default function V3Migration() { ) : ( Please connect your wallet to see migration tool.} /> )} diff --git a/src/components/AddressBlocked.tsx b/src/components/AddressBlocked.tsx index c5d604bd1b..305cacc7a5 100644 --- a/src/components/AddressBlocked.tsx +++ b/src/components/AddressBlocked.tsx @@ -3,18 +3,20 @@ import { useAddressAllowed } from 'src/hooks/useAddressAllowed'; import { MainLayout } from 'src/layouts/MainLayout'; import { useWeb3Context } from 'src/libs/hooks/useWeb3Context'; import { ENABLE_TESTNET } from 'src/utils/marketsAndNetworksConfig'; +import { useDisconnect } from 'wagmi'; import { AddressBlockedModal } from './AddressBlockedModal'; export const AddressBlocked = ({ children }: { children: ReactNode }) => { - const { currentAccount, disconnectWallet, readOnlyMode, loading } = useWeb3Context(); + const { currentAccount, readOnlyMode, loading } = useWeb3Context(); + const { disconnect } = useDisconnect(); const screenAddress = readOnlyMode || loading || ENABLE_TESTNET ? '' : currentAccount; const { isAllowed } = useAddressAllowed(screenAddress); if (!isAllowed) { return ( - ; + disconnect()} />; ); } diff --git a/src/components/ConnectWalletPaper.tsx b/src/components/ConnectWalletPaper.tsx index 85422e3325..d5f62de91a 100644 --- a/src/components/ConnectWalletPaper.tsx +++ b/src/components/ConnectWalletPaper.tsx @@ -1,22 +1,21 @@ import { Trans } from '@lingui/macro'; import { Box, CircularProgress, Paper, PaperProps, Typography } from '@mui/material'; +import { useModal } from 'connectkit'; import { ReactNode } from 'react'; +import { useWeb3Context } from 'src/libs/hooks/useWeb3Context'; import LandingGhost from '/public/resting-gho-hat-purple.svg'; import { ConnectWalletButton } from './WalletConnection/ConnectWalletButton'; interface ConnectWalletPaperProps extends PaperProps { - loading?: boolean; description?: ReactNode; } -export const ConnectWalletPaper = ({ - loading, - description, - sx, - ...rest -}: ConnectWalletPaperProps) => { +export const ConnectWalletPaper = ({ description, sx, ...rest }: ConnectWalletPaperProps) => { + const { open } = useModal(); + const { loading } = useWeb3Context(); + return ( <> - {loading ? ( + {open || loading ? ( ) : ( <> diff --git a/src/components/UserDisplay.tsx b/src/components/UserDisplay.tsx index 16c9b77a05..42ffe720dc 100644 --- a/src/components/UserDisplay.tsx +++ b/src/components/UserDisplay.tsx @@ -4,6 +4,7 @@ import { useMemo } from 'react'; import useGetEns from 'src/libs/hooks/use-get-ens'; import { useWeb3Context } from 'src/libs/hooks/useWeb3Context'; import { useRootStore } from 'src/store/root'; +import { useAccount } from 'wagmi'; import { shallow } from 'zustand/shallow'; import { Avatar, AvatarProps } from './Avatar'; @@ -27,12 +28,12 @@ export const UserDisplay: React.FC = ({ withLink, funnel, }) => { - const { account, defaultDomain, domainsLoading, accountLoading } = useRootStore( + const { isConnecting } = useAccount(); + const { account, defaultDomain, domainsLoading } = useRootStore( (state) => ({ account: state.account, defaultDomain: state.defaultDomain, domainsLoading: state.domainsLoading, - accountLoading: state.accountLoading, }), shallow ); @@ -41,7 +42,7 @@ export const UserDisplay: React.FC = ({ () => (account ? blo(account as `0x${string}`) : undefined), [account] ); - const loading = domainsLoading || accountLoading; + const loading = domainsLoading || isConnecting; return ( diff --git a/src/components/WalletConnection/ConnectWalletButton.tsx b/src/components/WalletConnection/ConnectWalletButton.tsx index e5cf129a8b..0d7c3694be 100644 --- a/src/components/WalletConnection/ConnectWalletButton.tsx +++ b/src/components/WalletConnection/ConnectWalletButton.tsx @@ -1,7 +1,6 @@ import { Trans } from '@lingui/macro'; import { Button } from '@mui/material'; import { ConnectKitButton } from 'connectkit'; -import { useWalletModalContext } from 'src/hooks/useWalletModal'; import { useRootStore } from 'src/store/root'; import { AUTH } from 'src/utils/mixPanelEvents'; @@ -10,6 +9,7 @@ import { UserDisplay } from '../UserDisplay'; export interface ConnectWalletProps { funnel?: string; + onIsConnecting?: (isConnecting: boolean) => void; } export const ConnectWalletButton: React.FC = ({ funnel }) => { @@ -24,6 +24,7 @@ export const ConnectWalletButton: React.FC = ({ funnel }) => variant={isConnected ? 'surface' : 'gradient'} onClick={() => { show && show(); + trackEvent(AUTH.CONNECT_WALLET, { funnel: funnel }); }} > {isConnected ? ( diff --git a/src/components/WalletConnection/ReadOnlyModal.tsx b/src/components/WalletConnection/ReadOnlyModal.tsx index 28325b6492..f7ba0f6bdd 100644 --- a/src/components/WalletConnection/ReadOnlyModal.tsx +++ b/src/components/WalletConnection/ReadOnlyModal.tsx @@ -5,20 +5,14 @@ import { useEffect, useState } from 'react'; import { ReadOnlyModeTooltip } from 'src/components/infoTooltips/ReadOnlyModeTooltip'; import { ModalType, useModalContext } from 'src/hooks/useModal'; import { useWeb3Context } from 'src/libs/hooks/useWeb3Context'; -import { WalletType } from 'src/libs/web3-data-provider/WalletOptions'; import { useRootStore } from 'src/store/root'; import { getENSProvider } from 'src/utils/marketsAndNetworksConfig'; import { AUTH } from 'src/utils/mixPanelEvents'; +import { mock, useConnect } from 'wagmi'; import { BasicModal } from '../primitives/BasicModal'; import { Warning } from '../primitives/Warning'; import { TxModalTitle } from '../transactions/FlowCommons/TxModalTitle'; -import { mock, useConnect } from 'wagmi'; - -export type WalletRowProps = { - walletName: string; - walletType: WalletType; -}; export enum ErrorType { UNSUPORTED_CHAIN, diff --git a/src/components/WalletConnection/WalletModal.tsx b/src/components/WalletConnection/WalletModal.tsx deleted file mode 100644 index 572b68e7c2..0000000000 --- a/src/components/WalletConnection/WalletModal.tsx +++ /dev/null @@ -1,14 +0,0 @@ -import { useWalletModalContext } from 'src/hooks/useWalletModal'; - -import { BasicModal } from '../primitives/BasicModal'; -import { WalletSelector } from './WalletSelector'; - -export const WalletModal = () => { - const { isWalletModalOpen, setWalletModalOpen } = useWalletModalContext(); - - return ( - - - - ); -}; diff --git a/src/components/WalletConnection/WalletSelector.tsx b/src/components/WalletConnection/WalletSelector.tsx deleted file mode 100644 index b85480f2f3..0000000000 --- a/src/components/WalletConnection/WalletSelector.tsx +++ /dev/null @@ -1,258 +0,0 @@ -import { Trans } from '@lingui/macro'; -import { Box, Button, InputBase, Link, Typography, useMediaQuery, useTheme } from '@mui/material'; -import { NoMetaMaskError } from '@web3-react/metamask'; -import { utils } from 'ethers'; -import { useState } from 'react'; -import { ReadOnlyModeTooltip } from 'src/components/infoTooltips/ReadOnlyModeTooltip'; -import { useWeb3Context } from 'src/libs/hooks/useWeb3Context'; -import { UserRejectedRequestError } from 'src/libs/web3-data-provider/connectors/WalletConnectConnector'; -import { WalletType } from 'src/libs/web3-data-provider/WalletOptions'; -import { useRootStore } from 'src/store/root'; -import { getENSProvider } from 'src/utils/marketsAndNetworksConfig'; -import { AUTH } from 'src/utils/mixPanelEvents'; - -import { Warning } from '../primitives/Warning'; -import { TxModalTitle } from '../transactions/FlowCommons/TxModalTitle'; - -export type WalletRowProps = { - walletName: string; - walletType: WalletType; -}; -const WalletRow = ({ walletName, walletType }: WalletRowProps) => { - const { connectWallet, loading } = useWeb3Context(); - const trackEvent = useRootStore((store) => store.trackEvent); - - const getWalletIcon = (walletType: WalletType) => { - switch (walletType) { - case WalletType.INJECTED: - return ( - {`browser - ); - case WalletType.WALLET_CONNECT: - return ( - {`browser - ); - case WalletType.COINBASE_WALLET: - return ( - {`browser - ); - // case WalletType.TORUS: - // return ( - // {`browser - // ); - // case WalletType.FRAME: - // return ( - // {`browser - // ); - default: - return null; - } - }; - - const connectWalletClick = () => { - trackEvent(AUTH.CONNECT_WALLET, { walletType: walletType, walletName: walletName }); - connectWallet(walletType); - }; - return ( - - ); -}; - -export enum ErrorType { - UNSUPORTED_CHAIN, - USER_REJECTED_REQUEST, - UNDETERMINED_ERROR, - NO_WALLET_DETECTED, -} - -export const WalletSelector = () => { - const { error, connectWallet } = useWeb3Context(); - const [inputMockWalletAddress, setInputMockWalletAddress] = useState(''); - const [validAddressError, setValidAddressError] = useState(false); - const { breakpoints } = useTheme(); - const sm = useMediaQuery(breakpoints.down('sm')); - const mainnetProvider = getENSProvider(); - const trackEvent = useRootStore((store) => store.trackEvent); - - let blockingError: ErrorType | undefined = undefined; - if (error) { - if (error instanceof UserRejectedRequestError) { - blockingError = ErrorType.UNSUPORTED_CHAIN; - } else if (error instanceof UserRejectedRequestError) { - blockingError = ErrorType.USER_REJECTED_REQUEST; - } else if (error instanceof NoMetaMaskError) { - blockingError = ErrorType.NO_WALLET_DETECTED; - } else { - blockingError = ErrorType.UNDETERMINED_ERROR; - } - // TODO: add other errors - } - - const handleBlocking = () => { - switch (blockingError) { - case ErrorType.UNSUPORTED_CHAIN: - return Network not supported for this wallet; - case ErrorType.USER_REJECTED_REQUEST: - return Rejected connection request; - case ErrorType.NO_WALLET_DETECTED: - return Wallet not detected. Connect or install wallet and retry; - default: - console.log('Uncatched error: ', error); - return Error connecting. Try refreshing the page.; - } - }; - - const handleReadAddress = async (inputMockWalletAddress: string): Promise => { - if (validAddressError) setValidAddressError(false); - if (utils.isAddress(inputMockWalletAddress)) { - console.log('connect the read only wallethere'); - connectWallet(WalletType.READ_ONLY_MODE, { address: inputMockWalletAddress }); - } else { - // Check if address could be valid ENS before trying to resolve - if (inputMockWalletAddress.slice(-4) === '.eth') { - // Attempt to resolve ENS name and use resolved address if valid - const resolvedAddress = await mainnetProvider.resolveName(inputMockWalletAddress); - if (resolvedAddress && utils.isAddress(resolvedAddress)) { - connectWallet(WalletType.READ_ONLY_MODE, { address: resolvedAddress }); - } else { - setValidAddressError(true); - } - } else { - setValidAddressError(true); - } - } - }; - - const handleSubmit = (event: React.FormEvent): void => { - event.preventDefault(); - handleReadAddress(inputMockWalletAddress); - }; - - return ( - - - {error && {handleBlocking()}} - - - - {/* */} - - - Track wallet balance in read-only mode - - - -
- ({ - py: 1, - px: 3, - border: `1px solid ${theme.palette.divider}`, - borderRadius: '6px', - mb: 1, - overflow: 'show', - fontSize: sm ? '16px' : '14px', - })} - placeholder="Enter ethereum address or ENS name" - fullWidth - value={inputMockWalletAddress} - onChange={(e) => setInputMockWalletAddress(e.target.value)} - inputProps={{ - 'aria-label': 'read-only mode address', - }} - /> - - - {validAddressError && ( - - Please enter a valid wallet address. - - )} - - - Need help connecting a wallet?{' '} - - Read our FAQ - - - - - - Wallets are provided by External Providers and by selecting you agree to Terms of those - Providers. Your access to the wallet might be reliant on the External Provider being - operational. - - -
- ); -}; diff --git a/src/hooks/useWalletModal.tsx b/src/hooks/useWalletModal.tsx deleted file mode 100644 index e98c0fb147..0000000000 --- a/src/hooks/useWalletModal.tsx +++ /dev/null @@ -1,9 +0,0 @@ -import { useRootStore } from 'src/store/root'; - -// TODO: remove this -// currently this reexport is a workaround so i don't have to alter and potentially create conflicts in 200 files -export const useWalletModalContext = () => - useRootStore((state) => ({ - isWalletModalOpen: state.isWalletModalOpen, - setWalletModalOpen: state.setWalletModalOpen, - })); diff --git a/src/layouts/AppHeader.tsx b/src/layouts/AppHeader.tsx index fbf7f6ebdb..ff758893f4 100644 --- a/src/layouts/AppHeader.tsx +++ b/src/layouts/AppHeader.tsx @@ -31,7 +31,6 @@ import { uiConfig } from '../uiConfig'; import { NavItems } from './components/NavItems'; import { MobileMenu } from './MobileMenu'; import { SettingsMenu } from './SettingsMenu'; -import WalletWidget from './WalletWidget'; interface Props { children: React.ReactElement; @@ -118,11 +117,6 @@ export function AppHeader() { const headerHeight = 48; - const toggleWalletWigit = (state: boolean) => { - if (md) setMobileDrawerOpen(state); - setWalletWidgetOpen(state); - }; - const toggleMobileMenu = (state: boolean) => { if (md) setMobileDrawerOpen(state); setMobileMenuOpen(state); diff --git a/src/layouts/WalletWidget.tsx b/src/layouts/WalletWidget.tsx deleted file mode 100644 index 5e562e89eb..0000000000 --- a/src/layouts/WalletWidget.tsx +++ /dev/null @@ -1,362 +0,0 @@ -import { DuplicateIcon } from '@heroicons/react/outline'; -import { ChevronDownIcon, ChevronUpIcon, ExternalLinkIcon } from '@heroicons/react/solid'; -import { Trans } from '@lingui/macro'; -import { - Box, - Button, - Divider, - List, - ListItem, - ListItemIcon, - ListItemText, - Menu, - MenuItem, - MenuList, - Skeleton, - SvgIcon, - Typography, - useMediaQuery, - useTheme, -} from '@mui/material'; -import React, { useState } from 'react'; -import { AvatarSize } from 'src/components/Avatar'; -import { CompactMode } from 'src/components/CompactableTypography'; -import { Warning } from 'src/components/primitives/Warning'; -import { UserDisplay } from 'src/components/UserDisplay'; -import { WalletModal } from 'src/components/WalletConnection/WalletModal'; -import { useWalletModalContext } from 'src/hooks/useWalletModal'; -import { useWeb3Context } from 'src/libs/hooks/useWeb3Context'; -import { useRootStore } from 'src/store/root'; -import { AUTH, GENERAL } from 'src/utils/mixPanelEvents'; - -import { Link } from '../components/primitives/Link'; -import { ENABLE_TESTNET, getNetworkConfig, STAGING_ENV } from '../utils/marketsAndNetworksConfig'; -import { DrawerWrapper } from './components/DrawerWrapper'; -import { MobileCloseButton } from './components/MobileCloseButton'; - -interface WalletWidgetProps { - open: boolean; - setOpen: (value: boolean) => void; - headerHeight: number; -} - -export default function WalletWidget({ open, setOpen, headerHeight }: WalletWidgetProps) { - const { currentAccount, connected, chainId, loading, readOnlyModeAddress } = useWeb3Context(); - - const { setWalletModalOpen } = useWalletModalContext(); - - const { breakpoints, palette } = useTheme(); - const xsm = useMediaQuery(breakpoints.down('xsm')); - const md = useMediaQuery(breakpoints.down('md')); - const trackEvent = useRootStore((store) => store.trackEvent); - - const [anchorEl, setAnchorEl] = useState(null); - - const networkConfig = getNetworkConfig(chainId); - let networkColor = ''; - if (networkConfig?.isFork) { - networkColor = '#ff4a8d'; - } else if (networkConfig?.isTestnet) { - networkColor = '#7157ff'; - } else { - networkColor = '#65c970'; - } - - const handleClose = () => { - setOpen(false); - }; - - const handleClick = (event: React.MouseEvent) => { - if (!connected) { - trackEvent(GENERAL.OPEN_MODAL, { modal: 'Connect Waller' }); - setWalletModalOpen(true); - } else { - setOpen(true); - setAnchorEl(event.currentTarget); - } - }; - - const handleDisconnect = () => { - if (connected) { - disconnectWallet(); - trackEvent(AUTH.DISCONNECT_WALLET); - handleClose(); - } - }; - - const handleCopy = async () => { - navigator.clipboard.writeText(currentAccount); - trackEvent(AUTH.COPY_ADDRESS); - handleClose(); - }; - - const handleSwitchWallet = (): void => { - setWalletModalOpen(true); - trackEvent(AUTH.SWITCH_WALLET); - handleClose(); - }; - - const handleViewOnExplorer = (): void => { - trackEvent(GENERAL.EXTERNAL_LINK, { Link: 'Etherscan for Wallet' }); - handleClose(); - }; - - const hideWalletAccountText = xsm && (ENABLE_TESTNET || STAGING_ENV || readOnlyModeAddress); - - const Content = ({ component = ListItem }: { component?: typeof MenuItem | typeof ListItem }) => ( - <> - - Account - - - - - - {readOnlyModeAddress && ( - - Read-only mode. - - )} - - - {!md && ( - - - - - )} - - - - - - - Network - - - - - - {networkConfig.name} - - - - - - - - - - - - - - Copy address - - - - {networkConfig?.explorerLinkBuilder && ( - - - - - - - - - View on Explorer - - - - )} - {md && ( - <> - - - - - - - )} - - ); - - return ( - <> - {md && connected && open ? ( - - ) : loading ? ( - - ) : ( - - )} - - {md ? ( - - - - - - ) : ( - - - - - - )} - - {/* */} - - ); -} diff --git a/src/libs/web3-data-provider/WalletOptions.ts b/src/libs/web3-data-provider/WalletOptions.ts deleted file mode 100644 index 26d1ef5566..0000000000 --- a/src/libs/web3-data-provider/WalletOptions.ts +++ /dev/null @@ -1,72 +0,0 @@ -import { Connector } from '@web3-react/types'; - -// import { LedgerHQFrameConnector } from 'web3-ledgerhq-frame-connector'; -import { coinbaseWallet } from './connectors/CoinbaseConnector'; -import { gnosisSafe } from './connectors/GnosisSafeConnector'; -import { metaMask } from './connectors/MetamaskConnector'; -import { readOnly } from './connectors/ReadOnlyConnector'; -import { walletConnect } from './connectors/WalletConnectConnector'; - -export enum WalletType { - INJECTED = 'injected', - WALLET_CONNECT = 'wallet_connect', - WALLET_LINK = 'wallet_link', - TORUS = 'torus', - FRAME = 'frame', - GNOSIS = 'gnosis', - LEDGER = 'ledger', - READ_ONLY_MODE = 'read_only_mode', - COINBASE_WALLET = 'coinbase_wallet', -} - -// const APP_NAME = 'Aave'; -// const APP_LOGO_URL = 'https://aave.com/favicon.ico'; - -export const getWallet = (wallet: WalletType): Connector => { - console.log('wallet', wallet); - switch (wallet) { - case WalletType.READ_ONLY_MODE: - return readOnly; - // case WalletType.LEDGER: - // return new LedgerHQFrameConnector({}); - case WalletType.INJECTED: - return metaMask; - case WalletType.COINBASE_WALLET: - return coinbaseWallet; - // case WalletType.WALLET_LINK: - // const networkConfig = getNetworkConfig(chainId); - // return new WalletLinkConnector({ - // appName: APP_NAME, - // appLogoUrl: APP_LOGO_URL, - // url: networkConfig.privateJsonRPCUrl || networkConfig.publicJsonRPCUrl[0], - // }); - case WalletType.WALLET_CONNECT: - return walletConnect; - case WalletType.GNOSIS: - if (window) { - return gnosisSafe; - } - throw new Error('Safe app not working'); - // case WalletType.TORUS: - // return new TorusConnector({ - // chainId, - // initOptions: { - // network: { - // host: chainId === ChainId.polygon ? 'matic' : chainId, - // }, - // showTorusButton: false, - // enableLogging: false, - // enabledVerifiers: false, - // }, - // }); - // case WalletType.FRAME: { - // if (chainId !== ChainId.mainnet) { - // throw new UnsupportedChainIdError(chainId, [1]); - // } - // return new FrameConnector({ supportedChainIds: [1] }); - // } - default: { - throw new Error(`unsupported wallet`); - } - } -}; diff --git a/src/libs/web3-data-provider/Web3Provider.tsx b/src/libs/web3-data-provider/Web3Provider.tsx index 5bf6520ed3..ea0cd8a6da 100644 --- a/src/libs/web3-data-provider/Web3Provider.tsx +++ b/src/libs/web3-data-provider/Web3Provider.tsx @@ -8,7 +8,6 @@ import { hexToAscii } from 'src/utils/utils'; import { UserRejectedRequestError } from 'viem'; import { useAccount, useConnect, useConnectorClient, useSwitchChain, useWatchAsset } from 'wagmi'; -// import { isLedgerDappBrowserProvider } from 'web3-ledgerhq-frame-connector'; import { Web3Context } from '../hooks/useWeb3Context'; import { clientToSigner, useEthersProvider } from './adapters/EthersAdapter'; @@ -38,31 +37,28 @@ export type Web3Data = { provider: JsonRpcProvider | undefined; }; -interface ConnectWalletOpts { - silently?: boolean; - address?: string | null; -} - let didConnect = false; export const Web3ContextProvider: React.FC<{ children: ReactElement }> = ({ children }) => { - // const { chainId: chainId, connector, provider, isActivating, isActive } = useWeb3React(); const { switchChainAsync } = useSwitchChain(); const { watchAssetAsync } = useWatchAsset(); - const { chainId, address, isConnected, isConnecting } = useAccount(); + const { chainId, address, isConnected, isConnecting, isReconnecting } = useAccount(); const { data: connectorClient } = useConnectorClient({ chainId }); const { connect, connectors } = useConnect(); + console.log('isConnected', isConnected); + console.log('isConnecting', isConnecting); + console.log('isReconnecting', isReconnecting); // const { sendTransaction } = useSendTransaction(); const provider = useEthersProvider({ chainId }); // const signer = useEthersSigner({ chainId }); const account = address; const [error, setError] = useState(); + console.log('TODO', setError); + const [switchNetworkError, setSwitchNetworkError] = useState(); const setAccount = useRootStore((store) => store.setAccount); - const setAccountLoading = useRootStore((store) => store.setAccountLoading); - const setWalletType = useRootStore((store) => store.setWalletType); useEffect(() => { // If running cypress tests, then we try to auto connect on app load @@ -77,91 +73,6 @@ export const Web3ContextProvider: React.FC<{ children: ReactElement }> = ({ chil didConnect = true; }); - // const disconnectWallet = useCallback(async () => { - // localStorage.removeItem('walletProvider'); - // localStorage.removeItem('readOnlyModeAddress'); - // connector.resetState(); - // if (connector.deactivate) { - // connector.deactivate(); - // } - // setWalletType(undefined); - // setSwitchNetworkError(undefined); - // }, [connector, setWalletType]); - - // connect to the wallet specified by wallet type - // const connectWallet = useCallback( - // async (wallet: WalletType, opts?: ConnectWalletOpts) => { - // try { - // const connector: Connector = getWallet(wallet); - // if (wallet === WalletType.READ_ONLY_MODE && opts?.address) { - // localStorage.setItem('readOnlyModeAddress', opts.address); - // } else { - // localStorage.removeItem('readOnlyModeAddress'); - // } - // await connector.activate(opts?.address); - // setSwitchNetworkError(undefined); - // setWalletType(wallet); - // localStorage.setItem('walletProvider', wallet.toString()); - // } catch (e) { - // if (!opts?.silently) { - // console.log('error on activation', e); - // setError(e); - // } - // localStorage.removeItem('readOnlyModeAddress'); - // localStorage.removeItem('walletProvider'); - // setWalletType(undefined); - // } - // }, - // [setWalletType] - // ); - - // handle logic to eagerly connect to the injected ethereum provider, - // if it exists and has granted access already - - // useEffect(() => { - // const tryAppWalletsSilently = async () => { - // await connectWallet(WalletType.GNOSIS, { silently: true }) - // .catch(async () => { - // // eslint-disable-next-line @typescript-eslint/no-explicit-any - // const provider = (window as any)?.ethereum; - - // if (provider && provider.isCoinbaseBrowser) { - // await connectWallet(WalletType.INJECTED); - // } else { - // // TODO check other providers? family - // throw new Error('No provider detected'); - // } - // }) - // .catch(); - // }; - // try { - // const lastWalletProvider = localStorage.getItem('walletProvider'); - // const lastReadOnlyAddress = localStorage.getItem('readOnlyModeAddress'); - // if (lastWalletProvider) { - // connectWallet(lastWalletProvider as WalletType, { - // address: lastReadOnlyAddress, - // silently: true, - // }); - // } else { - // tryAppWalletsSilently(); - // } - // } catch { - // localStorage.removeItem('walletProvider'); - // localStorage.removeItem('readOnlyModeAddress'); - // } - // }, [connectWallet]); - /* - // if the connection worked, wait until we get confirmation of that to flip the flag - useEffect(() => { - if (!tried && active) { - setTried(true); - } - }, [tried, active]); - - */ - - // Tx methods - // TODO: we use from instead of currentAccount because of the mock wallet. // If we used current account then the tx could get executed const sendTx = async ( @@ -263,7 +174,7 @@ export const Web3ContextProvider: React.FC<{ children: ReactElement }> = ({ chil value={{ web3ProviderData: { connected: isConnected, - loading: false, + loading: isConnecting && !isConnected, chainId: chainId || 1, switchNetwork, getTxError, diff --git a/src/libs/web3-data-provider/adapters/EthersAdapter.ts b/src/libs/web3-data-provider/adapters/EthersAdapter.ts index 55f5c9b366..5366c60b49 100644 --- a/src/libs/web3-data-provider/adapters/EthersAdapter.ts +++ b/src/libs/web3-data-provider/adapters/EthersAdapter.ts @@ -30,7 +30,9 @@ export function useEthersSigner({ chainId }: { chainId?: number } = {}) { } function getNetwork(chain: Chain) { - // if chain is undefined, it means that the client is connected to a chain that is not supported by the app + // If chain is undefined, it means that the client is connected to a chain that is not supported by the app. + // Just stub out the network so no errors are thrown, we show a message in the UI if they are not connected + // to the right network. const network = { chainId: chain?.id || -1, name: chain?.name || 'unknown', diff --git a/src/modules/bridge/BridgeWrapper.tsx b/src/modules/bridge/BridgeWrapper.tsx index 4c5a6cc0c4..65eb374f7a 100644 --- a/src/modules/bridge/BridgeWrapper.tsx +++ b/src/modules/bridge/BridgeWrapper.tsx @@ -20,7 +20,7 @@ import { } from './TransactionListItemLoader'; export function BridgeWrapper() { - const { currentAccount, loading: web3Loading } = useWeb3Context(); + const { currentAccount } = useWeb3Context(); const { openBridge } = useModalContext(); const theme = useTheme(); @@ -32,7 +32,6 @@ export function BridgeWrapper() { if (!currentAccount) { return ( Please connect your wallet to view transaction history.} /> ); diff --git a/src/modules/faucet/FaucetAssetsList.tsx b/src/modules/faucet/FaucetAssetsList.tsx index 7e2676cfc6..09092a15e0 100644 --- a/src/modules/faucet/FaucetAssetsList.tsx +++ b/src/modules/faucet/FaucetAssetsList.tsx @@ -49,7 +49,6 @@ export default function FaucetAssetsList() { if (!currentAccount || web3Loading) { return ( Please connect your wallet to get free testnet assets.} /> ); diff --git a/src/modules/history/HistoryWrapper.tsx b/src/modules/history/HistoryWrapper.tsx index c3c85332bf..1880a6a1b7 100644 --- a/src/modules/history/HistoryWrapper.tsx +++ b/src/modules/history/HistoryWrapper.tsx @@ -106,7 +106,7 @@ export const HistoryWrapper = () => { ); const theme = useTheme(); const downToMD = useMediaQuery(theme.breakpoints.down('md')); - const { currentAccount, loading: web3Loading } = useWeb3Context(); + const { currentAccount } = useWeb3Context(); const flatTxns = useMemo( () => transactions?.pages?.flatMap((page) => page) || [], @@ -141,7 +141,6 @@ export const HistoryWrapper = () => { if (!currentAccount) { return ( Please connect your wallet to view transaction history.} /> ); diff --git a/src/store/walletSlice.ts b/src/store/walletSlice.ts index 9943977334..b6a1d6c26e 100644 --- a/src/store/walletSlice.ts +++ b/src/store/walletSlice.ts @@ -1,4 +1,3 @@ -import { WalletType } from 'src/libs/web3-data-provider/WalletOptions'; import { StateCreator } from 'zustand'; import { RootStore } from './root'; @@ -10,11 +9,9 @@ export enum ApprovalMethod { export interface WalletSlice { account: string; - accountLoading: boolean; - walletType: WalletType | undefined; + walletType: string | undefined; setAccount: (account: string | undefined) => void; - setAccountLoading: (loading: boolean) => void; - setWalletType: (walletType: WalletType | undefined) => void; + setWalletType: (walletType: string | undefined) => void; isWalletModalOpen: boolean; setWalletModalOpen: (open: boolean) => void; walletApprovalMethodPreference: ApprovalMethod; @@ -48,9 +45,6 @@ export const createWalletSlice: StateCreator< const refresh = get().refreshWalletApprovalMethod; refresh(); }, - setAccountLoading(loading) { - set({ accountLoading: loading }); - }, isWalletModalOpen: false, setWalletModalOpen(open) { set({ isWalletModalOpen: open });