@sylix/coworker 2.0.11 → 2.0.14

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (169) hide show
  1. package/dist/commands/slash/config.d.ts.map +1 -1
  2. package/dist/commands/slash/config.js +22 -4
  3. package/dist/commands/slash/config.js.map +1 -1
  4. package/dist/core/CoWorkerAgent.d.ts.map +1 -1
  5. package/dist/core/CoWorkerAgent.js +6 -3
  6. package/dist/core/CoWorkerAgent.js.map +1 -1
  7. package/dist/skills/defaults/accessibility/screen-reader-testing.md +545 -0
  8. package/dist/skills/defaults/accessibility/wcag-audit-patterns.md +555 -0
  9. package/dist/skills/defaults/ai-ml/rag.md +276 -0
  10. package/dist/skills/defaults/backend-development/api-design-principles.md +528 -0
  11. package/dist/skills/defaults/backend-development/api-design.md +285 -0
  12. package/dist/skills/defaults/backend-development/architecture-patterns.md +494 -0
  13. package/dist/skills/defaults/backend-development/async-python.md +237 -0
  14. package/dist/skills/defaults/backend-development/auth-implementation-patterns.md +638 -0
  15. package/dist/skills/defaults/backend-development/bazel-build-optimization.md +387 -0
  16. package/dist/skills/defaults/backend-development/billing-automation/SKILL.md +566 -0
  17. package/dist/skills/defaults/backend-development/code-review-excellence.md +538 -0
  18. package/dist/skills/defaults/backend-development/cqrs-implementation.md +554 -0
  19. package/dist/skills/defaults/backend-development/database-design.md +305 -0
  20. package/dist/skills/defaults/backend-development/debugging-strategies.md +536 -0
  21. package/dist/skills/defaults/backend-development/e2e-testing-patterns.md +544 -0
  22. package/dist/skills/defaults/backend-development/error-handling-patterns.md +641 -0
  23. package/dist/skills/defaults/backend-development/fastapi-templates.md +559 -0
  24. package/dist/skills/defaults/backend-development/fastapi.md +309 -0
  25. package/dist/skills/defaults/backend-development/git-advanced-workflows.md +405 -0
  26. package/dist/skills/defaults/backend-development/microservices-patterns.md +595 -0
  27. package/dist/skills/defaults/backend-development/microservices.md +284 -0
  28. package/dist/skills/defaults/backend-development/monorepo-management.md +623 -0
  29. package/dist/skills/defaults/backend-development/nodejs-backend-patterns.md +1048 -0
  30. package/dist/skills/defaults/backend-development/nx-workspace-patterns.md +457 -0
  31. package/dist/skills/defaults/backend-development/paypal-integration/SKILL.md +478 -0
  32. package/dist/skills/defaults/backend-development/pci-compliance/SKILL.md +480 -0
  33. package/dist/skills/defaults/backend-development/python-anti-patterns.md +349 -0
  34. package/dist/skills/defaults/backend-development/python-background-jobs.md +364 -0
  35. package/dist/skills/defaults/backend-development/python-code-style.md +360 -0
  36. package/dist/skills/defaults/backend-development/python-configuration.md +368 -0
  37. package/dist/skills/defaults/backend-development/python-design-patterns.md +296 -0
  38. package/dist/skills/defaults/backend-development/python-error-handling.md +323 -0
  39. package/dist/skills/defaults/backend-development/python-packaging.md +887 -0
  40. package/dist/skills/defaults/backend-development/python-performance-optimization.md +874 -0
  41. package/dist/skills/defaults/backend-development/python-project-structure.md +252 -0
  42. package/dist/skills/defaults/backend-development/python-resilience.md +376 -0
  43. package/dist/skills/defaults/backend-development/python-resource-management.md +421 -0
  44. package/dist/skills/defaults/backend-development/python-type-safety.md +428 -0
  45. package/dist/skills/defaults/backend-development/sql-optimization-patterns.md +509 -0
  46. package/dist/skills/defaults/backend-development/stripe-integration/SKILL.md +522 -0
  47. package/dist/skills/defaults/backend-development/turborepo-caching.md +376 -0
  48. package/dist/skills/defaults/blockchain/defi-protocol-templates.md +430 -0
  49. package/dist/skills/defaults/blockchain/nft-standards.md +364 -0
  50. package/dist/skills/defaults/blockchain/solidity-security.md +514 -0
  51. package/dist/skills/defaults/blockchain/web3-testing.md +360 -0
  52. package/dist/skills/defaults/business/competitive-landscape/SKILL.md +527 -0
  53. package/dist/skills/defaults/business/market-sizing-analysis/SKILL.md +451 -0
  54. package/dist/skills/defaults/business/startup-financial-modeling/SKILL.md +494 -0
  55. package/dist/skills/defaults/business/startup-metrics-framework/SKILL.md +564 -0
  56. package/dist/skills/defaults/business/team-composition-analysis.md +437 -0
  57. package/dist/skills/defaults/compliance/employment-contract-templates/SKILL.md +527 -0
  58. package/dist/skills/defaults/compliance/gdpr-data-handling/SKILL.md +630 -0
  59. package/dist/skills/defaults/data-engineering/airflow-dag-patterns.md +436 -0
  60. package/dist/skills/defaults/data-engineering/airflow.md +519 -0
  61. package/dist/skills/defaults/data-engineering/data-quality.md +583 -0
  62. package/dist/skills/defaults/data-engineering/dbt-transformation-patterns.md +482 -0
  63. package/dist/skills/defaults/data-engineering/dbt.md +556 -0
  64. package/dist/skills/defaults/data-engineering/ml-pipeline-workflow/SKILL.md +247 -0
  65. package/dist/skills/defaults/data-engineering/spark-optimization.md +348 -0
  66. package/dist/skills/defaults/data-engineering/spark.md +411 -0
  67. package/dist/skills/defaults/database/postgresql.md +202 -0
  68. package/dist/skills/defaults/debugging/systematic-debugging.md +249 -0
  69. package/dist/skills/defaults/devops/architecture-decision-records.md +448 -0
  70. package/dist/skills/defaults/devops/changelog-automation.md +580 -0
  71. package/dist/skills/defaults/devops/cicd.md +314 -0
  72. package/dist/skills/defaults/devops/cloud.md +263 -0
  73. package/dist/skills/defaults/devops/code-review-excellence.md +299 -0
  74. package/dist/skills/defaults/devops/cost-optimization.md +295 -0
  75. package/dist/skills/defaults/devops/deployment-pipeline-design.md +356 -0
  76. package/dist/skills/defaults/devops/docker.md +281 -0
  77. package/dist/skills/defaults/devops/git-workflows.md +205 -0
  78. package/dist/skills/defaults/devops/github-actions.md +311 -0
  79. package/dist/skills/defaults/devops/gitlab-ci-patterns.md +266 -0
  80. package/dist/skills/defaults/devops/hybrid-cloud-networking.md +241 -0
  81. package/dist/skills/defaults/devops/istio-traffic-management.md +327 -0
  82. package/dist/skills/defaults/devops/kubernetes.md +339 -0
  83. package/dist/skills/defaults/devops/linkerd-patterns.md +311 -0
  84. package/dist/skills/defaults/devops/multi-cloud-architecture.md +181 -0
  85. package/dist/skills/defaults/devops/observability.md +243 -0
  86. package/dist/skills/defaults/devops/openapi-spec-generation.md +1024 -0
  87. package/dist/skills/defaults/devops/postmortem-writing.md +396 -0
  88. package/dist/skills/defaults/devops/prometheus-configuration.md +265 -0
  89. package/dist/skills/defaults/devops/secrets-management.md +341 -0
  90. package/dist/skills/defaults/devops/service-mesh-observability.md +385 -0
  91. package/dist/skills/defaults/devops/terraform-module-library.md +244 -0
  92. package/dist/skills/defaults/finance/backtesting-frameworks/SKILL.md +663 -0
  93. package/dist/skills/defaults/finance/risk-metrics-calculation/SKILL.md +557 -0
  94. package/dist/skills/defaults/frontend/accessibility-compliance.md +420 -0
  95. package/dist/skills/defaults/frontend/design-system-patterns.md +337 -0
  96. package/dist/skills/defaults/frontend/interaction-design.md +327 -0
  97. package/dist/skills/defaults/frontend/javascript.md +311 -0
  98. package/dist/skills/defaults/frontend/modern-javascript-patterns.md +927 -0
  99. package/dist/skills/defaults/frontend/react-native-design.md +440 -0
  100. package/dist/skills/defaults/frontend/react.md +345 -0
  101. package/dist/skills/defaults/frontend/responsive-design.md +472 -0
  102. package/dist/skills/defaults/frontend/tailwind-design-system.md +337 -0
  103. package/dist/skills/defaults/frontend/typescript-advanced-types.md +724 -0
  104. package/dist/skills/defaults/frontend/typescript.md +334 -0
  105. package/dist/skills/defaults/frontend/visual-design-foundations.md +326 -0
  106. package/dist/skills/defaults/frontend/web-component-design.md +279 -0
  107. package/dist/skills/defaults/game-development/godot-gdscript-patterns.md +188 -0
  108. package/dist/skills/defaults/game-development/unity-ecs-patterns.md +594 -0
  109. package/dist/skills/defaults/kubernetes/gitops-workflow.md +285 -0
  110. package/dist/skills/defaults/kubernetes/gitops.md +280 -0
  111. package/dist/skills/defaults/kubernetes/helm-chart-scaffolding.md +553 -0
  112. package/dist/skills/defaults/kubernetes/helm.md +343 -0
  113. package/dist/skills/defaults/kubernetes/k8s-manifest-generator.md +501 -0
  114. package/dist/skills/defaults/kubernetes/k8s-security-policies.md +342 -0
  115. package/dist/skills/defaults/kubernetes/manifests.md +330 -0
  116. package/dist/skills/defaults/kubernetes/security.md +337 -0
  117. package/dist/skills/defaults/llm-application/embedding-strategies.md +608 -0
  118. package/dist/skills/defaults/llm-application/hybrid-search-implementation.md +570 -0
  119. package/dist/skills/defaults/llm-application/hybrid-search.md +570 -0
  120. package/dist/skills/defaults/llm-application/langchain-architecture.md +666 -0
  121. package/dist/skills/defaults/llm-application/langchain.md +259 -0
  122. package/dist/skills/defaults/llm-application/llm-evaluation.md +695 -0
  123. package/dist/skills/defaults/llm-application/prompt-engineering-patterns.md +449 -0
  124. package/dist/skills/defaults/llm-application/prompt-engineering.md +219 -0
  125. package/dist/skills/defaults/llm-application/rag-implementation.md +434 -0
  126. package/dist/skills/defaults/llm-application/similarity-search-patterns.md +560 -0
  127. package/dist/skills/defaults/llm-application/similarity-search.md +560 -0
  128. package/dist/skills/defaults/llm-application/vector-index-tuning.md +523 -0
  129. package/dist/skills/defaults/mobile/mobile-android-design.md +440 -0
  130. package/dist/skills/defaults/mobile/mobile-ios-design.md +266 -0
  131. package/dist/skills/defaults/monitoring/distributed-tracing.md +436 -0
  132. package/dist/skills/defaults/monitoring/grafana-dashboards.md +370 -0
  133. package/dist/skills/defaults/monitoring/prometheus-configuration.md +379 -0
  134. package/dist/skills/defaults/monitoring/slo-implementation.md +323 -0
  135. package/dist/skills/defaults/refactoring/code-refactoring.md +349 -0
  136. package/dist/skills/defaults/security/anti-reversing-techniques/SKILL.md +559 -0
  137. package/dist/skills/defaults/security/auditor.md +168 -0
  138. package/dist/skills/defaults/security/binary-analysis-patterns/SKILL.md +438 -0
  139. package/dist/skills/defaults/security/memory-forensics/SKILL.md +483 -0
  140. package/dist/skills/defaults/security/mtls-configuration.md +349 -0
  141. package/dist/skills/defaults/security/protocol-reverse-engineering/SKILL.md +520 -0
  142. package/dist/skills/defaults/security/sast-configuration.md +182 -0
  143. package/dist/skills/defaults/security/security.md +313 -0
  144. package/dist/skills/defaults/security/stride-analysis.md +273 -0
  145. package/dist/skills/defaults/security/threat-mitigation-mapping.md +290 -0
  146. package/dist/skills/defaults/systems/bash-defensive-patterns/SKILL.md +539 -0
  147. package/dist/skills/defaults/systems/bats-testing-patterns/SKILL.md +631 -0
  148. package/dist/skills/defaults/systems/go-concurrency-patterns.md +657 -0
  149. package/dist/skills/defaults/systems/memory-safety-patterns.md +605 -0
  150. package/dist/skills/defaults/systems/rust-async-patterns.md +519 -0
  151. package/dist/skills/defaults/systems/shellcheck-configuration/SKILL.md +456 -0
  152. package/dist/skills/defaults/team-collaboration/multi-reviewer-patterns.md +126 -0
  153. package/dist/skills/defaults/team-collaboration/parallel-feature-development.md +151 -0
  154. package/dist/skills/defaults/testing/javascript-testing-patterns.md +1021 -0
  155. package/dist/skills/defaults/testing/python-testing-patterns.md +351 -0
  156. package/dist/skills/defaults/testing/testing.md +332 -0
  157. package/dist/skills/defaults/workflows/context-driven-development.md +384 -0
  158. package/dist/skills/defaults/workflows/track-management.md +592 -0
  159. package/dist/skills/defaults/workflows/workflow-patterns.md +622 -0
  160. package/dist/skills/index.d.ts +11 -0
  161. package/dist/skills/index.d.ts.map +1 -0
  162. package/dist/skills/index.js +129 -0
  163. package/dist/skills/index.js.map +1 -0
  164. package/dist/utils/character.js +4 -4
  165. package/dist/utils/character.js.map +1 -1
  166. package/dist/utils/inputbar.d.ts.map +1 -1
  167. package/dist/utils/inputbar.js +7 -0
  168. package/dist/utils/inputbar.js.map +1 -1
  169. package/package.json +1 -1
@@ -0,0 +1,364 @@
1
+ ---
2
+ name: nft-standards
3
+ description: Implement NFT standards (ERC-721, ERC-1155) with proper metadata handling, minting strategies, and marketplace integration
4
+ ---
5
+
6
+ # NFT Standards
7
+
8
+ Master ERC-721 and ERC-1155 NFT standards, metadata best practices, and advanced NFT features.
9
+
10
+ ## When to Use This Skill
11
+
12
+ - Creating NFT collections (art, gaming, collectibles)
13
+ - Implementing marketplace functionality
14
+ - Building on-chain or off-chain metadata
15
+ - Creating soulbound tokens (non-transferable)
16
+ - Implementing royalties and revenue sharing
17
+ - Developing dynamic/evolving NFTs
18
+
19
+ ## ERC-721 (Non-Fungible Token Standard)
20
+
21
+ ```solidity
22
+ // SPDX-License-Identifier: MIT
23
+ pragma solidity ^0.8.0;
24
+
25
+ import "@openzeppelin/contracts/token/ERC721/extensions/ERC721URIStorage.sol";
26
+ import "@openzeppelin/contracts/token/ERC721/extensions/ERC721Enumerable.sol";
27
+ import "@openzeppelin/contracts/access/Ownable.sol";
28
+ import "@openzeppelin/contracts/utils/Counters.sol";
29
+
30
+ contract MyNFT is ERC721URIStorage, ERC721Enumerable, Ownable {
31
+ using Counters for Counters.Counter;
32
+ Counters.Counter private _tokenIds;
33
+
34
+ uint256 public constant MAX_SUPPLY = 10000;
35
+ uint256 public constant MINT_PRICE = 0.08 ether;
36
+ uint256 public constant MAX_PER_MINT = 20;
37
+
38
+ constructor() ERC721("MyNFT", "MNFT") {}
39
+
40
+ function mint(uint256 quantity) external payable {
41
+ require(quantity > 0 && quantity <= MAX_PER_MINT, "Invalid quantity");
42
+ require(_tokenIds.current() + quantity <= MAX_SUPPLY, "Exceeds max supply");
43
+ require(msg.value >= MINT_PRICE * quantity, "Insufficient payment");
44
+
45
+ for (uint256 i = 0; i < quantity; i++) {
46
+ _tokenIds.increment();
47
+ uint256 newTokenId = _tokenIds.current();
48
+ _safeMint(msg.sender, newTokenId);
49
+ _setTokenURI(newTokenId, generateTokenURI(newTokenId));
50
+ }
51
+ }
52
+
53
+ function generateTokenURI(uint256 tokenId) internal pure returns (string memory) {
54
+ return string(abi.encodePacked("ipfs://QmHash/", Strings.toString(tokenId), ".json"));
55
+ }
56
+
57
+ function _beforeTokenTransfer(
58
+ address from,
59
+ address to,
60
+ uint256 tokenId,
61
+ uint256 batchSize
62
+ ) internal override(ERC721, ERC721Enumerable) {
63
+ super._beforeTokenTransfer(from, to, tokenId, batchSize);
64
+ }
65
+
66
+ function _burn(uint256 tokenId) internal override(ERC721, ERC721URIStorage) {
67
+ super._burn(tokenId);
68
+ }
69
+
70
+ function tokenURI(uint256 tokenId) public view override(ERC721, ERC721URIStorage) returns (string memory) {
71
+ return super.tokenURI(tokenId);
72
+ }
73
+
74
+ function supportsInterface(bytes4 interfaceId)
75
+ public
76
+ view
77
+ override(ERC721, ERC721Enumerable)
78
+ returns (bool)
79
+ {
80
+ return super.supportsInterface(interfaceId);
81
+ }
82
+
83
+ function withdraw() external onlyOwner {
84
+ payable(owner()).transfer(address(this).balance);
85
+ }
86
+ }
87
+ ```
88
+
89
+ ## ERC-1155 (Multi-Token Standard)
90
+
91
+ ```solidity
92
+ // SPDX-License-Identifier: MIT
93
+ pragma solidity ^0.8.0;
94
+
95
+ import "@openzeppelin/contracts/token/ERC1155/ERC1155.sol";
96
+ import "@openzeppelin/contracts/access/Ownable.sol";
97
+
98
+ contract GameItems is ERC1155, Ownable {
99
+ uint256 public constant SWORD = 1;
100
+ uint256 public constant SHIELD = 2;
101
+ uint256 public constant POTION = 3;
102
+
103
+ mapping(uint256 => uint256) public tokenSupply;
104
+ mapping(uint256 => uint256) public maxSupply;
105
+
106
+ constructor() ERC1155("ipfs://QmBaseHash/{id}.json") {
107
+ maxSupply[SWORD] = 1000;
108
+ maxSupply[SHIELD] = 500;
109
+ maxSupply[POTION] = 10000;
110
+ }
111
+
112
+ function mint(
113
+ address to,
114
+ uint256 id,
115
+ uint256 amount
116
+ ) external onlyOwner {
117
+ require(tokenSupply[id] + amount <= maxSupply[id], "Exceeds max supply");
118
+
119
+ _mint(to, id, amount, "");
120
+ tokenSupply[id] += amount;
121
+ }
122
+
123
+ function mintBatch(
124
+ address to,
125
+ uint256[] memory ids,
126
+ uint256[] memory amounts
127
+ ) external onlyOwner {
128
+ for (uint256 i = 0; i < ids.length; i++) {
129
+ require(tokenSupply[ids[i]] + amounts[i] <= maxSupply[ids[i]], "Exceeds max supply");
130
+ tokenSupply[ids[i]] += amounts[i];
131
+ }
132
+
133
+ _mintBatch(to, ids, amounts, "");
134
+ }
135
+
136
+ function burn(
137
+ address from,
138
+ uint256 id,
139
+ uint256 amount
140
+ ) external {
141
+ require(from == msg.sender || isApprovedForAll(from, msg.sender), "Not authorized");
142
+ _burn(from, id, amount);
143
+ tokenSupply[id] -= amount;
144
+ }
145
+ }
146
+ ```
147
+
148
+ ## Metadata Standards
149
+
150
+ ### Off-Chain Metadata (IPFS)
151
+
152
+ ```json
153
+ {
154
+ "name": "NFT #1",
155
+ "description": "Description of the NFT",
156
+ "image": "ipfs://QmImageHash",
157
+ "attributes": [
158
+ {
159
+ "trait_type": "Background",
160
+ "value": "Blue"
161
+ },
162
+ {
163
+ "trait_type": "Rarity",
164
+ "value": "Legendary"
165
+ },
166
+ {
167
+ "trait_type": "Power",
168
+ "value": 95,
169
+ "display_type": "number",
170
+ "max_value": 100
171
+ }
172
+ ]
173
+ }
174
+ ```
175
+
176
+ ### On-Chain Metadata
177
+
178
+ ```solidity
179
+ contract OnChainNFT is ERC721 {
180
+ struct Traits {
181
+ uint8 background;
182
+ uint8 body;
183
+ uint8 head;
184
+ uint8 rarity;
185
+ }
186
+
187
+ mapping(uint256 => Traits) public tokenTraits;
188
+
189
+ function tokenURI(uint256 tokenId) public view override returns (string memory) {
190
+ Traits memory traits = tokenTraits[tokenId];
191
+
192
+ string memory json = Base64.encode(
193
+ bytes(
194
+ string(
195
+ abi.encodePacked(
196
+ '{"name": "NFT #', Strings.toString(tokenId), '",',
197
+ '"description": "On-chain NFT",',
198
+ '"image": "data:image/svg+xml;base64,', generateSVG(traits), '",',
199
+ '"attributes": [',
200
+ '{"trait_type": "Background", "value": "', Strings.toString(traits.background), '"},',
201
+ '{"trait_type": "Rarity", "value": "', getRarityName(traits.rarity), '"}',
202
+ ']}'
203
+ )
204
+ )
205
+ )
206
+ );
207
+
208
+ return string(abi.encodePacked("data:application/json;base64,", json));
209
+ }
210
+
211
+ function generateSVG(Traits memory traits) internal pure returns (string memory) {
212
+ return "...";
213
+ }
214
+ }
215
+ ```
216
+
217
+ ## Royalties (EIP-2981)
218
+
219
+ ```solidity
220
+ import "@openzeppelin/contracts/interfaces/IERC2981.sol";
221
+
222
+ contract NFTWithRoyalties is ERC721, IERC2981 {
223
+ address public royaltyRecipient;
224
+ uint96 public royaltyFee = 500;
225
+
226
+ constructor() ERC721("Royalty NFT", "RNFT") {
227
+ royaltyRecipient = msg.sender;
228
+ }
229
+
230
+ function royaltyInfo(uint256 tokenId, uint256 salePrice)
231
+ external
232
+ view
233
+ override
234
+ returns (address receiver, uint256 royaltyAmount)
235
+ {
236
+ return (royaltyRecipient, (salePrice * royaltyFee) / 10000);
237
+ }
238
+
239
+ function setRoyalty(address recipient, uint96 fee) external onlyOwner {
240
+ require(fee <= 1000, "Royalty fee too high");
241
+ royaltyRecipient = recipient;
242
+ royaltyFee = fee;
243
+ }
244
+
245
+ function supportsInterface(bytes4 interfaceId)
246
+ public
247
+ view
248
+ override(ERC721, IERC165)
249
+ returns (bool)
250
+ {
251
+ return interfaceId == type(IERC2981).interfaceId ||
252
+ super.supportsInterface(interfaceId);
253
+ }
254
+ }
255
+ ```
256
+
257
+ ## Soulbound Tokens (Non-Transferable)
258
+
259
+ ```solidity
260
+ contract SoulboundToken is ERC721 {
261
+ constructor() ERC721("Soulbound", "SBT") {}
262
+
263
+ function _beforeTokenTransfer(
264
+ address from,
265
+ address to,
266
+ uint256 tokenId,
267
+ uint256 batchSize
268
+ ) internal virtual override {
269
+ require(from == address(0) || to == address(0), "Token is soulbound");
270
+ super._beforeTokenTransfer(from, to, tokenId, batchSize);
271
+ }
272
+
273
+ function mint(address to) external {
274
+ uint256 tokenId = totalSupply() + 1;
275
+ _safeMint(to, tokenId);
276
+ }
277
+
278
+ function burn(uint256 tokenId) external {
279
+ require(ownerOf(tokenId) == msg.sender, "Not token owner");
280
+ _burn(tokenId);
281
+ }
282
+ }
283
+ ```
284
+
285
+ ## Dynamic NFTs
286
+
287
+ ```solidity
288
+ contract DynamicNFT is ERC721 {
289
+ struct TokenState {
290
+ uint256 level;
291
+ uint256 experience;
292
+ uint256 lastUpdated;
293
+ }
294
+
295
+ mapping(uint256 => TokenState) public tokenStates;
296
+
297
+ function gainExperience(uint256 tokenId, uint256 exp) external {
298
+ require(ownerOf(tokenId) == msg.sender, "Not token owner");
299
+
300
+ TokenState storage state = tokenStates[tokenId];
301
+ state.experience += exp;
302
+
303
+ if (state.experience >= state.level * 100) {
304
+ state.level++;
305
+ }
306
+
307
+ state.lastUpdated = block.timestamp;
308
+ }
309
+
310
+ function tokenURI(uint256 tokenId) public view override returns (string memory) {
311
+ TokenState memory state = tokenStates[tokenId];
312
+ return generateMetadata(tokenId, state);
313
+ }
314
+
315
+ function generateMetadata(uint256 tokenId, TokenState memory state)
316
+ internal
317
+ pure
318
+ returns (string memory)
319
+ {
320
+ return "";
321
+ }
322
+ }
323
+ ```
324
+
325
+ ## Gas-Optimized Minting (ERC721A)
326
+
327
+ ```solidity
328
+ import "erc721a/contracts/ERC721A.sol";
329
+
330
+ contract OptimizedNFT is ERC721A {
331
+ uint256 public constant MAX_SUPPLY = 10000;
332
+ uint256 public constant MINT_PRICE = 0.05 ether;
333
+
334
+ constructor() ERC721A("Optimized NFT", "ONFT") {}
335
+
336
+ function mint(uint256 quantity) external payable {
337
+ require(_totalMinted() + quantity <= MAX_SUPPLY, "Exceeds max supply");
338
+ require(msg.value >= MINT_PRICE * quantity, "Insufficient payment");
339
+
340
+ _mint(msg.sender, quantity);
341
+ }
342
+
343
+ function _baseURI() internal pure override returns (string memory) {
344
+ return "ipfs://QmBaseHash/";
345
+ }
346
+ }
347
+ ```
348
+
349
+ ## Best Practices
350
+
351
+ 1. **Use OpenZeppelin**: Battle-tested implementations
352
+ 2. **Pin Metadata**: Use IPFS with pinning service
353
+ 3. **Implement Royalties**: EIP-2981 for marketplace compatibility
354
+ 4. **Gas Optimization**: Use ERC721A for batch minting
355
+ 5. **Reveal Mechanism**: Placeholder → reveal pattern
356
+ 6. **Enumeration**: Support walletOfOwner for marketplaces
357
+ 7. **Whitelist**: Merkle trees for efficient whitelisting
358
+
359
+ ## Marketplace Integration
360
+
361
+ - OpenSea: ERC-721/1155, metadata standards
362
+ - LooksRare: Royalty enforcement
363
+ - Rarible: Protocol fees, lazy minting
364
+ - Blur: Gas-optimized trading