From 3cf1570d99c274cc604e34f2a3229d17332a1ba0 Mon Sep 17 00:00:00 2001 From: Jordan Ribbink <17958158+jribbink@users.noreply.github.com> Date: Wed, 2 Oct 2024 14:17:46 -0700 Subject: [PATCH] Add timeout for mobile WalletConnect URI pre-loader (#268) --- components/views/WalletSelection.tsx | 21 ++++++++++++++++++++- 1 file changed, 20 insertions(+), 1 deletion(-) diff --git a/components/views/WalletSelection.tsx b/components/views/WalletSelection.tsx index ac3de90..82fd6f9 100644 --- a/components/views/WalletSelection.tsx +++ b/components/views/WalletSelection.tsx @@ -8,6 +8,7 @@ import { useWallets } from '../../hooks/useWallets' import { DeviceType } from '../../helpers/device' import { ViewContainer } from '../layout/ViewContainer' import { useRpc } from '../../contexts/FclContext' +import { useEffect, useState } from 'react' type Props = { onSelectWallet: (wallet: Wallet) => void @@ -68,8 +69,26 @@ const MobileWrapper = ({ const { rpcEnabled } = useRpc() const shouldShowLoading = (wcUriLoading && rpcEnabled) || isLoading + // If the WC URI is still loading after 5 seconds, there is likely an issue + // with WalletConnect. The loading spinner will be disabled in order to prevent + // blocking the entire page. If the user proceeds to a mobile wallet and the WC URI + // happens to load, deep linking may not work as expected, but the user can still + // manually retry the connection. + const [isTimedOut, setIsTimedOut] = useState(false) + useEffect(() => { + if (!wcUriLoading) { + return + } + const timeout = setTimeout(() => { + setIsTimedOut(true) + }, 5000) + return () => clearTimeout(timeout) + }, [wcUriLoading]) + return ( - {children} + + {children} + ) }