ContractKit Class

The ContractKit class provided by the Contract Kit is a factory class that facilitates the creation of Contract instances. Only one instance is required for each blockchain in the application and should be made widely available in the application.

Creation

When using the ContractKit within a web application, an instance of the class must first be created. The only required argument during the creation of the ContractKit is an instance of an APIClient, to allow it to make requests to the specified blockchain.

import { ContractKit } from "@wharfkit/contract"
import { APIClient } from "@wharfkit/antelope"

const contractKit = new ContractKit({
  client: new APIClient("https://jungle4.greymass.com"),
})

This instance of the ContractKit can now be used to generate any number of [Contract] instances for the specified blockchain.

Arguments

A single argument is required to initialize a ContractKit instance:

  • client: The APIClient used to fetch data from the blockchain.

Options

The ContractKit allows for additional optional parameters to be passed for more advanced use cases.

ABICache

An optional instance of the ABICache interface to manually specify an alternative cache. By default every instance of the ContractKit comes with a built-in ABICache, and this is only required for advanced use cases where overriding the default is required.

import { ContractKit } from "@wharfkit/contract"
import { APIClient, ABICache } from "@wharfkit/antelope"

const client = new APIClient("https://jungle4.greymass.com")

const kit = new ContractKit({
    client,
}, {
    abiCache: new ABICache(client)
});

ABIs

An array of existing ABI objects that have already been loaded in the application. This option can be used to pass ABIs directly to the ContractKit instance, eliminating the need for the ContractKit to fetch them using an APIClient.

import { ContractKit } from "@wharfkit/contract"
import { APIClient } from "@wharfkit/antelope"

import abi from "./abi.json" // ABI for a contract that will be loaded

const kit = new ContractKit({
    client,
}, {
    abis: [abi]
});

Usage

Load

Once a ContractKit instance is created, the load method can be used to instantiate a specific Contract instance.

const contract = await contractKit.load("eosio.token")

The only parameter required is the name of the account where the contract is deployed on-chain.