123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158 |
- // SPDX-License-Identifier: MIT
- pragma solidity ^0.8.0;
- import "../token/ERC721/extensions/ERC721Burnable.sol";
- import "../token/ERC721/extensions/ERC721Consecutive.sol";
- import "../token/ERC721/extensions/ERC721Enumerable.sol";
- import "../token/ERC721/extensions/ERC721Pausable.sol";
- import "../token/ERC721/extensions/draft-ERC721Votes.sol";
- /**
- * @title ERC721ConsecutiveMock
- */
- contract ERC721ConsecutiveMock is ERC721Burnable, ERC721Consecutive, ERC721Pausable, ERC721Votes {
- constructor(
- string memory name,
- string memory symbol,
- address[] memory delegates,
- address[] memory receivers,
- uint96[] memory amounts
- ) ERC721(name, symbol) EIP712(name, "1") {
- for (uint256 i = 0; i < delegates.length; ++i) {
- _delegate(delegates[i], delegates[i]);
- }
- for (uint256 i = 0; i < receivers.length; ++i) {
- _mintConsecutive(receivers[i], amounts[i]);
- }
- }
- function pause() external {
- _pause();
- }
- function unpause() external {
- _unpause();
- }
- function exists(uint256 tokenId) public view returns (bool) {
- return _exists(tokenId);
- }
- function mint(address to, uint256 tokenId) public {
- _mint(to, tokenId);
- }
- function mintConsecutive(address to, uint96 amount) public {
- _mintConsecutive(to, amount);
- }
- function safeMint(address to, uint256 tokenId) public {
- _safeMint(to, tokenId);
- }
- function _ownerOf(uint256 tokenId) internal view virtual override(ERC721, ERC721Consecutive) returns (address) {
- return super._ownerOf(tokenId);
- }
- function _mint(address to, uint256 tokenId) internal virtual override(ERC721, ERC721Consecutive) {
- super._mint(to, tokenId);
- }
- function _beforeTokenTransfer(
- address from,
- address to,
- uint256 tokenId
- ) internal virtual override(ERC721, ERC721Pausable) {
- super._beforeTokenTransfer(from, to, tokenId);
- }
- function _afterTokenTransfer(
- address from,
- address to,
- uint256 tokenId
- ) internal virtual override(ERC721, ERC721Votes, ERC721Consecutive) {
- super._afterTokenTransfer(from, to, tokenId);
- }
- function _beforeConsecutiveTokenTransfer(
- address from,
- address to,
- uint256 first,
- uint96 size
- ) internal virtual override(ERC721, ERC721Pausable) {
- super._beforeConsecutiveTokenTransfer(from, to, first, size);
- }
- function _afterConsecutiveTokenTransfer(
- address from,
- address to,
- uint256 first,
- uint96 size
- ) internal virtual override(ERC721, ERC721Votes) {
- super._afterConsecutiveTokenTransfer(from, to, first, size);
- }
- }
- contract ERC721ConsecutiveEnumerableMock is ERC721Consecutive, ERC721Enumerable {
- constructor(
- string memory name,
- string memory symbol,
- address[] memory receivers,
- uint96[] memory amounts
- ) ERC721(name, symbol) {
- for (uint256 i = 0; i < receivers.length; ++i) {
- _mintConsecutive(receivers[i], amounts[i]);
- }
- }
- function supportsInterface(bytes4 interfaceId)
- public
- view
- virtual
- override(ERC721, ERC721Enumerable)
- returns (bool)
- {
- return super.supportsInterface(interfaceId);
- }
- function _ownerOf(uint256 tokenId) internal view virtual override(ERC721, ERC721Consecutive) returns (address) {
- return super._ownerOf(tokenId);
- }
- function _mint(address to, uint256 tokenId) internal virtual override(ERC721, ERC721Consecutive) {
- super._mint(to, tokenId);
- }
- function _beforeTokenTransfer(
- address from,
- address to,
- uint256 tokenId
- ) internal virtual override(ERC721, ERC721Enumerable) {
- super._beforeTokenTransfer(from, to, tokenId);
- }
- function _afterTokenTransfer(
- address from,
- address to,
- uint256 tokenId
- ) internal virtual override(ERC721, ERC721Consecutive) {
- super._afterTokenTransfer(from, to, tokenId);
- }
- function _beforeConsecutiveTokenTransfer(
- address from,
- address to,
- uint256 first,
- uint96 size
- ) internal virtual override(ERC721, ERC721Enumerable) {
- super._beforeConsecutiveTokenTransfer(from, to, first, size);
- }
- }
- contract ERC721ConsecutiveNoConstructorMintMock is ERC721Consecutive {
- constructor(string memory name, string memory symbol) ERC721(name, symbol) {
- _mint(msg.sender, 0);
- }
- }
|