@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,43 +0,0 @@
1
- # Hierarchical Injectors
2
-
3
- Angular's dependency injection system is hierarchical, meaning services can be scoped to different levels of the application.
4
-
5
- ## Types of Injector Hierarchies
6
-
7
- 1. **`EnvironmentInjector` Hierarchy**: Configured via `@Injectable({ providedIn: 'root' })` or `ApplicationConfig.providers` during bootstrap. These are global singletons.
8
- 2. **`ElementInjector` Hierarchy**: Created implicitly at each DOM element. Configured via the `providers` or `viewProviders` array in `@Component()` or `@Directive()`.
9
-
10
- ## Resolution Rules
11
-
12
- When a dependency is requested, Angular resolves it in two phases:
13
-
14
- 1. It searches up the **`ElementInjector`** tree, starting from the requesting component/directive up to the root element.
15
- 2. If not found, it searches the **`EnvironmentInjector`** tree, starting from the closest environment injector up to the root.
16
- 3. If still not found, it throws an error (unless marked optional).
17
-
18
- ## Resolution Modifiers
19
-
20
- You can alter how Angular searches for a dependency using the options object in `inject()`:
21
-
22
- - **`optional`**: If the dependency isn't found, return `null` instead of throwing an error.
23
- - **`self`**: Only check the current `ElementInjector`. Do not look up the parent tree.
24
- - **`skipSelf`**: Start searching in the parent `ElementInjector`, skipping the current element.
25
- - **`host`**: Stop searching when reaching the host component's view boundary.
26
-
27
- ```ts
28
- @Component({...})
29
- export class Example {
30
- // Returns null if not found instead of crashing
31
- optionalService = inject(MyService, { optional: true });
32
-
33
- // Skips this component's providers, looks at parent
34
- parentService = inject(ParentService, { skipSelf: true });
35
- }
36
- ```
37
-
38
- ## `providers` vs `viewProviders`
39
-
40
- When providing a service at the component level:
41
-
42
- - **`providers`**: The service is available to the component, its view (template), and any **projected content** (`<ng-content>`).
43
- - **`viewProviders`**: The service is available to the component and its view, but **NOT** to projected content. Use this to isolate services from content passed in by consumers.
@@ -1,80 +0,0 @@
1
- # Component Host Elements
2
-
3
- The **host element** is the DOM element that matches a component's selector. The component's template renders inside this element.
4
-
5
- ## Binding to the Host Element
6
-
7
- Use the `host` property in the `@Component` decorator to bind properties, attributes, styles, and events to the host element. This is the **preferred approach** over legacy decorators.
8
-
9
- ```ts
10
- @Component({
11
- selector: 'custom-slider',
12
- host: {
13
- 'role': 'slider', // Static attribute
14
- '[attr.aria-valuenow]': 'value', // Attribute binding
15
- '[class.active]': 'isActive()', // Class binding
16
- '[style.color]': 'color()', // Style binding
17
- '[tabIndex]': 'disabled ? -1 : 0', // Property binding
18
- '(keydown)': 'onKeyDown($event)', // Event binding
19
- },
20
- })
21
- export class CustomSlider {
22
- value = 0;
23
- disabled = false;
24
- isActive = signal(false);
25
- color = signal('blue');
26
-
27
- onKeyDown(event: KeyboardEvent) {
28
- /* ... */
29
- }
30
- }
31
- ```
32
-
33
- ## Legacy Decorators
34
-
35
- `@HostBinding` and `@HostListener` are supported for backwards compatibility but should be avoided in new code.
36
-
37
- ```ts
38
- export class CustomSlider {
39
- @HostBinding('tabIndex')
40
- get tabIndex() {
41
- return this.disabled ? -1 : 0;
42
- }
43
-
44
- @HostListener('keydown', ['$event'])
45
- onKeyDown(event: KeyboardEvent) {
46
- /* ... */
47
- }
48
- }
49
- ```
50
-
51
- ## Binding Collisions
52
-
53
- If both the component (host binding) and the consumer (template binding) bind to the same property:
54
-
55
- 1. **Static vs Static**: The instance (consumer) binding wins.
56
- 2. **Static vs Dynamic**: The dynamic binding wins.
57
- 3. **Dynamic vs Dynamic**: The component's host binding wins.
58
-
59
- ## Injecting Host Attributes
60
-
61
- Use `HostAttributeToken` with the `inject` function to read static attributes from the host element at construction time.
62
-
63
- ```ts
64
- import {Component, HostAttributeToken, inject} from '@angular/core';
65
-
66
- @Component({
67
- selector: 'app-btn',
68
- template: `<ng-content />`,
69
- })
70
- export class AppButton {
71
- // Throws error if 'type' is missing unless injected with { optional: true }
72
- type = inject(new HostAttributeToken('type'));
73
- }
74
- ```
75
-
76
- Usage:
77
-
78
- ```html
79
- <app-btn type="primary">Click Me</app-btn>
80
- ```
@@ -1,63 +0,0 @@
1
- # Injection Context
2
-
3
- The `inject()` function can only be used when code is executing within an **injection context**.
4
-
5
- ## Where is an Injection Context Available?
6
-
7
- An injection context is automatically available in:
8
-
9
- 1. **Field initializers** of classes instantiated by DI (`@Injectable`, `@Component`, `@Directive`, `@Pipe`).
10
- 2. **Constructors** of classes instantiated by DI.
11
- 3. **Factory functions** specified in `useFactory` or `InjectionToken` configurations.
12
- 4. **Functional APIs** executed by Angular (e.g., functional route guards, resolvers, interceptors).
13
-
14
- ```ts
15
- @Component({...})
16
- export class Example {
17
- // Valid: Field initializer
18
- private router = inject(Router);
19
-
20
- constructor() {
21
- // Valid: Constructor
22
- const http = inject(HttpClient);
23
- }
24
-
25
- onClick() {
26
- // Invalid: Not an injection context
27
- // const auth = inject(AuthService);
28
- }
29
- }
30
- ```
31
-
32
- ## `runInInjectionContext`
33
-
34
- If you need to run a function within an injection context (often needed for dynamic component creation or testing), use `runInInjectionContext`. This requires access to an existing injector (like `EnvironmentInjector` or `Injector`).
35
-
36
- ```ts
37
- import {Injectable, inject, EnvironmentInjector, runInInjectionContext} from '@angular/core';
38
-
39
- @Injectable({providedIn: 'root'})
40
- export class MyService {
41
- private injector = inject(EnvironmentInjector);
42
-
43
- doSomethingDynamic() {
44
- runInInjectionContext(this.injector, () => {
45
- // Now valid to use inject() here
46
- const router = inject(Router);
47
- });
48
- }
49
- }
50
- ```
51
-
52
- ## `assertInInjectionContext`
53
-
54
- Use `assertInInjectionContext` in utility functions to guarantee they are called from a valid context. It throws a clear error if not.
55
-
56
- ```ts
57
- import {assertInInjectionContext, inject, ElementRef} from '@angular/core';
58
-
59
- export function injectNativeElement<T extends Element>(): T {
60
- assertInInjectionContext(injectNativeElement);
61
- return inject(ElementRef).nativeElement;
62
- }
63
- ```
@@ -1,101 +0,0 @@
1
- # Inputs
2
-
3
- Inputs allow data to flow from a parent component to a child component. Angular recommends using the signal-based `input` API for modern applications.
4
-
5
- ## Signal-based Inputs
6
-
7
- Declare inputs using the `input()` function. This returns an `InputSignal`.
8
-
9
- ```ts
10
- import {Component, input, computed} from '@angular/core';
11
-
12
- @Component({
13
- selector: 'app-user',
14
- template: `<p>User: {{ name() }} ({{ age() }})</p>`,
15
- })
16
- export class User {
17
- // Optional input with default value
18
- name = input('Guest');
19
-
20
- // Required input
21
- age = input.required<number>();
22
-
23
- // Inputs are reactive signals
24
- label = computed(() => `Name: ${this.name()}`);
25
- }
26
- ```
27
-
28
- ### Usage in Template
29
-
30
- ```html
31
- <app-user [name]="userName" [age]="25" />
32
- ```
33
-
34
- ## Configuration Options
35
-
36
- The `input` function accepts a config object:
37
-
38
- - **Alias**: Change the property name used in templates.
39
- - **Transform**: Modify the value before it reaches the component.
40
-
41
- ```ts
42
- import { input, booleanAttribute } from '@angular/core';
43
-
44
- @Component({...})
45
- export class CustomButton {
46
- // Alias example
47
- label = input('', { alias: 'btnLabel' });
48
-
49
- // Transform example using built-in helper
50
- disabled = input(false, { transform: booleanAttribute });
51
- }
52
- ```
53
-
54
- ## Model Inputs (Two-Way Binding)
55
-
56
- Use `model()` to create an input that supports two-way data binding.
57
-
58
- ```ts
59
- @Component({
60
- selector: 'custom-counter',
61
- template: `<button (click)="increment()">+</button>`,
62
- })
63
- export class CustomCounter {
64
- value = model(0);
65
-
66
- increment() {
67
- this.value.update((v) => v + 1);
68
- }
69
- }
70
- ```
71
-
72
- ### Usage
73
-
74
- ```html
75
- <!-- Two-way binding with a signal -->
76
- <custom-counter [(value)]="mySignal" />
77
-
78
- <!-- Two-way binding with a plain property -->
79
- <custom-counter [(value)]="myProperty" />
80
- ```
81
-
82
- ## Decorator-based Inputs (@Input)
83
-
84
- The legacy API remains supported but is not recommended for new code.
85
-
86
- ```ts
87
- import { Component, Input } from '@angular/core';
88
-
89
- @Component({...})
90
- export class Legacy {
91
- @Input({ required: true }) value = 0;
92
- @Input({ transform: trimString }) label = '';
93
- }
94
- ```
95
-
96
- ## Best Practices
97
-
98
- - **Prefer Signals**: Use `input()` instead of `@Input()` for better reactivity and type safety.
99
- - **Required Inputs**: Use `input.required()` for mandatory data to get build-time errors.
100
- - **Pure Transforms**: Ensure input transform functions are pure and statically analyzable.
101
- - **Avoid Collisions**: Do not use input names that collide with standard DOM properties (e.g., `id`, `title`).
@@ -1,59 +0,0 @@
1
- # Dependent State with `linkedSignal`
2
-
3
- The `linkedSignal` function lets you create writable state that is intrinsically linked to some other state. It is perfect for state that needs a default value derived from an input or another signal, but can still be independently modified by the user.
4
-
5
- If the source state changes, the `linkedSignal` resets to a new computed value.
6
-
7
- ## Basic Usage
8
-
9
- When you only need to recompute based on a source, pass a computation function. `linkedSignal` works like `computed`, but the resulting signal is writable (you can call `.set()` or `.update()` on it).
10
-
11
- ```ts
12
- import { Component, signal, linkedSignal } from '@angular/core';
13
-
14
- @Component({...})
15
- export class ShippingMethodPicker {
16
- shippingOptions = signal(['Ground', 'Air', 'Sea']);
17
-
18
- // Defaults to the first option.
19
- // If shippingOptions changes, selectedOption resets to the new first option.
20
- selectedOption = linkedSignal(() => this.shippingOptions()[0]);
21
-
22
- changeShipping(index: number) {
23
- // We can still manually update this signal!
24
- this.selectedOption.set(this.shippingOptions()[index]);
25
- }
26
- }
27
- ```
28
-
29
- ## Advanced Usage: Accounting for Previous State
30
-
31
- Sometimes, when the source state changes, you want to preserve the user's manual selection if it is still valid. To do this, use the object syntax providing `source` and `computation`.
32
-
33
- The `computation` function receives the new value of the source, and a `previous` object containing the previous source value and the previous `linkedSignal` value.
34
-
35
- ```ts
36
- interface ShippingMethod { id: number; name: string; }
37
-
38
- @Component({...})
39
- export class ShippingMethodPicker {
40
- shippingOptions = signal<ShippingMethod[]>([
41
- {id: 0, name: 'Ground'}, {id: 1, name: 'Air'}, {id: 2, name: 'Sea'}
42
- ]);
43
-
44
- selectedOption = linkedSignal<ShippingMethod[], ShippingMethod>({
45
- source: this.shippingOptions,
46
- computation: (newOptions, previous) => {
47
- // If the newly loaded options still contain the user's previously
48
- // selected option, keep it selected. Otherwise, reset to the first option.
49
- return newOptions.find(opt => opt.id === previous?.value.id) ?? newOptions[0];
50
- }
51
- });
52
- }
53
- ```
54
-
55
- ### When to use `linkedSignal` vs `computed` vs `effect`
56
-
57
- - Use `computed`: When state is **strictly** derived from other state and should never be manually updated.
58
- - Use `linkedSignal`: When state is derived from other state, but the user **must** be able to override or manually update it.
59
- - **Never** use `effect` to sync one piece of state to another. That is an anti-pattern. Use `computed` or `linkedSignal` instead.
@@ -1,61 +0,0 @@
1
- # Route Loading Strategies
2
-
3
- Angular supports two main strategies for loading routes and components to balance initial load time and navigation responsiveness.
4
-
5
- ## Eager Loading
6
-
7
- Components are bundled into the initial JavaScript payload and are available immediately.
8
-
9
- ```ts
10
- { path: 'home', component: Home }
11
- ```
12
-
13
- - **Pros**: Seamless transitions.
14
- - **Cons**: Increases initial bundle size.
15
-
16
- ## Lazy Loading
17
-
18
- Components or routes are loaded only when the user navigates to them. This creates separate JavaScript "chunks".
19
-
20
- ### Lazy Loading Components
21
-
22
- Use `loadComponent` to fetch the component on demand.
23
-
24
- ```ts
25
- {
26
- path: 'admin',
27
- loadComponent: () => import('./admin/admin.component').then(m => m.AdminComponent)`,
28
- }
29
- ```
30
-
31
- ### Lazy Loading Child Routes
32
-
33
- Use `loadChildren` to fetch a set of routes.
34
-
35
- ```ts
36
- {
37
- path: 'settings',
38
- loadChildren: () => import('./settings/settings.routes'),
39
- }
40
- ```
41
-
42
- ## Injection Context and Lazy Loading
43
-
44
- Loader functions run within the **injection context** of the current route. This allows you to call `inject()` to make context-aware loading decisions.
45
-
46
- ```ts
47
- {
48
- path: 'dashboard',
49
- loadComponent: () => {
50
- const flags = inject(FeatureFlags);
51
- return flags.isPremium
52
- ? import('./premium-dashboard')
53
- : import('./basic-dashboard');
54
- },
55
- }
56
- ```
57
-
58
- ## Recommendation
59
-
60
- - Use **Eager Loading** for the primary landing pages.
61
- - Use **Lazy Loading** for all other feature areas to keep the initial bundle small.
@@ -1,108 +0,0 @@
1
- # Angular CLI MCP Server
2
-
3
- The Angular CLI includes a Model Context Protocol (MCP) server that enables AI assistants (like Cursor, Gemini CLI, JetBrains AI, etc.) to interact directly with the Angular CLI. It provides tools for code generation, modernizing code, fetching examples, and running builds/tests.
4
-
5
- ## Available Tools (Default)
6
-
7
- When the MCP server is enabled, AI agents have access to the following tools:
8
-
9
- | Name | Description |
10
- | :-------------------------- | :-------------------------------------------------------------------------------------------------------- |
11
- | `ai_tutor` | Launches an interactive AI-powered Angular tutor. |
12
- | `find_examples` | Finds authoritative, best-practice code examples for modern Angular features. |
13
- | `get_best_practices` | Retrieves the Angular Best Practices Guide (crucial for standalone components, typed forms, etc.). |
14
- | `list_projects` | Lists all applications and libraries in the workspace by reading `angular.json`. |
15
- | `onpush_zoneless_migration` | Analyzes code and provides a plan to migrate it to `OnPush` change detection (prerequisite for zoneless). |
16
- | `search_documentation` | Searches the official documentation at `https://angular.dev`. |
17
-
18
- ## Experimental Tools
19
-
20
- Some tools must be enabled explicitly using the `--experimental-tool` (or `-E`) flag.
21
-
22
- | Name | Description |
23
- | :------------------------- | :----------------------------------------------------------------------- |
24
- | `build` | Performs a one-off build using `ng build`. |
25
- | `devserver.start` | Asynchronously starts a dev server (`ng serve`). Returns immediately. |
26
- | `devserver.stop` | Stops the dev server. |
27
- | `devserver.wait_for_build` | Returns the logs of the most recent build in a running dev server. |
28
- | `e2e` | Executes end-to-end tests. |
29
- | `modernize` | Performs code migrations to align with latest best practices and syntax. |
30
- | `test` | Runs the project's unit tests. |
31
-
32
- ## Configuration
33
-
34
- To use the MCP server, you configure your host environment (IDE or CLI) to run `npx @angular/cli mcp`.
35
-
36
- ### Antigravity IDE
37
-
38
- Create a file named `.antigravity/mcp.json` in your project's root:
39
-
40
- ```json
41
- {
42
- "mcpServers": {
43
- "angular-cli": {
44
- "command": "npx",
45
- "args": ["-y", "@angular/cli", "mcp"]
46
- }
47
- }
48
- }
49
- ```
50
-
51
- ### Gemini CLI
52
-
53
- Create `.gemini/settings.json` in the project root:
54
-
55
- ```json
56
- {
57
- "mcpServers": {
58
- "angular-cli": {
59
- "command": "npx",
60
- "args": ["-y", "@angular/cli", "mcp"]
61
- }
62
- }
63
- }
64
- ```
65
-
66
- ### Cursor
67
-
68
- Create `.cursor/mcp.json` in the project root (or globally at `~/.cursor/mcp.json`):
69
-
70
- ```json
71
- {
72
- "mcpServers": {
73
- "angular-cli": {
74
- "command": "npx",
75
- "args": ["-y", "@angular/cli", "mcp"]
76
- }
77
- }
78
- }
79
- ```
80
-
81
- ### VS Code
82
-
83
- Create `.vscode/mcp.json`:
84
-
85
- ```json
86
- {
87
- "servers": {
88
- "angular-cli": {
89
- "command": "npx",
90
- "args": ["-y", "@angular/cli", "mcp"]
91
- }
92
- }
93
- }
94
- ```
95
-
96
- ## Command Options
97
-
98
- You can pass arguments to the MCP server in the `args` array of your configuration:
99
-
100
- - `--read-only`: Only registers tools that do not modify the project.
101
- - `--local-only`: Only registers tools that do not require an internet connection.
102
- - `--experimental-tool` (`-E`): Enables specific experimental tools (e.g., `-E build`, `-E devserver`).
103
-
104
- Example for read-only mode with experimental tools enabled:
105
-
106
- ```json
107
- "args": ["-y", "@angular/cli", "mcp", "--read-only", "-E", "build", "-E", "modernize"]
108
- ```
@@ -1,69 +0,0 @@
1
- # Navigate to Routes
2
-
3
- Angular provides both declarative and programmatic ways to navigate between routes.
4
-
5
- ## Declarative Navigation (`RouterLink`)
6
-
7
- Use the `RouterLink` directive on anchor elements.
8
-
9
- ```ts
10
- import {RouterLink, RouterLinkActive} from '@angular/router';
11
-
12
- @Component({
13
- imports: [RouterLink, RouterLinkActive],
14
- template: `
15
- <nav>
16
- <a routerLink="/dashboard" routerLinkActive="active-link">Dashboard</a>
17
- <a [routerLink]="['/user', userId]">Profile</a>
18
- </nav>
19
- `,
20
- })
21
- export class Nav {
22
- userId = '123';
23
- }
24
- ```
25
-
26
- - **Absolute Paths**: Start with `/` (e.g., `/settings`).
27
- - **Relative Paths**: No leading `/`. Use `../` to go up a level.
28
-
29
- ## Programmatic Navigation (`Router`)
30
-
31
- Inject the `Router` service to navigate via TypeScript code.
32
-
33
- ### `router.navigate()`
34
-
35
- Uses an array of commands.
36
-
37
- ```ts
38
- private router = inject(Router);
39
- private route = inject(ActivatedRoute);
40
-
41
- // Standard navigation
42
- this.router.navigate(['/profile']);
43
-
44
- // With parameters
45
- this.router.navigate(['/search'], {
46
- queryParams: { q: 'angular' },
47
- fragment: 'results'
48
- });
49
-
50
- // Relative navigation
51
- this.router.navigate(['edit'], { relativeTo: this.route });
52
- ```
53
-
54
- ### `router.navigateByUrl()`
55
-
56
- Uses a string path. Ideal for absolute navigation or full URLs.
57
-
58
- ```ts
59
- this.router.navigateByUrl('/products/123?view=details');
60
-
61
- // Replace current entry in history
62
- this.router.navigateByUrl('/login', {replaceUrl: true});
63
- ```
64
-
65
- ## URL Parameters
66
-
67
- - **Route Params**: Part of the path (e.g., `/user/123`).
68
- - **Query Params**: After the `?` (e.g., `/search?q=query`).
69
- - **Matrix Params**: Scoped to a segment (e.g., `/products;category=books`).
@@ -1,86 +0,0 @@
1
- # Outputs (Custom Events)
2
-
3
- Outputs allow a child component to emit custom events that a parent component can listen to. Angular recommends using the new `output()` function for modern applications.
4
-
5
- ## Function-based outputs
6
-
7
- Declare outputs using the `output()` function. This returns an `OutputEmitterRef`.
8
-
9
- ```ts
10
- import {Component, output} from '@angular/core';
11
-
12
- @Component({
13
- selector: 'custom-slider',
14
- template: `<button (click)="changeValue(50)">Set to 50</button>`,
15
- })
16
- export class CustomSlider {
17
- // Output without event data
18
- panelClosed = output<void>();
19
-
20
- // Output with event data (number)
21
- valueChanged = output<number>();
22
-
23
- changeValue(newValue: number) {
24
- this.valueChanged.emit(newValue);
25
- }
26
- }
27
- ```
28
-
29
- ### Usage in Template
30
-
31
- Bind to the output event using parentheses `()`. If the event emits data, access it using the special `$event` variable.
32
-
33
- ```html
34
- <custom-slider (panelClosed)="savePanelState()" (valueChanged)="logValue($event)" />
35
- ```
36
-
37
- ## Configuration Options
38
-
39
- The `output` function accepts a config object to specify an alias.
40
-
41
- ```ts
42
- @Component({...})
43
- export class CustomSlider {
44
- // The event is named 'valueChanged' in the template,
45
- // but accessed as 'changed' in the component class.
46
- changed = output<number>({ alias: 'valueChanged' });
47
- }
48
- ```
49
-
50
- ## Programmatic Subscription
51
-
52
- When creating components dynamically, you can subscribe to outputs programmatically:
53
-
54
- ```ts
55
- const componentRef = viewContainerRef.createComponent(CustomSlider);
56
-
57
- const subscription = componentRef.instance.valueChanged.subscribe((val) => {
58
- console.log('Value changed:', val);
59
- });
60
-
61
- // Clean up manually if needed (Angular cleans up destroyed components automatically)
62
- subscription.unsubscribe();
63
- ```
64
-
65
- ## Decorator-based Outputs (@Output)
66
-
67
- The legacy API uses the `@Output()` decorator with an `EventEmitter`. It remains supported but is not recommended for new code.
68
-
69
- ```ts
70
- import { Component, Output, EventEmitter } from '@angular/core';
71
-
72
- @Component({...})
73
- export class LegacyExample {
74
- @Output() valueChanged = new EventEmitter<number>();
75
-
76
- // With alias
77
- @Output('customEventName') changed = new EventEmitter<void>();
78
- }
79
- ```
80
-
81
- ## Best Practices
82
-
83
- - **Prefer `output()`**: Use the function-based `output()` instead of `@Output()` and `EventEmitter`.
84
- - **Naming**: Use `camelCase` for output names. Avoid prefixing with `on` (e.g., use `valueChanged` instead of `onValueChanged`).
85
- - **No DOM Bubbling**: Angular custom events do not bubble up the DOM tree like native events.
86
- - **Avoid Collisions**: Do not choose names that collide with native DOM events (like `click` or `submit`).