import { Dialog, Transition } from '@headlessui/react' import Image from 'next/image' import { Fragment, useState } from 'react' import { toast } from 'react-toastify' import useWalletStore from 'stores/useWalletStore' import { Wallet } from 'types' import { getInjectiveAddress } from 'utils/address' import { chain } from 'utils/chains' import { getExperimentalChainConfigBasedOnChainId } from 'utils/experimental-chains' type Props = { isOpen: boolean onClose: () => void } const ConnectModal = ({ isOpen, onClose }: Props) => { const [isLoading, setIsLoading] = useState(false) const actions = useWalletStore((s) => s.actions) const metamaskInstalled = useWalletStore((s) => s.metamaskInstalled) const isKeplrInstalled = typeof window !== 'undefined' && window.keplr const handleConnectSuccess = () => { onClose() // defering update on loading state to avoid updating before close animation is finished setTimeout(() => { setIsLoading(false) }, 500) } const handleConnectKeplr = async () => { if (!window.keplr) { toast.error('You need Keplr extension installed') return } setIsLoading(true) try { const chainData = getExperimentalChainConfigBasedOnChainId(chain.chainId) if (chainData) { await window.keplr.experimentalSuggestChain(chainData) } const key = await window.keplr.getKey(chain.chainId) actions.connect(key.bech32Address, Wallet.Keplr) handleConnectSuccess() } catch (e) { // TODO: handle exception console.log(e) setIsLoading(false) } } const handleConnectMetamask = async () => { if (!metamaskInstalled) { toast.error('You need Metamask extension installed') return } setIsLoading(true) try { // TODO: missing type definitions const addresses = await (window.ethereum as any).request({ method: 'eth_requestAccounts', }) const [address] = addresses actions.connect(getInjectiveAddress(address), Wallet.Metamask) handleConnectSuccess() } catch (e) { // TODO: handle exception console.log(e) setIsLoading(false) } } return (
Connect your wallet {isLoading ? (
Loading...
) : (
)}
) } export default ConnectModal