Crescendo

Dynamically priced NFTs

NFT drop utilizing a gas-optimzed version of ERC1155 with bonding curves to enable dynamic pricing for fan powered price discovery and guarantee liquidity to collectors.

Getting Started
Module Methods
Smart Contract Methods

Getting Started

To begin we'll import the FrostySDK, chain configurations, and the Crescendo module.

Then we'll setup our signer (via wagmi/ethers) and create a new instance of the FrostySDK.

// Import SDK, chain configurations, and the Crescendo module
import { FrostySDK, chain, crescendo } from "frosty-sdk";

// Get the signer via wagmi or configure using ethers
// Setup the SDK with the desired chain and signer
const sdk = new FrostySDK(chain.goerli, signer);

Module Methods

deploy
Deploy a minimal proxy clone of the Crescendo implementation contract.

getContract
Get an ethers contract instance of a previously deployed Crescendo contract.

deploy

Deploy a minimal proxy clone of the Crescendo implementation contract.

const myNFT = await crescendo.deploy(
  sdk,
  name,
  symbol,
  initialPrice,
  step1,
  step2,
  hitch,
  takeRateBPS,
  unlockDate,
  royaltyBPS,
  metadataURI,
  metadataRendererInit,
  onTxPending,
  onTxReceipt
);

console.log("Crescendo deployed to: ", myNFT.address);

sdk (SDK)
An instance of the FrostySDK, configured with a chain and signer.

name (string)
The name of the NFT collection.

symbol (string)
The symbol of the NFT collection.

initialPrice (BigNumber)
The initial price (in Wei) to mint a token from the collection.

step1 (BigNumber)
The amount to increment/decrement the per token price pre-hitch.

step2 (BigNumber)
The amount to increment/decrement the per token price post-hitch.

hitch (number)
Once total supply exceeds the hitch, the amount by which we increment/decrement pricing increases.

takeRateBPS (number)
The take rate in basis points used to calculate reserve funds for trading liquidity.

unlockDate (number)
The timestamp at which crescendo will unlock and allow profit distributions.

royaltyBPS (number)
The maximum number of tokens allowed per mint.

metadataURI (string)
The base URI for the collection metadata.

metadataRendererInit (MetadataRendererInit)
An object containing metadata to initialize with the on-chain metadata renderer.

onTxPending (Function) - optional
A callback function executed upon submission of the deploy transaction.

onTxReceipt (Function) - optional
A callback function executed upon receipt of the deploy transaction.

getContract

Get an ethers contract instance of a previously deployed Crescendo contract.

const myNFT = await crescendo.getContract(sdk, address);

sdk (SDK)
An instance of the FrostySDK, configured with a chain and signer.

address (string)
The contract address of a previously deployed Crescendo contract.

Smart Contract Methods

buy
Mint an NFT at the current mint rate

sell
Sell an NFT at the current burn rate

totalSupply
Returns the total number of NFTs currently in circulation.

flipSaleState
Toggles whether to allow minting.

withdraw
Allows the account authorized for payouts to withdraw dividends at the specified take rate.

liquidity
Returns the peak liquidity held by the contract.

reserveAmt
Returns the peak reserve funds held by the contract.

updateUri
Allows the owner to update the URI serving metadata for the NFT collection.

buy

Mint an NFT at the current mint rate

const myNFT = await crescendo.getContract(sdk, address);
const currentPrice = await crescendo.calculateCurvedMintReturn(1, 0);
await crescendo.buy(0, { value: currentPrice });

tokenId (uint256)
The id of the token.

sell

Sell an NFT at the current burn rate

const myNFT = await crescendo.getContract(sdk, address);
await crescendo.sell(0);

tokenId (uint256)
The id of the token. (must be zero)

totalSupply

Returns the total number of NFTs currently in circulation.

const myNFT = await crescendo.getContract(sdk, address);
await crescendo.totalSupply(0);

tokenId (uint256)
The id of the token. (must be zero)

flipSaleState

Toggles whether to allow minting.

const myNFT = await crescendo.getContract(sdk, address);
await crescendo.flipSaleState();

withdraw

Allows the contract owner to withdraw dividends at the specified take rate.

const myNFT = await crescendo.getContract(sdk, address);
await crescendo.withdraw();

liquidity

Returns the peak liquidity held by the contract.

const myNFT = await crescendo.getContract(sdk, address);
const liquidity = await crescendo.liquidity();

reserveAmt

Returns the peak reserve funds held by the contract.

const myNFT = await crescendo.getContract(sdk, address);
const reserve = await crescendo.reserveAmt();

updateUri

Allows the owner to update the URI serving metadata for the NFT collection.

const myNFT = await crescendo.getContract(sdk, address);
await crescendo.updateUri('https://nft.example/metadata/{id}.json');

uri (uint256)
The URI serving metadata for the NFT collection.