ERC721ConsecutiveEnumerableMock.sol 1.6 KB

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