The Headless Checkout multiple line items feature is used to build more elaborate purchase experiences, which require multiple NFT purchases at once. Multiple line items is currently only supported for NFTs.
Currently, there is a maximum limit of 15 NFTs per order.
- A marketplace where a buyer can add multiple NFTs to a cart and make the purchase in a single transaction.
- Enabling the purchase of multiple distinct tokens from an ERC-1155 contract in a single transaction.
Marketplace Sales
The following example requires that you have a custom collectionId that supports secondary sales provisioned for you by your Crossmint Customer Success Engineer. For more information on marketplace and launchpad support, check this guide.
If you need to contact the team about getting set up with reservoir-powered secondary sales support contact the team.
Multiple lineItems for Secondary Sales
To enable a multi item purchase, you simply need to pass an array of lineItems instead of a single object when creating an order.
The below examples demonstrate how to create a multiple line item order for secondary sales:
curl --request POST \
  --url https://staging.crossmint.com/api/2022-06-09/orders \
  --header 'Content-Type: application/json' \
  --header 'x-api-key: _YOUR_API_KEY_' \
  --data '{
    "recipient": {
      "email": "testy@crossmint.com"
    },
    "locale": "en-US",
    "payment": {
      "receiptEmail": "testy@crossmint.com",
      "method": "ethereum-sepolia",
      "currency": "eth"
    },
    "lineItems": [
      {
        "collectionLocator": "crossmint:_YOUR_SECONDARY_SALES_COLLECTION_ID_",
        "callData": {
          "contractAddress": "0x___CONTRACT_ADDRESS_OF_TOKEN",
          "tokenId": "234"
        }
      },
      {
        "collectionLocator": "crossmint:_YOUR_SECONDARY_SALES_COLLECTION_ID_",
        "callData": {
          "contractAddress": "0x___ANOTHER_TOKEN_CONTRACT",
          "tokenId": "567"
        }
      }
    ]
  }'
Primary Sales of Multiple Items
If you have a custom ERC-721 contract that supports the minter being able to specify which token they want to mint
you could use the example(s) below to enable them to purchase multiple and specific tokens in the same transaction.
This is an uncommon pattern for ERC-721 contracts though.
_id passed in the callData of each lineItem is unique (1 and 2).
curl --request POST \
  --url https://staging.crossmint.com/api/2022-06-09/orders \
  --header 'Content-Type: application/json' \
  --header 'x-api-key: _YOUR_API_KEY_' \
  --data '{
  "recipient": {
    "email": "testy@crossmint.com"
  },
  "locale": "en-US",
  "payment": {
    "receiptEmail": "testy@crossmint.com",
    "method": "ethereum-sepolia",
    "currency": "eth"
  },
  "lineItems": [
    {
      "collectionLocator": "crossmint:_YOUR_COLLECTION_ID_",
      "callData": {
        "_id_": "1",
        "quantity": "1"
      }
    },
    {
      "collectionLocator": "crossmint:_YOUR_COLLECTION_ID_",
      "callData": {
        "_id_": "2",
        "quantity": "1"
      }
    },
  ]
}'
Error Handling
As outlined in the Delivery Phase of the order lifecycle guides, it is important to keep track of the delivery for each item passed when you created the order and report back to the user on the status of the order.
Each line item is attempted and processed independently. If one line item fails, others will still go through and be fulfilled. If any items are undeliverable, the buyer will be automatically refunded for that specific portion of their order.
For definitions of delivery and line item statuses, see the Status Codes page.