Sending Transactions with Stacks.js

Any Stacks dapp is going to require sending transactions at some point, so how do we do that? We use the @stacks/transactions package.

Again, this particular snippet is pulled from our Hello Stacks tutorial.

But first, you'll need to install the right NPM package.

Install
yarn add @stacks/transactions

Stacks.js Frontend Code

Assuming you are authenticated, you'll need to import from the network package to connect and import the right Clarity values to convert.

You need to convert values from JS into the right format for Clarity values to ingest. You can view the complete list of types on the Stacks.js docs: https://stacks.js.org/modules/_stacks_transactions#constructing-clarity-values

Imports
import { StacksMocknet } from "@stacks/network";
import { stringUtf8CV } from "@stacks/transactions";

Let's assume we have a message that we need to send.

Hello this is something I need to say.
Submitting a contract call
const submitMessage = async (e) => {
  e.preventDefault();

  const network = new StacksMocknet();

  const options = {
    contractAddress: "ST1PQHQKV0RJXZFY1DGX8MNSNYVE3VGZJSRTPGZGM",
    contractName: "hello-stacks",
    functionName: "write-message",
    functionArgs: [stringUtf8CV(message)],
    network,
    appDetails,
    onFinish: ({ txId }) => console.log(txId),
  };

  await openContractCall(options);
};

For more details on the different types of transactions you can send, the Stacks.js docs have multiple examples: https://stacks.js.org/modules/_stacks_transactions

Was this helpful?