@vechain/dapp-kit
The Vechain DApp Kit serves as a sophisticated layer built upon @vechain/connex, providing a simplified and efficient avenue for engaging with a multitude of Vechain wallets. This innovative toolkit enhances the ease of interaction, offering developers a seamless bridge to connect with diverse Vechain wallet functionalities. For more information, please refer to the official Vechain Docs
Installation
yarn add @vechain/dapp-kit
- Optional: Configure wallet connect options
import type { WalletConnectOptions } from '@vechain/dapp-kit';
const walletConnectOptions: WalletConnectOptions = {
projectId: '<PROJECT_ID>',
metadata: {
name: 'My dApp',
description: 'My dApp description',
url: window.location.origin,
icons: [`${window.location.origin}/images/my-dapp-icon.png`],
},
};
- Create a new instance of
DAppKit
and pass in the options thor
will be ready to use to interact with the chain, but calling any methods requiring a wallet will throw an
error. See the next step to finalise the setup.
import { DAppKit } from '@vechain/dapp-kit';
const { thor, vendor, wallet } = new DAppKit({
nodeUrl: 'https://sync-testnet.vechain.org/',
genesis: 'main',
walletConnectOptions,
});
- You can set the wallet source when the user selects a wallet, or if you want to default to a specific wallet.
- Connex is ready to use as normal
import type { WalletSource } from '@vechain/dapp-kit';
const mySource: WalletSource = 'veworld';
wallet.setSource('veworld');
- Connect to the wallet. This will return the user's address
verified
indicates whether a certificate is signed by the user. If a sign in is required and the account is not
verified, you should request a subsequent certificate sign in
const {account, verified} = await wallet.connect();
const tx = await thor.account("0x...123")
.method(...)
.transact()
.signer(account)
.request();
const certRes = await vendor.sign("cert", {...})
.requset();