Utilities
You can use the utilities to work with networks that the SDK supports:
import { Network } from '@holyheld/sdk';
holyheldSDK.getAvailableNetworks(); // ['ethereum', 'polygon', ...]
holyheldSDK.getNetworkChainId(Network.ethereum); // 1
holyheldSDK.getNetwork(Network.ethereum); // NetworkInfo
holyheldSDK.getNetworkByChainId(1); // NetworkInfo
(async () => {
// estimate transaction price (supports estimation only for native tokens used for gas fees)
const value = await holyheldSDK.offRamp.getTopUpEstimation(
publicClient, // create public client. https://viem.sh/docs/clients/public.html
Network.ethereum,
'5.25', // token amount
'0x...', // wallet address
true, // true if connected wallet supportsSignTypedDataV4 (for more human friendly signature request)
);
console.log(value); // '287499997500000' (in WEI)
})();
Types:
type Token = {
// smart contract address of the token
address: string;
// token decimal digits (as in ERC20 implementation)
decimals: number;
// token symbol
symbol: string;
// network (blockchain), on which this token resides
network: Network;
// name of the token
name: string;
// logo (picture) for the token
iconURL: string;
};
type NetworkInfo = {
network: Network;
// name of the blockchain network
name: string; // example: 'Polygon Mainnet'
// chainId of the corresponding network
chainId: number; // example: 137
// block explorer URL of corresponding network
explorerURL: string; // example: 'https://polygonscan.com'
// block explorer name (e.g. to display user friendly link 'view on X')
explorerName: string; // example: 'Polygonscan'
// base asset (native/gas token) of the network
baseAsset: Token;
// RPC URLs array (array supported for redundancy purposes)
rpcUrls: string[]; // example: ['https://polygon-rpc.com/'']
// logo (picture) for the network, displayed near token logo to identify on which network the token is on
iconURL: string; // example: 'data:image/png;base64,...'
// name of the network to display
displayedName: string; // example: 'Polygon'
// id for sorting
orderIdx: number; // example: 1
};