yarn add @depay/web3-wallets
or
npm install --save @depay/web3-wallets
import { getWallets } from '@depay/web3-wallets'
let wallets = getWallets()
let wallet = wallets[0]
wallet.name // MetaMask
await wallet.connect() // 0x317D875cA3B9f8d14f960486C0d1D1913be74e90
https://depayfi.github.io/web3-wallets/demo.html
This library supports the following blockchains:
This library supports the following wallets:
100+ different wallets via WalletConnect, such as:
- Trust Wallet
- DeFi Wallet by crypto.com
- 1inch Wallet
- imToken Wallet
- TokenPocket
- Pillar
- Math Wallet
- Ledger Live
- Argent Wallet
- AlphaWallet
- Unstoppable Wallet
- Atomic Wallet
- Rainbow
- and more...
In case you want to use and package only specific platforms, use platform-specific packages:
import { getWallets } from '@depay/web3-wallets-evm'
getWallets
: Returns an array of available/connectable wallets.
let wallets = getWallets();
// [<Wallet name='MetaMask'>, <Wallet name='Phantom'>]
let wallets = getWallets();
// [] no wallets detected. (you can still try WalletConnect or WalletLink)
{ getWallets, wallets } from "@depay/web3-wallets"
let foundWallets = getWallets()
let wallet
if(foundWallets.length == 1) {
wallet = foundWallets[0]
} else if(foundWallets.length > 1) {
wallet = foundWallets[parseInt(prompt('Which wallet do you want to connect?'), 10)]
} else {
// Let the user choose:
// you can still try to connect via wallets.WalletConnect.connect()
// or wallets.WalletLink.connect()
wallet = wallets.WalletLink
}
getConnectedWallets
: Returns an array of currently connected wallets.
let wallets = await getConnectedWallets();
// [<Wallet name='MetaMask'>, <Wallet name='Phantom'>]
name:string
: Returns the name of the wallet.
wallet.name // 'MetaMask'
logo:string
: Returns the logo of the wallet as PNG base64-encoded.
wallet.logo // ''
async account():string
: Gets the currently connected and active account (without prompting a connect screen). Returns undefined
if no account is connected.
await wallet.account() // '0xAb5801a7D398351b8bE11C439e05C5B3259aeC9B'
async connect():string
: Connects account. Potentially opens wallet connect screen. Provides connected account in async return. If wallet fails to connect, it returns undefined
.
await wallet.connect() // '0xAb5801a7D398351b8bE11C439e05C5B3259aeC9B'
blockchains:Array
: Array containing the names of supported blockchains
wallet.name // MetaMask
wallet.blockchains // ['ethereum', 'bsc', 'polygon']
async connectedTo(blockchain):Boolean
: Checks if wallet is connected to a specific blockchain.
await wallet.connectedTo('ethereum') // true
If no param is given it well tell you to which blockchain the wallet is connected to:
await wallet.connectedTo() // 'bsc'
on(string, function):undefined
: Register a callback function for given events.
wallet.on('account', (newAccount)=>{
doSomething(newAccount)
})
on('account', (newAccount)=>{})
: Triggers when user changes the connected/active wallet account.
.on
returns a callback function that needs to be passed to .off
if you want to deregister the event listener:
let callback = wallet.on('account', (newAccount)=>{
doSomething(newAccount)
})
//...
wallet.off('account', callback) // removes listener
async switchTo(blockchain)
: Changes wallet connection to a specific network (adds it to the wallet in case it's missing)
await wallet.switchTo('bsc')
Available arguments for EVM blockchains:
blockchain: String
: Name of the blockchain e.g. 'ethereum'.
to String
: Address of the contract to be transacted with.
api: Array
: Api of the contract (e.g. abi for Ethereum).
method: String
: Name of the contract method to be called.
params: Object or Array
: Parameters passed to the method.
value: Number or BigNumber as String
: Value of the transaction (amount of the native blockchain currency sent along with the transaction).
sent: Function (transaction)=>{}
: Callback to be executed if transaction has been sent to the network.
succeeded: Function (transaction)=>{}
: Callback to be executed if transaction was successful and has been confirmed once by the network.
failed: Function (transaction, error)=>{}
: Callback to be executed if transaction failed (e.g. reverted).
e.g. sending 0.01 ETH on Ethereum:
let sentTransaction = await wallet.sendTransaction({
blockchain: 'ethereum',
to: '0xae60aC8e69414C2Dc362D0e6a03af643d1D85b92',
value: 0.01,
sent: function(transaction){},
succeeded: function(transaction){},
failed: function(transaction, error){}
})
let sentTransaction = await wallet.sendTransaction({
blockchain: 'ethereum',
to: '0xae60aC8e69414C2Dc362D0e6a03af643d1D85b92',
api: [{"inputs":[{"internalType":"address","name":"_configuration","type":"address"}],"stateMutability":"nonpayable","type":"constructor"},{"inputs":[],"name":"ETH","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"configuration","outputs":[{"internalType":"contract DePayRouterV1Configuration","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"pluginAddress","type":"address"}],"name":"isApproved","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address[]","name":"path","type":"address[]"},{"internalType":"uint256[]","name":"amounts","type":"uint256[]"},{"internalType":"address[]","name":"addresses","type":"address[]"},{"internalType":"address[]","name":"plugins","type":"address[]"},{"internalType":"string[]","name":"data","type":"string[]"}],"name":"route","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"payable","type":"function"},{"inputs":[{"internalType":"address","name":"token","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"withdraw","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"stateMutability":"payable","type":"receive"}],
method: 'route',
params: {
path: ["0xb056c38f6b7Dc4064367403E26424CD2c60655e1","0xC02aaA39b223FE8D0A0e5C4F27eAD9083C756Cc2","0xa0bEd124a09ac2Bd941b10349d8d224fe3c955eb"],
amounts: ["11275067000000000000000","100000000000000000000", "1632063302"],
addresses: ["0x39794c3171d4D82eB9C6FBb764749Eb7ED92881d", "0x39794c3171d4D82eB9C6FBb764749Eb7ED92881d"],
plugins: ["0xe04b08Dfc6CaA0F4Ec523a3Ae283Ece7efE00019", "0x99F3F4685a7178F26EB4F4Ca8B75a1724F1577B9"],
data: []
},
value: "0",
sent: function(transaction){},
succeeded: function(transaction){},
failed: function(transaction, error){}
})
Available arguments for Solana blockchains:
blockchain: String
: Name of the blockchain e.g. 'solana'.
sent: Function (transaction)=>{}
: Callback to be executed if transaction has been sent to the network.
succeeded: Function (transaction)=>{}
: Callback to be executed if transaction was successful and has been confirmed once by the network.
failed: Function (transaction, error)=>{}
: Callback to be executed if transaction failed (e.g. reverted).
e.g. send 0.01 SOL on Solana:
to String
: Address of the receiver.
value: Number or BigNumber as String
: Value of the transaction (only needed for simple SOL transfers).
let sentTransaction = await wallet.sendTransaction({
blockchain: 'solana',
to: '2UgCJaHU5y8NC4uWQcZYeV9a5RyYLF7iKYCybCsdFFD1',
value: 0.01,
sent: function(transaction){},
succeeded: function(transaction){},
failed: function(transaction, error){}
})
instructions Array
: A set of TransactionInstructions
e.g. Send 1 USDC:
import { Token } from '@depay/web3-tokens'
let sentTransaction = await wallet.sendTransaction({
blockchain: 'solana',
instructions: [
await Token.solana.createTransferInstructions({
token: 'EPjFWdd5AufqSSqeM2qN1xzybapC8G4wEGGkZwyTDt1v',
amount: '1000000',
from: await wallet.account(),
to: '5AcFMJZkXo14r3Hj99iYd1HScPiM4hAcLZf552DfZkxas'
})
],
sent: function(transaction){},
succeeded: function(transaction){},
failed: function(transaction, error){}
})
If value is passed as a number it's gonna be converted into a big number applying the individual blockhain's default decimals:
let transaction = new Transaction({
...,
value: 1
})
transaction.value // '1000000000000000000'
If value is passed as a string or as a BigNumber, value is used just as provided:
let transaction = new Transaction({
...,
value: '1000000000000000000'
})
transaction.value // '1000000000000000000'
sendTransaction
rejects with:
{ code: 'WRONG_NETWORK' }
in case wallet is connected to the wrong network and network cant be switched automatically.
let signature = await wallet.sign("This is a message to be signed")
yarn install
yarn dev
npm publish