Skip to main content

useScaffoldEventSubscriber

Use this hook to subscribe to events emitted by your smart contract, and receive real-time updates when these events are emitted.

useScaffoldEventSubscriber({
contractName: "YourContract",
eventName: "GreetingChange",
// The listener function is called whenever a GreetingChange event is emitted by the contract.
// Parameters emitted by the event can be destructed using the below example
// for this example: event GreetingChange(address greetingSetter, string newGreeting, bool premium, uint256 value);
listener: logs => {
logs.map(log => {
const { greetingSetter, value, premium, newGreeting } = log.args;
console.log("📡 GreetingChange event", greetingSetter, value, premium, newGreeting);
});
},
});

This example subscribes to the GreetingChange event emitted by the YourContract smart contract and logs the parameters from the event to the console when it's emitted. The listener function accepts an array of logs that occurred during the pollingInterval (set at scaffold.config.ts) and each array items contains an args property which can be destructured to get the parameters emitted by the event, this function can customized according to your needs.

This hook is a wrap for useContractEvent wagmi hook.

note

It is recommended to setState using updater function in listener function to avoid problems due to caching.