@rubix0270/arboris 1.0.1 → 1.0.3

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/package.json +8 -19
  2. package/run.mjs +10 -0
  3. package/dist/cli.mjs +0 -382
  4. package/manifest.json +0 -323
  5. package/prisma/skills/accessibility/SKILL.md +0 -147
  6. package/prisma/skills/agent-architecture-audit/SKILL.md +0 -257
  7. package/prisma/skills/agent-eval/SKILL.md +0 -146
  8. package/prisma/skills/agent-harness-construction/SKILL.md +0 -74
  9. package/prisma/skills/agent-introspection-debugging/SKILL.md +0 -154
  10. package/prisma/skills/agent-payment-x402/SKILL.md +0 -225
  11. package/prisma/skills/agent-self-evaluation/SKILL.md +0 -182
  12. package/prisma/skills/agent-self-evaluation/examples/high-score-example.md +0 -87
  13. package/prisma/skills/agent-self-evaluation/examples/low-score-example.md +0 -86
  14. package/prisma/skills/agent-self-evaluation/references/evaluation-criteria.md +0 -71
  15. package/prisma/skills/agent-self-evaluation/references/hook-integration.md +0 -64
  16. package/prisma/skills/agent-self-evaluation/scripts/evaluate.py +0 -408
  17. package/prisma/skills/agent-self-evaluation/templates/evaluation-report.md +0 -86
  18. package/prisma/skills/agent-sort/SKILL.md +0 -216
  19. package/prisma/skills/agentic-engineering/SKILL.md +0 -64
  20. package/prisma/skills/agentic-os/SKILL.md +0 -388
  21. package/prisma/skills/ai-first-engineering/SKILL.md +0 -52
  22. package/prisma/skills/ai-regression-testing/SKILL.md +0 -386
  23. package/prisma/skills/android-clean-architecture/SKILL.md +0 -340
  24. package/prisma/skills/angular-developer/SKILL.md +0 -155
  25. package/prisma/skills/angular-developer/references/angular-animations.md +0 -160
  26. package/prisma/skills/angular-developer/references/angular-aria.md +0 -410
  27. package/prisma/skills/angular-developer/references/cli.md +0 -86
  28. package/prisma/skills/angular-developer/references/component-harnesses.md +0 -59
  29. package/prisma/skills/angular-developer/references/component-styling.md +0 -91
  30. package/prisma/skills/angular-developer/references/components.md +0 -117
  31. package/prisma/skills/angular-developer/references/creating-services.md +0 -97
  32. package/prisma/skills/angular-developer/references/data-resolvers.md +0 -69
  33. package/prisma/skills/angular-developer/references/define-routes.md +0 -67
  34. package/prisma/skills/angular-developer/references/defining-providers.md +0 -72
  35. package/prisma/skills/angular-developer/references/di-fundamentals.md +0 -120
  36. package/prisma/skills/angular-developer/references/e2e-testing.md +0 -56
  37. package/prisma/skills/angular-developer/references/effects.md +0 -83
  38. package/prisma/skills/angular-developer/references/hierarchical-injectors.md +0 -43
  39. package/prisma/skills/angular-developer/references/host-elements.md +0 -80
  40. package/prisma/skills/angular-developer/references/injection-context.md +0 -63
  41. package/prisma/skills/angular-developer/references/inputs.md +0 -101
  42. package/prisma/skills/angular-developer/references/linked-signal.md +0 -59
  43. package/prisma/skills/angular-developer/references/loading-strategies.md +0 -61
  44. package/prisma/skills/angular-developer/references/mcp.md +0 -108
  45. package/prisma/skills/angular-developer/references/navigate-to-routes.md +0 -69
  46. package/prisma/skills/angular-developer/references/outputs.md +0 -86
  47. package/prisma/skills/angular-developer/references/reactive-forms.md +0 -122
  48. package/prisma/skills/angular-developer/references/rendering-strategies.md +0 -44
  49. package/prisma/skills/angular-developer/references/resource.md +0 -77
  50. package/prisma/skills/angular-developer/references/route-animations.md +0 -56
  51. package/prisma/skills/angular-developer/references/route-guards.md +0 -52
  52. package/prisma/skills/angular-developer/references/router-lifecycle.md +0 -45
  53. package/prisma/skills/angular-developer/references/router-testing.md +0 -87
  54. package/prisma/skills/angular-developer/references/show-routes-with-outlets.md +0 -68
  55. package/prisma/skills/angular-developer/references/signal-forms.md +0 -795
  56. package/prisma/skills/angular-developer/references/signals-overview.md +0 -94
  57. package/prisma/skills/angular-developer/references/tailwind-css.md +0 -69
  58. package/prisma/skills/angular-developer/references/template-driven-forms.md +0 -114
  59. package/prisma/skills/angular-developer/references/testing-fundamentals.md +0 -65
  60. package/prisma/skills/api-connector-builder/SKILL.md +0 -121
  61. package/prisma/skills/api-design/SKILL.md +0 -524
  62. package/prisma/skills/architecture-decision-records/SKILL.md +0 -180
  63. package/prisma/skills/article-writing/SKILL.md +0 -80
  64. package/prisma/skills/automation-audit-ops/SKILL.md +0 -143
  65. package/prisma/skills/autonomous-agent-harness/SKILL.md +0 -274
  66. package/prisma/skills/autonomous-loops/SKILL.md +0 -611
  67. package/prisma/skills/backend-patterns/SKILL.md +0 -562
  68. package/prisma/skills/benchmark/SKILL.md +0 -94
  69. package/prisma/skills/benchmark-methodology/SKILL.md +0 -190
  70. package/prisma/skills/benchmark-optimization-loop/SKILL.md +0 -70
  71. package/prisma/skills/blender-motion-state-inspection/SKILL.md +0 -165
  72. package/prisma/skills/blueprint/SKILL.md +0 -106
  73. package/prisma/skills/brand-discovery/SKILL.md +0 -145
  74. package/prisma/skills/brand-discovery/references/10_purpose-why.md +0 -40
  75. package/prisma/skills/brand-discovery/references/20_positioning.md +0 -44
  76. package/prisma/skills/brand-discovery/references/30_audience-niche.md +0 -52
  77. package/prisma/skills/brand-discovery/references/40_personality-archetype.md +0 -57
  78. package/prisma/skills/brand-discovery/references/50_voice-tone.md +0 -59
  79. package/prisma/skills/brand-discovery/references/60_narrative-story.md +0 -50
  80. package/prisma/skills/brand-discovery/references/70_founder-tension.md +0 -49
  81. package/prisma/skills/brand-discovery/references/90_SYNTHESIS.md +0 -133
  82. package/prisma/skills/brand-voice/SKILL.md +0 -98
  83. package/prisma/skills/brand-voice/references/voice-profile-schema.md +0 -55
  84. package/prisma/skills/browser-qa/SKILL.md +0 -105
  85. package/prisma/skills/bun-runtime/SKILL.md +0 -85
  86. package/prisma/skills/canary-watch/SKILL.md +0 -108
  87. package/prisma/skills/carrier-relationship-management/SKILL.md +0 -212
  88. package/prisma/skills/cisco-ios-patterns/SKILL.md +0 -164
  89. package/prisma/skills/ck/SKILL.md +0 -148
  90. package/prisma/skills/ck/commands/forget.mjs +0 -44
  91. package/prisma/skills/ck/commands/info.mjs +0 -24
  92. package/prisma/skills/ck/commands/init.mjs +0 -143
  93. package/prisma/skills/ck/commands/list.mjs +0 -40
  94. package/prisma/skills/ck/commands/migrate.mjs +0 -202
  95. package/prisma/skills/ck/commands/resume.mjs +0 -36
  96. package/prisma/skills/ck/commands/save.mjs +0 -210
  97. package/prisma/skills/ck/commands/shared.mjs +0 -387
  98. package/prisma/skills/ck/hooks/session-start.mjs +0 -224
  99. package/prisma/skills/claude-devfleet/SKILL.md +0 -112
  100. package/prisma/skills/click-path-audit/SKILL.md +0 -245
  101. package/prisma/skills/clickhouse-io/SKILL.md +0 -440
  102. package/prisma/skills/code-tour/SKILL.md +0 -254
  103. package/prisma/skills/codebase-onboarding/SKILL.md +0 -234
  104. package/prisma/skills/codehealth-mcp/SKILL.md +0 -167
  105. package/prisma/skills/coding-standards/SKILL.md +0 -551
  106. package/prisma/skills/competitive-platform-analysis/SKILL.md +0 -214
  107. package/prisma/skills/competitive-report-structure/SKILL.md +0 -162
  108. package/prisma/skills/compose-multiplatform-patterns/SKILL.md +0 -300
  109. package/prisma/skills/config-gc/SKILL.md +0 -120
  110. package/prisma/skills/configure-ecc/SKILL.md +0 -385
  111. package/prisma/skills/connections-optimizer/SKILL.md +0 -190
  112. package/prisma/skills/content-engine/SKILL.md +0 -132
  113. package/prisma/skills/content-hash-cache-pattern/SKILL.md +0 -162
  114. package/prisma/skills/context-budget/SKILL.md +0 -136
  115. package/prisma/skills/continuous-agent-loop/SKILL.md +0 -46
  116. package/prisma/skills/continuous-learning/SKILL.md +0 -132
  117. package/prisma/skills/continuous-learning/config.json +0 -18
  118. package/prisma/skills/continuous-learning/evaluate-session.sh +0 -69
  119. package/prisma/skills/continuous-learning-v2/SKILL.md +0 -361
  120. package/prisma/skills/continuous-learning-v2/agents/observer-loop.sh +0 -359
  121. package/prisma/skills/continuous-learning-v2/agents/observer.md +0 -189
  122. package/prisma/skills/continuous-learning-v2/agents/session-guardian.sh +0 -150
  123. package/prisma/skills/continuous-learning-v2/agents/start-observer.sh +0 -248
  124. package/prisma/skills/continuous-learning-v2/config.json +0 -8
  125. package/prisma/skills/continuous-learning-v2/hooks/observe.sh +0 -585
  126. package/prisma/skills/continuous-learning-v2/scripts/detect-project.sh +0 -322
  127. package/prisma/skills/continuous-learning-v2/scripts/instinct-cli.py +0 -1956
  128. package/prisma/skills/continuous-learning-v2/scripts/lib/homunculus-dir.sh +0 -31
  129. package/prisma/skills/continuous-learning-v2/scripts/migrate-homunculus.sh +0 -68
  130. package/prisma/skills/continuous-learning-v2/scripts/test_parse_instinct.py +0 -1421
  131. package/prisma/skills/cost-aware-llm-pipeline/SKILL.md +0 -184
  132. package/prisma/skills/cost-tracking/SKILL.md +0 -97
  133. package/prisma/skills/council/SKILL.md +0 -204
  134. package/prisma/skills/cpp-coding-standards/SKILL.md +0 -724
  135. package/prisma/skills/cpp-testing/SKILL.md +0 -325
  136. package/prisma/skills/crosspost/SKILL.md +0 -112
  137. package/prisma/skills/csharp-testing/SKILL.md +0 -322
  138. package/prisma/skills/customer-billing-ops/SKILL.md +0 -141
  139. package/prisma/skills/customs-trade-compliance/SKILL.md +0 -263
  140. package/prisma/skills/dart-flutter-patterns/SKILL.md +0 -564
  141. package/prisma/skills/dashboard-builder/SKILL.md +0 -109
  142. package/prisma/skills/data-scraper-agent/SKILL.md +0 -765
  143. package/prisma/skills/data-throughput-accelerator/SKILL.md +0 -73
  144. package/prisma/skills/database-migrations/SKILL.md +0 -430
  145. package/prisma/skills/deep-research/SKILL.md +0 -160
  146. package/prisma/skills/defi-amm-security/SKILL.md +0 -167
  147. package/prisma/skills/delivery-gate/SKILL.md +0 -126
  148. package/prisma/skills/delivery-gate/hooks/quality-gate.py +0 -220
  149. package/prisma/skills/deployment-patterns/SKILL.md +0 -428
  150. package/prisma/skills/design-system/SKILL.md +0 -83
  151. package/prisma/skills/django-celery/SKILL.md +0 -458
  152. package/prisma/skills/django-patterns/SKILL.md +0 -735
  153. package/prisma/skills/django-security/SKILL.md +0 -644
  154. package/prisma/skills/django-tdd/SKILL.md +0 -730
  155. package/prisma/skills/django-verification/SKILL.md +0 -470
  156. package/prisma/skills/dmux-workflows/SKILL.md +0 -192
  157. package/prisma/skills/docker-patterns/SKILL.md +0 -365
  158. package/prisma/skills/documentation-lookup/SKILL.md +0 -91
  159. package/prisma/skills/dotnet-patterns/SKILL.md +0 -322
  160. package/prisma/skills/dynamic-workflow-mode/SKILL.md +0 -124
  161. package/prisma/skills/e2e-testing/SKILL.md +0 -327
  162. package/prisma/skills/ecc-guide/SKILL.md +0 -190
  163. package/prisma/skills/ecc-recipes/SKILL.md +0 -149
  164. package/prisma/skills/ecc-tools-cost-audit/SKILL.md +0 -161
  165. package/prisma/skills/email-ops/SKILL.md +0 -122
  166. package/prisma/skills/energy-procurement/SKILL.md +0 -228
  167. package/prisma/skills/enterprise-agent-ops/SKILL.md +0 -51
  168. package/prisma/skills/error-handling/SKILL.md +0 -377
  169. package/prisma/skills/eval-harness/SKILL.md +0 -271
  170. package/prisma/skills/evm-token-decimals/SKILL.md +0 -131
  171. package/prisma/skills/exa-search/SKILL.md +0 -108
  172. package/prisma/skills/fal-ai-media/SKILL.md +0 -289
  173. package/prisma/skills/fastapi-patterns/SKILL.md +0 -514
  174. package/prisma/skills/finance-billing-ops/SKILL.md +0 -128
  175. package/prisma/skills/flox-environments/SKILL.md +0 -497
  176. package/prisma/skills/flutter-dart-code-review/SKILL.md +0 -436
  177. package/prisma/skills/foundation-models-on-device/SKILL.md +0 -243
  178. package/prisma/skills/frontend-a11y/SKILL.md +0 -446
  179. package/prisma/skills/frontend-design-direction/SKILL.md +0 -93
  180. package/prisma/skills/frontend-patterns/SKILL.md +0 -657
  181. package/prisma/skills/frontend-slides/SKILL.md +0 -185
  182. package/prisma/skills/frontend-slides/STYLE_PRESETS.md +0 -330
  183. package/prisma/skills/frontend-slides/animation-patterns.md +0 -122
  184. package/prisma/skills/frontend-slides/html-template.md +0 -419
  185. package/prisma/skills/frontend-slides/scripts/export-pdf.sh +0 -418
  186. package/prisma/skills/frontend-slides/scripts/extract-pptx.py +0 -96
  187. package/prisma/skills/frontend-slides/viewport-base.css +0 -153
  188. package/prisma/skills/fsharp-testing/SKILL.md +0 -281
  189. package/prisma/skills/gan-style-harness/SKILL.md +0 -279
  190. package/prisma/skills/gateguard/SKILL.md +0 -133
  191. package/prisma/skills/generating-python-installer/SKILL.md +0 -820
  192. package/prisma/skills/git-workflow/SKILL.md +0 -716
  193. package/prisma/skills/github-ops/SKILL.md +0 -145
  194. package/prisma/skills/golang-patterns/SKILL.md +0 -675
  195. package/prisma/skills/golang-testing/SKILL.md +0 -721
  196. package/prisma/skills/google-workspace-ops/SKILL.md +0 -96
  197. package/prisma/skills/growth-log/SKILL.md +0 -128
  198. package/prisma/skills/healthcare-cdss-patterns/SKILL.md +0 -246
  199. package/prisma/skills/healthcare-emr-patterns/SKILL.md +0 -160
  200. package/prisma/skills/healthcare-eval-harness/SKILL.md +0 -208
  201. package/prisma/skills/healthcare-phi-compliance/SKILL.md +0 -146
  202. package/prisma/skills/hermes-imports/SKILL.md +0 -89
  203. package/prisma/skills/hexagonal-architecture/SKILL.md +0 -277
  204. package/prisma/skills/hipaa-compliance/SKILL.md +0 -79
  205. package/prisma/skills/homelab-network-readiness/SKILL.md +0 -170
  206. package/prisma/skills/homelab-network-setup/SKILL.md +0 -130
  207. package/prisma/skills/homelab-pihole-dns/SKILL.md +0 -275
  208. package/prisma/skills/homelab-vlan-segmentation/SKILL.md +0 -312
  209. package/prisma/skills/homelab-wireguard-vpn/SKILL.md +0 -306
  210. package/prisma/skills/hookify-rules/SKILL.md +0 -128
  211. package/prisma/skills/inherit-legacy-style/SKILL.md +0 -157
  212. package/prisma/skills/intent-driven-development/SKILL.md +0 -360
  213. package/prisma/skills/inventory-demand-planning/SKILL.md +0 -247
  214. package/prisma/skills/investor-materials/SKILL.md +0 -97
  215. package/prisma/skills/investor-outreach/SKILL.md +0 -92
  216. package/prisma/skills/ios-icon-gen/SKILL.md +0 -158
  217. package/prisma/skills/ios-icon-gen/scripts/generate_icons.swift +0 -258
  218. package/prisma/skills/ios-icon-gen/scripts/iconify_gen.sh +0 -235
  219. package/prisma/skills/iterative-retrieval/SKILL.md +0 -212
  220. package/prisma/skills/ito-basket-compare/SKILL.md +0 -64
  221. package/prisma/skills/ito-data-atlas-agent/SKILL.md +0 -64
  222. package/prisma/skills/ito-market-intelligence/SKILL.md +0 -61
  223. package/prisma/skills/ito-trade-planner/SKILL.md +0 -68
  224. package/prisma/skills/java-coding-standards/SKILL.md +0 -384
  225. package/prisma/skills/jira-integration/SKILL.md +0 -303
  226. package/prisma/skills/jpa-patterns/SKILL.md +0 -152
  227. package/prisma/skills/knowledge-ops/SKILL.md +0 -155
  228. package/prisma/skills/kotlin-coroutines-flows/SKILL.md +0 -285
  229. package/prisma/skills/kotlin-exposed-patterns/SKILL.md +0 -720
  230. package/prisma/skills/kotlin-ktor-patterns/SKILL.md +0 -690
  231. package/prisma/skills/kotlin-patterns/SKILL.md +0 -712
  232. package/prisma/skills/kotlin-testing/SKILL.md +0 -825
  233. package/prisma/skills/kubernetes-patterns/SKILL.md +0 -756
  234. package/prisma/skills/laravel-patterns/SKILL.md +0 -416
  235. package/prisma/skills/laravel-plugin-discovery/SKILL.md +0 -230
  236. package/prisma/skills/laravel-security/SKILL.md +0 -948
  237. package/prisma/skills/laravel-tdd/SKILL.md +0 -675
  238. package/prisma/skills/laravel-verification/SKILL.md +0 -180
  239. package/prisma/skills/latency-critical-systems/SKILL.md +0 -74
  240. package/prisma/skills/lead-intelligence/SKILL.md +0 -322
  241. package/prisma/skills/lead-intelligence/agents/enrichment-agent.md +0 -85
  242. package/prisma/skills/lead-intelligence/agents/mutual-mapper.md +0 -75
  243. package/prisma/skills/lead-intelligence/agents/outreach-drafter.md +0 -98
  244. package/prisma/skills/lead-intelligence/agents/signal-scorer.md +0 -60
  245. package/prisma/skills/liquid-glass-design/SKILL.md +0 -279
  246. package/prisma/skills/llm-trading-agent-security/SKILL.md +0 -147
  247. package/prisma/skills/logistics-exception-management/SKILL.md +0 -222
  248. package/prisma/skills/loop-design-check/SKILL.md +0 -143
  249. package/prisma/skills/mailtrap-email-integration/SKILL.md +0 -77
  250. package/prisma/skills/make-interfaces-feel-better/SKILL.md +0 -152
  251. package/prisma/skills/manim-video/SKILL.md +0 -90
  252. package/prisma/skills/manim-video/assets/network_graph_scene.py +0 -52
  253. package/prisma/skills/market-research/SKILL.md +0 -76
  254. package/prisma/skills/marketing-campaign/SKILL.md +0 -114
  255. package/prisma/skills/mcp-server-patterns/SKILL.md +0 -70
  256. package/prisma/skills/messages-ops/SKILL.md +0 -105
  257. package/prisma/skills/ml-adoption-playbook/SKILL.md +0 -57
  258. package/prisma/skills/mle-workflow/SKILL.md +0 -347
  259. package/prisma/skills/motion-advanced/SKILL.md +0 -596
  260. package/prisma/skills/motion-foundations/SKILL.md +0 -299
  261. package/prisma/skills/motion-patterns/SKILL.md +0 -434
  262. package/prisma/skills/motion-ui/SKILL.md +0 -576
  263. package/prisma/skills/mysql-patterns/SKILL.md +0 -413
  264. package/prisma/skills/nanoclaw-repl/SKILL.md +0 -34
  265. package/prisma/skills/nestjs-patterns/SKILL.md +0 -231
  266. package/prisma/skills/netmiko-ssh-automation/SKILL.md +0 -174
  267. package/prisma/skills/network-bgp-diagnostics/SKILL.md +0 -168
  268. package/prisma/skills/network-config-validation/SKILL.md +0 -211
  269. package/prisma/skills/network-interface-health/SKILL.md +0 -153
  270. package/prisma/skills/nextjs-turbopack/SKILL.md +0 -58
  271. package/prisma/skills/nodejs-keccak256/SKILL.md +0 -103
  272. package/prisma/skills/nutrient-document-processing/SKILL.md +0 -168
  273. package/prisma/skills/nuxt4-patterns/SKILL.md +0 -101
  274. package/prisma/skills/openclaw-persona-forge/SKILL.md +0 -289
  275. package/prisma/skills/openclaw-persona-forge/gacha.py +0 -224
  276. package/prisma/skills/openclaw-persona-forge/gacha.sh +0 -5
  277. package/prisma/skills/openclaw-persona-forge/references/avatar-style.md +0 -124
  278. package/prisma/skills/openclaw-persona-forge/references/boundary-rules.md +0 -53
  279. package/prisma/skills/openclaw-persona-forge/references/error-handling.md +0 -53
  280. package/prisma/skills/openclaw-persona-forge/references/identity-tension.md +0 -48
  281. package/prisma/skills/openclaw-persona-forge/references/naming-system.md +0 -39
  282. package/prisma/skills/openclaw-persona-forge/references/output-template.md +0 -166
  283. package/prisma/skills/opensource-pipeline/SKILL.md +0 -256
  284. package/prisma/skills/orch-add-feature/SKILL.md +0 -45
  285. package/prisma/skills/orch-build-mvp/SKILL.md +0 -49
  286. package/prisma/skills/orch-change-feature/SKILL.md +0 -43
  287. package/prisma/skills/orch-fix-defect/SKILL.md +0 -43
  288. package/prisma/skills/orch-pipeline/SKILL.md +0 -121
  289. package/prisma/skills/orch-refine-code/SKILL.md +0 -44
  290. package/prisma/skills/parallel-execution-optimizer/SKILL.md +0 -73
  291. package/prisma/skills/perl-patterns/SKILL.md +0 -505
  292. package/prisma/skills/perl-security/SKILL.md +0 -504
  293. package/prisma/skills/perl-testing/SKILL.md +0 -476
  294. package/prisma/skills/plan-orchestrate/SKILL.md +0 -263
  295. package/prisma/skills/plankton-code-quality/SKILL.md +0 -237
  296. package/prisma/skills/postgres-patterns/SKILL.md +0 -148
  297. package/prisma/skills/prediction-market-oracle-research/SKILL.md +0 -64
  298. package/prisma/skills/prediction-market-risk-review/SKILL.md +0 -61
  299. package/prisma/skills/prisma-patterns/SKILL.md +0 -401
  300. package/prisma/skills/product-capability/SKILL.md +0 -142
  301. package/prisma/skills/product-lens/SKILL.md +0 -93
  302. package/prisma/skills/production-audit/SKILL.md +0 -207
  303. package/prisma/skills/production-scheduling/SKILL.md +0 -238
  304. package/prisma/skills/project-flow-ops/SKILL.md +0 -112
  305. package/prisma/skills/prompt-optimizer/SKILL.md +0 -398
  306. package/prisma/skills/python-patterns/SKILL.md +0 -751
  307. package/prisma/skills/python-testing/SKILL.md +0 -817
  308. package/prisma/skills/pytorch-patterns/SKILL.md +0 -397
  309. package/prisma/skills/quality-nonconformance/SKILL.md +0 -260
  310. package/prisma/skills/quarkus-patterns/SKILL.md +0 -723
  311. package/prisma/skills/quarkus-security/SKILL.md +0 -468
  312. package/prisma/skills/quarkus-tdd/SKILL.md +0 -812
  313. package/prisma/skills/quarkus-verification/SKILL.md +0 -480
  314. package/prisma/skills/ralphinho-rfc-pipeline/SKILL.md +0 -68
  315. package/prisma/skills/react-native-patterns/SKILL.md +0 -326
  316. package/prisma/skills/react-patterns/SKILL.md +0 -342
  317. package/prisma/skills/react-performance/SKILL.md +0 -575
  318. package/prisma/skills/react-testing/SKILL.md +0 -424
  319. package/prisma/skills/recsys-pipeline-architect/SKILL.md +0 -115
  320. package/prisma/skills/recursive-decision-ledger/SKILL.md +0 -80
  321. package/prisma/skills/redis-patterns/SKILL.md +0 -404
  322. package/prisma/skills/regex-vs-llm-structured-text/SKILL.md +0 -221
  323. package/prisma/skills/remotion-video-creation/SKILL.md +0 -43
  324. package/prisma/skills/remotion-video-creation/rules/3d.md +0 -86
  325. package/prisma/skills/remotion-video-creation/rules/animations.md +0 -29
  326. package/prisma/skills/remotion-video-creation/rules/assets/charts-bar-chart.tsx +0 -173
  327. package/prisma/skills/remotion-video-creation/rules/assets/text-animations-typewriter.tsx +0 -100
  328. package/prisma/skills/remotion-video-creation/rules/assets/text-animations-word-highlight.tsx +0 -108
  329. package/prisma/skills/remotion-video-creation/rules/assets.md +0 -78
  330. package/prisma/skills/remotion-video-creation/rules/audio.md +0 -172
  331. package/prisma/skills/remotion-video-creation/rules/calculate-metadata.md +0 -104
  332. package/prisma/skills/remotion-video-creation/rules/can-decode.md +0 -75
  333. package/prisma/skills/remotion-video-creation/rules/charts.md +0 -58
  334. package/prisma/skills/remotion-video-creation/rules/compositions.md +0 -146
  335. package/prisma/skills/remotion-video-creation/rules/display-captions.md +0 -126
  336. package/prisma/skills/remotion-video-creation/rules/extract-frames.md +0 -229
  337. package/prisma/skills/remotion-video-creation/rules/fonts.md +0 -152
  338. package/prisma/skills/remotion-video-creation/rules/get-audio-duration.md +0 -58
  339. package/prisma/skills/remotion-video-creation/rules/get-video-dimensions.md +0 -68
  340. package/prisma/skills/remotion-video-creation/rules/get-video-duration.md +0 -58
  341. package/prisma/skills/remotion-video-creation/rules/gifs.md +0 -138
  342. package/prisma/skills/remotion-video-creation/rules/images.md +0 -130
  343. package/prisma/skills/remotion-video-creation/rules/import-srt-captions.md +0 -67
  344. package/prisma/skills/remotion-video-creation/rules/lottie.md +0 -67
  345. package/prisma/skills/remotion-video-creation/rules/measuring-dom-nodes.md +0 -34
  346. package/prisma/skills/remotion-video-creation/rules/measuring-text.md +0 -143
  347. package/prisma/skills/remotion-video-creation/rules/sequencing.md +0 -106
  348. package/prisma/skills/remotion-video-creation/rules/tailwind.md +0 -11
  349. package/prisma/skills/remotion-video-creation/rules/text-animations.md +0 -20
  350. package/prisma/skills/remotion-video-creation/rules/timing.md +0 -179
  351. package/prisma/skills/remotion-video-creation/rules/transcribe-captions.md +0 -19
  352. package/prisma/skills/remotion-video-creation/rules/transitions.md +0 -122
  353. package/prisma/skills/remotion-video-creation/rules/trimming.md +0 -52
  354. package/prisma/skills/remotion-video-creation/rules/videos.md +0 -171
  355. package/prisma/skills/repo-scan/SKILL.md +0 -79
  356. package/prisma/skills/research-ops/SKILL.md +0 -113
  357. package/prisma/skills/returns-reverse-logistics/SKILL.md +0 -240
  358. package/prisma/skills/rules-distill/SKILL.md +0 -265
  359. package/prisma/skills/rules-distill/scripts/scan-rules.sh +0 -58
  360. package/prisma/skills/rules-distill/scripts/scan-skills.sh +0 -129
  361. package/prisma/skills/rust-patterns/SKILL.md +0 -500
  362. package/prisma/skills/rust-testing/SKILL.md +0 -501
  363. package/prisma/skills/safety-guard/SKILL.md +0 -76
  364. package/prisma/skills/santa-method/SKILL.md +0 -307
  365. package/prisma/skills/scientific-db-pubmed-database/SKILL.md +0 -176
  366. package/prisma/skills/scientific-db-uspto-database/SKILL.md +0 -178
  367. package/prisma/skills/scientific-pkg-gget/SKILL.md +0 -167
  368. package/prisma/skills/scientific-thinking-literature-review/SKILL.md +0 -193
  369. package/prisma/skills/scientific-thinking-scholar-evaluation/SKILL.md +0 -161
  370. package/prisma/skills/search-first/SKILL.md +0 -183
  371. package/prisma/skills/security-bounty-hunter/SKILL.md +0 -100
  372. package/prisma/skills/security-review/SKILL.md +0 -504
  373. package/prisma/skills/security-review/cloud-infrastructure-security.md +0 -361
  374. package/prisma/skills/security-scan/SKILL.md +0 -166
  375. package/prisma/skills/seo/SKILL.md +0 -155
  376. package/prisma/skills/skill-comply/SKILL.md +0 -59
  377. package/prisma/skills/skill-comply/fixtures/compliant_trace.jsonl +0 -5
  378. package/prisma/skills/skill-comply/fixtures/noncompliant_trace.jsonl +0 -3
  379. package/prisma/skills/skill-comply/fixtures/tdd_spec.yaml +0 -44
  380. package/prisma/skills/skill-comply/prompts/classifier.md +0 -24
  381. package/prisma/skills/skill-comply/prompts/scenario_generator.md +0 -62
  382. package/prisma/skills/skill-comply/prompts/spec_generator.md +0 -42
  383. package/prisma/skills/skill-comply/pyproject.toml +0 -15
  384. package/prisma/skills/skill-comply/scripts/__init__.py +0 -0
  385. package/prisma/skills/skill-comply/scripts/classifier.py +0 -85
  386. package/prisma/skills/skill-comply/scripts/grader.py +0 -124
  387. package/prisma/skills/skill-comply/scripts/parser.py +0 -107
  388. package/prisma/skills/skill-comply/scripts/report.py +0 -170
  389. package/prisma/skills/skill-comply/scripts/run.py +0 -127
  390. package/prisma/skills/skill-comply/scripts/runner.py +0 -194
  391. package/prisma/skills/skill-comply/scripts/scenario_generator.py +0 -70
  392. package/prisma/skills/skill-comply/scripts/spec_generator.py +0 -72
  393. package/prisma/skills/skill-comply/scripts/utils.py +0 -13
  394. package/prisma/skills/skill-comply/tests/test_grader.py +0 -197
  395. package/prisma/skills/skill-comply/tests/test_parser.py +0 -90
  396. package/prisma/skills/skill-comply/tests/test_runner.py +0 -172
  397. package/prisma/skills/skill-scout/SKILL.md +0 -141
  398. package/prisma/skills/skill-stocktake/SKILL.md +0 -195
  399. package/prisma/skills/skill-stocktake/scripts/quick-diff.sh +0 -87
  400. package/prisma/skills/skill-stocktake/scripts/save-results.sh +0 -56
  401. package/prisma/skills/skill-stocktake/scripts/scan.sh +0 -170
  402. package/prisma/skills/social-graph-ranker/SKILL.md +0 -155
  403. package/prisma/skills/social-publisher/SKILL.md +0 -130
  404. package/prisma/skills/springboot-patterns/SKILL.md +0 -315
  405. package/prisma/skills/springboot-security/SKILL.md +0 -273
  406. package/prisma/skills/springboot-tdd/SKILL.md +0 -159
  407. package/prisma/skills/springboot-verification/SKILL.md +0 -232
  408. package/prisma/skills/strategic-compact/SKILL.md +0 -136
  409. package/prisma/skills/swift-actor-persistence/SKILL.md +0 -144
  410. package/prisma/skills/swift-concurrency-6-2/SKILL.md +0 -216
  411. package/prisma/skills/swift-protocol-di-testing/SKILL.md +0 -191
  412. package/prisma/skills/swiftui-patterns/SKILL.md +0 -259
  413. package/prisma/skills/taste/SKILL.md +0 -264
  414. package/prisma/skills/taste/references/genre-taxonomy.md +0 -87
  415. package/prisma/skills/tdd-workflow/SKILL.md +0 -583
  416. package/prisma/skills/team-agent-orchestration/SKILL.md +0 -111
  417. package/prisma/skills/team-builder/SKILL.md +0 -169
  418. package/prisma/skills/terminal-ops/SKILL.md +0 -110
  419. package/prisma/skills/tinystruct-patterns/SKILL.md +0 -279
  420. package/prisma/skills/tinystruct-patterns/references/architecture.md +0 -90
  421. package/prisma/skills/tinystruct-patterns/references/data-handling.md +0 -60
  422. package/prisma/skills/tinystruct-patterns/references/database.md +0 -99
  423. package/prisma/skills/tinystruct-patterns/references/routing.md +0 -64
  424. package/prisma/skills/tinystruct-patterns/references/system-usage.md +0 -97
  425. package/prisma/skills/tinystruct-patterns/references/testing.md +0 -72
  426. package/prisma/skills/token-budget-advisor/SKILL.md +0 -134
  427. package/prisma/skills/ui-demo/SKILL.md +0 -466
  428. package/prisma/skills/ui-to-vue/SKILL.md +0 -135
  429. package/prisma/skills/uncloud/SKILL.md +0 -344
  430. package/prisma/skills/unified-notifications-ops/SKILL.md +0 -188
  431. package/prisma/skills/verification-loop/SKILL.md +0 -127
  432. package/prisma/skills/video-editing/SKILL.md +0 -311
  433. package/prisma/skills/videodb/SKILL.md +0 -375
  434. package/prisma/skills/videodb/reference/api-reference.md +0 -550
  435. package/prisma/skills/videodb/reference/capture-reference.md +0 -407
  436. package/prisma/skills/videodb/reference/capture.md +0 -101
  437. package/prisma/skills/videodb/reference/editor.md +0 -443
  438. package/prisma/skills/videodb/reference/generative.md +0 -331
  439. package/prisma/skills/videodb/reference/rtstream-reference.md +0 -564
  440. package/prisma/skills/videodb/reference/rtstream.md +0 -65
  441. package/prisma/skills/videodb/reference/search.md +0 -230
  442. package/prisma/skills/videodb/reference/streaming.md +0 -406
  443. package/prisma/skills/videodb/reference/use-cases.md +0 -118
  444. package/prisma/skills/videodb/scripts/ws_listener.py +0 -282
  445. package/prisma/skills/visa-doc-translate/README.md +0 -86
  446. package/prisma/skills/visa-doc-translate/SKILL.md +0 -117
  447. package/prisma/skills/vite-patterns/SKILL.md +0 -450
  448. package/prisma/skills/vue-patterns/SKILL.md +0 -471
  449. package/prisma/skills/windows-desktop-e2e/SKILL.md +0 -888
  450. package/prisma/skills/workspace-surface-audit/SKILL.md +0 -126
  451. package/prisma/skills/x-api/SKILL.md +0 -235
@@ -1,575 +0,0 @@
1
- ---
2
- name: react-performance
3
- description: React and Next.js performance optimization patterns adapted from Vercel Engineering's React Best Practices (https://github.com/vercel-labs/agent-skills). Organizes 70+ rules across 8 priority categories — waterfalls, bundle size, server-side, client fetching, re-render, rendering, JS micro-perf, advanced. Use when writing, reviewing, or refactoring React/Next.js code for performance.
4
- metadata:
5
- origin: ECC
6
- ---
7
-
8
- # React Performance
9
-
10
- Performance optimization patterns for React 18/19 and Next.js, adapted from [Vercel Labs `react-best-practices`](https://github.com/vercel-labs/agent-skills/tree/main/skills/react-best-practices) (MIT, v1.0.0). This skill organizes rules by priority and provides decision-tree guidance for active code review and refactoring.
11
-
12
- ## When to Activate
13
-
14
- - Writing or reviewing React/Next.js code for performance
15
- - Diagnosing slow page loads, slow interactions, or high CPU on the client
16
- - Auditing bundle size or Lighthouse Core Web Vitals regressions
17
- - Removing waterfalls in Server Components / API routes
18
- - Reducing client-side re-renders
19
- - Optimizing long lists, animations, or hydration
20
- - Auditing optimization choices in PRs touching `app/`, `pages/`, `components/`, or data layers
21
-
22
- ## Priority Index
23
-
24
- | Priority | Category | Prefix | When it matters |
25
- |---|---|---|---|
26
- | 1 — CRITICAL | Eliminating Waterfalls | `async-` | Anytime `await` is followed by independent `await` |
27
- | 2 — CRITICAL | Bundle Size Optimization | `bundle-` | First-load JS, route-level imports, third-party libs |
28
- | 3 — HIGH | Server-Side Performance | `server-` | RSC, Server Actions, API routes, SSR |
29
- | 4 — MEDIUM-HIGH | Client-Side Data Fetching | `client-` | SWR / TanStack Query / raw `fetch` in hooks |
30
- | 5 — MEDIUM | Re-render Optimization | `rerender-` | High-frequency state updates, parent-child fan-out |
31
- | 6 — MEDIUM | Rendering Performance | `rendering-` | Long lists, animations, hydration |
32
- | 7 — LOW-MEDIUM | JavaScript Performance | `js-` | Hot loops, frequent allocations |
33
- | 8 — LOW | Advanced Patterns | `advanced-` | Effect-event integration, stable refs |
34
-
35
- ## 1. Eliminating Waterfalls (CRITICAL)
36
-
37
- > "Waterfalls are the #1 performance killer" — every sequential `await` adds full network latency.
38
-
39
- ### Cheap conditions before await
40
-
41
- Check sync conditions (props, env, hardcoded flags) before awaiting remote data.
42
-
43
- ```ts
44
- // INCORRECT
45
- async function Page({ id }: { id: string }) {
46
- const flag = await getFlag("show-page");
47
- if (!flag || !id) return null;
48
- const data = await getData(id);
49
- // ...
50
- }
51
-
52
- // CORRECT — short-circuit on cheap sync condition first
53
- async function Page({ id }: { id: string }) {
54
- if (!id) return null;
55
- const flag = await getFlag("show-page");
56
- if (!flag) return null;
57
- const data = await getData(id);
58
- }
59
- ```
60
-
61
- ### Defer awaits until used
62
-
63
- Move `await` into the branch that uses it.
64
-
65
- ```ts
66
- // INCORRECT — awaits before deciding it needs the data
67
- const user = await getUser(id);
68
- if (mode === "guest") return renderGuest();
69
- return renderUser(user);
70
-
71
- // CORRECT
72
- if (mode === "guest") return renderGuest();
73
- const user = await getUser(id);
74
- return renderUser(user);
75
- ```
76
-
77
- ### Promise.all for independent work
78
-
79
- ```ts
80
- // INCORRECT — sequential
81
- const user = await getUser(id);
82
- const posts = await getPosts(id);
83
- const followers = await getFollowers(id);
84
-
85
- // CORRECT — parallel
86
- const [user, posts, followers] = await Promise.all([
87
- getUser(id),
88
- getPosts(id),
89
- getFollowers(id),
90
- ]);
91
- ```
92
-
93
- ### Partial dependencies — start early, await late
94
-
95
- ```ts
96
- // CORRECT — kick off all promises, await only when each result is needed
97
- const userP = getUser(id);
98
- const postsP = getPosts(id);
99
- const profile = await getProfile(id);
100
- if (profile.private) return null;
101
- const [user, posts] = await Promise.all([userP, postsP]);
102
- ```
103
-
104
- ### Suspense for streaming
105
-
106
- Push `<Suspense>` boundaries close to the data so the page paints what it can while slower sub-trees stream in. The trade-off: layout shift when content arrives — reserve space (skeleton or `min-height`).
107
-
108
- ### Server Components: parallel through composition
109
-
110
- ```tsx
111
- // INCORRECT — sibling awaits run sequentially inside one component
112
- export default async function Page() {
113
- const user = await getUser();
114
- const cart = await getCart();
115
- return <View user={user} cart={cart} />;
116
- }
117
-
118
- // CORRECT — split into children, React runs them in parallel
119
- export default async function Page() {
120
- return (
121
- <View>
122
- <UserSection />
123
- <CartSection />
124
- </View>
125
- );
126
- }
127
- ```
128
-
129
- ## 2. Bundle Size Optimization (CRITICAL)
130
-
131
- ### Direct imports, not barrels
132
-
133
- Barrel `index.ts` files force the bundler to walk the entire module graph even when tree-shaking removes most of it. Direct imports save 200-800ms of first-load JS in many real-world apps.
134
-
135
- ```ts
136
- // INCORRECT
137
- import { Button, Card, Modal } from "@/components";
138
-
139
- // CORRECT
140
- import { Button } from "@/components/Button";
141
- import { Card } from "@/components/Card";
142
- import { Modal } from "@/components/Modal";
143
- ```
144
-
145
- Next.js 13.5+ has [Optimize Package Imports](https://nextjs.org/docs/app/api-reference/next-config-js/optimizePackageImports) that automates this for listed packages — use it; manual direct imports still required for non-listed libs.
146
-
147
- ### Statically analyzable paths
148
-
149
- ```ts
150
- // INCORRECT — defeats bundler/trace analysis
151
- const mod = await import(`./pages/${name}`);
152
-
153
- // CORRECT — explicit per branch
154
- const mod = name === "home" ? await import("./pages/home") : await import("./pages/about");
155
- ```
156
-
157
- ### Dynamic imports for heavy components
158
-
159
- ```tsx
160
- import dynamic from "next/dynamic";
161
-
162
- const HeavyChart = dynamic(() => import("./HeavyChart"), {
163
- loading: () => <Skeleton />,
164
- ssr: false, // when client-only
165
- });
166
- ```
167
-
168
- ### Defer third-party scripts
169
-
170
- Load analytics, logging, support widgets AFTER hydration. Use `next/script` with `strategy="afterInteractive"` (default) or `"lazyOnload"`.
171
-
172
- ### Conditional module loading
173
-
174
- ```tsx
175
- if (user.role === "admin") {
176
- const { AdminPanel } = await import("./admin/AdminPanel");
177
- // ...
178
- }
179
- ```
180
-
181
- ### Preload on hover/focus
182
-
183
- Trigger `<link rel="preload">` or `import()` on hover so the bundle is in cache by the time the user clicks.
184
-
185
- ## 3. Server-Side Performance (HIGH)
186
-
187
- ### Authenticate Server Actions like API routes
188
-
189
- Every `"use server"` function is a public endpoint. Authenticate AND authorize inside the action — never rely on the calling Client Component's gating.
190
-
191
- ```ts
192
- "use server";
193
- export async function deleteUser(formData: FormData) {
194
- const session = await getSession();
195
- if (!session?.user) throw new Error("Unauthorized");
196
- const targetId = String(formData.get("id"));
197
- if (session.user.role !== "admin" && session.user.id !== targetId) {
198
- throw new Error("Forbidden");
199
- }
200
- await db.user.delete({ where: { id: targetId } });
201
- }
202
- ```
203
-
204
- ### `React.cache()` for per-request deduplication
205
-
206
- ```ts
207
- import { cache } from "react";
208
-
209
- export const getUser = cache(async (id: string) => {
210
- return db.user.findUnique({ where: { id } });
211
- });
212
- ```
213
-
214
- `React.cache` dedupes within a single request. Calling `getUser("1")` from three Server Components in the same render = one DB query.
215
-
216
- ### LRU cache for cross-request data
217
-
218
- For data that does NOT change per request (config, lookup tables), cache outside React with an LRU cache or `unstable_cache`.
219
-
220
- ### Avoid duplicate serialization in RSC props
221
-
222
- When a Server Component renders the same data into multiple Client Components, the data is serialized once per consumer. Lift the Client Component up and pass children.
223
-
224
- ### Hoist static I/O to module scope
225
-
226
- ```ts
227
- // CORRECT — runs once at module load
228
- const fontData = readFileSync(fontPath);
229
-
230
- export async function Page() {
231
- return <Banner font={fontData} />;
232
- }
233
- ```
234
-
235
- ### No mutable module-level state in RSC/SSR
236
-
237
- Module state on the server is shared across all requests — a race condition between users. Use request-scoped storage (`headers()`, `cookies()`, async context) instead.
238
-
239
- ### Minimize data passed to Client Components
240
-
241
- Only serialize what the Client needs. Strip fields, paginate, project columns at the DB layer.
242
-
243
- ### Parallelize nested fetches with Promise.all per item
244
-
245
- ```ts
246
- const users = await getUsers();
247
- const enriched = await Promise.all(
248
- users.map(async (u) => ({ ...u, posts: await getPostsFor(u.id) })),
249
- );
250
- ```
251
-
252
- ### Use `after()` for non-blocking work
253
-
254
- Next.js 15 `after()` runs work after the response is sent — logging, cache warming, analytics.
255
-
256
- ```ts
257
- import { after } from "next/server";
258
- export async function GET() {
259
- const data = await getData();
260
- after(() => logAnalytics(data));
261
- return Response.json(data);
262
- }
263
- ```
264
-
265
- ## 4. Client-Side Data Fetching (MEDIUM-HIGH)
266
-
267
- ### SWR / TanStack Query for deduplication
268
-
269
- Multiple components calling `useUser(id)` should share one network request and one cache entry. Use SWR or TanStack Query — never roll your own `useEffect` + `fetch` for shared data.
270
-
271
- ### Deduplicate global event listeners
272
-
273
- ```tsx
274
- // INCORRECT — every component adds its own
275
- useEffect(() => {
276
- window.addEventListener("scroll", handler);
277
- return () => window.removeEventListener("scroll", handler);
278
- }, []);
279
-
280
- // CORRECT — single shared listener via a hook + global subject
281
- const useScroll = createScrollHook(); // singleton subject under the hood
282
- ```
283
-
284
- ### Passive listeners for scroll
285
-
286
- ```ts
287
- window.addEventListener("scroll", handler, { passive: true });
288
- ```
289
-
290
- Improves scrolling smoothness; the listener cannot `preventDefault()`.
291
-
292
- ### localStorage: version + minimize
293
-
294
- - Always store a `version` field; bump on schema change and migrate or discard old data
295
- - Keep payloads small — `localStorage` is synchronous and blocks main thread
296
-
297
- ## 5. Re-render Optimization (MEDIUM)
298
-
299
- ### Don't subscribe to state used only in callbacks
300
-
301
- ```tsx
302
- // INCORRECT — re-renders every time count changes
303
- const count = useStore((s) => s.count);
304
- const handler = () => doSomething(count);
305
-
306
- // CORRECT — read once on call
307
- const handler = () => {
308
- const count = useStore.getState().count;
309
- doSomething(count);
310
- };
311
- ```
312
-
313
- ### Extract expensive work into memoized components
314
-
315
- ```tsx
316
- // CORRECT — child re-renders only when `items` changes
317
- const Heavy = memo(function Heavy({ items }: { items: Item[] }) {
318
- return <Chart data={transform(items)} />;
319
- });
320
- ```
321
-
322
- ### Hoist default non-primitive props
323
-
324
- ```tsx
325
- // INCORRECT — new array each render breaks memo
326
- <List items={items ?? []} />
327
-
328
- // CORRECT
329
- const EMPTY: Item[] = [];
330
- <List items={items ?? EMPTY} />
331
- ```
332
-
333
- ### Primitive dependencies in effects
334
-
335
- ```tsx
336
- // INCORRECT — new object identity every render
337
- useEffect(() => {}, [{ id, name }]);
338
-
339
- // CORRECT — primitives
340
- useEffect(() => {}, [id, name]);
341
- ```
342
-
343
- ### Subscribe to derived booleans, not raw values
344
-
345
- ```tsx
346
- // INCORRECT — re-renders for any cart change
347
- const cart = useStore((s) => s.cart);
348
- const hasItems = cart.length > 0;
349
-
350
- // CORRECT — re-renders only when emptiness flips
351
- const hasItems = useStore((s) => s.cart.length > 0);
352
- ```
353
-
354
- ### Derive during render, never via `useEffect`
355
-
356
- ```tsx
357
- // INCORRECT
358
- const [full, setFull] = useState("");
359
- useEffect(() => setFull(`${first} ${last}`), [first, last]);
360
-
361
- // CORRECT
362
- const full = `${first} ${last}`;
363
- ```
364
-
365
- ### Functional `setState` for stable callbacks
366
-
367
- ```tsx
368
- // CORRECT
369
- const increment = useCallback(() => setCount((c) => c + 1), []);
370
- ```
371
-
372
- ### Lazy state initializer for expensive values
373
-
374
- ```tsx
375
- const [tree] = useState(() => parseTree(largeInput));
376
- ```
377
-
378
- ### Avoid memo for simple primitives
379
-
380
- `useMemo(() => x + 1, [x])` is overhead. Memo earns its keep on object identity and expensive computation.
381
-
382
- ### Split hooks with independent deps
383
-
384
- ```tsx
385
- // INCORRECT — both selectors re-run if either source changes
386
- const { a, b } = useSomething(source1, source2);
387
-
388
- // CORRECT
389
- const a = useA(source1);
390
- const b = useB(source2);
391
- ```
392
-
393
- ### Move interaction logic into event handlers
394
-
395
- Event handlers run only on the user action — `useEffect` re-runs whenever deps change.
396
-
397
- ### `startTransition` for non-urgent updates
398
-
399
- ```tsx
400
- const [pending, startTransition] = useTransition();
401
- startTransition(() => setFilters(newFilters));
402
- ```
403
-
404
- ### `useDeferredValue` for expensive renders
405
-
406
- ```tsx
407
- const deferredQuery = useDeferredValue(query);
408
- const results = useMemo(() => expensiveSearch(deferredQuery), [deferredQuery]);
409
- ```
410
-
411
- ### `useRef` for transient frequent values
412
-
413
- For values that change often but should not trigger re-render (timestamps, last-key, accumulators).
414
-
415
- ### Don't define components inside components
416
-
417
- ```tsx
418
- // INCORRECT — Inner is a new component on every Outer render
419
- function Outer() {
420
- const Inner = () => <span />;
421
- return <Inner />;
422
- }
423
- ```
424
-
425
- Each render makes a new `Inner` type, defeating reconciliation and unmounting children.
426
-
427
- ## 6. Rendering Performance (MEDIUM)
428
-
429
- ### Animate the wrapper, not the SVG
430
-
431
- Transforming a `<div>` wrapper around an SVG is GPU-accelerated; transforming the SVG itself triggers paint.
432
-
433
- ### `content-visibility: auto` for long lists
434
-
435
- ```css
436
- .row { content-visibility: auto; contain-intrinsic-size: auto 80px; }
437
- ```
438
-
439
- Browser skips offscreen rendering — major win for lists with hundreds of rows.
440
-
441
- ### Hoist static JSX
442
-
443
- ```tsx
444
- const STATIC_HEADER = <h1>Title</h1>;
445
- function Page() {
446
- return <>{STATIC_HEADER}<Body /></>;
447
- }
448
- ```
449
-
450
- ### SVG: reduce coordinate precision
451
-
452
- `d="M10.123456,20.654321"` → `d="M10.12,20.65"`. Each digit costs bytes; the visual difference is sub-pixel.
453
-
454
- ### Hydration no-flicker via inline script
455
-
456
- For values needed before hydration (theme, locale), inline a `<script>` that sets `document.documentElement.dataset.*` before React mounts.
457
-
458
- ### Suppress expected hydration mismatches narrowly
459
-
460
- ```tsx
461
- <time suppressHydrationWarning>{new Date().toLocaleString()}</time>
462
- ```
463
-
464
- Use ONLY for known-divergent leaf nodes — never on a tree containing other children.
465
-
466
- ### `<Activity>` for show/hide instead of mount/unmount
467
-
468
- React 19 `<Activity mode="visible|hidden">` keeps tree state and effects mounted but hides — cheaper than unmount/remount for tabs and accordions.
469
-
470
- ### Ternary over `&&` for conditional render
471
-
472
- ```tsx
473
- // INCORRECT — `0` renders as text node
474
- {count && <Badge>{count}</Badge>}
475
-
476
- // CORRECT
477
- {count > 0 ? <Badge>{count}</Badge> : null}
478
- ```
479
-
480
- ### `useTransition` for loading states
481
-
482
- Pair `startTransition` with the action; React shows the previous UI as `isPending` while the next state computes.
483
-
484
- ### React DOM resource hints
485
-
486
- ```tsx
487
- import { preload, preconnect } from "react-dom";
488
- preload("/api/critical", { as: "fetch" });
489
- preconnect("https://api.example.com");
490
- ```
491
-
492
- ### `defer` / `async` on `<script>` tags
493
-
494
- `defer` for ordered execution after DOMContentLoaded; `async` for fire-and-forget.
495
-
496
- ## 7. JavaScript Performance (LOW-MEDIUM)
497
-
498
- - **Batch DOM/CSS changes** — apply via class swap or `cssText`, not property-by-property
499
- - **`Map` for repeated lookups** — `O(1)` vs `O(n)` linear scan
500
- - **Cache property access in loops** — `const len = arr.length`
501
- - **Memoize pure functions** — module-level `Map<key, result>`
502
- - **Cache `localStorage` reads** — sync API; one read per render
503
- - **Combine `filter().map()` into one pass** — `flatMap` or single `for`
504
- - **Check array length first** before expensive comparisons
505
- - **Early return** from functions
506
- - **Hoist RegExp** out of loops — compilation is not free
507
- - **Loop for min/max** instead of `sort()` — `O(n)` vs `O(n log n)`
508
- - **`Set`/`Map` for membership** — `O(1)` vs `Array.includes` `O(n)`
509
- - **`toSorted()` over mutation** when immutability matters
510
- - **`flatMap` to map and filter in one pass**
511
- - **`requestIdleCallback`** for non-critical work
512
-
513
- ## 8. Advanced Patterns (LOW)
514
-
515
- ### `useEffectEvent` deps
516
-
517
- Values from `useEffectEvent` are stable — do NOT add them to effect deps.
518
-
519
- ### Event handler refs
520
-
521
- For stable callbacks passed to memoized children:
522
-
523
- ```tsx
524
- const handlerRef = useRef(handler);
525
- useEffect(() => { handlerRef.current = handler; });
526
- const stable = useCallback((arg) => handlerRef.current(arg), []);
527
- ```
528
-
529
- ### Init once per app load
530
-
531
- For module-level singletons (telemetry, logger), guard with a module-scope flag — not `useEffect`.
532
-
533
- ### `useLatest` for stable callback refs
534
-
535
- ```tsx
536
- function useLatest<T>(value: T) {
537
- const ref = useRef(value);
538
- ref.current = value;
539
- return ref;
540
- }
541
- ```
542
-
543
- ## Automated Tools
544
-
545
- Many of these rules are now automated:
546
-
547
- - **Next.js 13.5+ Optimize Package Imports** — barrel import optimization
548
- - **React Compiler** (RFC, in canary) — auto-memoization
549
- - **Turbopack** — faster builds, better tree-shaking
550
- - **Bundle Analyzer** (`@next/bundle-analyzer`) — visualize first-load JS
551
-
552
- When the project ships React Compiler, demote `rerender-*` manual memoization rules to "review-only" — the compiler handles them. Manual `useMemo`/`useCallback` becomes unnecessary noise.
553
-
554
- ## Lighthouse / Web Vitals Mapping
555
-
556
- | Metric | Most relevant categories |
557
- |---|---|
558
- | **LCP** (Largest Contentful Paint) | Waterfalls, Bundle Size, Resource Hints |
559
- | **INP** (Interaction to Next Paint) | Re-render, Rendering, JavaScript |
560
- | **CLS** (Cumulative Layout Shift) | Rendering (Suspense placement, image dimensions) |
561
- | **TBT** (Total Blocking Time) | Bundle Size, JavaScript, Defer Third-Party |
562
- | **FID** (legacy) | Bundle Size, Hydration |
563
-
564
- ## Related
565
-
566
- - Skills: [react-patterns](../react-patterns/SKILL.md), [react-testing](../react-testing/SKILL.md), [frontend-patterns](../frontend-patterns/SKILL.md), [accessibility](../accessibility/SKILL.md), [nextjs-turbopack](../nextjs-turbopack/SKILL.md)
567
- - Rules: [rules/react/](../../rules/react/)
568
- - Agents: `react-reviewer` enforces these rules in code review; `react-build-resolver` handles related build failures
569
- - Commands: `/react-review`, `/react-build`, `/react-test`
570
-
571
- ## Attribution
572
-
573
- Adapted from Vercel Labs `react-best-practices` skill (MIT License, copyright Vercel Engineering, v1.0.0 January 2026). Source: [https://github.com/vercel-labs/agent-skills/tree/main/skills/react-best-practices](https://github.com/vercel-labs/agent-skills/tree/main/skills/react-best-practices).
574
-
575
- This skill restructures and adapts the original 70-rule catalog into a single navigable reference. For the full original ruleset with extended examples, see the upstream repository.