useWallet() allows dapp users to connect to the provider of their choice in a way that is as straightforward as possible. It provides a common data structure for any connected account, no matter what provider has been chosen by the user. It aims to provide some features that are often reimplemented by dapp developers: connecting to a wallet, keeping track of transactions, and more (submit a issue or PR!).
- All-in-one solution to connect to Ethereum providers.
- Completely library agnostic (use Web3.js, ethers.js, …).
- Provides the current balance.
- Keeps track of the recent transactions (coming soon).
Oh yes:
- React only.
- Ethereum only (for now).
- Supports one network at a time.
- Embeds as many providers as possible.
- Every prop and parameter is optional.
- An Ethereum wallet implementation.
- A low-level, fully configurable connection system for Ethereum providers (see web3-react if you are after that).
- An general library to interact with Ethereum (see ethers.js, Web3.js, etc.).
- Aragon client
- Aragon's Court Dashboard
- (Your project!)
Add it to your project:
yarn add use-wallet
Use it in your React app:
// App.js
import React from 'react'
import { useWallet, UseWalletProvider } from 'use-wallet'
function App() {
const wallet = useWallet()
const blockNumber = wallet.getBlockNumber()
return (
<>
<h1>Wallet</h1>
{wallet.connected ? (
<div>
<div>Account: {wallet.account}</div>
<div>Balance: {wallet.balance}</div>
<button onClick={() => wallet.deactivate()}>disconnect</button>
</div>
) : (
<div>
Connect:
<button onClick={() => wallet.activate()}>MetaMask</button>
<button onClick={() => wallet.activate('frame')}>Frame</button>
<button onClick={() => wallet.activate('portis')}>Portis</button>
</div>
)}
</>
)
}
// Wrap everything in <UseWalletProvider />
export default () => (
<UseWalletProvider
chainId={1}
connectors={{
// This is how connectors get configured
portis: { dAppId: 'my-dapp-id-123-xyz' },
}}
>
<App />
</UseWalletProvider>
)
This is the provider component. It should be placed above any component using useWallet()
. Apart from children
, it accepts two other props:
The Chain ID supported by the connection. Defaults to 1.
Configuration for the different connectors. If you use a connector that requires a configuration but do not provide one, an error will be thrown.
injected
: no configuration needed.frame
: no configuration needed.fortmatic
:{ apiKey }
portis
:{ dAppId }
provided
:{ provider }
authereum
: no configuration needed.squarelink
:{ clientId, options }
walletconnect
:{ rpcUrl }
walletlink
:{ url, appName, appLogoUrl }
See the web3-react documentation for more details.
This is the hook to be used throughout the app.
It takes an optional object as a single param, containing the following:
pollBalanceInterval
: the interval used to poll the wallet balance. Defaults to 2000.pollBlockNumberInterval
: the interval used to poll the block number. Defaults to 5000.
It returns an object representing the connected account (“wallet”), containing:
account
: the address of the account, ornull
when disconnected.activate(connectorId)
: call this function with a connector ID to “connect” to a provider (see above for the connectors provided by default).activated
: which provider is currently activated.null
otherwise.activating
: which provider is currently waiting to be activated.null
otherwise.balance
: the balance of the account, in wei.getBlockNumber()
: this function returns the current block number. This is a function because the block number updates often, which could triggers as many extra renders. Making an explicit call for the block number allows users ofuseWallet()
to avoid extra renders when the block number is not needed.connected
: whether the account is connected or not (same as testingaccount !== null
).connectors
: the full list of connectors.deactivate()
: call this function to “disconnect” from the current provider.ethereum
: the connected Ethereum provider.isContract
: whether or not the account is a contract.networkName
: a human-readable name corresponding to the Chain ID.
useWallet() is a built on web3-react and its connectors, which are doing all the hard work internally.