useTransactor
Use this hook to interact with the chain and give UI feedback on the transaction status.

Any error will instead show a popup with nice error message.

const transactor = useTransactor();
const writeTx = transactor({
  to: "0x97843608a00e2bbc75ab0C1911387E002565DEDE", // address of buidlguidl.eth
  value: 1000000000000000000n,
});
await writeTx();
This example tries to send 1 ETH to the address buidlguidl.eth, prompting the connected WalletClient for a signature. And in the case of a successful transaction, it will show a popup in the UI with the message: "π Transaction completed successfully!".
You can pass in anything that is a valid parameter to Viem's sendTransaction function to callback function. It also possible to pass it an promise that resolves in with a transaction hash for example promise from Wagmi's writeContractAsync function.
Refer to this recipe for a more detailed example.
Configurationβ
useTransactorβ
| Parameter | Type | Description | 
|---|---|---|
| _walletClient (optional) | WalletClient | The wallet client that should sign the transaction. Defaults to the connected wallet client, and is only needed if the transaction is not already sent using writeContractAsync | 
callback functionβ
| Parameter | Type | Description | 
|---|---|---|
| tx | sendTransaction-parameters orPromise<Hash> | Either valid parameters for sendTransaction-parameters or a promise that resolves with the transaction hash, e.g. Wagmi'swriteContractAsyncfunction. | 
| options (optional) | object | Additional options for the confirmation. | 
| ββoptions.blockConfirmations (optional) | number | The number of block confirmations to wait for before resolving. Defaults to 1. | 
| ββoptions.onBlockConfirmation (optional) | function | A callback function that is called once all blockConfirmationsis reached. | 
Return Valuesβ
useTransactorβ
- The callback function that is used to initialize the UI feedback flow.
callback functionβ
- A promise that resolves with the transaction hash once the transaction is mined.