Easily deploy an NFT collection on Quai Network.
Enter the name of your collection.
Enter your collection symbol.
Metadata Extension
Enter the file extension type for your metadata.
Metadata URI
Enter the CID for your collection's metadata ".json" files.
Set the size of your collection.
The ERC721 Contract
The Quai NFT deployer is configured to deploy the base implementation of Open Zeppelin's ERC721 standard expanded with the URI-Storage extension and Ownable modifier contract. Deploying the contract will create a new NFT collection with the specified name, symbol, metadata, and collection size. You as the owner will be able to mint new NFTs and transfer ownership of the collection.
While the contract contract below is useful for simple deployments, it lacks customizability. If your NFT collection requires more advanced features such as custom minting or complex metadata, consider writing your own contract and deploying it via Hardhat.
erc721.sol
1// SPDX-License-Identifier: MIT2pragma solidity ^0.8.20;34import "@openzeppelin/contracts/token/ERC721/extensions/ERC721URIStorage.sol";5import "@openzeppelin/contracts/access/Ownable.sol";6import "@openzeppelin/contracts/utils/Strings.sol";78contract TestERC721 is ERC721URIStorage, Ownable {9using Strings for uint256;10string private baseTokenURI;11uint256 private mintedTokens;12uint256 private maxTokens;1314/**15* @dev Constructor sets msg.sender as contract owner.16* @dev Sets the base token URI.17*18* @param name Name of the token.19* @param symbol Symbol of the token.20* @param baseTokenURI_ Base token URI.21*/22constructor(string memory name, string memory symbol, string memory baseTokenURI_, uint256 maxTokens_) ERC721(name, symbol) Ownable(msg.sender) {23baseTokenURI = baseTokenURI_;24mintedTokens = 0;25maxTokens = maxTokens_;26}2728/**29* @dev Mints tokens to the specified address.30* @dev Modifier onlyOwner restricts the minting function to the contract owner.31* @dev Restricts the number of tokens that can be minted to 1000.32*33* @param to Address to which tokens are to be minted.34*/35function mint(address to) public onlyOwner {36require(mintedTokens < maxTokens, "All tokens have been minted");37_safeMint(to, mintedTokens);38mintedTokens++;39}4041/**42* @dev Override required by ERC721URIStorage to return the token URI.43* Adds ".json" to the end of the token ID to match the expected format of the tokenURI.44* Reverts if token does not exist.45*46* @param tokenId The token ID to return the URI for.47*/48function tokenURI(uint256 tokenId) public view virtual override returns (string memory) {49require(tokenId <= maxTokens, "Token ID out of range.");50require(ownerOf(tokenId) != address(0), "Nonexistent token.");51string memory baseURI = _baseURI();52return bytes(baseURI).length > 0 ? string(abi.encodePacked(baseURI, tokenId.toString(), ".json")) : "";53}5455/**56* @dev Returns the base token URI.57*/58function _baseURI() internal view virtual override returns (string memory) {59return baseTokenURI;60}6162/**63* @dev Returns the collection size.64*/65function _maxTokens() public view returns (uint256) {66return maxTokens;67}68}