useOffers
Hook for getting all of the offers made on a direct listing on a Marketplace contract.
import { useOffers } from "@thirdweb-dev/react";
const { data: offers, isLoading, error } = useOffers(contract, listingId);
Usage
Provide your Marketplace contract from the
useContract hook and the listingId of the listing you want to get the offers for as
arguments to the hook.
import { useOffers, useContract } from "@thirdweb-dev/react";
// Your smart contract address
const contractAddress = "{{contract_address}}";
// The listing ID you want to fetch offers for
const listingId = "{{listing_id}}";
function App() {
  const { contract } = useContract(contractAddress, "marketplace");
  const { data: offers, isLoading, error } = useOffers(contract, listingId);
}
Configuration
listingId (required)
listingId (required)
The ID of the listing to get the offers for.
If the listing cannot be found, is not a direct listing, or is not active, the error property will be set.
import { useOffers, useContract } from "@thirdweb-dev/react";
// Your smart contract address
const contractAddress = "{{contract_address}}";
// The listing ID you want to fetch offers for
const listingId = "{{listing_id}}";
function App() {
  const { contract } = useContract(contractAddress, "marketplace");
  const {
    data: offers,
    isLoading,
    error,
  } = useOffers(
    contract,
    listingId,
  );
}
Return Value
Return Value
This hook uses the useEvents hook under the hood to fetch NewOffer events for the given listing ID.
The return value is an array of NewOffer event objects. Each event object has the following properties:
{
  offeror: string;
  offerId: BigNumber;
  assetContract: string;
  offer: {
    offerId: BigNumber;
    offeror: string;
    assetContract: string;
    tokenId: BigNumber;
    quantity: BigNumber;
    currency: string;
    totalPrice: BigNumber;
    expirationTimestamp: BigNumber;
    tokenType: "ERC721" | "ERC1155";
    status: "UNSET" | "CREATED" | "COMPLETED" | "CANCELLED";
  }
}