Created
January 27, 2022 12:56
-
-
Save jackpmorgan/2cf75c3d8c3d7d4f77de876fe3781a97 to your computer and use it in GitHub Desktop.
Created using remix-ide: Realtime Ethereum Contract Compiler and Runtime. Load this file by pasting this gists URL or ID at https://remix.ethereum.org/#version=soljson-v0.8.7+commit.e28d00a7.js&optimize=false&runs=200&gist=
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
// SPDX-License-Identifier: GPL-3.0 | |
pragma solidity >=0.7.0 <0.9.0; | |
import "@openzeppelin/contracts/token/ERC721/extensions/ERC721Enumerable.sol"; | |
import "@openzeppelin/contracts/access/Ownable.sol"; | |
contract NFT_PAYSPLIT is ERC721Enumerable, Ownable { | |
using Strings for uint256; | |
string public baseURI; | |
string public baseExtension = ".json"; | |
uint256 public cost = 1 ether; | |
uint256 public maxSupply = 10000; | |
uint256 public maxMintAmount = 20; | |
bool public paused = false; | |
mapping(address => bool) public whitelisted; | |
address payable public payments; | |
constructor( | |
string memory _name, | |
string memory _symbol, | |
string memory _initBaseURI, | |
address _payments | |
) ERC721(_name, _symbol) { | |
setBaseURI(_initBaseURI); | |
payments = payable(_payments); | |
} | |
// internal | |
function _baseURI() internal view virtual override returns (string memory) { | |
return baseURI; | |
} | |
// public | |
function mint(address _to, uint256 _mintAmount) public payable { | |
uint256 supply = totalSupply(); | |
require(!paused); | |
require(_mintAmount > 0); | |
require(_mintAmount <= maxMintAmount); | |
require(supply + _mintAmount <= maxSupply); | |
if (msg.sender != owner()) { | |
require(msg.value >= cost * _mintAmount); | |
} | |
for (uint256 i = 1; i <= _mintAmount; i++) { | |
_safeMint(_to, supply + i); | |
} | |
} | |
function walletOfOwner(address _owner) | |
public | |
view | |
returns (uint256[] memory) | |
{ | |
uint256 ownerTokenCount = balanceOf(_owner); | |
uint256[] memory tokenIds = new uint256[](ownerTokenCount); | |
for (uint256 i; i < ownerTokenCount; i++) { | |
tokenIds[i] = tokenOfOwnerByIndex(_owner, i); | |
} | |
return tokenIds; | |
} | |
function tokenURI(uint256 tokenId) | |
public | |
view | |
virtual | |
override | |
returns (string memory) | |
{ | |
require( | |
_exists(tokenId), | |
"ERC721Metadata: URI query for nonexistent token" | |
); | |
string memory currentBaseURI = _baseURI(); | |
return bytes(currentBaseURI).length > 0 | |
? string(abi.encodePacked(currentBaseURI, tokenId.toString(), baseExtension)) | |
: ""; | |
} | |
//only owner | |
function setCost(uint256 _newCost) public onlyOwner { | |
cost = _newCost; | |
} | |
function setmaxMintAmount(uint256 _newmaxMintAmount) public onlyOwner { | |
maxMintAmount = _newmaxMintAmount; | |
} | |
function setBaseURI(string memory _newBaseURI) public onlyOwner { | |
baseURI = _newBaseURI; | |
} | |
function setBaseExtension(string memory _newBaseExtension) public onlyOwner { | |
baseExtension = _newBaseExtension; | |
} | |
function pause(bool _state) public onlyOwner { | |
paused = _state; | |
} | |
function withdraw() public payable onlyOwner { | |
(bool success, ) = payable(payments).call{value: address(this).balance}(""); | |
require(success); | |
} | |
} |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment