agim-cli 1.2.147 → 1.2.149

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 (350) hide show
  1. package/CHANGELOG.md +158 -0
  2. package/dist/core/skills/builtin/ECC_LICENSE +21 -0
  3. package/dist/core/skills/builtin/ECC_NOTICE.md +28 -0
  4. package/dist/core/skills/builtin/accessibility/SKILL.md +146 -0
  5. package/dist/core/skills/builtin/agent-eval/SKILL.md +145 -0
  6. package/dist/core/skills/builtin/agent-harness-construction/SKILL.md +73 -0
  7. package/dist/core/skills/builtin/agent-introspection-debugging/SKILL.md +153 -0
  8. package/dist/core/skills/builtin/agentic-engineering/SKILL.md +63 -0
  9. package/dist/core/skills/builtin/ai-first-engineering/SKILL.md +51 -0
  10. package/dist/core/skills/builtin/ai-regression-testing/SKILL.md +385 -0
  11. package/dist/core/skills/builtin/android-clean-architecture/SKILL.md +339 -0
  12. package/dist/core/skills/builtin/angular-developer/SKILL.md +154 -0
  13. package/dist/core/skills/builtin/angular-developer/references/angular-animations.md +160 -0
  14. package/dist/core/skills/builtin/angular-developer/references/angular-aria.md +410 -0
  15. package/dist/core/skills/builtin/angular-developer/references/cli.md +86 -0
  16. package/dist/core/skills/builtin/angular-developer/references/component-harnesses.md +59 -0
  17. package/dist/core/skills/builtin/angular-developer/references/component-styling.md +91 -0
  18. package/dist/core/skills/builtin/angular-developer/references/components.md +117 -0
  19. package/dist/core/skills/builtin/angular-developer/references/creating-services.md +97 -0
  20. package/dist/core/skills/builtin/angular-developer/references/data-resolvers.md +69 -0
  21. package/dist/core/skills/builtin/angular-developer/references/define-routes.md +67 -0
  22. package/dist/core/skills/builtin/angular-developer/references/defining-providers.md +72 -0
  23. package/dist/core/skills/builtin/angular-developer/references/di-fundamentals.md +120 -0
  24. package/dist/core/skills/builtin/angular-developer/references/e2e-testing.md +56 -0
  25. package/dist/core/skills/builtin/angular-developer/references/effects.md +83 -0
  26. package/dist/core/skills/builtin/angular-developer/references/hierarchical-injectors.md +43 -0
  27. package/dist/core/skills/builtin/angular-developer/references/host-elements.md +80 -0
  28. package/dist/core/skills/builtin/angular-developer/references/injection-context.md +63 -0
  29. package/dist/core/skills/builtin/angular-developer/references/inputs.md +101 -0
  30. package/dist/core/skills/builtin/angular-developer/references/linked-signal.md +59 -0
  31. package/dist/core/skills/builtin/angular-developer/references/loading-strategies.md +61 -0
  32. package/dist/core/skills/builtin/angular-developer/references/mcp.md +108 -0
  33. package/dist/core/skills/builtin/angular-developer/references/navigate-to-routes.md +69 -0
  34. package/dist/core/skills/builtin/angular-developer/references/outputs.md +86 -0
  35. package/dist/core/skills/builtin/angular-developer/references/reactive-forms.md +122 -0
  36. package/dist/core/skills/builtin/angular-developer/references/rendering-strategies.md +44 -0
  37. package/dist/core/skills/builtin/angular-developer/references/resource.md +77 -0
  38. package/dist/core/skills/builtin/angular-developer/references/route-animations.md +56 -0
  39. package/dist/core/skills/builtin/angular-developer/references/route-guards.md +52 -0
  40. package/dist/core/skills/builtin/angular-developer/references/router-lifecycle.md +45 -0
  41. package/dist/core/skills/builtin/angular-developer/references/router-testing.md +87 -0
  42. package/dist/core/skills/builtin/angular-developer/references/show-routes-with-outlets.md +68 -0
  43. package/dist/core/skills/builtin/angular-developer/references/signal-forms.md +795 -0
  44. package/dist/core/skills/builtin/angular-developer/references/signals-overview.md +94 -0
  45. package/dist/core/skills/builtin/angular-developer/references/tailwind-css.md +69 -0
  46. package/dist/core/skills/builtin/angular-developer/references/template-driven-forms.md +114 -0
  47. package/dist/core/skills/builtin/angular-developer/references/testing-fundamentals.md +65 -0
  48. package/dist/core/skills/builtin/api-connector-builder/SKILL.md +120 -0
  49. package/dist/core/skills/builtin/api-design/SKILL.md +523 -0
  50. package/dist/core/skills/builtin/architecture-decision-records/SKILL.md +179 -0
  51. package/dist/core/skills/builtin/article-writing/SKILL.md +79 -0
  52. package/dist/core/skills/builtin/automation-audit-ops/SKILL.md +142 -0
  53. package/dist/core/skills/builtin/autonomous-agent-harness/SKILL.md +273 -0
  54. package/dist/core/skills/builtin/autonomous-loops/SKILL.md +610 -0
  55. package/dist/core/skills/builtin/backend-patterns/SKILL.md +561 -0
  56. package/dist/core/skills/builtin/benchmark/SKILL.md +93 -0
  57. package/dist/core/skills/builtin/benchmark-optimization-loop/SKILL.md +69 -0
  58. package/dist/core/skills/builtin/blueprint/SKILL.md +105 -0
  59. package/dist/core/skills/builtin/browser-qa/SKILL.md +87 -0
  60. package/dist/core/skills/builtin/bun-runtime/SKILL.md +84 -0
  61. package/dist/core/skills/builtin/cisco-ios-patterns/SKILL.md +163 -0
  62. package/dist/core/skills/builtin/claude-devfleet/SKILL.md +111 -0
  63. package/dist/core/skills/builtin/click-path-audit/SKILL.md +244 -0
  64. package/dist/core/skills/builtin/clickhouse-io/SKILL.md +439 -0
  65. package/dist/core/skills/builtin/code-tour/SKILL.md +236 -0
  66. package/dist/core/skills/builtin/codebase-onboarding/SKILL.md +233 -0
  67. package/dist/core/skills/builtin/codehealth-mcp/SKILL.md +166 -0
  68. package/dist/core/skills/builtin/coding-standards/SKILL.md +550 -0
  69. package/dist/core/skills/builtin/compose-multiplatform-patterns/SKILL.md +299 -0
  70. package/dist/core/skills/builtin/config-gc/SKILL.md +119 -0
  71. package/dist/core/skills/builtin/content-engine/SKILL.md +131 -0
  72. package/dist/core/skills/builtin/content-hash-cache-pattern/SKILL.md +161 -0
  73. package/dist/core/skills/builtin/context-budget/SKILL.md +135 -0
  74. package/dist/core/skills/builtin/continuous-agent-loop/SKILL.md +45 -0
  75. package/dist/core/skills/builtin/continuous-learning/SKILL.md +131 -0
  76. package/dist/core/skills/builtin/continuous-learning/config.json +18 -0
  77. package/dist/core/skills/builtin/continuous-learning/evaluate-session.sh +69 -0
  78. package/dist/core/skills/builtin/continuous-learning-v2/SKILL.md +360 -0
  79. package/dist/core/skills/builtin/continuous-learning-v2/agents/observer-loop.sh +335 -0
  80. package/dist/core/skills/builtin/continuous-learning-v2/agents/observer.md +198 -0
  81. package/dist/core/skills/builtin/continuous-learning-v2/agents/session-guardian.sh +150 -0
  82. package/dist/core/skills/builtin/continuous-learning-v2/agents/start-observer.sh +248 -0
  83. package/dist/core/skills/builtin/continuous-learning-v2/config.json +8 -0
  84. package/dist/core/skills/builtin/continuous-learning-v2/hooks/observe.sh +498 -0
  85. package/dist/core/skills/builtin/continuous-learning-v2/scripts/detect-project.sh +322 -0
  86. package/dist/core/skills/builtin/continuous-learning-v2/scripts/instinct-cli.py +1914 -0
  87. package/dist/core/skills/builtin/continuous-learning-v2/scripts/lib/homunculus-dir.sh +31 -0
  88. package/dist/core/skills/builtin/continuous-learning-v2/scripts/migrate-homunculus.sh +62 -0
  89. package/dist/core/skills/builtin/continuous-learning-v2/scripts/test_parse_instinct.py +1045 -0
  90. package/dist/core/skills/builtin/cost-aware-llm-pipeline/SKILL.md +183 -0
  91. package/dist/core/skills/builtin/cost-tracking/SKILL.md +147 -0
  92. package/dist/core/skills/builtin/council/SKILL.md +203 -0
  93. package/dist/core/skills/builtin/cpp-coding-standards/SKILL.md +723 -0
  94. package/dist/core/skills/builtin/cpp-testing/SKILL.md +324 -0
  95. package/dist/core/skills/builtin/crosspost/SKILL.md +111 -0
  96. package/dist/core/skills/builtin/csharp-testing/SKILL.md +321 -0
  97. package/dist/core/skills/builtin/customs-trade-compliance/SKILL.md +263 -0
  98. package/dist/core/skills/builtin/dart-flutter-patterns/SKILL.md +563 -0
  99. package/dist/core/skills/builtin/dashboard-builder/SKILL.md +108 -0
  100. package/dist/core/skills/builtin/data-scraper-agent/SKILL.md +764 -0
  101. package/dist/core/skills/builtin/data-throughput-accelerator/SKILL.md +72 -0
  102. package/dist/core/skills/builtin/database-migrations/SKILL.md +429 -0
  103. package/dist/core/skills/builtin/deep-research/SKILL.md +159 -0
  104. package/dist/core/skills/builtin/defi-amm-security/SKILL.md +166 -0
  105. package/dist/core/skills/builtin/deployment-patterns/SKILL.md +427 -0
  106. package/dist/core/skills/builtin/design-system/SKILL.md +82 -0
  107. package/dist/core/skills/builtin/django-celery/SKILL.md +457 -0
  108. package/dist/core/skills/builtin/django-patterns/SKILL.md +734 -0
  109. package/dist/core/skills/builtin/django-security/SKILL.md +593 -0
  110. package/dist/core/skills/builtin/django-tdd/SKILL.md +729 -0
  111. package/dist/core/skills/builtin/django-verification/SKILL.md +469 -0
  112. package/dist/core/skills/builtin/dmux-workflows/SKILL.md +191 -0
  113. package/dist/core/skills/builtin/docker-patterns/SKILL.md +364 -0
  114. package/dist/core/skills/builtin/documentation-lookup/SKILL.md +90 -0
  115. package/dist/core/skills/builtin/dotnet-patterns/SKILL.md +321 -0
  116. package/dist/core/skills/builtin/dynamic-workflow-mode/SKILL.md +123 -0
  117. package/dist/core/skills/builtin/e2e-testing/SKILL.md +326 -0
  118. package/dist/core/skills/builtin/email-ops/SKILL.md +121 -0
  119. package/dist/core/skills/builtin/energy-procurement/SKILL.md +228 -0
  120. package/dist/core/skills/builtin/enterprise-agent-ops/SKILL.md +50 -0
  121. package/dist/core/skills/builtin/error-handling/SKILL.md +376 -0
  122. package/dist/core/skills/builtin/eval-harness/SKILL.md +270 -0
  123. package/dist/core/skills/builtin/evm-token-decimals/SKILL.md +130 -0
  124. package/dist/core/skills/builtin/exa-search/SKILL.md +107 -0
  125. package/dist/core/skills/builtin/fal-ai-media/SKILL.md +288 -0
  126. package/dist/core/skills/builtin/fastapi-patterns/SKILL.md +513 -0
  127. package/dist/core/skills/builtin/finance-billing-ops/SKILL.md +127 -0
  128. package/dist/core/skills/builtin/flox-environments/SKILL.md +496 -0
  129. package/dist/core/skills/builtin/flutter-dart-code-review/SKILL.md +435 -0
  130. package/dist/core/skills/builtin/foundation-models-on-device/SKILL.md +243 -0
  131. package/dist/core/skills/builtin/frontend-a11y/SKILL.md +445 -0
  132. package/dist/core/skills/builtin/frontend-design-direction/SKILL.md +92 -0
  133. package/dist/core/skills/builtin/frontend-patterns/SKILL.md +656 -0
  134. package/dist/core/skills/builtin/frontend-slides/SKILL.md +184 -0
  135. package/dist/core/skills/builtin/frontend-slides/STYLE_PRESETS.md +330 -0
  136. package/dist/core/skills/builtin/frontend-slides/animation-patterns.md +122 -0
  137. package/dist/core/skills/builtin/frontend-slides/html-template.md +419 -0
  138. package/dist/core/skills/builtin/frontend-slides/scripts/export-pdf.sh +418 -0
  139. package/dist/core/skills/builtin/frontend-slides/scripts/extract-pptx.py +96 -0
  140. package/dist/core/skills/builtin/frontend-slides/viewport-base.css +153 -0
  141. package/dist/core/skills/builtin/fsharp-testing/SKILL.md +280 -0
  142. package/dist/core/skills/builtin/gan-style-harness/SKILL.md +278 -0
  143. package/dist/core/skills/builtin/gateguard/SKILL.md +132 -0
  144. package/dist/core/skills/builtin/git-workflow/SKILL.md +715 -0
  145. package/dist/core/skills/builtin/github-ops/SKILL.md +144 -0
  146. package/dist/core/skills/builtin/golang-patterns/SKILL.md +674 -0
  147. package/dist/core/skills/builtin/golang-testing/SKILL.md +720 -0
  148. package/dist/core/skills/builtin/healthcare-cdss-patterns/SKILL.md +245 -0
  149. package/dist/core/skills/builtin/healthcare-emr-patterns/SKILL.md +159 -0
  150. package/dist/core/skills/builtin/healthcare-eval-harness/SKILL.md +207 -0
  151. package/dist/core/skills/builtin/healthcare-phi-compliance/SKILL.md +145 -0
  152. package/dist/core/skills/builtin/hermes-imports/SKILL.md +88 -0
  153. package/dist/core/skills/builtin/hexagonal-architecture/SKILL.md +276 -0
  154. package/dist/core/skills/builtin/hipaa-compliance/SKILL.md +78 -0
  155. package/dist/core/skills/builtin/hookify-rules/SKILL.md +128 -0
  156. package/dist/core/skills/builtin/inherit-legacy-style/SKILL.md +156 -0
  157. package/dist/core/skills/builtin/intent-driven-development/SKILL.md +360 -0
  158. package/dist/core/skills/builtin/inventory-demand-planning/SKILL.md +247 -0
  159. package/dist/core/skills/builtin/ios-icon-gen/SKILL.md +157 -0
  160. package/dist/core/skills/builtin/ios-icon-gen/scripts/generate_icons.swift +258 -0
  161. package/dist/core/skills/builtin/ios-icon-gen/scripts/iconify_gen.sh +235 -0
  162. package/dist/core/skills/builtin/iterative-retrieval/SKILL.md +211 -0
  163. package/dist/core/skills/builtin/java-coding-standards/SKILL.md +383 -0
  164. package/dist/core/skills/builtin/jira-integration/SKILL.md +302 -0
  165. package/dist/core/skills/builtin/jpa-patterns/SKILL.md +151 -0
  166. package/dist/core/skills/builtin/knowledge-ops/SKILL.md +154 -0
  167. package/dist/core/skills/builtin/kotlin-coroutines-flows/SKILL.md +284 -0
  168. package/dist/core/skills/builtin/kotlin-exposed-patterns/SKILL.md +719 -0
  169. package/dist/core/skills/builtin/kotlin-ktor-patterns/SKILL.md +689 -0
  170. package/dist/core/skills/builtin/kotlin-patterns/SKILL.md +711 -0
  171. package/dist/core/skills/builtin/kotlin-testing/SKILL.md +824 -0
  172. package/dist/core/skills/builtin/kubernetes-patterns/SKILL.md +755 -0
  173. package/dist/core/skills/builtin/laravel-patterns/SKILL.md +415 -0
  174. package/dist/core/skills/builtin/laravel-plugin-discovery/SKILL.md +229 -0
  175. package/dist/core/skills/builtin/laravel-security/SKILL.md +947 -0
  176. package/dist/core/skills/builtin/laravel-tdd/SKILL.md +674 -0
  177. package/dist/core/skills/builtin/laravel-verification/SKILL.md +179 -0
  178. package/dist/core/skills/builtin/latency-critical-systems/SKILL.md +73 -0
  179. package/dist/core/skills/builtin/lead-intelligence/SKILL.md +321 -0
  180. package/dist/core/skills/builtin/lead-intelligence/agents/enrichment-agent.md +85 -0
  181. package/dist/core/skills/builtin/lead-intelligence/agents/mutual-mapper.md +75 -0
  182. package/dist/core/skills/builtin/lead-intelligence/agents/outreach-drafter.md +98 -0
  183. package/dist/core/skills/builtin/lead-intelligence/agents/signal-scorer.md +60 -0
  184. package/dist/core/skills/builtin/liquid-glass-design/SKILL.md +279 -0
  185. package/dist/core/skills/builtin/llm-trading-agent-security/SKILL.md +146 -0
  186. package/dist/core/skills/builtin/logistics-exception-management/SKILL.md +222 -0
  187. package/dist/core/skills/builtin/make-interfaces-feel-better/SKILL.md +151 -0
  188. package/dist/core/skills/builtin/market-research/SKILL.md +75 -0
  189. package/dist/core/skills/builtin/marketing-campaign/SKILL.md +113 -0
  190. package/dist/core/skills/builtin/mcp-server-patterns/SKILL.md +69 -0
  191. package/dist/core/skills/builtin/messages-ops/SKILL.md +104 -0
  192. package/dist/core/skills/builtin/mle-workflow/SKILL.md +346 -0
  193. package/dist/core/skills/builtin/motion-advanced/SKILL.md +596 -0
  194. package/dist/core/skills/builtin/motion-foundations/SKILL.md +299 -0
  195. package/dist/core/skills/builtin/motion-patterns/SKILL.md +434 -0
  196. package/dist/core/skills/builtin/motion-ui/SKILL.md +575 -0
  197. package/dist/core/skills/builtin/mysql-patterns/SKILL.md +412 -0
  198. package/dist/core/skills/builtin/nanoclaw-repl/SKILL.md +33 -0
  199. package/dist/core/skills/builtin/nestjs-patterns/SKILL.md +230 -0
  200. package/dist/core/skills/builtin/netmiko-ssh-automation/SKILL.md +173 -0
  201. package/dist/core/skills/builtin/network-bgp-diagnostics/SKILL.md +167 -0
  202. package/dist/core/skills/builtin/network-config-validation/SKILL.md +210 -0
  203. package/dist/core/skills/builtin/network-interface-health/SKILL.md +152 -0
  204. package/dist/core/skills/builtin/nextjs-turbopack/SKILL.md +57 -0
  205. package/dist/core/skills/builtin/nodejs-keccak256/SKILL.md +102 -0
  206. package/dist/core/skills/builtin/nutrient-document-processing/SKILL.md +167 -0
  207. package/dist/core/skills/builtin/nuxt4-patterns/SKILL.md +100 -0
  208. package/dist/core/skills/builtin/openclaw-persona-forge/SKILL.md +288 -0
  209. package/dist/core/skills/builtin/openclaw-persona-forge/gacha.py +224 -0
  210. package/dist/core/skills/builtin/openclaw-persona-forge/gacha.sh +5 -0
  211. package/dist/core/skills/builtin/openclaw-persona-forge/references/avatar-style.md +124 -0
  212. package/dist/core/skills/builtin/openclaw-persona-forge/references/boundary-rules.md +53 -0
  213. package/dist/core/skills/builtin/openclaw-persona-forge/references/error-handling.md +53 -0
  214. package/dist/core/skills/builtin/openclaw-persona-forge/references/identity-tension.md +48 -0
  215. package/dist/core/skills/builtin/openclaw-persona-forge/references/naming-system.md +39 -0
  216. package/dist/core/skills/builtin/openclaw-persona-forge/references/output-template.md +166 -0
  217. package/dist/core/skills/builtin/opensource-pipeline/SKILL.md +255 -0
  218. package/dist/core/skills/builtin/orch-add-feature/SKILL.md +44 -0
  219. package/dist/core/skills/builtin/orch-build-mvp/SKILL.md +48 -0
  220. package/dist/core/skills/builtin/orch-change-feature/SKILL.md +42 -0
  221. package/dist/core/skills/builtin/orch-fix-defect/SKILL.md +42 -0
  222. package/dist/core/skills/builtin/orch-pipeline/SKILL.md +120 -0
  223. package/dist/core/skills/builtin/orch-refine-code/SKILL.md +43 -0
  224. package/dist/core/skills/builtin/parallel-execution-optimizer/SKILL.md +72 -0
  225. package/dist/core/skills/builtin/perl-patterns/SKILL.md +504 -0
  226. package/dist/core/skills/builtin/perl-security/SKILL.md +503 -0
  227. package/dist/core/skills/builtin/perl-testing/SKILL.md +475 -0
  228. package/dist/core/skills/builtin/plan-orchestrate/SKILL.md +262 -0
  229. package/dist/core/skills/builtin/plankton-code-quality/SKILL.md +236 -0
  230. package/dist/core/skills/builtin/postgres-patterns/SKILL.md +147 -0
  231. package/dist/core/skills/builtin/prediction-market-oracle-research/SKILL.md +63 -0
  232. package/dist/core/skills/builtin/prediction-market-risk-review/SKILL.md +60 -0
  233. package/dist/core/skills/builtin/prisma-patterns/SKILL.md +371 -0
  234. package/dist/core/skills/builtin/product-capability/SKILL.md +141 -0
  235. package/dist/core/skills/builtin/product-lens/SKILL.md +92 -0
  236. package/dist/core/skills/builtin/production-audit/SKILL.md +206 -0
  237. package/dist/core/skills/builtin/production-scheduling/SKILL.md +238 -0
  238. package/dist/core/skills/builtin/prompt-optimizer/SKILL.md +398 -0
  239. package/dist/core/skills/builtin/python-patterns/SKILL.md +750 -0
  240. package/dist/core/skills/builtin/python-testing/SKILL.md +816 -0
  241. package/dist/core/skills/builtin/pytorch-patterns/SKILL.md +396 -0
  242. package/dist/core/skills/builtin/quality-nonconformance/SKILL.md +260 -0
  243. package/dist/core/skills/builtin/quarkus-patterns/SKILL.md +722 -0
  244. package/dist/core/skills/builtin/quarkus-security/SKILL.md +467 -0
  245. package/dist/core/skills/builtin/quarkus-tdd/SKILL.md +811 -0
  246. package/dist/core/skills/builtin/quarkus-verification/SKILL.md +479 -0
  247. package/dist/core/skills/builtin/ralphinho-rfc-pipeline/SKILL.md +67 -0
  248. package/dist/core/skills/builtin/react-patterns/SKILL.md +341 -0
  249. package/dist/core/skills/builtin/react-performance/SKILL.md +574 -0
  250. package/dist/core/skills/builtin/react-testing/SKILL.md +423 -0
  251. package/dist/core/skills/builtin/recsys-pipeline-architect/SKILL.md +114 -0
  252. package/dist/core/skills/builtin/recursive-decision-ledger/SKILL.md +79 -0
  253. package/dist/core/skills/builtin/redis-patterns/SKILL.md +403 -0
  254. package/dist/core/skills/builtin/regex-vs-llm-structured-text/SKILL.md +220 -0
  255. package/dist/core/skills/builtin/repo-scan/SKILL.md +78 -0
  256. package/dist/core/skills/builtin/research-ops/SKILL.md +112 -0
  257. package/dist/core/skills/builtin/returns-reverse-logistics/SKILL.md +240 -0
  258. package/dist/core/skills/builtin/rules-distill/SKILL.md +264 -0
  259. package/dist/core/skills/builtin/rules-distill/scripts/scan-rules.sh +58 -0
  260. package/dist/core/skills/builtin/rules-distill/scripts/scan-skills.sh +129 -0
  261. package/dist/core/skills/builtin/rust-patterns/SKILL.md +499 -0
  262. package/dist/core/skills/builtin/rust-testing/SKILL.md +500 -0
  263. package/dist/core/skills/builtin/safety-guard/SKILL.md +75 -0
  264. package/dist/core/skills/builtin/santa-method/SKILL.md +306 -0
  265. package/dist/core/skills/builtin/scientific-db-pubmed-database/SKILL.md +175 -0
  266. package/dist/core/skills/builtin/scientific-db-uspto-database/SKILL.md +177 -0
  267. package/dist/core/skills/builtin/scientific-pkg-gget/SKILL.md +166 -0
  268. package/dist/core/skills/builtin/scientific-thinking-literature-review/SKILL.md +192 -0
  269. package/dist/core/skills/builtin/scientific-thinking-scholar-evaluation/SKILL.md +160 -0
  270. package/dist/core/skills/builtin/search-first/SKILL.md +182 -0
  271. package/dist/core/skills/builtin/security-bounty-hunter/SKILL.md +99 -0
  272. package/dist/core/skills/builtin/security-review/SKILL.md +503 -0
  273. package/dist/core/skills/builtin/security-review/cloud-infrastructure-security.md +361 -0
  274. package/dist/core/skills/builtin/security-scan/SKILL.md +165 -0
  275. package/dist/core/skills/builtin/seo/SKILL.md +154 -0
  276. package/dist/core/skills/builtin/skill-comply/SKILL.md +58 -0
  277. package/dist/core/skills/builtin/skill-comply/fixtures/compliant_trace.jsonl +5 -0
  278. package/dist/core/skills/builtin/skill-comply/fixtures/noncompliant_trace.jsonl +3 -0
  279. package/dist/core/skills/builtin/skill-comply/fixtures/tdd_spec.yaml +44 -0
  280. package/dist/core/skills/builtin/skill-comply/prompts/classifier.md +24 -0
  281. package/dist/core/skills/builtin/skill-comply/prompts/scenario_generator.md +62 -0
  282. package/dist/core/skills/builtin/skill-comply/prompts/spec_generator.md +42 -0
  283. package/dist/core/skills/builtin/skill-comply/pyproject.toml +15 -0
  284. package/dist/core/skills/builtin/skill-comply/scripts/__init__.py +0 -0
  285. package/dist/core/skills/builtin/skill-comply/scripts/classifier.py +85 -0
  286. package/dist/core/skills/builtin/skill-comply/scripts/grader.py +124 -0
  287. package/dist/core/skills/builtin/skill-comply/scripts/parser.py +107 -0
  288. package/dist/core/skills/builtin/skill-comply/scripts/report.py +170 -0
  289. package/dist/core/skills/builtin/skill-comply/scripts/run.py +127 -0
  290. package/dist/core/skills/builtin/skill-comply/scripts/runner.py +186 -0
  291. package/dist/core/skills/builtin/skill-comply/scripts/scenario_generator.py +70 -0
  292. package/dist/core/skills/builtin/skill-comply/scripts/spec_generator.py +72 -0
  293. package/dist/core/skills/builtin/skill-comply/scripts/utils.py +13 -0
  294. package/dist/core/skills/builtin/skill-comply/tests/test_grader.py +197 -0
  295. package/dist/core/skills/builtin/skill-comply/tests/test_parser.py +90 -0
  296. package/dist/core/skills/builtin/skill-comply/tests/test_runner.py +172 -0
  297. package/dist/core/skills/builtin/skill-scout/SKILL.md +140 -0
  298. package/dist/core/skills/builtin/skill-stocktake/SKILL.md +194 -0
  299. package/dist/core/skills/builtin/skill-stocktake/scripts/quick-diff.sh +87 -0
  300. package/dist/core/skills/builtin/skill-stocktake/scripts/save-results.sh +56 -0
  301. package/dist/core/skills/builtin/skill-stocktake/scripts/scan.sh +170 -0
  302. package/dist/core/skills/builtin/springboot-patterns/SKILL.md +314 -0
  303. package/dist/core/skills/builtin/springboot-security/SKILL.md +272 -0
  304. package/dist/core/skills/builtin/springboot-tdd/SKILL.md +158 -0
  305. package/dist/core/skills/builtin/springboot-verification/SKILL.md +231 -0
  306. package/dist/core/skills/builtin/strategic-compact/SKILL.md +135 -0
  307. package/dist/core/skills/builtin/swift-actor-persistence/SKILL.md +143 -0
  308. package/dist/core/skills/builtin/swift-concurrency-6-2/SKILL.md +216 -0
  309. package/dist/core/skills/builtin/swift-protocol-di-testing/SKILL.md +190 -0
  310. package/dist/core/skills/builtin/swiftui-patterns/SKILL.md +259 -0
  311. package/dist/core/skills/builtin/tdd-workflow/SKILL.md +463 -0
  312. package/dist/core/skills/builtin/team-agent-orchestration/SKILL.md +110 -0
  313. package/dist/core/skills/builtin/team-builder/SKILL.md +168 -0
  314. package/dist/core/skills/builtin/terminal-ops/SKILL.md +109 -0
  315. package/dist/core/skills/builtin/tinystruct-patterns/SKILL.md +203 -0
  316. package/dist/core/skills/builtin/tinystruct-patterns/references/architecture.md +90 -0
  317. package/dist/core/skills/builtin/tinystruct-patterns/references/data-handling.md +60 -0
  318. package/dist/core/skills/builtin/tinystruct-patterns/references/database.md +99 -0
  319. package/dist/core/skills/builtin/tinystruct-patterns/references/routing.md +64 -0
  320. package/dist/core/skills/builtin/tinystruct-patterns/references/system-usage.md +97 -0
  321. package/dist/core/skills/builtin/tinystruct-patterns/references/testing.md +72 -0
  322. package/dist/core/skills/builtin/token-budget-advisor/SKILL.md +133 -0
  323. package/dist/core/skills/builtin/ui-demo/SKILL.md +465 -0
  324. package/dist/core/skills/builtin/ui-to-vue/SKILL.md +134 -0
  325. package/dist/core/skills/builtin/uncloud/SKILL.md +343 -0
  326. package/dist/core/skills/builtin/unified-notifications-ops/SKILL.md +187 -0
  327. package/dist/core/skills/builtin/verification-loop/SKILL.md +126 -0
  328. package/dist/core/skills/builtin/video-editing/SKILL.md +310 -0
  329. package/dist/core/skills/builtin/videodb/SKILL.md +374 -0
  330. package/dist/core/skills/builtin/videodb/reference/api-reference.md +550 -0
  331. package/dist/core/skills/builtin/videodb/reference/capture-reference.md +407 -0
  332. package/dist/core/skills/builtin/videodb/reference/capture.md +101 -0
  333. package/dist/core/skills/builtin/videodb/reference/editor.md +443 -0
  334. package/dist/core/skills/builtin/videodb/reference/generative.md +331 -0
  335. package/dist/core/skills/builtin/videodb/reference/rtstream-reference.md +564 -0
  336. package/dist/core/skills/builtin/videodb/reference/rtstream.md +65 -0
  337. package/dist/core/skills/builtin/videodb/reference/search.md +230 -0
  338. package/dist/core/skills/builtin/videodb/reference/streaming.md +406 -0
  339. package/dist/core/skills/builtin/videodb/reference/use-cases.md +118 -0
  340. package/dist/core/skills/builtin/videodb/scripts/ws_listener.py +282 -0
  341. package/dist/core/skills/builtin/visa-doc-translate/README.md +86 -0
  342. package/dist/core/skills/builtin/visa-doc-translate/SKILL.md +117 -0
  343. package/dist/core/skills/builtin/vite-patterns/SKILL.md +449 -0
  344. package/dist/core/skills/builtin/windows-desktop-e2e/SKILL.md +887 -0
  345. package/dist/core/skills/builtin/x-api/SKILL.md +234 -0
  346. package/dist/core/skills/loader.d.ts +23 -12
  347. package/dist/core/skills/loader.d.ts.map +1 -1
  348. package/dist/core/skills/loader.js +105 -2
  349. package/dist/core/skills/loader.js.map +1 -1
  350. package/package.json +1 -1
@@ -0,0 +1,656 @@
1
+ ---
2
+ name: frontend-patterns
3
+ description: [ECC] Frontend development patterns for React, Next.js, state management, performance optimization, and UI best practices.
4
+ origin: ECC
5
+ ---
6
+
7
+ # Frontend Development Patterns
8
+
9
+ Modern frontend patterns for React, Next.js, and performant user interfaces.
10
+
11
+ ## When to Activate
12
+
13
+ - Building React components (composition, props, rendering)
14
+ - Managing state (useState, useReducer, Zustand, Context)
15
+ - Implementing data fetching (SWR, React Query, server components)
16
+ - Optimizing performance (memoization, virtualization, code splitting)
17
+ - Working with forms (validation, controlled inputs, Zod schemas)
18
+ - Handling client-side routing and navigation
19
+ - Building accessible, responsive UI patterns
20
+
21
+ ## Component Patterns
22
+
23
+ ### Composition Over Inheritance
24
+
25
+ ```typescript
26
+ // PASS: GOOD: Component composition
27
+ interface CardProps {
28
+ children: React.ReactNode
29
+ variant?: 'default' | 'outlined'
30
+ }
31
+
32
+ export function Card({ children, variant = 'default' }: CardProps) {
33
+ return <div className={`card card-${variant}`}>{children}</div>
34
+ }
35
+
36
+ export function CardHeader({ children }: { children: React.ReactNode }) {
37
+ return <div className="card-header">{children}</div>
38
+ }
39
+
40
+ export function CardBody({ children }: { children: React.ReactNode }) {
41
+ return <div className="card-body">{children}</div>
42
+ }
43
+
44
+ // Usage
45
+ <Card>
46
+ <CardHeader>Title</CardHeader>
47
+ <CardBody>Content</CardBody>
48
+ </Card>
49
+ ```
50
+
51
+ ### Compound Components
52
+
53
+ ```typescript
54
+ interface TabsContextValue {
55
+ activeTab: string
56
+ setActiveTab: (tab: string) => void
57
+ }
58
+
59
+ const TabsContext = createContext<TabsContextValue | undefined>(undefined)
60
+
61
+ export function Tabs({ children, defaultTab }: {
62
+ children: React.ReactNode
63
+ defaultTab: string
64
+ }) {
65
+ const [activeTab, setActiveTab] = useState(defaultTab)
66
+
67
+ return (
68
+ <TabsContext.Provider value={{ activeTab, setActiveTab }}>
69
+ {children}
70
+ </TabsContext.Provider>
71
+ )
72
+ }
73
+
74
+ export function TabList({ children }: { children: React.ReactNode }) {
75
+ return <div className="tab-list">{children}</div>
76
+ }
77
+
78
+ export function Tab({ id, children }: { id: string, children: React.ReactNode }) {
79
+ const context = useContext(TabsContext)
80
+ if (!context) throw new Error('Tab must be used within Tabs')
81
+
82
+ return (
83
+ <button
84
+ className={context.activeTab === id ? 'active' : ''}
85
+ onClick={() => context.setActiveTab(id)}
86
+ >
87
+ {children}
88
+ </button>
89
+ )
90
+ }
91
+
92
+ // Usage
93
+ <Tabs defaultTab="overview">
94
+ <TabList>
95
+ <Tab id="overview">Overview</Tab>
96
+ <Tab id="details">Details</Tab>
97
+ </TabList>
98
+ </Tabs>
99
+ ```
100
+
101
+ ### Render Props Pattern
102
+
103
+ ```typescript
104
+ interface DataLoaderProps<T> {
105
+ url: string
106
+ children: (data: T | null, loading: boolean, error: Error | null) => React.ReactNode
107
+ }
108
+
109
+ export function DataLoader<T>({ url, children }: DataLoaderProps<T>) {
110
+ const [data, setData] = useState<T | null>(null)
111
+ const [loading, setLoading] = useState(true)
112
+ const [error, setError] = useState<Error | null>(null)
113
+
114
+ useEffect(() => {
115
+ fetch(url)
116
+ .then(res => res.json())
117
+ .then(setData)
118
+ .catch(setError)
119
+ .finally(() => setLoading(false))
120
+ }, [url])
121
+
122
+ return <>{children(data, loading, error)}</>
123
+ }
124
+
125
+ // Usage
126
+ <DataLoader<Market[]> url="/api/markets">
127
+ {(markets, loading, error) => {
128
+ if (loading) return <Spinner />
129
+ if (error) return <Error error={error} />
130
+ return <MarketList markets={markets!} />
131
+ }}
132
+ </DataLoader>
133
+ ```
134
+
135
+ ## Custom Hooks Patterns
136
+
137
+ ### State Management Hook
138
+
139
+ ```typescript
140
+ export function useToggle(initialValue = false): [boolean, () => void] {
141
+ const [value, setValue] = useState(initialValue)
142
+
143
+ const toggle = useCallback(() => {
144
+ setValue(v => !v)
145
+ }, [])
146
+
147
+ return [value, toggle]
148
+ }
149
+
150
+ // Usage
151
+ const [isOpen, toggleOpen] = useToggle()
152
+ ```
153
+
154
+ ### Async Data Fetching Hook
155
+
156
+ ```typescript
157
+ interface UseQueryOptions<T> {
158
+ onSuccess?: (data: T) => void
159
+ onError?: (error: Error) => void
160
+ enabled?: boolean
161
+ }
162
+
163
+ export function useQuery<T>(
164
+ key: string,
165
+ fetcher: () => Promise<T>,
166
+ options?: UseQueryOptions<T>
167
+ ) {
168
+ const [data, setData] = useState<T | null>(null)
169
+ const [error, setError] = useState<Error | null>(null)
170
+ const [loading, setLoading] = useState(false)
171
+
172
+ // Keep the latest fetcher/options in refs so refetch stays referentially
173
+ // stable even when callers pass inline functions and object literals.
174
+ // Without this, every render creates a new refetch, and the effect below
175
+ // re-runs after each state update - an infinite fetch loop.
176
+ const fetcherRef = useRef(fetcher)
177
+ const optionsRef = useRef(options)
178
+ useEffect(() => {
179
+ fetcherRef.current = fetcher
180
+ optionsRef.current = options
181
+ })
182
+
183
+ const refetch = useCallback(async () => {
184
+ setLoading(true)
185
+ setError(null)
186
+
187
+ try {
188
+ const result = await fetcherRef.current()
189
+ setData(result)
190
+ optionsRef.current?.onSuccess?.(result)
191
+ } catch (err) {
192
+ const error = err as Error
193
+ setError(error)
194
+ optionsRef.current?.onError?.(error)
195
+ } finally {
196
+ setLoading(false)
197
+ }
198
+ }, [])
199
+
200
+ const enabled = options?.enabled !== false
201
+
202
+ useEffect(() => {
203
+ if (enabled) {
204
+ refetch()
205
+ }
206
+ }, [key, enabled, refetch])
207
+
208
+ return { data, error, loading, refetch }
209
+ }
210
+
211
+ // Usage
212
+ const { data: markets, loading, error, refetch } = useQuery(
213
+ 'markets',
214
+ () => fetch('/api/markets').then(r => r.json()),
215
+ {
216
+ onSuccess: data => console.log('Fetched', data.length, 'markets'),
217
+ onError: err => console.error('Failed:', err)
218
+ }
219
+ )
220
+ ```
221
+
222
+ ### Debounce Hook
223
+
224
+ ```typescript
225
+ export function useDebounce<T>(value: T, delay: number): T {
226
+ const [debouncedValue, setDebouncedValue] = useState<T>(value)
227
+
228
+ useEffect(() => {
229
+ const handler = setTimeout(() => {
230
+ setDebouncedValue(value)
231
+ }, delay)
232
+
233
+ return () => clearTimeout(handler)
234
+ }, [value, delay])
235
+
236
+ return debouncedValue
237
+ }
238
+
239
+ // Usage
240
+ const [searchQuery, setSearchQuery] = useState('')
241
+ const debouncedQuery = useDebounce(searchQuery, 500)
242
+
243
+ useEffect(() => {
244
+ if (debouncedQuery) {
245
+ performSearch(debouncedQuery)
246
+ }
247
+ }, [debouncedQuery])
248
+ ```
249
+
250
+ ## State Management Patterns
251
+
252
+ ### Context + Reducer Pattern
253
+
254
+ ```typescript
255
+ interface State {
256
+ markets: Market[]
257
+ selectedMarket: Market | null
258
+ loading: boolean
259
+ }
260
+
261
+ type Action =
262
+ | { type: 'SET_MARKETS'; payload: Market[] }
263
+ | { type: 'SELECT_MARKET'; payload: Market }
264
+ | { type: 'SET_LOADING'; payload: boolean }
265
+
266
+ function reducer(state: State, action: Action): State {
267
+ switch (action.type) {
268
+ case 'SET_MARKETS':
269
+ return { ...state, markets: action.payload }
270
+ case 'SELECT_MARKET':
271
+ return { ...state, selectedMarket: action.payload }
272
+ case 'SET_LOADING':
273
+ return { ...state, loading: action.payload }
274
+ default:
275
+ return state
276
+ }
277
+ }
278
+
279
+ const MarketContext = createContext<{
280
+ state: State
281
+ dispatch: Dispatch<Action>
282
+ } | undefined>(undefined)
283
+
284
+ export function MarketProvider({ children }: { children: React.ReactNode }) {
285
+ const [state, dispatch] = useReducer(reducer, {
286
+ markets: [],
287
+ selectedMarket: null,
288
+ loading: false
289
+ })
290
+
291
+ return (
292
+ <MarketContext.Provider value={{ state, dispatch }}>
293
+ {children}
294
+ </MarketContext.Provider>
295
+ )
296
+ }
297
+
298
+ export function useMarkets() {
299
+ const context = useContext(MarketContext)
300
+ if (!context) throw new Error('useMarkets must be used within MarketProvider')
301
+ return context
302
+ }
303
+ ```
304
+
305
+ ## Performance Optimization
306
+
307
+ ### Memoization
308
+
309
+ ```typescript
310
+ // PASS: useMemo for expensive computations
311
+ // Copy before sorting - Array.prototype.sort mutates in place
312
+ const sortedMarkets = useMemo(() => {
313
+ return [...markets].sort((a, b) => b.volume - a.volume)
314
+ }, [markets])
315
+
316
+ // PASS: useCallback for functions passed to children
317
+ const handleSearch = useCallback((query: string) => {
318
+ setSearchQuery(query)
319
+ }, [])
320
+
321
+ // PASS: React.memo for pure components
322
+ export const MarketCard = React.memo<MarketCardProps>(({ market }) => {
323
+ return (
324
+ <div className="market-card">
325
+ <h3>{market.name}</h3>
326
+ <p>{market.description}</p>
327
+ </div>
328
+ )
329
+ })
330
+ ```
331
+
332
+ ### Code Splitting & Lazy Loading
333
+
334
+ ```typescript
335
+ import { lazy, Suspense } from 'react'
336
+
337
+ // PASS: Lazy load heavy components
338
+ const HeavyChart = lazy(() => import('./HeavyChart'))
339
+ const ThreeJsBackground = lazy(() => import('./ThreeJsBackground'))
340
+
341
+ export function Dashboard() {
342
+ return (
343
+ <div>
344
+ <Suspense fallback={<ChartSkeleton />}>
345
+ <HeavyChart data={data} />
346
+ </Suspense>
347
+
348
+ <Suspense fallback={null}>
349
+ <ThreeJsBackground />
350
+ </Suspense>
351
+ </div>
352
+ )
353
+ }
354
+ ```
355
+
356
+ ### Virtualization for Long Lists
357
+
358
+ ```typescript
359
+ import { useVirtualizer } from '@tanstack/react-virtual'
360
+
361
+ export function VirtualMarketList({ markets }: { markets: Market[] }) {
362
+ const parentRef = useRef<HTMLDivElement>(null)
363
+
364
+ const virtualizer = useVirtualizer({
365
+ count: markets.length,
366
+ getScrollElement: () => parentRef.current,
367
+ estimateSize: () => 100, // Estimated row height
368
+ overscan: 5 // Extra items to render
369
+ })
370
+
371
+ return (
372
+ <div ref={parentRef} style={{ height: '600px', overflow: 'auto' }}>
373
+ <div
374
+ style={{
375
+ height: `${virtualizer.getTotalSize()}px`,
376
+ position: 'relative'
377
+ }}
378
+ >
379
+ {virtualizer.getVirtualItems().map(virtualRow => (
380
+ <div
381
+ key={virtualRow.index}
382
+ style={{
383
+ position: 'absolute',
384
+ top: 0,
385
+ left: 0,
386
+ width: '100%',
387
+ height: `${virtualRow.size}px`,
388
+ transform: `translateY(${virtualRow.start}px)`
389
+ }}
390
+ >
391
+ <MarketCard market={markets[virtualRow.index]} />
392
+ </div>
393
+ ))}
394
+ </div>
395
+ </div>
396
+ )
397
+ }
398
+ ```
399
+
400
+ ## Form Handling Patterns
401
+
402
+ ### Controlled Form with Validation
403
+
404
+ ```typescript
405
+ interface FormData {
406
+ name: string
407
+ description: string
408
+ endDate: string
409
+ }
410
+
411
+ interface FormErrors {
412
+ name?: string
413
+ description?: string
414
+ endDate?: string
415
+ }
416
+
417
+ export function CreateMarketForm() {
418
+ const [formData, setFormData] = useState<FormData>({
419
+ name: '',
420
+ description: '',
421
+ endDate: ''
422
+ })
423
+
424
+ const [errors, setErrors] = useState<FormErrors>({})
425
+
426
+ const validate = (): boolean => {
427
+ const newErrors: FormErrors = {}
428
+
429
+ if (!formData.name.trim()) {
430
+ newErrors.name = 'Name is required'
431
+ } else if (formData.name.length > 200) {
432
+ newErrors.name = 'Name must be under 200 characters'
433
+ }
434
+
435
+ if (!formData.description.trim()) {
436
+ newErrors.description = 'Description is required'
437
+ }
438
+
439
+ if (!formData.endDate) {
440
+ newErrors.endDate = 'End date is required'
441
+ }
442
+
443
+ setErrors(newErrors)
444
+ return Object.keys(newErrors).length === 0
445
+ }
446
+
447
+ const handleSubmit = async (e: React.FormEvent) => {
448
+ e.preventDefault()
449
+
450
+ if (!validate()) return
451
+
452
+ try {
453
+ await createMarket(formData)
454
+ // Success handling
455
+ } catch (error) {
456
+ // Error handling
457
+ }
458
+ }
459
+
460
+ return (
461
+ <form onSubmit={handleSubmit}>
462
+ <input
463
+ value={formData.name}
464
+ onChange={e => setFormData(prev => ({ ...prev, name: e.target.value }))}
465
+ placeholder="Market name"
466
+ />
467
+ {errors.name && <span className="error">{errors.name}</span>}
468
+
469
+ {/* Other fields */}
470
+
471
+ <button type="submit">Create Market</button>
472
+ </form>
473
+ )
474
+ }
475
+ ```
476
+
477
+ ## Error Boundary Pattern
478
+
479
+ ```typescript
480
+ interface ErrorBoundaryState {
481
+ hasError: boolean
482
+ error: Error | null
483
+ }
484
+
485
+ export class ErrorBoundary extends React.Component<
486
+ { children: React.ReactNode },
487
+ ErrorBoundaryState
488
+ > {
489
+ state: ErrorBoundaryState = {
490
+ hasError: false,
491
+ error: null
492
+ }
493
+
494
+ static getDerivedStateFromError(error: Error): ErrorBoundaryState {
495
+ return { hasError: true, error }
496
+ }
497
+
498
+ componentDidCatch(error: Error, errorInfo: React.ErrorInfo) {
499
+ console.error('Error boundary caught:', error, errorInfo)
500
+ }
501
+
502
+ render() {
503
+ if (this.state.hasError) {
504
+ return (
505
+ <div className="error-fallback">
506
+ <h2>Something went wrong</h2>
507
+ <p>{this.state.error?.message}</p>
508
+ <button onClick={() => this.setState({ hasError: false })}>
509
+ Try again
510
+ </button>
511
+ </div>
512
+ )
513
+ }
514
+
515
+ return this.props.children
516
+ }
517
+ }
518
+
519
+ // Usage
520
+ <ErrorBoundary>
521
+ <App />
522
+ </ErrorBoundary>
523
+ ```
524
+
525
+ ## Animation Patterns
526
+
527
+ ### Framer Motion Animations
528
+
529
+ ```typescript
530
+ import { motion, AnimatePresence } from 'framer-motion'
531
+
532
+ // PASS: List animations
533
+ export function AnimatedMarketList({ markets }: { markets: Market[] }) {
534
+ return (
535
+ <AnimatePresence>
536
+ {markets.map(market => (
537
+ <motion.div
538
+ key={market.id}
539
+ initial={{ opacity: 0, y: 20 }}
540
+ animate={{ opacity: 1, y: 0 }}
541
+ exit={{ opacity: 0, y: -20 }}
542
+ transition={{ duration: 0.3 }}
543
+ >
544
+ <MarketCard market={market} />
545
+ </motion.div>
546
+ ))}
547
+ </AnimatePresence>
548
+ )
549
+ }
550
+
551
+ // PASS: Modal animations
552
+ export function Modal({ isOpen, onClose, children }: ModalProps) {
553
+ return (
554
+ <AnimatePresence>
555
+ {isOpen && (
556
+ <>
557
+ <motion.div
558
+ className="modal-overlay"
559
+ initial={{ opacity: 0 }}
560
+ animate={{ opacity: 1 }}
561
+ exit={{ opacity: 0 }}
562
+ onClick={onClose}
563
+ />
564
+ <motion.div
565
+ className="modal-content"
566
+ initial={{ opacity: 0, scale: 0.9, y: 20 }}
567
+ animate={{ opacity: 1, scale: 1, y: 0 }}
568
+ exit={{ opacity: 0, scale: 0.9, y: 20 }}
569
+ >
570
+ {children}
571
+ </motion.div>
572
+ </>
573
+ )}
574
+ </AnimatePresence>
575
+ )
576
+ }
577
+ ```
578
+
579
+ ## Accessibility Patterns
580
+
581
+ ### Keyboard Navigation
582
+
583
+ ```typescript
584
+ export function Dropdown({ options, onSelect }: DropdownProps) {
585
+ const [isOpen, setIsOpen] = useState(false)
586
+ const [activeIndex, setActiveIndex] = useState(0)
587
+
588
+ const handleKeyDown = (e: React.KeyboardEvent) => {
589
+ switch (e.key) {
590
+ case 'ArrowDown':
591
+ e.preventDefault()
592
+ setActiveIndex(i => Math.min(i + 1, options.length - 1))
593
+ break
594
+ case 'ArrowUp':
595
+ e.preventDefault()
596
+ setActiveIndex(i => Math.max(i - 1, 0))
597
+ break
598
+ case 'Enter':
599
+ e.preventDefault()
600
+ onSelect(options[activeIndex])
601
+ setIsOpen(false)
602
+ break
603
+ case 'Escape':
604
+ setIsOpen(false)
605
+ break
606
+ }
607
+ }
608
+
609
+ return (
610
+ <div
611
+ role="combobox"
612
+ aria-expanded={isOpen}
613
+ aria-haspopup="listbox"
614
+ onKeyDown={handleKeyDown}
615
+ >
616
+ {/* Dropdown implementation */}
617
+ </div>
618
+ )
619
+ }
620
+ ```
621
+
622
+ ### Focus Management
623
+
624
+ ```typescript
625
+ export function Modal({ isOpen, onClose, children }: ModalProps) {
626
+ const modalRef = useRef<HTMLDivElement>(null)
627
+ const previousFocusRef = useRef<HTMLElement | null>(null)
628
+
629
+ useEffect(() => {
630
+ if (isOpen) {
631
+ // Save currently focused element
632
+ previousFocusRef.current = document.activeElement as HTMLElement
633
+
634
+ // Focus modal
635
+ modalRef.current?.focus()
636
+ } else {
637
+ // Restore focus when closing
638
+ previousFocusRef.current?.focus()
639
+ }
640
+ }, [isOpen])
641
+
642
+ return isOpen ? (
643
+ <div
644
+ ref={modalRef}
645
+ role="dialog"
646
+ aria-modal="true"
647
+ tabIndex={-1}
648
+ onKeyDown={e => e.key === 'Escape' && onClose()}
649
+ >
650
+ {children}
651
+ </div>
652
+ ) : null
653
+ }
654
+ ```
655
+
656
+ **Remember**: Modern frontend patterns enable maintainable, performant user interfaces. Choose patterns that fit your project complexity.