AMFI Connect Wallet
This package provides the ability to connect wallets to website or application via MetaMask extension (through a browser or the mobile application), WalletConnect service using QR code scanner, CoinbaseWallet extension and KardiaChain.
Features
- Connect to any blockchains.
- Add Contracts by providing Contract address and ABI code.
- Work with Contracts methods.
- Check transactions in blockchain.
- Add custom blockhain.
Usage
1. Install package.
Via NPM
npm install @amfi/connect-wallet
Via Yarn
yarn add @amfi/connect-wallet
2. Import and initialize ConnectWallet in project.
import { ConnectWallet } from '@amfi/connect-wallet';
const connectWallet = new ConnectWallet();
3. Add custom blockchain.
If you need to add custom blockhain use addChains(...chain)
method before you create connect.
Usage example:
const chains: IChain[] = [
...
{
name: 'binance',
chainID: 56,
hex: '0x38',
},
{
name: 'binance-test',
chainID: 97,
hex: '0x61',
},
...
];
connectWallet.addChains(this.chains);
4. Create configuration for Connect Wallet
Method connect(provider, network, settings)
.
Example configuration:
Want use Ethereum mainnet?
Set useProvider: infura
and provide mainnet Infura.
Remove rpc if it needed.
const config = {
wallets: ['MetaMask', 'WalletConnect', 'CoinbaseWallet', 'KardiaChain'],
network: {
name: 'Ropsten',
chainID: 3,
},
provider: {
MetaMask: {
name: 'MetaMask',
},
CoinbaseWallet: {
name: 'CoinbaseWallet',
},
KardiaChain: {
name: 'KardiaChain',
},
WalletConnect: {
name: 'WalletConnect',
useProvider: 'rpc',
provider: {
infura: {
infuraID: 'PASS_HERE_INFURA_ID',
},
rpc: {
rpc: {
3: 'https://ropsten.infura.io/v3/PASS_HERE_BLOCKCHAIN_RPC',
56: 'https://bsc-dataseed.binance.org/',
},
chainId: 3,
},
},
},
},
settings: {
providerType: true,
},
};
connectWallet.connect(config);
RPC configuration:
rpc: {
rpc: {
[BLOCKCHAIN_NUMBER]: "BLOCKCHAIN_RPC",
[BLOCKCHAIN_NUMBER]: "BLOCKCHAIN_RPC",
...
[BLOCKCHAIN_NUMBER]: "BLOCKCHAIN_RPC"
},
chainId: BLOCKCHAIN_NUMBER
},
5. Pass configuration to ConnectWallet.
You need to pass 3 configuration options: provider, network, settings in connect()
method.
Provider
For MetaMask:
{
name: string;
}
For Wallet Connect:
{
name: string;
useProvider?: string;
provider?: {
infura?: {
infuraID?: string;
}
rpc?: {
rpc: {
[index: number]: string;
};
chainId?: number;
};
};
}
Network
{
name: string;
chainID: number;
}
Settings
{
providerType?: boolean;
}
Pass configuration
connectWallet.connect(provider, network, settings).then(
(connected: boolean) => console.log('connect wallet: ', connected),
(err: any) => console.log('connect wallet error: ', err)
);
6. If connect established add contracts in Connect Wallet.
Need to use 3 parameters in the addContract
: ContractName, address, abi.
interface:
{
name: string;
address: string;
abi: Array<any>;
}
connectWallet.addContract({'Staking1', '0x000...', ABI[]}).then((i) => {},(err) => {});
connectWallet.addContract({'Staking2', '0x000...', ABI[]}).then((i) => {},(err) => {});
connectWallet.addContract({'Token', '0x000...', ABI[]}).then((i) => {},(err) => {});
7. Use Contracts.
To use contracr methods use method contract(CONTRACT_NAME)
.
CONTRACT_NAME
- pass your contact name that was added in step 5.
const start = connectWallet
.contract('Staking1')
.stakeStart('123')
.send({ from: '0x000...' })
.then((tx: any) => console.log(tx));
const end = connectWallet
.contract('Staking2')
.stakeEnd('123')
.send({ from: '0x000...' })
.then((tx: any) => console.log(tx));
const balance = connectWallet
.contract('Token')
.methods.balanceOf('0x000...')
.call()
.then(
(balance: string) => console.log(balance),
(err: any) => console.log(err)
);
8. Get account and provider.
When the Connect established, you can get information about the account of the user wallet using the getaccounts ()
method.
connectWallet.getAccounts().then(
(user: any) => console.log('account: ', user),
(err: any) => console.log('error: ', err)
);
9. Check transaction.
Provide transaction Hash to txCheck()
method for check if transaction are in blockchain or not.
connectWallet.txCheck('TX_HASH').then(
(info: any) => console.log('info: ', info),
(err: any) => console.log('tx error:', err)
);
10. Get current Web3.
Get current Web3 and access to all Web3 functions via currentWeb3()
method.
const currentWeb3 = connectWallet.currentWeb3();
11. Subscribe on events.
Subscribe to events from current connection: connect, disconnect, chain change, account change and etc.
connectWallet.eventSubscriber().subscribe(
(event: IEvent) => console.log('event from subscribe', event),
(err: IEventError) => console.log('event error', err)
);