@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,471 @@
1
+ ---
2
+ name: vue-patterns
3
+ description: Vue.js 3 Composition API patterns, component architecture, reactivity best practices, Pinia state management, Vue Router navigation, and Nuxt SSR patterns. Activates for Vue, Nuxt, Vite, or Pinia projects.
4
+ origin: ECC
5
+ ---
6
+
7
+ # Vue.js Patterns and Best Practices
8
+
9
+ Comprehensive guide for Vue.js 3 development using Composition API (`<script setup>`), covering component design, reactivity, state management, routing, testing, and SSR patterns. Nuxt-specific guidance is included where it differs from vanilla Vue.
10
+
11
+ ## When to Activate
12
+
13
+ Activate this skill when:
14
+ - The project uses Vue.js (any version), Nuxt, Vite + Vue, or Pinia.
15
+ - The user asks about Vue component architecture, composables, reactivity, or state management.
16
+ - Reviewing Vue Single-File Components (`.vue` files).
17
+ - Setting up Vue Router, Pinia stores, or Vite/Vitest configuration.
18
+ - Discussing Vue-specific performance, security, or SSR patterns.
19
+
20
+ ---
21
+
22
+ ## 1. Project Structure
23
+
24
+ ### Recommended Layout (Feature-First)
25
+
26
+ ```
27
+ src/
28
+ ├── api/ # API client and endpoint definitions
29
+ ├── assets/ # Static assets (images, fonts, icons)
30
+ ├── components/ # Shared/reusable components
31
+ │ ├── base/ # Base UI primitives (Button, Input, Modal)
32
+ │ └── features/ # Feature-specific shared components
33
+ ├── composables/ # Reusable Composition API logic
34
+ ├── layouts/ # Page layouts (optional)
35
+ ├── pages/ # Route-level page components
36
+ ├── router/ # Vue Router configuration
37
+ ├── stores/ # Pinia stores
38
+ ├── types/ # TypeScript type definitions
39
+ ├── utils/ # Pure utility functions
40
+ └── App.vue # Root component
41
+ ```
42
+
43
+ ### File Naming
44
+
45
+ | Convention | When to Use |
46
+ |-----------|-------------|
47
+ | `PascalCase.vue` | All components (enforced by `vue/multi-word-component-names`) |
48
+ | `useCamelCase.ts` | Composables |
49
+ | `camelCase.ts` | Utilities, API clients, types |
50
+ | `kebab-case` directories | Route segments, feature folders |
51
+
52
+ ---
53
+
54
+ ## 2. Component Architecture
55
+
56
+ ### Single-File Component Order
57
+
58
+ ```vue
59
+ <script setup lang="ts">
60
+ // 1. Imports (vue → ecosystem → absolute → relative)
61
+ // 2. Props & Emits & Slots
62
+ // 3. Composables
63
+ // 4. Local state (ref/reactive)
64
+ // 5. Computed properties
65
+ // 6. Methods
66
+ // 7. Watchers
67
+ // 8. Lifecycle hooks
68
+ </script>
69
+
70
+ <template>
71
+ <!-- Template content -->
72
+ </template>
73
+
74
+ <style scoped>
75
+ /* Scoped styles */
76
+ </style>
77
+ ```
78
+
79
+ ### Presentational vs Container
80
+
81
+ - **Container components**: Own data fetching, state, and side effects. Render presentational components.
82
+ - **Presentational components**: Receive props, emit events. No API calls, no store access. Pure rendering.
83
+
84
+ ### Props Best Practices
85
+
86
+ ```ts
87
+ // Type-based props with defaults
88
+ interface Props {
89
+ label: string;
90
+ variant?: "primary" | "secondary";
91
+ disabled?: boolean;
92
+ items: Item[];
93
+ }
94
+
95
+ const props = withDefaults(defineProps<Props>(), {
96
+ variant: "primary",
97
+ disabled: false,
98
+ });
99
+ ```
100
+
101
+ - Always provide `type`, and `required`/`default` where appropriate.
102
+ - Boolean props: `isXxx`, `hasXxx`, `canXxx`.
103
+ - Never mutate props — emit events instead.
104
+ - For v-model binding, use `defineModel()` (Vue 3.4+) or `modelValue` + `update:modelValue`.
105
+
106
+ ### Events
107
+
108
+ ```ts
109
+ const emit = defineEmits<{
110
+ submit: [];
111
+ "update:modelValue": [value: string];
112
+ select: [id: string, index: number];
113
+ }>();
114
+ ```
115
+
116
+ - Use kebab-case in templates (`@update:model-value`).
117
+ - Use camelCase in script (`emit("update:modelValue", val)`).
118
+
119
+ ---
120
+
121
+ ## 3. Composables (Reusable Logic)
122
+
123
+ ### Structure
124
+
125
+ ```ts
126
+ // composables/useDebounce.ts
127
+ export function useDebounce<T>(value: MaybeRef<T>, delay: number): Ref<T> {
128
+ const debounced = ref(toValue(value)) as Ref<T>;
129
+
130
+ let timer: ReturnType<typeof setTimeout>;
131
+ watch(
132
+ () => toValue(value),
133
+ (newVal) => {
134
+ clearTimeout(timer);
135
+ timer = setTimeout(() => { debounced.value = newVal; }, delay);
136
+ }
137
+ );
138
+
139
+ onUnmounted(() => clearTimeout(timer));
140
+ return readonly(debounced);
141
+ }
142
+ ```
143
+
144
+ ### Rules
145
+
146
+ - Must start with `use` prefix.
147
+ - Return reactive values (`ref`, `computed`, `reactive`), never plain primitives.
148
+ - Accept reactive inputs via `MaybeRef` / `toRef()` / `toValue()`.
149
+ - Clean up side effects in `onUnmounted` or watcher `onCleanup`.
150
+ - No module-scope side effects.
151
+
152
+ ### vs Mixins
153
+
154
+ Composables replace Vue 2 mixins entirely:
155
+ - **Mixins**: Opaque data flow, source-of-truth collisions, name conflicts.
156
+ - **Composables**: Explicit imports, clear return values, composable and tree-shakable.
157
+
158
+ ---
159
+
160
+ ## 4. State Management
161
+
162
+ ### When to Use What
163
+
164
+ | Pattern | Use Case |
165
+ |---------|----------|
166
+ | `ref()` / `reactive()` | Local component state |
167
+ | Props + Emits | Parent-child communication |
168
+ | Provide / Inject | Theme, config, plugin API |
169
+ | Pinia store | Global, shared, complex state |
170
+ | Server state composable | API data with caching (wrap `fetch`/TanStack Query) |
171
+
172
+ ### Pinia Setup Store (Preferred)
173
+
174
+ ```ts
175
+ // stores/useCartStore.ts
176
+ export const useCartStore = defineStore("cart", () => {
177
+ const items = ref<CartItem[]>([]);
178
+ const isLoading = ref(false);
179
+
180
+ const totalPrice = computed(() =>
181
+ items.value.reduce((sum, i) => sum + i.price * i.quantity, 0)
182
+ );
183
+ const itemCount = computed(() =>
184
+ items.value.reduce((sum, i) => sum + i.quantity, 0)
185
+ );
186
+
187
+ async function addItem(productId: string) {
188
+ isLoading.value = true;
189
+ try {
190
+ const item = await fetchProduct(productId);
191
+ const existing = items.value.find(i => i.id === item.id);
192
+ if (existing) existing.quantity++;
193
+ else items.value.push({ ...item, quantity: 1 });
194
+ } finally {
195
+ isLoading.value = false;
196
+ }
197
+ }
198
+
199
+ return { items, isLoading, totalPrice, itemCount, addItem };
200
+ });
201
+ ```
202
+
203
+ - Use Setup Store syntax (not Options Store).
204
+ - Prefer actions for business-level mutations and `$patch()` for grouped updates.
205
+ - Every async action: handle loading + success + error.
206
+
207
+ ---
208
+
209
+ ## 5. Vue Router
210
+
211
+ ### Route Definitions
212
+
213
+ ```ts
214
+ const routes = [
215
+ {
216
+ path: "/users/:id",
217
+ name: "user-detail",
218
+ component: () => import("@/pages/UserDetail.vue"), // lazy
219
+ props: true, // pass params as props
220
+ meta: { requiresAuth: true },
221
+ },
222
+ ];
223
+ ```
224
+
225
+ ### Navigation Guards
226
+
227
+ ```ts
228
+ router.beforeEach((to, from) => {
229
+ const { isLoggedIn } = useAuthStore();
230
+ if (to.meta.requiresAuth && !isLoggedIn) {
231
+ return { name: "login", query: { redirect: to.fullPath } };
232
+ }
233
+ });
234
+ ```
235
+
236
+ ### Reactive Route Params
237
+
238
+ When a component stays mounted but route params change:
239
+
240
+ ```ts
241
+ const route = useRoute();
242
+ const id = computed(() => route.params.id as string);
243
+ watch(id, (newId) => fetchItem(newId));
244
+ ```
245
+
246
+ ---
247
+
248
+ ## 6. Template Patterns
249
+
250
+ ### Template Syntax
251
+
252
+ ```vue
253
+ <!-- v-if/v-else-if/v-else -->
254
+ <div v-if="isLoading">Loading...</div>
255
+ <div v-else-if="error">Error: {{ error }}</div>
256
+ <div v-else>{{ content }}</div>
257
+
258
+ <!-- v-show for frequent toggles -->
259
+ <div v-show="isOpen">Toggled content</div>
260
+
261
+ <!-- v-for with stable keys -->
262
+ <div v-for="item in items" :key="item.id">{{ item.name }}</div>
263
+
264
+ <!-- Computed filtered list (not v-if + v-for on same element) -->
265
+ <div v-for="item in activeItems" :key="item.id">{{ item.name }}</div>
266
+
267
+ <!-- Event handling -->
268
+ <form @submit.prevent="handleSubmit">
269
+ <button type="submit">Save</button>
270
+ </form>
271
+
272
+ <!-- v-model -->
273
+ <input v-model="name" />
274
+ <CustomInput v-model="value" v-model:title="title" />
275
+ ```
276
+
277
+ ---
278
+
279
+ ## 7. Performance
280
+
281
+ | Technique | When to Use |
282
+ |-----------|-------------|
283
+ | `v-memo` | List items that rarely change |
284
+ | `v-once` | Content rendered once and static forever |
285
+ | `shallowRef()` | Large data structures replaced wholesale |
286
+ | `shallowReactive()` | Only top-level properties are reactive |
287
+ | `v-show` over `v-if` | Frequent visibility toggles |
288
+ | `<KeepAlive :max="10">` | Cache toggled views |
289
+ | Lazy routes | `() => import(...)` for non-critical routes |
290
+ | `Suspense` | Async component loading with fallback |
291
+
292
+ ---
293
+
294
+ ## 8. Testing
295
+
296
+ ### Stack
297
+
298
+ - **Vitest** for unit and component tests
299
+ - **Vue Test Utils** for mounting and interaction
300
+ - **@pinia/testing** for store mocking
301
+ - **Playwright** for E2E
302
+
303
+ ### Component Test Pattern
304
+
305
+ ```ts
306
+ import { mount } from "@vue/test-utils";
307
+ import { createPinia, setActivePinia } from "pinia";
308
+ import UserCard from "./UserCard.vue";
309
+
310
+ beforeEach(() => { setActivePinia(createPinia()); });
311
+
312
+ it("renders and emits", async () => {
313
+ const wrapper = mount(UserCard, {
314
+ props: { user: { id: "1", name: "Alice" } },
315
+ });
316
+ expect(wrapper.text()).toContain("Alice");
317
+ await wrapper.find("button").trigger("click");
318
+ expect(wrapper.emitted("select")![0]).toEqual(["1"]);
319
+ });
320
+ ```
321
+
322
+ ---
323
+
324
+ ## 9. Nuxt-Specific Patterns
325
+
326
+ ### Auto-Imports
327
+
328
+ Nuxt auto-imports `ref`, `computed`, `watch`, `useFetch`, `useAsyncData`, etc. Use them directly without importing. For non-Nuxt projects, always import explicitly.
329
+
330
+ ### useAsyncData / useFetch
331
+
332
+ ```ts
333
+ const { data: user, pending, error, refresh } = await useAsyncData(
334
+ "user", // unique key for caching
335
+ () => $fetch(`/api/users/${id}`),
336
+ );
337
+
338
+ const { data: posts } = await useFetch("/api/posts", {
339
+ query: { page: 1 },
340
+ key: "posts-page-1", // dedupes requests
341
+ });
342
+ ```
343
+
344
+ ### Server Routes
345
+
346
+ ```ts
347
+ // server/api/users/[id].ts
348
+ export default defineEventHandler(async (event) => {
349
+ const { id } = await getValidatedRouterParams(event, z.object({
350
+ id: z.string().uuid(),
351
+ }).parse);
352
+ // ... fetch and return
353
+ });
354
+ ```
355
+
356
+ ### Runtime Config
357
+
358
+ ```ts
359
+ // nuxt.config.ts
360
+ export default defineNuxtConfig({
361
+ runtimeConfig: {
362
+ // server-only
363
+ apiSecret: "",
364
+ // public (exposed to client)
365
+ public: {
366
+ apiBase: "https://api.example.com",
367
+ },
368
+ },
369
+ });
370
+ ```
371
+
372
+ ---
373
+
374
+ ## 10. Vue 3.5+ New APIs
375
+
376
+ ### Reactive Props Destructure
377
+
378
+ Vue 3.5 stabilized reactive props destructure — destructured variables from `defineProps()` are automatically reactive:
379
+
380
+ ```ts
381
+ // Vue 3.5+: destructured props are reactive (no need for toRefs)
382
+ const { count = 0, msg = "hello" } = defineProps<{
383
+ count?: number;
384
+ msg?: string;
385
+ }>();
386
+
387
+ // Limitation: cannot watch destructured prop directly
388
+ watch(() => count, (newVal) => { ... }); // PASS getter required
389
+ ```
390
+
391
+ ### `useTemplateRef()`
392
+
393
+ Replace name-matched plain refs with `useTemplateRef()` for template references:
394
+
395
+ ```ts
396
+ import { useTemplateRef } from "vue";
397
+ const inputEl = useTemplateRef<HTMLInputElement>("input");
398
+ // "input" matches the ref="input" attribute in template, not the variable name
399
+ ```
400
+
401
+ Supports dynamic ref IDs: `useTemplateRef(dynamicRefId)`.
402
+
403
+ ### `onWatcherCleanup()`
404
+
405
+ Globally importable watcher cleanup API (Vue 3.5+). It must be called synchronously inside the watcher callback:
406
+
407
+ ```ts
408
+ import { watch, onWatcherCleanup } from "vue";
409
+
410
+ watch(userId, async (newId) => {
411
+ const controller = new AbortController();
412
+ onWatcherCleanup(() => controller.abort());
413
+ // ... fetch with signal
414
+ });
415
+ ```
416
+
417
+ ### `useId()`
418
+
419
+ SSR-stable unique ID generation for form elements and accessibility:
420
+
421
+ ```ts
422
+ import { useId } from "vue";
423
+ const id = useId();
424
+ ```
425
+
426
+ ### `defer` Teleport
427
+
428
+ `<Teleport defer>` allows teleporting to targets rendered in the same cycle:
429
+
430
+ ```vue
431
+ <Teleport defer to="#container">Content</Teleport>
432
+ <div id="container"></div>
433
+ ```
434
+
435
+ ### Lazy Hydration (SSR)
436
+
437
+ `defineAsyncComponent()` now supports `hydrate` strategy:
438
+
439
+ ```ts
440
+ import { defineAsyncComponent, hydrateOnVisible } from "vue";
441
+ const AsyncComp = defineAsyncComponent({
442
+ loader: () => import("./Comp.vue"),
443
+ hydrate: hydrateOnVisible(),
444
+ });
445
+ ```
446
+
447
+ ---
448
+
449
+ ## Anti-Patterns
450
+
451
+ | Anti-Pattern | Why It's Wrong | The Fix |
452
+ |-------------|---------------|---------|
453
+ | Destructuring `defineProps()` (Vue < 3.5) | Captures snapshot, loses reactivity | Access via `props.xxx` or use `toRefs()` |
454
+ | `watch()` on destructured prop (Vue 3.5+) | Compile-time error — destructured props can't be watched directly | Use getter wrapper: `watch(() => count, ...)` |
455
+ | `v-if` + `v-for` on same element | Ambiguous execution order | Use computed filtered array |
456
+ | `v-for` key = index | Broken state on reorder | Use stable database IDs |
457
+ | Mutating props | Violates one-way data flow | Emit events or use `v-model` |
458
+ | `v-html` with user content | XSS vulnerability | Sanitize with DOMPurify |
459
+ | Mixins in Vue 3 | Opaque, collision-prone | Replace with composables |
460
+ | Module-scope side effects in composable | Shared across instances | Scope in `onMounted` + `onUnmounted` |
461
+ | `reactive()` for replaceable state | Replacement breaks reactivity | Use `ref()` instead |
462
+ | Watcher without cleanup | Memory leaks, race conditions | Use `onCleanup` or `onWatcherCleanup()` (Vue 3.5+) |
463
+ | Options API in new Vue 3 code | Ecosystem move to Composition API | Use `<script setup>` |
464
+ | Plain ref for template references | No dynamic ref support, name-matching fragile | Use `useTemplateRef()` (Vue 3.5+) |
465
+
466
+ ## Related Skills
467
+
468
+ - `accessibility` — ARIA, semantic HTML, focus management
469
+ - `frontend-patterns` — Cross-framework frontend architecture
470
+ - `typescript` — TypeScript best practices applied to Vue projects
471
+ - `coding-standards` — General code quality standards