Sending USDC, or other ERC-20 tokens, is one of the most common actions taken by wallet users on Ethereum-based chains. This guide will walk you through how to format the transaction input data for these tokens, using USDC as an example.

1. Get the USDC contract address

To send USDC, you’ll need the contract address for USDC. The address is different for each network, so make sure you get the correct address for the network you’re targeting. You can go to Circle’s website to look up the USDC address on both main networks and test networks.

2. Format the transaction send input data

USDC, and other ERC-20 tokens, are smart contracts. In order to send these tokens, your transaction needs to call the transfer function on the contract, which takes in two parameters:

  • to: The address of the recipient
  • value: The amount of tokens to send

When formatting the transaction input data, you must define the expected interface of the function you’re calling by providing an ABI. You can use helper packages like viem to provide the ABI and encode the function parameters.

Additionally, each ERC-20 token defines a decimals value, which is the number of decimal places for the token. For USDC, the decimals value is usually 6, but for most other ERC-20 tokens, it’s 18.

import {encodeFunctionData, erc20Abi} from 'viem';

const recipientAddress = '0x...';
const amountToSend = 1; // Sender wants to send 1 USDC
const decimals = 6; // USDC has 6 decimals

const encodedData = encodeFunctionData({
  abi: erc20Abi,
  functionName: 'transfer',
  args: [recipientAddress, amountToSend * 10 ** decimals]
});

3. Send the transaction

You can send the transaction using the Privy API. Below are examples for React, React Native, and NodeJS; you can find other SDKs’ send transaction examples in the Send a transaction guide.

import { useSendTransaction } from '@privy-io/react-auth';
const { sendTransaction } = useSendTransaction();

const { hash } = await sendTransaction({
to: usdcContractAddress,
data: encodedData, // from the previous step
chainId: 8453, // Base's chainId
})

You’ve successfully sent USDC!