ERC721ConsecutiveEnumerableMock.sol 1.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152
  1. // SPDX-License-Identifier: MIT
  2. pragma solidity ^0.8.19;
  3. import {ERC721} from "../../token/ERC721/ERC721.sol";
  4. import {ERC721Consecutive} from "../../token/ERC721/extensions/ERC721Consecutive.sol";
  5. import {ERC721Enumerable} from "../../token/ERC721/extensions/ERC721Enumerable.sol";
  6. contract ERC721ConsecutiveEnumerableMock is ERC721Consecutive, ERC721Enumerable {
  7. constructor(
  8. string memory name,
  9. string memory symbol,
  10. address[] memory receivers,
  11. uint96[] memory amounts
  12. ) ERC721(name, symbol) {
  13. for (uint256 i = 0; i < receivers.length; ++i) {
  14. _mintConsecutive(receivers[i], amounts[i]);
  15. }
  16. }
  17. function supportsInterface(
  18. bytes4 interfaceId
  19. ) public view virtual override(ERC721, ERC721Enumerable) returns (bool) {
  20. return super.supportsInterface(interfaceId);
  21. }
  22. function _ownerOf(uint256 tokenId) internal view virtual override(ERC721, ERC721Consecutive) returns (address) {
  23. return super._ownerOf(tokenId);
  24. }
  25. function _mint(address to, uint256 tokenId) internal virtual override(ERC721, ERC721Consecutive) {
  26. super._mint(to, tokenId);
  27. }
  28. function _beforeTokenTransfer(
  29. address from,
  30. address to,
  31. uint256 firstTokenId,
  32. uint256 batchSize
  33. ) internal virtual override(ERC721, ERC721Enumerable) {
  34. super._beforeTokenTransfer(from, to, firstTokenId, batchSize);
  35. }
  36. function _afterTokenTransfer(
  37. address from,
  38. address to,
  39. uint256 firstTokenId,
  40. uint256 batchSize
  41. ) internal virtual override(ERC721, ERC721Consecutive) {
  42. super._afterTokenTransfer(from, to, firstTokenId, batchSize);
  43. }
  44. }