Web3modal - easily connect any wallet with your dApp

Hi,

I am one of the maintainers of Web3modal. It is a project that allows you easily to connect any wallet with your web3.js project.

image

There are five categories of Ethereum wallets that can interact with dApps

  • Browser built-in (Opera, Brave, …)
  • Browser extension (MetaMask, …)
  • Mobile wallets (Trust, Walleth, Pillar, …)
  • Account-based web wallets (Fortmatic, 3box, …)
  • Hardware wallets (Ledger, Trezor, …)

Different wallets have a different user experience to connect. For example, with MetaMask you get a Connect pop up. With mobile wallets, you scan a QR code.

See the repo

We recently added a vanilla JavaScript example how to use it:

5 Likes

Hi @miohtama,

Thanks for sharing Web3Modal :pray:

I had a play with the test site and connecting MetaMask.

A post was split to a new topic: Transfer using vanilla JavaScript

I think it's not working with walletconnect provider.
every contract interaction remains stuck pending in await (not resolving).
What's the problem?

If every contract interaction stuck in pending, it is using your Ethereum node underlying node for JSON-RPC calls. Probably an issue with your node.

To give an exact answer though, a full repeatable, self-contained code example would be required.

Here is a list of free and commercial node providers: https://ethereumnodes.com/

Thank you for the reply.
I'm using infura for rinkeby as mentioned in instructions.
When I tap on button "approve" in example (to approve dai for my application) into my react app, I see correctly the approval form on my metamask app (on android). When I confirm approve on metamask app, I wait for the message of confirmation in my metamask app, when I see message, I expect my app to go ahead (my app works perfectly with metamask chrome extension using web3modal), but it doesnt. Do you still need code or can you help me with this informations?

and more. If I tap on "reject" I see correctly the error message. So the problem is in resolving with success the transaction.
I send

await dai.methods.approve(icoquantix_address,amnt).send({from:address,type:type});

any answer for me? :wink:

How to connect with TrustWallet?

1 Like

Hi, I am not able to open the dialo on mobile. Can you please assist:

init = async () => {
    try {
      const providerOptions = {
        injected: {
          display: {
            logo: '',
            name: 'Metamask',
            description: 'Connect with the provider in your Browser',
          },
          package: null,
        },
        walletconnect: {
          display: {
            logo: '',
            name: 'Mobile',
            description: 'Scan qrcode with your mobile wallet',
          },
          package: WalletConnectProvider,
          options: {
            rpc: {
              56: 'https://bsc-dataseed.binance.org/',
            },
            network: 'binance',
            chainId: 56,
          },
        },
      };

      const web3Modal = new Web3Modal({
        network: 'binance', // optional
        cacheProvider: true, // optional
        providerOptions, // required
      });

      this.setState({
        web3Modal,
      });
    } catch (err: any) {
      console.log(err);
    }
  };

  connectToWeb3 = async () => {
    const provider = await this.state.web3Modal.connect();
    const web3 = new Web3(provider);

    localStorage.setItem('WEB3_CONNECTED', 'true');

    this.setState({
      web3,
      provider,
    });
    await this.loadBlockchainData();
    await this.getLiquidityOwner(this.state.tokenAData, this.state.tokenBData);
  };

have you found a fix for this? I am having the same issue. userOptions in the web3modal object contains all the options on desktop, but only metamask on mobile.

The library is garbage. Use web3-react.

@miohtama I tried https://web3modal.com using Brave Browser mobile app but couldn't connect. Is it meant to work?

I can't open multiple wallets using vanilla javaScript its showing by defualte only one