@rubix0270/arboris 1.0.0

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 (451) hide show
  1. package/README.md +151 -0
  2. package/cli/manifest.json +323 -0
  3. package/dist/cli.mjs +376 -0
  4. package/package.json +81 -0
  5. package/prisma/skills/accessibility/SKILL.md +147 -0
  6. package/prisma/skills/agent-architecture-audit/SKILL.md +257 -0
  7. package/prisma/skills/agent-eval/SKILL.md +146 -0
  8. package/prisma/skills/agent-harness-construction/SKILL.md +74 -0
  9. package/prisma/skills/agent-introspection-debugging/SKILL.md +154 -0
  10. package/prisma/skills/agent-payment-x402/SKILL.md +225 -0
  11. package/prisma/skills/agent-self-evaluation/SKILL.md +182 -0
  12. package/prisma/skills/agent-self-evaluation/examples/high-score-example.md +87 -0
  13. package/prisma/skills/agent-self-evaluation/examples/low-score-example.md +86 -0
  14. package/prisma/skills/agent-self-evaluation/references/evaluation-criteria.md +71 -0
  15. package/prisma/skills/agent-self-evaluation/references/hook-integration.md +64 -0
  16. package/prisma/skills/agent-self-evaluation/scripts/evaluate.py +408 -0
  17. package/prisma/skills/agent-self-evaluation/templates/evaluation-report.md +86 -0
  18. package/prisma/skills/agent-sort/SKILL.md +216 -0
  19. package/prisma/skills/agentic-engineering/SKILL.md +64 -0
  20. package/prisma/skills/agentic-os/SKILL.md +388 -0
  21. package/prisma/skills/ai-first-engineering/SKILL.md +52 -0
  22. package/prisma/skills/ai-regression-testing/SKILL.md +386 -0
  23. package/prisma/skills/android-clean-architecture/SKILL.md +340 -0
  24. package/prisma/skills/angular-developer/SKILL.md +155 -0
  25. package/prisma/skills/angular-developer/references/angular-animations.md +160 -0
  26. package/prisma/skills/angular-developer/references/angular-aria.md +410 -0
  27. package/prisma/skills/angular-developer/references/cli.md +86 -0
  28. package/prisma/skills/angular-developer/references/component-harnesses.md +59 -0
  29. package/prisma/skills/angular-developer/references/component-styling.md +91 -0
  30. package/prisma/skills/angular-developer/references/components.md +117 -0
  31. package/prisma/skills/angular-developer/references/creating-services.md +97 -0
  32. package/prisma/skills/angular-developer/references/data-resolvers.md +69 -0
  33. package/prisma/skills/angular-developer/references/define-routes.md +67 -0
  34. package/prisma/skills/angular-developer/references/defining-providers.md +72 -0
  35. package/prisma/skills/angular-developer/references/di-fundamentals.md +120 -0
  36. package/prisma/skills/angular-developer/references/e2e-testing.md +56 -0
  37. package/prisma/skills/angular-developer/references/effects.md +83 -0
  38. package/prisma/skills/angular-developer/references/hierarchical-injectors.md +43 -0
  39. package/prisma/skills/angular-developer/references/host-elements.md +80 -0
  40. package/prisma/skills/angular-developer/references/injection-context.md +63 -0
  41. package/prisma/skills/angular-developer/references/inputs.md +101 -0
  42. package/prisma/skills/angular-developer/references/linked-signal.md +59 -0
  43. package/prisma/skills/angular-developer/references/loading-strategies.md +61 -0
  44. package/prisma/skills/angular-developer/references/mcp.md +108 -0
  45. package/prisma/skills/angular-developer/references/navigate-to-routes.md +69 -0
  46. package/prisma/skills/angular-developer/references/outputs.md +86 -0
  47. package/prisma/skills/angular-developer/references/reactive-forms.md +122 -0
  48. package/prisma/skills/angular-developer/references/rendering-strategies.md +44 -0
  49. package/prisma/skills/angular-developer/references/resource.md +77 -0
  50. package/prisma/skills/angular-developer/references/route-animations.md +56 -0
  51. package/prisma/skills/angular-developer/references/route-guards.md +52 -0
  52. package/prisma/skills/angular-developer/references/router-lifecycle.md +45 -0
  53. package/prisma/skills/angular-developer/references/router-testing.md +87 -0
  54. package/prisma/skills/angular-developer/references/show-routes-with-outlets.md +68 -0
  55. package/prisma/skills/angular-developer/references/signal-forms.md +795 -0
  56. package/prisma/skills/angular-developer/references/signals-overview.md +94 -0
  57. package/prisma/skills/angular-developer/references/tailwind-css.md +69 -0
  58. package/prisma/skills/angular-developer/references/template-driven-forms.md +114 -0
  59. package/prisma/skills/angular-developer/references/testing-fundamentals.md +65 -0
  60. package/prisma/skills/api-connector-builder/SKILL.md +121 -0
  61. package/prisma/skills/api-design/SKILL.md +524 -0
  62. package/prisma/skills/architecture-decision-records/SKILL.md +180 -0
  63. package/prisma/skills/article-writing/SKILL.md +80 -0
  64. package/prisma/skills/automation-audit-ops/SKILL.md +143 -0
  65. package/prisma/skills/autonomous-agent-harness/SKILL.md +274 -0
  66. package/prisma/skills/autonomous-loops/SKILL.md +611 -0
  67. package/prisma/skills/backend-patterns/SKILL.md +562 -0
  68. package/prisma/skills/benchmark/SKILL.md +94 -0
  69. package/prisma/skills/benchmark-methodology/SKILL.md +190 -0
  70. package/prisma/skills/benchmark-optimization-loop/SKILL.md +70 -0
  71. package/prisma/skills/blender-motion-state-inspection/SKILL.md +165 -0
  72. package/prisma/skills/blueprint/SKILL.md +106 -0
  73. package/prisma/skills/brand-discovery/SKILL.md +145 -0
  74. package/prisma/skills/brand-discovery/references/10_purpose-why.md +40 -0
  75. package/prisma/skills/brand-discovery/references/20_positioning.md +44 -0
  76. package/prisma/skills/brand-discovery/references/30_audience-niche.md +52 -0
  77. package/prisma/skills/brand-discovery/references/40_personality-archetype.md +57 -0
  78. package/prisma/skills/brand-discovery/references/50_voice-tone.md +59 -0
  79. package/prisma/skills/brand-discovery/references/60_narrative-story.md +50 -0
  80. package/prisma/skills/brand-discovery/references/70_founder-tension.md +49 -0
  81. package/prisma/skills/brand-discovery/references/90_SYNTHESIS.md +133 -0
  82. package/prisma/skills/brand-voice/SKILL.md +98 -0
  83. package/prisma/skills/brand-voice/references/voice-profile-schema.md +55 -0
  84. package/prisma/skills/browser-qa/SKILL.md +105 -0
  85. package/prisma/skills/bun-runtime/SKILL.md +85 -0
  86. package/prisma/skills/canary-watch/SKILL.md +108 -0
  87. package/prisma/skills/carrier-relationship-management/SKILL.md +212 -0
  88. package/prisma/skills/cisco-ios-patterns/SKILL.md +164 -0
  89. package/prisma/skills/ck/SKILL.md +148 -0
  90. package/prisma/skills/ck/commands/forget.mjs +44 -0
  91. package/prisma/skills/ck/commands/info.mjs +24 -0
  92. package/prisma/skills/ck/commands/init.mjs +143 -0
  93. package/prisma/skills/ck/commands/list.mjs +40 -0
  94. package/prisma/skills/ck/commands/migrate.mjs +202 -0
  95. package/prisma/skills/ck/commands/resume.mjs +36 -0
  96. package/prisma/skills/ck/commands/save.mjs +210 -0
  97. package/prisma/skills/ck/commands/shared.mjs +387 -0
  98. package/prisma/skills/ck/hooks/session-start.mjs +224 -0
  99. package/prisma/skills/claude-devfleet/SKILL.md +112 -0
  100. package/prisma/skills/click-path-audit/SKILL.md +245 -0
  101. package/prisma/skills/clickhouse-io/SKILL.md +440 -0
  102. package/prisma/skills/code-tour/SKILL.md +254 -0
  103. package/prisma/skills/codebase-onboarding/SKILL.md +234 -0
  104. package/prisma/skills/codehealth-mcp/SKILL.md +167 -0
  105. package/prisma/skills/coding-standards/SKILL.md +551 -0
  106. package/prisma/skills/competitive-platform-analysis/SKILL.md +214 -0
  107. package/prisma/skills/competitive-report-structure/SKILL.md +162 -0
  108. package/prisma/skills/compose-multiplatform-patterns/SKILL.md +300 -0
  109. package/prisma/skills/config-gc/SKILL.md +120 -0
  110. package/prisma/skills/configure-ecc/SKILL.md +385 -0
  111. package/prisma/skills/connections-optimizer/SKILL.md +190 -0
  112. package/prisma/skills/content-engine/SKILL.md +132 -0
  113. package/prisma/skills/content-hash-cache-pattern/SKILL.md +162 -0
  114. package/prisma/skills/context-budget/SKILL.md +136 -0
  115. package/prisma/skills/continuous-agent-loop/SKILL.md +46 -0
  116. package/prisma/skills/continuous-learning/SKILL.md +132 -0
  117. package/prisma/skills/continuous-learning/config.json +18 -0
  118. package/prisma/skills/continuous-learning/evaluate-session.sh +69 -0
  119. package/prisma/skills/continuous-learning-v2/SKILL.md +361 -0
  120. package/prisma/skills/continuous-learning-v2/agents/observer-loop.sh +359 -0
  121. package/prisma/skills/continuous-learning-v2/agents/observer.md +189 -0
  122. package/prisma/skills/continuous-learning-v2/agents/session-guardian.sh +150 -0
  123. package/prisma/skills/continuous-learning-v2/agents/start-observer.sh +248 -0
  124. package/prisma/skills/continuous-learning-v2/config.json +8 -0
  125. package/prisma/skills/continuous-learning-v2/hooks/observe.sh +585 -0
  126. package/prisma/skills/continuous-learning-v2/scripts/detect-project.sh +322 -0
  127. package/prisma/skills/continuous-learning-v2/scripts/instinct-cli.py +1956 -0
  128. package/prisma/skills/continuous-learning-v2/scripts/lib/homunculus-dir.sh +31 -0
  129. package/prisma/skills/continuous-learning-v2/scripts/migrate-homunculus.sh +68 -0
  130. package/prisma/skills/continuous-learning-v2/scripts/test_parse_instinct.py +1421 -0
  131. package/prisma/skills/cost-aware-llm-pipeline/SKILL.md +184 -0
  132. package/prisma/skills/cost-tracking/SKILL.md +97 -0
  133. package/prisma/skills/council/SKILL.md +204 -0
  134. package/prisma/skills/cpp-coding-standards/SKILL.md +724 -0
  135. package/prisma/skills/cpp-testing/SKILL.md +325 -0
  136. package/prisma/skills/crosspost/SKILL.md +112 -0
  137. package/prisma/skills/csharp-testing/SKILL.md +322 -0
  138. package/prisma/skills/customer-billing-ops/SKILL.md +141 -0
  139. package/prisma/skills/customs-trade-compliance/SKILL.md +263 -0
  140. package/prisma/skills/dart-flutter-patterns/SKILL.md +564 -0
  141. package/prisma/skills/dashboard-builder/SKILL.md +109 -0
  142. package/prisma/skills/data-scraper-agent/SKILL.md +765 -0
  143. package/prisma/skills/data-throughput-accelerator/SKILL.md +73 -0
  144. package/prisma/skills/database-migrations/SKILL.md +430 -0
  145. package/prisma/skills/deep-research/SKILL.md +160 -0
  146. package/prisma/skills/defi-amm-security/SKILL.md +167 -0
  147. package/prisma/skills/delivery-gate/SKILL.md +126 -0
  148. package/prisma/skills/delivery-gate/hooks/quality-gate.py +220 -0
  149. package/prisma/skills/deployment-patterns/SKILL.md +428 -0
  150. package/prisma/skills/design-system/SKILL.md +83 -0
  151. package/prisma/skills/django-celery/SKILL.md +458 -0
  152. package/prisma/skills/django-patterns/SKILL.md +735 -0
  153. package/prisma/skills/django-security/SKILL.md +644 -0
  154. package/prisma/skills/django-tdd/SKILL.md +730 -0
  155. package/prisma/skills/django-verification/SKILL.md +470 -0
  156. package/prisma/skills/dmux-workflows/SKILL.md +192 -0
  157. package/prisma/skills/docker-patterns/SKILL.md +365 -0
  158. package/prisma/skills/documentation-lookup/SKILL.md +91 -0
  159. package/prisma/skills/dotnet-patterns/SKILL.md +322 -0
  160. package/prisma/skills/dynamic-workflow-mode/SKILL.md +124 -0
  161. package/prisma/skills/e2e-testing/SKILL.md +327 -0
  162. package/prisma/skills/ecc-guide/SKILL.md +190 -0
  163. package/prisma/skills/ecc-recipes/SKILL.md +149 -0
  164. package/prisma/skills/ecc-tools-cost-audit/SKILL.md +161 -0
  165. package/prisma/skills/email-ops/SKILL.md +122 -0
  166. package/prisma/skills/energy-procurement/SKILL.md +228 -0
  167. package/prisma/skills/enterprise-agent-ops/SKILL.md +51 -0
  168. package/prisma/skills/error-handling/SKILL.md +377 -0
  169. package/prisma/skills/eval-harness/SKILL.md +271 -0
  170. package/prisma/skills/evm-token-decimals/SKILL.md +131 -0
  171. package/prisma/skills/exa-search/SKILL.md +108 -0
  172. package/prisma/skills/fal-ai-media/SKILL.md +289 -0
  173. package/prisma/skills/fastapi-patterns/SKILL.md +514 -0
  174. package/prisma/skills/finance-billing-ops/SKILL.md +128 -0
  175. package/prisma/skills/flox-environments/SKILL.md +497 -0
  176. package/prisma/skills/flutter-dart-code-review/SKILL.md +436 -0
  177. package/prisma/skills/foundation-models-on-device/SKILL.md +243 -0
  178. package/prisma/skills/frontend-a11y/SKILL.md +446 -0
  179. package/prisma/skills/frontend-design-direction/SKILL.md +93 -0
  180. package/prisma/skills/frontend-patterns/SKILL.md +657 -0
  181. package/prisma/skills/frontend-slides/SKILL.md +185 -0
  182. package/prisma/skills/frontend-slides/STYLE_PRESETS.md +330 -0
  183. package/prisma/skills/frontend-slides/animation-patterns.md +122 -0
  184. package/prisma/skills/frontend-slides/html-template.md +419 -0
  185. package/prisma/skills/frontend-slides/scripts/export-pdf.sh +418 -0
  186. package/prisma/skills/frontend-slides/scripts/extract-pptx.py +96 -0
  187. package/prisma/skills/frontend-slides/viewport-base.css +153 -0
  188. package/prisma/skills/fsharp-testing/SKILL.md +281 -0
  189. package/prisma/skills/gan-style-harness/SKILL.md +279 -0
  190. package/prisma/skills/gateguard/SKILL.md +133 -0
  191. package/prisma/skills/generating-python-installer/SKILL.md +820 -0
  192. package/prisma/skills/git-workflow/SKILL.md +716 -0
  193. package/prisma/skills/github-ops/SKILL.md +145 -0
  194. package/prisma/skills/golang-patterns/SKILL.md +675 -0
  195. package/prisma/skills/golang-testing/SKILL.md +721 -0
  196. package/prisma/skills/google-workspace-ops/SKILL.md +96 -0
  197. package/prisma/skills/growth-log/SKILL.md +128 -0
  198. package/prisma/skills/healthcare-cdss-patterns/SKILL.md +246 -0
  199. package/prisma/skills/healthcare-emr-patterns/SKILL.md +160 -0
  200. package/prisma/skills/healthcare-eval-harness/SKILL.md +208 -0
  201. package/prisma/skills/healthcare-phi-compliance/SKILL.md +146 -0
  202. package/prisma/skills/hermes-imports/SKILL.md +89 -0
  203. package/prisma/skills/hexagonal-architecture/SKILL.md +277 -0
  204. package/prisma/skills/hipaa-compliance/SKILL.md +79 -0
  205. package/prisma/skills/homelab-network-readiness/SKILL.md +170 -0
  206. package/prisma/skills/homelab-network-setup/SKILL.md +130 -0
  207. package/prisma/skills/homelab-pihole-dns/SKILL.md +275 -0
  208. package/prisma/skills/homelab-vlan-segmentation/SKILL.md +312 -0
  209. package/prisma/skills/homelab-wireguard-vpn/SKILL.md +306 -0
  210. package/prisma/skills/hookify-rules/SKILL.md +128 -0
  211. package/prisma/skills/inherit-legacy-style/SKILL.md +157 -0
  212. package/prisma/skills/intent-driven-development/SKILL.md +360 -0
  213. package/prisma/skills/inventory-demand-planning/SKILL.md +247 -0
  214. package/prisma/skills/investor-materials/SKILL.md +97 -0
  215. package/prisma/skills/investor-outreach/SKILL.md +92 -0
  216. package/prisma/skills/ios-icon-gen/SKILL.md +158 -0
  217. package/prisma/skills/ios-icon-gen/scripts/generate_icons.swift +258 -0
  218. package/prisma/skills/ios-icon-gen/scripts/iconify_gen.sh +235 -0
  219. package/prisma/skills/iterative-retrieval/SKILL.md +212 -0
  220. package/prisma/skills/ito-basket-compare/SKILL.md +64 -0
  221. package/prisma/skills/ito-data-atlas-agent/SKILL.md +64 -0
  222. package/prisma/skills/ito-market-intelligence/SKILL.md +61 -0
  223. package/prisma/skills/ito-trade-planner/SKILL.md +68 -0
  224. package/prisma/skills/java-coding-standards/SKILL.md +384 -0
  225. package/prisma/skills/jira-integration/SKILL.md +303 -0
  226. package/prisma/skills/jpa-patterns/SKILL.md +152 -0
  227. package/prisma/skills/knowledge-ops/SKILL.md +155 -0
  228. package/prisma/skills/kotlin-coroutines-flows/SKILL.md +285 -0
  229. package/prisma/skills/kotlin-exposed-patterns/SKILL.md +720 -0
  230. package/prisma/skills/kotlin-ktor-patterns/SKILL.md +690 -0
  231. package/prisma/skills/kotlin-patterns/SKILL.md +712 -0
  232. package/prisma/skills/kotlin-testing/SKILL.md +825 -0
  233. package/prisma/skills/kubernetes-patterns/SKILL.md +756 -0
  234. package/prisma/skills/laravel-patterns/SKILL.md +416 -0
  235. package/prisma/skills/laravel-plugin-discovery/SKILL.md +230 -0
  236. package/prisma/skills/laravel-security/SKILL.md +948 -0
  237. package/prisma/skills/laravel-tdd/SKILL.md +675 -0
  238. package/prisma/skills/laravel-verification/SKILL.md +180 -0
  239. package/prisma/skills/latency-critical-systems/SKILL.md +74 -0
  240. package/prisma/skills/lead-intelligence/SKILL.md +322 -0
  241. package/prisma/skills/lead-intelligence/agents/enrichment-agent.md +85 -0
  242. package/prisma/skills/lead-intelligence/agents/mutual-mapper.md +75 -0
  243. package/prisma/skills/lead-intelligence/agents/outreach-drafter.md +98 -0
  244. package/prisma/skills/lead-intelligence/agents/signal-scorer.md +60 -0
  245. package/prisma/skills/liquid-glass-design/SKILL.md +279 -0
  246. package/prisma/skills/llm-trading-agent-security/SKILL.md +147 -0
  247. package/prisma/skills/logistics-exception-management/SKILL.md +222 -0
  248. package/prisma/skills/loop-design-check/SKILL.md +143 -0
  249. package/prisma/skills/mailtrap-email-integration/SKILL.md +77 -0
  250. package/prisma/skills/make-interfaces-feel-better/SKILL.md +152 -0
  251. package/prisma/skills/manim-video/SKILL.md +90 -0
  252. package/prisma/skills/manim-video/assets/network_graph_scene.py +52 -0
  253. package/prisma/skills/market-research/SKILL.md +76 -0
  254. package/prisma/skills/marketing-campaign/SKILL.md +114 -0
  255. package/prisma/skills/mcp-server-patterns/SKILL.md +70 -0
  256. package/prisma/skills/messages-ops/SKILL.md +105 -0
  257. package/prisma/skills/ml-adoption-playbook/SKILL.md +57 -0
  258. package/prisma/skills/mle-workflow/SKILL.md +347 -0
  259. package/prisma/skills/motion-advanced/SKILL.md +596 -0
  260. package/prisma/skills/motion-foundations/SKILL.md +299 -0
  261. package/prisma/skills/motion-patterns/SKILL.md +434 -0
  262. package/prisma/skills/motion-ui/SKILL.md +576 -0
  263. package/prisma/skills/mysql-patterns/SKILL.md +413 -0
  264. package/prisma/skills/nanoclaw-repl/SKILL.md +34 -0
  265. package/prisma/skills/nestjs-patterns/SKILL.md +231 -0
  266. package/prisma/skills/netmiko-ssh-automation/SKILL.md +174 -0
  267. package/prisma/skills/network-bgp-diagnostics/SKILL.md +168 -0
  268. package/prisma/skills/network-config-validation/SKILL.md +211 -0
  269. package/prisma/skills/network-interface-health/SKILL.md +153 -0
  270. package/prisma/skills/nextjs-turbopack/SKILL.md +58 -0
  271. package/prisma/skills/nodejs-keccak256/SKILL.md +103 -0
  272. package/prisma/skills/nutrient-document-processing/SKILL.md +168 -0
  273. package/prisma/skills/nuxt4-patterns/SKILL.md +101 -0
  274. package/prisma/skills/openclaw-persona-forge/SKILL.md +289 -0
  275. package/prisma/skills/openclaw-persona-forge/gacha.py +224 -0
  276. package/prisma/skills/openclaw-persona-forge/gacha.sh +5 -0
  277. package/prisma/skills/openclaw-persona-forge/references/avatar-style.md +124 -0
  278. package/prisma/skills/openclaw-persona-forge/references/boundary-rules.md +53 -0
  279. package/prisma/skills/openclaw-persona-forge/references/error-handling.md +53 -0
  280. package/prisma/skills/openclaw-persona-forge/references/identity-tension.md +48 -0
  281. package/prisma/skills/openclaw-persona-forge/references/naming-system.md +39 -0
  282. package/prisma/skills/openclaw-persona-forge/references/output-template.md +166 -0
  283. package/prisma/skills/opensource-pipeline/SKILL.md +256 -0
  284. package/prisma/skills/orch-add-feature/SKILL.md +45 -0
  285. package/prisma/skills/orch-build-mvp/SKILL.md +49 -0
  286. package/prisma/skills/orch-change-feature/SKILL.md +43 -0
  287. package/prisma/skills/orch-fix-defect/SKILL.md +43 -0
  288. package/prisma/skills/orch-pipeline/SKILL.md +121 -0
  289. package/prisma/skills/orch-refine-code/SKILL.md +44 -0
  290. package/prisma/skills/parallel-execution-optimizer/SKILL.md +73 -0
  291. package/prisma/skills/perl-patterns/SKILL.md +505 -0
  292. package/prisma/skills/perl-security/SKILL.md +504 -0
  293. package/prisma/skills/perl-testing/SKILL.md +476 -0
  294. package/prisma/skills/plan-orchestrate/SKILL.md +263 -0
  295. package/prisma/skills/plankton-code-quality/SKILL.md +237 -0
  296. package/prisma/skills/postgres-patterns/SKILL.md +148 -0
  297. package/prisma/skills/prediction-market-oracle-research/SKILL.md +64 -0
  298. package/prisma/skills/prediction-market-risk-review/SKILL.md +61 -0
  299. package/prisma/skills/prisma-patterns/SKILL.md +401 -0
  300. package/prisma/skills/product-capability/SKILL.md +142 -0
  301. package/prisma/skills/product-lens/SKILL.md +93 -0
  302. package/prisma/skills/production-audit/SKILL.md +207 -0
  303. package/prisma/skills/production-scheduling/SKILL.md +238 -0
  304. package/prisma/skills/project-flow-ops/SKILL.md +112 -0
  305. package/prisma/skills/prompt-optimizer/SKILL.md +398 -0
  306. package/prisma/skills/python-patterns/SKILL.md +751 -0
  307. package/prisma/skills/python-testing/SKILL.md +817 -0
  308. package/prisma/skills/pytorch-patterns/SKILL.md +397 -0
  309. package/prisma/skills/quality-nonconformance/SKILL.md +260 -0
  310. package/prisma/skills/quarkus-patterns/SKILL.md +723 -0
  311. package/prisma/skills/quarkus-security/SKILL.md +468 -0
  312. package/prisma/skills/quarkus-tdd/SKILL.md +812 -0
  313. package/prisma/skills/quarkus-verification/SKILL.md +480 -0
  314. package/prisma/skills/ralphinho-rfc-pipeline/SKILL.md +68 -0
  315. package/prisma/skills/react-native-patterns/SKILL.md +326 -0
  316. package/prisma/skills/react-patterns/SKILL.md +342 -0
  317. package/prisma/skills/react-performance/SKILL.md +575 -0
  318. package/prisma/skills/react-testing/SKILL.md +424 -0
  319. package/prisma/skills/recsys-pipeline-architect/SKILL.md +115 -0
  320. package/prisma/skills/recursive-decision-ledger/SKILL.md +80 -0
  321. package/prisma/skills/redis-patterns/SKILL.md +404 -0
  322. package/prisma/skills/regex-vs-llm-structured-text/SKILL.md +221 -0
  323. package/prisma/skills/remotion-video-creation/SKILL.md +43 -0
  324. package/prisma/skills/remotion-video-creation/rules/3d.md +86 -0
  325. package/prisma/skills/remotion-video-creation/rules/animations.md +29 -0
  326. package/prisma/skills/remotion-video-creation/rules/assets/charts-bar-chart.tsx +173 -0
  327. package/prisma/skills/remotion-video-creation/rules/assets/text-animations-typewriter.tsx +100 -0
  328. package/prisma/skills/remotion-video-creation/rules/assets/text-animations-word-highlight.tsx +108 -0
  329. package/prisma/skills/remotion-video-creation/rules/assets.md +78 -0
  330. package/prisma/skills/remotion-video-creation/rules/audio.md +172 -0
  331. package/prisma/skills/remotion-video-creation/rules/calculate-metadata.md +104 -0
  332. package/prisma/skills/remotion-video-creation/rules/can-decode.md +75 -0
  333. package/prisma/skills/remotion-video-creation/rules/charts.md +58 -0
  334. package/prisma/skills/remotion-video-creation/rules/compositions.md +146 -0
  335. package/prisma/skills/remotion-video-creation/rules/display-captions.md +126 -0
  336. package/prisma/skills/remotion-video-creation/rules/extract-frames.md +229 -0
  337. package/prisma/skills/remotion-video-creation/rules/fonts.md +152 -0
  338. package/prisma/skills/remotion-video-creation/rules/get-audio-duration.md +58 -0
  339. package/prisma/skills/remotion-video-creation/rules/get-video-dimensions.md +68 -0
  340. package/prisma/skills/remotion-video-creation/rules/get-video-duration.md +58 -0
  341. package/prisma/skills/remotion-video-creation/rules/gifs.md +138 -0
  342. package/prisma/skills/remotion-video-creation/rules/images.md +130 -0
  343. package/prisma/skills/remotion-video-creation/rules/import-srt-captions.md +67 -0
  344. package/prisma/skills/remotion-video-creation/rules/lottie.md +67 -0
  345. package/prisma/skills/remotion-video-creation/rules/measuring-dom-nodes.md +34 -0
  346. package/prisma/skills/remotion-video-creation/rules/measuring-text.md +143 -0
  347. package/prisma/skills/remotion-video-creation/rules/sequencing.md +106 -0
  348. package/prisma/skills/remotion-video-creation/rules/tailwind.md +11 -0
  349. package/prisma/skills/remotion-video-creation/rules/text-animations.md +20 -0
  350. package/prisma/skills/remotion-video-creation/rules/timing.md +179 -0
  351. package/prisma/skills/remotion-video-creation/rules/transcribe-captions.md +19 -0
  352. package/prisma/skills/remotion-video-creation/rules/transitions.md +122 -0
  353. package/prisma/skills/remotion-video-creation/rules/trimming.md +52 -0
  354. package/prisma/skills/remotion-video-creation/rules/videos.md +171 -0
  355. package/prisma/skills/repo-scan/SKILL.md +79 -0
  356. package/prisma/skills/research-ops/SKILL.md +113 -0
  357. package/prisma/skills/returns-reverse-logistics/SKILL.md +240 -0
  358. package/prisma/skills/rules-distill/SKILL.md +265 -0
  359. package/prisma/skills/rules-distill/scripts/scan-rules.sh +58 -0
  360. package/prisma/skills/rules-distill/scripts/scan-skills.sh +129 -0
  361. package/prisma/skills/rust-patterns/SKILL.md +500 -0
  362. package/prisma/skills/rust-testing/SKILL.md +501 -0
  363. package/prisma/skills/safety-guard/SKILL.md +76 -0
  364. package/prisma/skills/santa-method/SKILL.md +307 -0
  365. package/prisma/skills/scientific-db-pubmed-database/SKILL.md +176 -0
  366. package/prisma/skills/scientific-db-uspto-database/SKILL.md +178 -0
  367. package/prisma/skills/scientific-pkg-gget/SKILL.md +167 -0
  368. package/prisma/skills/scientific-thinking-literature-review/SKILL.md +193 -0
  369. package/prisma/skills/scientific-thinking-scholar-evaluation/SKILL.md +161 -0
  370. package/prisma/skills/search-first/SKILL.md +183 -0
  371. package/prisma/skills/security-bounty-hunter/SKILL.md +100 -0
  372. package/prisma/skills/security-review/SKILL.md +504 -0
  373. package/prisma/skills/security-review/cloud-infrastructure-security.md +361 -0
  374. package/prisma/skills/security-scan/SKILL.md +166 -0
  375. package/prisma/skills/seo/SKILL.md +155 -0
  376. package/prisma/skills/skill-comply/SKILL.md +59 -0
  377. package/prisma/skills/skill-comply/fixtures/compliant_trace.jsonl +5 -0
  378. package/prisma/skills/skill-comply/fixtures/noncompliant_trace.jsonl +3 -0
  379. package/prisma/skills/skill-comply/fixtures/tdd_spec.yaml +44 -0
  380. package/prisma/skills/skill-comply/prompts/classifier.md +24 -0
  381. package/prisma/skills/skill-comply/prompts/scenario_generator.md +62 -0
  382. package/prisma/skills/skill-comply/prompts/spec_generator.md +42 -0
  383. package/prisma/skills/skill-comply/pyproject.toml +15 -0
  384. package/prisma/skills/skill-comply/scripts/__init__.py +0 -0
  385. package/prisma/skills/skill-comply/scripts/classifier.py +85 -0
  386. package/prisma/skills/skill-comply/scripts/grader.py +124 -0
  387. package/prisma/skills/skill-comply/scripts/parser.py +107 -0
  388. package/prisma/skills/skill-comply/scripts/report.py +170 -0
  389. package/prisma/skills/skill-comply/scripts/run.py +127 -0
  390. package/prisma/skills/skill-comply/scripts/runner.py +194 -0
  391. package/prisma/skills/skill-comply/scripts/scenario_generator.py +70 -0
  392. package/prisma/skills/skill-comply/scripts/spec_generator.py +72 -0
  393. package/prisma/skills/skill-comply/scripts/utils.py +13 -0
  394. package/prisma/skills/skill-comply/tests/test_grader.py +197 -0
  395. package/prisma/skills/skill-comply/tests/test_parser.py +90 -0
  396. package/prisma/skills/skill-comply/tests/test_runner.py +172 -0
  397. package/prisma/skills/skill-scout/SKILL.md +141 -0
  398. package/prisma/skills/skill-stocktake/SKILL.md +195 -0
  399. package/prisma/skills/skill-stocktake/scripts/quick-diff.sh +87 -0
  400. package/prisma/skills/skill-stocktake/scripts/save-results.sh +56 -0
  401. package/prisma/skills/skill-stocktake/scripts/scan.sh +170 -0
  402. package/prisma/skills/social-graph-ranker/SKILL.md +155 -0
  403. package/prisma/skills/social-publisher/SKILL.md +130 -0
  404. package/prisma/skills/springboot-patterns/SKILL.md +315 -0
  405. package/prisma/skills/springboot-security/SKILL.md +273 -0
  406. package/prisma/skills/springboot-tdd/SKILL.md +159 -0
  407. package/prisma/skills/springboot-verification/SKILL.md +232 -0
  408. package/prisma/skills/strategic-compact/SKILL.md +136 -0
  409. package/prisma/skills/swift-actor-persistence/SKILL.md +144 -0
  410. package/prisma/skills/swift-concurrency-6-2/SKILL.md +216 -0
  411. package/prisma/skills/swift-protocol-di-testing/SKILL.md +191 -0
  412. package/prisma/skills/swiftui-patterns/SKILL.md +259 -0
  413. package/prisma/skills/taste/SKILL.md +264 -0
  414. package/prisma/skills/taste/references/genre-taxonomy.md +87 -0
  415. package/prisma/skills/tdd-workflow/SKILL.md +583 -0
  416. package/prisma/skills/team-agent-orchestration/SKILL.md +111 -0
  417. package/prisma/skills/team-builder/SKILL.md +169 -0
  418. package/prisma/skills/terminal-ops/SKILL.md +110 -0
  419. package/prisma/skills/tinystruct-patterns/SKILL.md +279 -0
  420. package/prisma/skills/tinystruct-patterns/references/architecture.md +90 -0
  421. package/prisma/skills/tinystruct-patterns/references/data-handling.md +60 -0
  422. package/prisma/skills/tinystruct-patterns/references/database.md +99 -0
  423. package/prisma/skills/tinystruct-patterns/references/routing.md +64 -0
  424. package/prisma/skills/tinystruct-patterns/references/system-usage.md +97 -0
  425. package/prisma/skills/tinystruct-patterns/references/testing.md +72 -0
  426. package/prisma/skills/token-budget-advisor/SKILL.md +134 -0
  427. package/prisma/skills/ui-demo/SKILL.md +466 -0
  428. package/prisma/skills/ui-to-vue/SKILL.md +135 -0
  429. package/prisma/skills/uncloud/SKILL.md +344 -0
  430. package/prisma/skills/unified-notifications-ops/SKILL.md +188 -0
  431. package/prisma/skills/verification-loop/SKILL.md +127 -0
  432. package/prisma/skills/video-editing/SKILL.md +311 -0
  433. package/prisma/skills/videodb/SKILL.md +375 -0
  434. package/prisma/skills/videodb/reference/api-reference.md +550 -0
  435. package/prisma/skills/videodb/reference/capture-reference.md +407 -0
  436. package/prisma/skills/videodb/reference/capture.md +101 -0
  437. package/prisma/skills/videodb/reference/editor.md +443 -0
  438. package/prisma/skills/videodb/reference/generative.md +331 -0
  439. package/prisma/skills/videodb/reference/rtstream-reference.md +564 -0
  440. package/prisma/skills/videodb/reference/rtstream.md +65 -0
  441. package/prisma/skills/videodb/reference/search.md +230 -0
  442. package/prisma/skills/videodb/reference/streaming.md +406 -0
  443. package/prisma/skills/videodb/reference/use-cases.md +118 -0
  444. package/prisma/skills/videodb/scripts/ws_listener.py +282 -0
  445. package/prisma/skills/visa-doc-translate/README.md +86 -0
  446. package/prisma/skills/visa-doc-translate/SKILL.md +117 -0
  447. package/prisma/skills/vite-patterns/SKILL.md +450 -0
  448. package/prisma/skills/vue-patterns/SKILL.md +471 -0
  449. package/prisma/skills/windows-desktop-e2e/SKILL.md +888 -0
  450. package/prisma/skills/workspace-surface-audit/SKILL.md +126 -0
  451. package/prisma/skills/x-api/SKILL.md +235 -0
@@ -0,0 +1,551 @@
1
+ ---
2
+ name: coding-standards
3
+ description: Baseline cross-project coding conventions for naming, readability, immutability, and code-quality review. Use detailed frontend or backend skills for framework-specific patterns.
4
+ metadata:
5
+ origin: ECC
6
+ ---
7
+
8
+ # Coding Standards & Best Practices
9
+
10
+ Baseline coding conventions applicable across projects.
11
+
12
+ This skill is the shared floor, not the detailed framework playbook.
13
+
14
+ - Use `frontend-patterns` for React, state, forms, rendering, and UI architecture.
15
+ - Use `backend-patterns` or `api-design` for repository/service layers, endpoint design, validation, and server-specific concerns.
16
+ - Use `rules/common/coding-style.md` when you need the shortest reusable rule layer instead of a full skill walkthrough.
17
+
18
+ ## When to Activate
19
+
20
+ - Starting a new project or module
21
+ - Reviewing code for quality and maintainability
22
+ - Refactoring existing code to follow conventions
23
+ - Enforcing naming, formatting, or structural consistency
24
+ - Setting up linting, formatting, or type-checking rules
25
+ - Onboarding new contributors to coding conventions
26
+
27
+ ## Scope Boundaries
28
+
29
+ Activate this skill for:
30
+ - descriptive naming
31
+ - immutability defaults
32
+ - readability, KISS, DRY, and YAGNI enforcement
33
+ - error-handling expectations and code-smell review
34
+
35
+ Do not use this skill as the primary source for:
36
+ - React composition, hooks, or rendering patterns
37
+ - backend architecture, API design, or database layering
38
+ - domain-specific framework guidance when a narrower ECC skill already exists
39
+
40
+ ## Code Quality Principles
41
+
42
+ ### 1. Readability First
43
+ - Code is read more than written
44
+ - Clear variable and function names
45
+ - Self-documenting code preferred over comments
46
+ - Consistent formatting
47
+
48
+ ### 2. KISS (Keep It Simple, Stupid)
49
+ - Simplest solution that works
50
+ - Avoid over-engineering
51
+ - No premature optimization
52
+ - Easy to understand > clever code
53
+
54
+ ### 3. DRY (Don't Repeat Yourself)
55
+ - Extract common logic into functions
56
+ - Create reusable components
57
+ - Share utilities across modules
58
+ - Avoid copy-paste programming
59
+
60
+ ### 4. YAGNI (You Aren't Gonna Need It)
61
+ - Don't build features before they're needed
62
+ - Avoid speculative generality
63
+ - Add complexity only when required
64
+ - Start simple, refactor when needed
65
+
66
+ ## TypeScript/JavaScript Standards
67
+
68
+ ### Variable Naming
69
+
70
+ ```typescript
71
+ // PASS: GOOD: Descriptive names
72
+ const marketSearchQuery = 'election'
73
+ const isUserAuthenticated = true
74
+ const totalRevenue = 1000
75
+
76
+ // FAIL: BAD: Unclear names
77
+ const q = 'election'
78
+ const flag = true
79
+ const x = 1000
80
+ ```
81
+
82
+ ### Function Naming
83
+
84
+ ```typescript
85
+ // PASS: GOOD: Verb-noun pattern
86
+ async function fetchMarketData(marketId: string) { }
87
+ function calculateSimilarity(a: number[], b: number[]) { }
88
+ function isValidEmail(email: string): boolean { }
89
+
90
+ // FAIL: BAD: Unclear or noun-only
91
+ async function market(id: string) { }
92
+ function similarity(a, b) { }
93
+ function email(e) { }
94
+ ```
95
+
96
+ ### Immutability Pattern (CRITICAL)
97
+
98
+ ```typescript
99
+ // PASS: ALWAYS use spread operator
100
+ const updatedUser = {
101
+ ...user,
102
+ name: 'New Name'
103
+ }
104
+
105
+ const updatedArray = [...items, newItem]
106
+
107
+ // FAIL: NEVER mutate directly
108
+ user.name = 'New Name' // BAD
109
+ items.push(newItem) // BAD
110
+ ```
111
+
112
+ ### Error Handling
113
+
114
+ ```typescript
115
+ // PASS: GOOD: Comprehensive error handling
116
+ async function fetchData(url: string) {
117
+ try {
118
+ const response = await fetch(url)
119
+
120
+ if (!response.ok) {
121
+ throw new Error(`HTTP ${response.status}: ${response.statusText}`)
122
+ }
123
+
124
+ return await response.json()
125
+ } catch (error) {
126
+ console.error('Fetch failed:', error)
127
+ throw new Error('Failed to fetch data')
128
+ }
129
+ }
130
+
131
+ // FAIL: BAD: No error handling
132
+ async function fetchData(url) {
133
+ const response = await fetch(url)
134
+ return response.json()
135
+ }
136
+ ```
137
+
138
+ ### Async/Await Best Practices
139
+
140
+ ```typescript
141
+ // PASS: GOOD: Parallel execution when possible
142
+ const [users, markets, stats] = await Promise.all([
143
+ fetchUsers(),
144
+ fetchMarkets(),
145
+ fetchStats()
146
+ ])
147
+
148
+ // FAIL: BAD: Sequential when unnecessary
149
+ const users = await fetchUsers()
150
+ const markets = await fetchMarkets()
151
+ const stats = await fetchStats()
152
+ ```
153
+
154
+ ### Type Safety
155
+
156
+ ```typescript
157
+ // PASS: GOOD: Proper types
158
+ interface Market {
159
+ id: string
160
+ name: string
161
+ status: 'active' | 'resolved' | 'closed'
162
+ created_at: Date
163
+ }
164
+
165
+ function getMarket(id: string): Promise<Market> {
166
+ // Implementation
167
+ }
168
+
169
+ // FAIL: BAD: Using 'any'
170
+ function getMarket(id: any): Promise<any> {
171
+ // Implementation
172
+ }
173
+ ```
174
+
175
+ ## React Best Practices
176
+
177
+ ### Component Structure
178
+
179
+ ```typescript
180
+ // PASS: GOOD: Functional component with types
181
+ interface ButtonProps {
182
+ children: React.ReactNode
183
+ onClick: () => void
184
+ disabled?: boolean
185
+ variant?: 'primary' | 'secondary'
186
+ }
187
+
188
+ export function Button({
189
+ children,
190
+ onClick,
191
+ disabled = false,
192
+ variant = 'primary'
193
+ }: ButtonProps) {
194
+ return (
195
+ <button
196
+ onClick={onClick}
197
+ disabled={disabled}
198
+ className={`btn btn-${variant}`}
199
+ >
200
+ {children}
201
+ </button>
202
+ )
203
+ }
204
+
205
+ // FAIL: BAD: No types, unclear structure
206
+ export function Button(props) {
207
+ return <button onClick={props.onClick}>{props.children}</button>
208
+ }
209
+ ```
210
+
211
+ ### Custom Hooks
212
+
213
+ ```typescript
214
+ // PASS: GOOD: Reusable custom hook
215
+ export function useDebounce<T>(value: T, delay: number): T {
216
+ const [debouncedValue, setDebouncedValue] = useState<T>(value)
217
+
218
+ useEffect(() => {
219
+ const handler = setTimeout(() => {
220
+ setDebouncedValue(value)
221
+ }, delay)
222
+
223
+ return () => clearTimeout(handler)
224
+ }, [value, delay])
225
+
226
+ return debouncedValue
227
+ }
228
+
229
+ // Usage
230
+ const debouncedQuery = useDebounce(searchQuery, 500)
231
+ ```
232
+
233
+ ### State Management
234
+
235
+ ```typescript
236
+ // PASS: GOOD: Proper state updates
237
+ const [count, setCount] = useState(0)
238
+
239
+ // Functional update for state based on previous state
240
+ setCount(prev => prev + 1)
241
+
242
+ // FAIL: BAD: Direct state reference
243
+ setCount(count + 1) // Can be stale in async scenarios
244
+ ```
245
+
246
+ ### Conditional Rendering
247
+
248
+ ```typescript
249
+ // PASS: GOOD: Clear conditional rendering
250
+ {isLoading && <Spinner />}
251
+ {error && <ErrorMessage error={error} />}
252
+ {data && <DataDisplay data={data} />}
253
+
254
+ // FAIL: BAD: Ternary hell
255
+ {isLoading ? <Spinner /> : error ? <ErrorMessage error={error} /> : data ? <DataDisplay data={data} /> : null}
256
+ ```
257
+
258
+ ## API Design Standards
259
+
260
+ ### REST API Conventions
261
+
262
+ ```
263
+ GET /api/markets # List all markets
264
+ GET /api/markets/:id # Get specific market
265
+ POST /api/markets # Create new market
266
+ PUT /api/markets/:id # Update market (full)
267
+ PATCH /api/markets/:id # Update market (partial)
268
+ DELETE /api/markets/:id # Delete market
269
+
270
+ # Query parameters for filtering
271
+ GET /api/markets?status=active&limit=10&offset=0
272
+ ```
273
+
274
+ ### Response Format
275
+
276
+ ```typescript
277
+ // PASS: GOOD: Consistent response structure
278
+ interface ApiResponse<T> {
279
+ success: boolean
280
+ data?: T
281
+ error?: string
282
+ meta?: {
283
+ total: number
284
+ page: number
285
+ limit: number
286
+ }
287
+ }
288
+
289
+ // Success response
290
+ return NextResponse.json({
291
+ success: true,
292
+ data: markets,
293
+ meta: { total: 100, page: 1, limit: 10 }
294
+ })
295
+
296
+ // Error response
297
+ return NextResponse.json({
298
+ success: false,
299
+ error: 'Invalid request'
300
+ }, { status: 400 })
301
+ ```
302
+
303
+ ### Input Validation
304
+
305
+ ```typescript
306
+ import { z } from 'zod'
307
+
308
+ // PASS: GOOD: Schema validation
309
+ const CreateMarketSchema = z.object({
310
+ name: z.string().min(1).max(200),
311
+ description: z.string().min(1).max(2000),
312
+ endDate: z.string().datetime(),
313
+ categories: z.array(z.string()).min(1)
314
+ })
315
+
316
+ export async function POST(request: Request) {
317
+ const body = await request.json()
318
+
319
+ try {
320
+ const validated = CreateMarketSchema.parse(body)
321
+ // Proceed with validated data
322
+ } catch (error) {
323
+ if (error instanceof z.ZodError) {
324
+ return NextResponse.json({
325
+ success: false,
326
+ error: 'Validation failed',
327
+ details: error.issues
328
+ }, { status: 400 })
329
+ }
330
+ }
331
+ }
332
+ ```
333
+
334
+ ## File Organization
335
+
336
+ ### Project Structure
337
+
338
+ ```
339
+ src/
340
+ ├── app/ # Next.js App Router
341
+ │ ├── api/ # API routes
342
+ │ ├── markets/ # Market pages
343
+ │ └── (auth)/ # Auth pages (route groups)
344
+ ├── components/ # React components
345
+ │ ├── ui/ # Generic UI components
346
+ │ ├── forms/ # Form components
347
+ │ └── layouts/ # Layout components
348
+ ├── hooks/ # Custom React hooks
349
+ ├── lib/ # Utilities and configs
350
+ │ ├── api/ # API clients
351
+ │ ├── utils/ # Helper functions
352
+ │ └── constants/ # Constants
353
+ ├── types/ # TypeScript types
354
+ └── styles/ # Global styles
355
+ ```
356
+
357
+ ### File Naming
358
+
359
+ ```
360
+ components/Button.tsx # PascalCase for components
361
+ hooks/useAuth.ts # camelCase with 'use' prefix
362
+ lib/formatDate.ts # camelCase for utilities
363
+ types/market.types.ts # camelCase with .types suffix
364
+ ```
365
+
366
+ ## Comments & Documentation
367
+
368
+ ### When to Comment
369
+
370
+ ```typescript
371
+ // PASS: GOOD: Explain WHY, not WHAT
372
+ // Use exponential backoff to avoid overwhelming the API during outages
373
+ const delay = Math.min(1000 * Math.pow(2, retryCount), 30000)
374
+
375
+ // Deliberately using mutation here for performance with large arrays
376
+ items.push(newItem)
377
+
378
+ // FAIL: BAD: Stating the obvious
379
+ // Increment counter by 1
380
+ count++
381
+
382
+ // Set name to user's name
383
+ name = user.name
384
+ ```
385
+
386
+ ### JSDoc for Public APIs
387
+
388
+ ```typescript
389
+ /**
390
+ * Searches markets using semantic similarity.
391
+ *
392
+ * @param query - Natural language search query
393
+ * @param limit - Maximum number of results (default: 10)
394
+ * @returns Array of markets sorted by similarity score
395
+ * @throws {Error} If OpenAI API fails or Redis unavailable
396
+ *
397
+ * @example
398
+ * ```typescript
399
+ * const results = await searchMarkets('election', 5)
400
+ * console.log(results[0].name) // "Trump vs Biden"
401
+ * ```
402
+ */
403
+ export async function searchMarkets(
404
+ query: string,
405
+ limit: number = 10
406
+ ): Promise<Market[]> {
407
+ // Implementation
408
+ }
409
+ ```
410
+
411
+ ## Performance Best Practices
412
+
413
+ ### Memoization
414
+
415
+ ```typescript
416
+ import { useMemo, useCallback } from 'react'
417
+
418
+ // PASS: GOOD: Memoize expensive computations
419
+ // Copy before sorting - Array.prototype.sort mutates in place
420
+ const sortedMarkets = useMemo(() => {
421
+ return [...markets].sort((a, b) => b.volume - a.volume)
422
+ }, [markets])
423
+
424
+ // PASS: GOOD: Memoize callbacks
425
+ const handleSearch = useCallback((query: string) => {
426
+ setSearchQuery(query)
427
+ }, [])
428
+ ```
429
+
430
+ ### Lazy Loading
431
+
432
+ ```typescript
433
+ import { lazy, Suspense } from 'react'
434
+
435
+ // PASS: GOOD: Lazy load heavy components
436
+ const HeavyChart = lazy(() => import('./HeavyChart'))
437
+
438
+ export function Dashboard() {
439
+ return (
440
+ <Suspense fallback={<Spinner />}>
441
+ <HeavyChart />
442
+ </Suspense>
443
+ )
444
+ }
445
+ ```
446
+
447
+ ### Database Queries
448
+
449
+ ```typescript
450
+ // PASS: GOOD: Select only needed columns
451
+ const { data } = await supabase
452
+ .from('markets')
453
+ .select('id, name, status')
454
+ .limit(10)
455
+
456
+ // FAIL: BAD: Select everything
457
+ const { data } = await supabase
458
+ .from('markets')
459
+ .select('*')
460
+ ```
461
+
462
+ ## Testing Standards
463
+
464
+ ### Test Structure (AAA Pattern)
465
+
466
+ ```typescript
467
+ test('calculates similarity correctly', () => {
468
+ // Arrange
469
+ const vector1 = [1, 0, 0]
470
+ const vector2 = [0, 1, 0]
471
+
472
+ // Act
473
+ const similarity = calculateCosineSimilarity(vector1, vector2)
474
+
475
+ // Assert
476
+ expect(similarity).toBe(0)
477
+ })
478
+ ```
479
+
480
+ ### Test Naming
481
+
482
+ ```typescript
483
+ // PASS: GOOD: Descriptive test names
484
+ test('returns empty array when no markets match query', () => { })
485
+ test('throws error when OpenAI API key is missing', () => { })
486
+ test('falls back to substring search when Redis unavailable', () => { })
487
+
488
+ // FAIL: BAD: Vague test names
489
+ test('works', () => { })
490
+ test('test search', () => { })
491
+ ```
492
+
493
+ ## Code Smell Detection
494
+
495
+ Watch for these anti-patterns:
496
+
497
+ ### 1. Long Functions
498
+ ```typescript
499
+ // FAIL: BAD: Function > 50 lines
500
+ function processMarketData() {
501
+ // 100 lines of code
502
+ }
503
+
504
+ // PASS: GOOD: Split into smaller functions
505
+ function processMarketData() {
506
+ const validated = validateData()
507
+ const transformed = transformData(validated)
508
+ return saveData(transformed)
509
+ }
510
+ ```
511
+
512
+ ### 2. Deep Nesting
513
+ ```typescript
514
+ // FAIL: BAD: 5+ levels of nesting
515
+ if (user) {
516
+ if (user.isAdmin) {
517
+ if (market) {
518
+ if (market.isActive) {
519
+ if (hasPermission) {
520
+ // Do something
521
+ }
522
+ }
523
+ }
524
+ }
525
+ }
526
+
527
+ // PASS: GOOD: Early returns
528
+ if (!user) return
529
+ if (!user.isAdmin) return
530
+ if (!market) return
531
+ if (!market.isActive) return
532
+ if (!hasPermission) return
533
+
534
+ // Do something
535
+ ```
536
+
537
+ ### 3. Magic Numbers
538
+ ```typescript
539
+ // FAIL: BAD: Unexplained numbers
540
+ if (retryCount > 3) { }
541
+ setTimeout(callback, 500)
542
+
543
+ // PASS: GOOD: Named constants
544
+ const MAX_RETRIES = 3
545
+ const DEBOUNCE_DELAY_MS = 500
546
+
547
+ if (retryCount > MAX_RETRIES) { }
548
+ setTimeout(callback, DEBOUNCE_DELAY_MS)
549
+ ```
550
+
551
+ **Remember**: Code quality is not negotiable. Clear, maintainable code enables rapid development and confident refactoring.