Docs

useValidEnglishAuctions

Hook to get all valid English auctions from a Marketplace V3 contract.

A listing is considered valid if the:

  • Auction has not expired (i.e. current time is before the end time of the auction)

  • Auction has not been canceled

  • Auction has not been bought out (all quantity has been sold)

This hook is only for Marketplace V3 contracts.

For Marketplace contracts, use useActiveListings instead.

Example

import {
useValidEnglishAuctions,
useContract,
} from "@thirdweb-dev/react";
// Your smart contract address
const contractAddress = "{{contract_address}}";
function App() {
const { contract } = useContract(contractAddress, "marketplace-v3");
const {
data: englishAuctions,
isLoading,
error,
} = useValidEnglishAuctions(contract);
}

Parameters

Returns

A Query Result object that includes an array of english auctions The hook's data property, once loaded, is an array of EnglishAuction objects, each containing the following properties:

Array<{
// The id of the auction
id: string;
// The address of the creator of auction.
creatorAddress: string;
// The address of the asset being auctioned.
assetContractAddress: string;
// The ID of the token to auction.
tokenId: string;
// The quantity of tokens to include in the auction.
// For ERC721s, this value should always be 1 (and will be forced internally regardless of what is passed here).
quantity: string;
// The address of the currency to accept for the auction.
currencyContractAddress: string;
// The minimum price that a bid must be in order to be accepted.
minimumBidAmount: string;
// The `CurrencyValue` of the minimum bid amount.
// Useful for displaying the price information.
minimumBidCurrencyValue: CurrencyValue;
// The buyout price of the auction.
buyoutBidAmount: string;
// The `CurrencyValue` of the buyout price.
// Useful for displaying the price information.
buyoutCurrencyValue: CurrencyValue;
// This is a buffer e.g. x seconds.
// If a new winning bid is made less than x seconds before expirationTimestamp, the
// expirationTimestamp is increased by x seconds.
timeBufferInSeconds: number;
// This is a buffer in basis points e.g. x%.
// To be considered as a new winning bid, a bid must be at least x% greater than
// the current winning bid.
bidBufferBps: number;
// The start time of the auction.
startTimeInSeconds: number;
// The end time of the auction.
endTimeInSeconds: number;
// The asset being auctioned.
asset: NFTMetadata;
// Whether the listing is CREATED, COMPLETED, or CANCELLED.
status: Status;
}>;