Skip to content

Latest commit

 

History

History
75 lines (50 loc) · 2.18 KB

File metadata and controls

75 lines (50 loc) · 2.18 KB

Delist

Calling this method revokes token approval from the supplied market address resulting in the delisting of the provided token.

Token approvals are permissions granted to decentralized apps to transfer tokens you own on your behalf.

Removing this approval means that the marketplace won't be able to list your token for sale because they won't be able to transfer it once its sold.

Delisting removes the stored listing from the market contract resulting in the recovery of the storage deposit.

If no marketId is provided approval is removed from all markets/accounts

If you wish to remove a listing specifically on the mintbase market, addresses are:

testnet: market-v2-beta.mintspace2.testnet mainnet: simple.market.mintbase1.near

As with all new SDK api methods, this call should be wrapped in execute and passed a signing method

delist(args: DelistArgs): NearContractCall

delist takes a single argument of type DelistArgs

type DelistArgs = {
    // contract from which the token belongs to
    //as an argument or through CONTRACT_ADDRESS env
    contractAddress?: string;
    // id of the token for which the approval will be revoked
    tokenId: string;
    //if removal is necessary for only a specific market/account
    marketId?: string;
}

React example

Example usage of buy method in a hypothetical React component: {% code title="DelistComponent.ts" overflow="wrap" lineNumbers="true" %}

import { useState } from 'react';
import { useWallet } from '@mintbase-js/react';
import { execute, delist, DelistArgs } from '@mintbase-js/sdk';


export const DelistComponent = ({ contractAddress, tokenId, marketAddress }:DelistArgs): JSX.Element => {
  
  const { selector } = useWallet();
  
  const handleDelist = async (): Promise<void> => {
    
    const wallet = await selector.wallet();

    const delistArgs = {contractAddress: contractAddress, tokenId:tokenId, marketAddress:marketAddress}

    await execute(
      {wallet},
      delist(delistArgs)
    );

  }

  return (
    <div>
      <button onClick={handleDelist}>
        Burn provided token array from {contractAddress}
      </button>
    </div>
  );
};

{% endcode %}