12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061 |
- // SPDX-License-Identifier: MIT
- pragma solidity ^0.8.24;
- import {ERC721} from "../../token/ERC721/ERC721.sol";
- import {ERC721Consecutive} from "../../token/ERC721/extensions/ERC721Consecutive.sol";
- import {ERC721Pausable} from "../../token/ERC721/extensions/ERC721Pausable.sol";
- import {ERC721Votes} from "../../token/ERC721/extensions/ERC721Votes.sol";
- import {EIP712} from "../../utils/cryptography/EIP712.sol";
- /**
- * @title ERC721ConsecutiveMock
- */
- contract ERC721ConsecutiveMock is ERC721Consecutive, ERC721Pausable, ERC721Votes {
- uint96 private immutable _offset;
- constructor(
- string memory name,
- string memory symbol,
- uint96 offset,
- address[] memory delegates,
- address[] memory receivers,
- uint96[] memory amounts
- ) ERC721(name, symbol) EIP712(name, "1") {
- _offset = offset;
- 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 _firstConsecutiveId() internal view virtual override returns (uint96) {
- return _offset;
- }
- function _ownerOf(uint256 tokenId) internal view virtual override(ERC721, ERC721Consecutive) returns (address) {
- return super._ownerOf(tokenId);
- }
- function _update(
- address to,
- uint256 tokenId,
- address auth
- ) internal virtual override(ERC721Consecutive, ERC721Pausable, ERC721Votes) returns (address) {
- return super._update(to, tokenId, auth);
- }
- function _increaseBalance(address account, uint128 amount) internal virtual override(ERC721, ERC721Votes) {
- super._increaseBalance(account, amount);
- }
- }
- contract ERC721ConsecutiveNoConstructorMintMock is ERC721Consecutive {
- constructor(string memory name, string memory symbol) ERC721(name, symbol) {
- _mint(msg.sender, 0);
- }
- }
|