@heytherevibin/skillforge 0.2.1

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 (402) hide show
  1. package/CHANGELOG.md +16 -0
  2. package/CODE_OF_CONDUCT.md +34 -0
  3. package/CONTRIBUTING.md +38 -0
  4. package/LICENSE +21 -0
  5. package/README.md +337 -0
  6. package/RELEASING.md +93 -0
  7. package/SECURITY.md +31 -0
  8. package/STRATEGY.md +26 -0
  9. package/bin/cli.js +547 -0
  10. package/lib/packs.js +184 -0
  11. package/package.json +38 -0
  12. package/python/app/__init__.py +0 -0
  13. package/python/app/__pycache__/__init__.cpython-312.pyc +0 -0
  14. package/python/app/__pycache__/auth.cpython-312.pyc +0 -0
  15. package/python/app/__pycache__/main.cpython-312.pyc +0 -0
  16. package/python/app/auth.py +63 -0
  17. package/python/app/cli.py +78 -0
  18. package/python/app/db_paths.py +26 -0
  19. package/python/app/events_cli.py +175 -0
  20. package/python/app/main.py +647 -0
  21. package/python/app/materialize.py +138 -0
  22. package/python/app/mcp_server.py +610 -0
  23. package/python/app/route_cli.py +117 -0
  24. package/python/requirements-dev.txt +1 -0
  25. package/python/requirements.txt +7 -0
  26. package/python/tests/test_db_paths.py +41 -0
  27. package/skills/accessibility/SKILL.md +145 -0
  28. package/skills/agent-architecture-audit/SKILL.md +256 -0
  29. package/skills/agent-eval/SKILL.md +144 -0
  30. package/skills/agent-harness-construction/SKILL.md +72 -0
  31. package/skills/agent-introspection-debugging/SKILL.md +152 -0
  32. package/skills/agent-payment-x402/SKILL.md +224 -0
  33. package/skills/agent-sort/SKILL.md +214 -0
  34. package/skills/agentic-engineering/SKILL.md +62 -0
  35. package/skills/agentic-os/SKILL.md +386 -0
  36. package/skills/ai-first-engineering/SKILL.md +50 -0
  37. package/skills/ai-regression-testing/SKILL.md +384 -0
  38. package/skills/android-clean-architecture/SKILL.md +338 -0
  39. package/skills/angular-developer/SKILL.md +153 -0
  40. package/skills/angular-developer/references/angular-animations.md +160 -0
  41. package/skills/angular-developer/references/angular-aria.md +410 -0
  42. package/skills/angular-developer/references/cli.md +86 -0
  43. package/skills/angular-developer/references/component-harnesses.md +59 -0
  44. package/skills/angular-developer/references/component-styling.md +91 -0
  45. package/skills/angular-developer/references/components.md +117 -0
  46. package/skills/angular-developer/references/creating-services.md +97 -0
  47. package/skills/angular-developer/references/data-resolvers.md +69 -0
  48. package/skills/angular-developer/references/define-routes.md +67 -0
  49. package/skills/angular-developer/references/defining-providers.md +72 -0
  50. package/skills/angular-developer/references/di-fundamentals.md +120 -0
  51. package/skills/angular-developer/references/e2e-testing.md +56 -0
  52. package/skills/angular-developer/references/effects.md +83 -0
  53. package/skills/angular-developer/references/hierarchical-injectors.md +43 -0
  54. package/skills/angular-developer/references/host-elements.md +80 -0
  55. package/skills/angular-developer/references/injection-context.md +63 -0
  56. package/skills/angular-developer/references/inputs.md +101 -0
  57. package/skills/angular-developer/references/linked-signal.md +59 -0
  58. package/skills/angular-developer/references/loading-strategies.md +61 -0
  59. package/skills/angular-developer/references/mcp.md +108 -0
  60. package/skills/angular-developer/references/navigate-to-routes.md +69 -0
  61. package/skills/angular-developer/references/outputs.md +86 -0
  62. package/skills/angular-developer/references/reactive-forms.md +122 -0
  63. package/skills/angular-developer/references/rendering-strategies.md +44 -0
  64. package/skills/angular-developer/references/resource.md +77 -0
  65. package/skills/angular-developer/references/route-animations.md +56 -0
  66. package/skills/angular-developer/references/route-guards.md +52 -0
  67. package/skills/angular-developer/references/router-lifecycle.md +45 -0
  68. package/skills/angular-developer/references/router-testing.md +87 -0
  69. package/skills/angular-developer/references/show-routes-with-outlets.md +68 -0
  70. package/skills/angular-developer/references/signal-forms.md +795 -0
  71. package/skills/angular-developer/references/signals-overview.md +94 -0
  72. package/skills/angular-developer/references/tailwind-css.md +69 -0
  73. package/skills/angular-developer/references/template-driven-forms.md +114 -0
  74. package/skills/angular-developer/references/testing-fundamentals.md +65 -0
  75. package/skills/api-connector-builder/SKILL.md +120 -0
  76. package/skills/api-design/SKILL.md +522 -0
  77. package/skills/architecture-decision-records/SKILL.md +178 -0
  78. package/skills/article-writing/SKILL.md +78 -0
  79. package/skills/automation-audit-ops/SKILL.md +141 -0
  80. package/skills/autonomous-agent-harness/SKILL.md +272 -0
  81. package/skills/autonomous-loops/SKILL.md +609 -0
  82. package/skills/backend-patterns/SKILL.md +560 -0
  83. package/skills/benchmark/SKILL.md +92 -0
  84. package/skills/blueprint/SKILL.md +104 -0
  85. package/skills/browser-qa/SKILL.md +86 -0
  86. package/skills/bun-runtime/SKILL.md +83 -0
  87. package/skills/canary-watch/SKILL.md +98 -0
  88. package/skills/carrier-relationship-management/SKILL.md +211 -0
  89. package/skills/cisco-ios-patterns/SKILL.md +163 -0
  90. package/skills/ck/SKILL.md +147 -0
  91. package/skills/ck/commands/forget.mjs +44 -0
  92. package/skills/ck/commands/info.mjs +24 -0
  93. package/skills/ck/commands/init.mjs +143 -0
  94. package/skills/ck/commands/list.mjs +40 -0
  95. package/skills/ck/commands/migrate.mjs +202 -0
  96. package/skills/ck/commands/resume.mjs +36 -0
  97. package/skills/ck/commands/save.mjs +210 -0
  98. package/skills/ck/commands/shared.mjs +387 -0
  99. package/skills/ck/hooks/session-start.mjs +224 -0
  100. package/skills/claude-devfleet/SKILL.md +103 -0
  101. package/skills/click-path-audit/SKILL.md +244 -0
  102. package/skills/clickhouse-io/SKILL.md +438 -0
  103. package/skills/code-tour/SKILL.md +235 -0
  104. package/skills/codebase-onboarding/SKILL.md +232 -0
  105. package/skills/coding-standards/SKILL.md +548 -0
  106. package/skills/compose-multiplatform-patterns/SKILL.md +298 -0
  107. package/skills/connections-optimizer/SKILL.md +188 -0
  108. package/skills/content-engine/SKILL.md +126 -0
  109. package/skills/content-hash-cache-pattern/SKILL.md +160 -0
  110. package/skills/context-budget/SKILL.md +134 -0
  111. package/skills/continuous-agent-loop/SKILL.md +44 -0
  112. package/skills/continuous-learning/SKILL.md +129 -0
  113. package/skills/continuous-learning/config.json +18 -0
  114. package/skills/continuous-learning/evaluate-session.sh +69 -0
  115. package/skills/continuous-learning-v2/SKILL.md +358 -0
  116. package/skills/continuous-learning-v2/agents/observer-loop.sh +322 -0
  117. package/skills/continuous-learning-v2/agents/observer.md +198 -0
  118. package/skills/continuous-learning-v2/agents/session-guardian.sh +150 -0
  119. package/skills/continuous-learning-v2/agents/start-observer.sh +248 -0
  120. package/skills/continuous-learning-v2/config.json +8 -0
  121. package/skills/continuous-learning-v2/hooks/observe.sh +476 -0
  122. package/skills/continuous-learning-v2/scripts/detect-project.sh +288 -0
  123. package/skills/continuous-learning-v2/scripts/instinct-cli.py +1519 -0
  124. package/skills/continuous-learning-v2/scripts/lib/homunculus-dir.sh +31 -0
  125. package/skills/continuous-learning-v2/scripts/migrate-homunculus.sh +62 -0
  126. package/skills/continuous-learning-v2/scripts/test_parse_instinct.py +1018 -0
  127. package/skills/cost-aware-llm-pipeline/SKILL.md +182 -0
  128. package/skills/cost-tracking/SKILL.md +147 -0
  129. package/skills/council/SKILL.md +202 -0
  130. package/skills/cpp-coding-standards/SKILL.md +722 -0
  131. package/skills/cpp-testing/SKILL.md +323 -0
  132. package/skills/crosspost/SKILL.md +110 -0
  133. package/skills/csharp-testing/SKILL.md +320 -0
  134. package/skills/customer-billing-ops/SKILL.md +139 -0
  135. package/skills/customs-trade-compliance/SKILL.md +262 -0
  136. package/skills/dart-flutter-patterns/SKILL.md +562 -0
  137. package/skills/dashboard-builder/SKILL.md +108 -0
  138. package/skills/data-scraper-agent/SKILL.md +764 -0
  139. package/skills/database-migrations/SKILL.md +428 -0
  140. package/skills/deep-research/SKILL.md +158 -0
  141. package/skills/defi-amm-security/SKILL.md +166 -0
  142. package/skills/deployment-patterns/SKILL.md +426 -0
  143. package/skills/design-system/SKILL.md +81 -0
  144. package/skills/django-celery/SKILL.md +456 -0
  145. package/skills/django-patterns/SKILL.md +733 -0
  146. package/skills/django-security/SKILL.md +592 -0
  147. package/skills/django-tdd/SKILL.md +728 -0
  148. package/skills/django-verification/SKILL.md +468 -0
  149. package/skills/dmux-workflows/SKILL.md +190 -0
  150. package/skills/docker-patterns/SKILL.md +363 -0
  151. package/skills/documentation-lookup/SKILL.md +89 -0
  152. package/skills/dotnet-patterns/SKILL.md +320 -0
  153. package/skills/e2e-testing/SKILL.md +325 -0
  154. package/skills/email-ops/SKILL.md +120 -0
  155. package/skills/energy-procurement/SKILL.md +227 -0
  156. package/skills/enterprise-agent-ops/SKILL.md +49 -0
  157. package/skills/error-handling/SKILL.md +375 -0
  158. package/skills/eval-harness/SKILL.md +269 -0
  159. package/skills/evm-token-decimals/SKILL.md +130 -0
  160. package/skills/exa-search/SKILL.md +106 -0
  161. package/skills/fal-ai-media/SKILL.md +287 -0
  162. package/skills/fastapi-patterns/SKILL.md +327 -0
  163. package/skills/finance-billing-ops/SKILL.md +126 -0
  164. package/skills/flox-environments/SKILL.md +496 -0
  165. package/skills/flutter-dart-code-review/SKILL.md +434 -0
  166. package/skills/foundation-models-on-device/SKILL.md +243 -0
  167. package/skills/frontend-design-direction/SKILL.md +92 -0
  168. package/skills/frontend-patterns/SKILL.md +641 -0
  169. package/skills/frontend-slides/SKILL.md +183 -0
  170. package/skills/frontend-slides/STYLE_PRESETS.md +330 -0
  171. package/skills/frontend-slides/animation-patterns.md +122 -0
  172. package/skills/frontend-slides/html-template.md +419 -0
  173. package/skills/frontend-slides/scripts/export-pdf.sh +418 -0
  174. package/skills/frontend-slides/scripts/extract-pptx.py +96 -0
  175. package/skills/frontend-slides/viewport-base.css +153 -0
  176. package/skills/fsharp-testing/SKILL.md +279 -0
  177. package/skills/gan-style-harness/SKILL.md +278 -0
  178. package/skills/gateguard/SKILL.md +125 -0
  179. package/skills/git-workflow/SKILL.md +714 -0
  180. package/skills/github-ops/SKILL.md +143 -0
  181. package/skills/golang-patterns/SKILL.md +673 -0
  182. package/skills/golang-testing/SKILL.md +719 -0
  183. package/skills/google-workspace-ops/SKILL.md +94 -0
  184. package/skills/healthcare-cdss-patterns/SKILL.md +245 -0
  185. package/skills/healthcare-emr-patterns/SKILL.md +159 -0
  186. package/skills/healthcare-eval-harness/SKILL.md +207 -0
  187. package/skills/healthcare-phi-compliance/SKILL.md +145 -0
  188. package/skills/hermes-imports/SKILL.md +87 -0
  189. package/skills/hexagonal-architecture/SKILL.md +275 -0
  190. package/skills/hipaa-compliance/SKILL.md +78 -0
  191. package/skills/homelab-network-readiness/SKILL.md +169 -0
  192. package/skills/homelab-network-setup/SKILL.md +129 -0
  193. package/skills/homelab-pihole-dns/SKILL.md +274 -0
  194. package/skills/homelab-vlan-segmentation/SKILL.md +311 -0
  195. package/skills/homelab-wireguard-vpn/SKILL.md +305 -0
  196. package/skills/hookify-rules/SKILL.md +128 -0
  197. package/skills/inventory-demand-planning/SKILL.md +246 -0
  198. package/skills/investor-materials/SKILL.md +95 -0
  199. package/skills/investor-outreach/SKILL.md +90 -0
  200. package/skills/ios-icon-gen/SKILL.md +157 -0
  201. package/skills/ios-icon-gen/scripts/generate_icons.swift +258 -0
  202. package/skills/ios-icon-gen/scripts/iconify_gen.sh +235 -0
  203. package/skills/iterative-retrieval/SKILL.md +209 -0
  204. package/skills/java-coding-standards/SKILL.md +382 -0
  205. package/skills/jira-integration/SKILL.md +292 -0
  206. package/skills/jpa-patterns/SKILL.md +150 -0
  207. package/skills/knowledge-ops/SKILL.md +153 -0
  208. package/skills/kotlin-coroutines-flows/SKILL.md +283 -0
  209. package/skills/kotlin-exposed-patterns/SKILL.md +718 -0
  210. package/skills/kotlin-ktor-patterns/SKILL.md +688 -0
  211. package/skills/kotlin-patterns/SKILL.md +710 -0
  212. package/skills/kotlin-testing/SKILL.md +823 -0
  213. package/skills/laravel-patterns/SKILL.md +414 -0
  214. package/skills/laravel-plugin-discovery/SKILL.md +228 -0
  215. package/skills/laravel-security/SKILL.md +284 -0
  216. package/skills/laravel-tdd/SKILL.md +282 -0
  217. package/skills/laravel-verification/SKILL.md +178 -0
  218. package/skills/lead-intelligence/SKILL.md +320 -0
  219. package/skills/lead-intelligence/agents/enrichment-agent.md +85 -0
  220. package/skills/lead-intelligence/agents/mutual-mapper.md +75 -0
  221. package/skills/lead-intelligence/agents/outreach-drafter.md +98 -0
  222. package/skills/lead-intelligence/agents/signal-scorer.md +60 -0
  223. package/skills/liquid-glass-design/SKILL.md +279 -0
  224. package/skills/llm-trading-agent-security/SKILL.md +146 -0
  225. package/skills/logistics-exception-management/SKILL.md +221 -0
  226. package/skills/make-interfaces-feel-better/SKILL.md +151 -0
  227. package/skills/manim-video/SKILL.md +88 -0
  228. package/skills/manim-video/assets/network_graph_scene.py +52 -0
  229. package/skills/market-research/SKILL.md +74 -0
  230. package/skills/mcp-server-patterns/SKILL.md +68 -0
  231. package/skills/messages-ops/SKILL.md +103 -0
  232. package/skills/mle-workflow/SKILL.md +345 -0
  233. package/skills/motion-advanced/SKILL.md +596 -0
  234. package/skills/motion-foundations/SKILL.md +299 -0
  235. package/skills/motion-patterns/SKILL.md +435 -0
  236. package/skills/motion-ui/SKILL.md +574 -0
  237. package/skills/mysql-patterns/SKILL.md +411 -0
  238. package/skills/nanoclaw-repl/SKILL.md +32 -0
  239. package/skills/nestjs-patterns/SKILL.md +229 -0
  240. package/skills/netmiko-ssh-automation/SKILL.md +173 -0
  241. package/skills/network-bgp-diagnostics/SKILL.md +167 -0
  242. package/skills/network-config-validation/SKILL.md +210 -0
  243. package/skills/network-interface-health/SKILL.md +152 -0
  244. package/skills/nextjs-turbopack/SKILL.md +43 -0
  245. package/skills/nodejs-keccak256/SKILL.md +102 -0
  246. package/skills/nutrient-document-processing/SKILL.md +166 -0
  247. package/skills/nuxt4-patterns/SKILL.md +99 -0
  248. package/skills/openclaw-persona-forge/SKILL.md +288 -0
  249. package/skills/openclaw-persona-forge/gacha.py +224 -0
  250. package/skills/openclaw-persona-forge/gacha.sh +5 -0
  251. package/skills/openclaw-persona-forge/references/avatar-style.md +124 -0
  252. package/skills/openclaw-persona-forge/references/boundary-rules.md +53 -0
  253. package/skills/openclaw-persona-forge/references/error-handling.md +53 -0
  254. package/skills/openclaw-persona-forge/references/identity-tension.md +48 -0
  255. package/skills/openclaw-persona-forge/references/naming-system.md +39 -0
  256. package/skills/openclaw-persona-forge/references/output-template.md +166 -0
  257. package/skills/opensource-pipeline/SKILL.md +254 -0
  258. package/skills/perl-patterns/SKILL.md +503 -0
  259. package/skills/perl-security/SKILL.md +502 -0
  260. package/skills/perl-testing/SKILL.md +474 -0
  261. package/skills/plan-orchestrate/SKILL.md +253 -0
  262. package/skills/plankton-code-quality/SKILL.md +236 -0
  263. package/skills/postgres-patterns/SKILL.md +146 -0
  264. package/skills/product-capability/SKILL.md +140 -0
  265. package/skills/product-lens/SKILL.md +91 -0
  266. package/skills/production-audit/SKILL.md +206 -0
  267. package/skills/production-scheduling/SKILL.md +237 -0
  268. package/skills/project-flow-ops/SKILL.md +110 -0
  269. package/skills/prompt-optimizer/SKILL.md +398 -0
  270. package/skills/python-patterns/SKILL.md +749 -0
  271. package/skills/python-testing/SKILL.md +815 -0
  272. package/skills/pytorch-patterns/SKILL.md +395 -0
  273. package/skills/quality-nonconformance/SKILL.md +259 -0
  274. package/skills/quarkus-patterns/SKILL.md +721 -0
  275. package/skills/quarkus-security/SKILL.md +466 -0
  276. package/skills/quarkus-tdd/SKILL.md +810 -0
  277. package/skills/quarkus-verification/SKILL.md +478 -0
  278. package/skills/ralphinho-rfc-pipeline/SKILL.md +66 -0
  279. package/skills/redis-patterns/SKILL.md +402 -0
  280. package/skills/regex-vs-llm-structured-text/SKILL.md +219 -0
  281. package/skills/remotion-video-creation/SKILL.md +43 -0
  282. package/skills/remotion-video-creation/rules/3d.md +86 -0
  283. package/skills/remotion-video-creation/rules/animations.md +29 -0
  284. package/skills/remotion-video-creation/rules/assets/charts-bar-chart.tsx +173 -0
  285. package/skills/remotion-video-creation/rules/assets/text-animations-typewriter.tsx +100 -0
  286. package/skills/remotion-video-creation/rules/assets/text-animations-word-highlight.tsx +108 -0
  287. package/skills/remotion-video-creation/rules/assets.md +78 -0
  288. package/skills/remotion-video-creation/rules/audio.md +172 -0
  289. package/skills/remotion-video-creation/rules/calculate-metadata.md +104 -0
  290. package/skills/remotion-video-creation/rules/can-decode.md +75 -0
  291. package/skills/remotion-video-creation/rules/charts.md +58 -0
  292. package/skills/remotion-video-creation/rules/compositions.md +146 -0
  293. package/skills/remotion-video-creation/rules/display-captions.md +126 -0
  294. package/skills/remotion-video-creation/rules/extract-frames.md +229 -0
  295. package/skills/remotion-video-creation/rules/fonts.md +152 -0
  296. package/skills/remotion-video-creation/rules/get-audio-duration.md +58 -0
  297. package/skills/remotion-video-creation/rules/get-video-dimensions.md +68 -0
  298. package/skills/remotion-video-creation/rules/get-video-duration.md +58 -0
  299. package/skills/remotion-video-creation/rules/gifs.md +138 -0
  300. package/skills/remotion-video-creation/rules/images.md +130 -0
  301. package/skills/remotion-video-creation/rules/import-srt-captions.md +67 -0
  302. package/skills/remotion-video-creation/rules/lottie.md +67 -0
  303. package/skills/remotion-video-creation/rules/measuring-dom-nodes.md +34 -0
  304. package/skills/remotion-video-creation/rules/measuring-text.md +143 -0
  305. package/skills/remotion-video-creation/rules/sequencing.md +106 -0
  306. package/skills/remotion-video-creation/rules/tailwind.md +11 -0
  307. package/skills/remotion-video-creation/rules/text-animations.md +20 -0
  308. package/skills/remotion-video-creation/rules/timing.md +179 -0
  309. package/skills/remotion-video-creation/rules/transcribe-captions.md +19 -0
  310. package/skills/remotion-video-creation/rules/transitions.md +122 -0
  311. package/skills/remotion-video-creation/rules/trimming.md +52 -0
  312. package/skills/remotion-video-creation/rules/videos.md +171 -0
  313. package/skills/repo-scan/SKILL.md +78 -0
  314. package/skills/research-ops/SKILL.md +111 -0
  315. package/skills/returns-reverse-logistics/SKILL.md +239 -0
  316. package/skills/rules-distill/SKILL.md +263 -0
  317. package/skills/rules-distill/scripts/scan-rules.sh +58 -0
  318. package/skills/rules-distill/scripts/scan-skills.sh +129 -0
  319. package/skills/rust-patterns/SKILL.md +498 -0
  320. package/skills/rust-testing/SKILL.md +499 -0
  321. package/skills/safety-guard/SKILL.md +74 -0
  322. package/skills/santa-method/SKILL.md +306 -0
  323. package/skills/scientific-db-pubmed-database/SKILL.md +175 -0
  324. package/skills/scientific-db-uspto-database/SKILL.md +177 -0
  325. package/skills/scientific-pkg-gget/SKILL.md +166 -0
  326. package/skills/scientific-thinking-literature-review/SKILL.md +192 -0
  327. package/skills/scientific-thinking-scholar-evaluation/SKILL.md +160 -0
  328. package/skills/search-first/SKILL.md +181 -0
  329. package/skills/security-bounty-hunter/SKILL.md +99 -0
  330. package/skills/security-review/SKILL.md +502 -0
  331. package/skills/security-review/cloud-infrastructure-security.md +361 -0
  332. package/skills/seo/SKILL.md +153 -0
  333. package/skills/skill-comply/SKILL.md +57 -0
  334. package/skills/skill-comply/fixtures/compliant_trace.jsonl +5 -0
  335. package/skills/skill-comply/fixtures/noncompliant_trace.jsonl +3 -0
  336. package/skills/skill-comply/fixtures/tdd_spec.yaml +44 -0
  337. package/skills/skill-comply/prompts/classifier.md +24 -0
  338. package/skills/skill-comply/prompts/scenario_generator.md +62 -0
  339. package/skills/skill-comply/prompts/spec_generator.md +42 -0
  340. package/skills/skill-comply/pyproject.toml +15 -0
  341. package/skills/skill-comply/scripts/__init__.py +0 -0
  342. package/skills/skill-comply/scripts/classifier.py +85 -0
  343. package/skills/skill-comply/scripts/grader.py +124 -0
  344. package/skills/skill-comply/scripts/parser.py +107 -0
  345. package/skills/skill-comply/scripts/report.py +170 -0
  346. package/skills/skill-comply/scripts/run.py +127 -0
  347. package/skills/skill-comply/scripts/runner.py +186 -0
  348. package/skills/skill-comply/scripts/scenario_generator.py +70 -0
  349. package/skills/skill-comply/scripts/spec_generator.py +72 -0
  350. package/skills/skill-comply/scripts/utils.py +13 -0
  351. package/skills/skill-comply/tests/test_grader.py +197 -0
  352. package/skills/skill-comply/tests/test_parser.py +90 -0
  353. package/skills/skill-comply/tests/test_runner.py +172 -0
  354. package/skills/skill-scout/SKILL.md +139 -0
  355. package/skills/skill-stocktake/SKILL.md +193 -0
  356. package/skills/skill-stocktake/scripts/quick-diff.sh +87 -0
  357. package/skills/skill-stocktake/scripts/save-results.sh +56 -0
  358. package/skills/skill-stocktake/scripts/scan.sh +170 -0
  359. package/skills/social-graph-ranker/SKILL.md +153 -0
  360. package/skills/springboot-patterns/SKILL.md +313 -0
  361. package/skills/springboot-security/SKILL.md +271 -0
  362. package/skills/springboot-tdd/SKILL.md +157 -0
  363. package/skills/springboot-verification/SKILL.md +230 -0
  364. package/skills/strategic-compact/SKILL.md +129 -0
  365. package/skills/strategic-compact/suggest-compact.sh +54 -0
  366. package/skills/swift-actor-persistence/SKILL.md +142 -0
  367. package/skills/swift-concurrency-6-2/SKILL.md +216 -0
  368. package/skills/swift-protocol-di-testing/SKILL.md +189 -0
  369. package/skills/swiftui-patterns/SKILL.md +259 -0
  370. package/skills/tdd-workflow/SKILL.md +462 -0
  371. package/skills/team-builder/SKILL.md +166 -0
  372. package/skills/terminal-ops/SKILL.md +108 -0
  373. package/skills/tinystruct-patterns/SKILL.md +130 -0
  374. package/skills/tinystruct-patterns/references/architecture.md +77 -0
  375. package/skills/tinystruct-patterns/references/data-handling.md +35 -0
  376. package/skills/tinystruct-patterns/references/routing.md +57 -0
  377. package/skills/tinystruct-patterns/references/system-usage.md +74 -0
  378. package/skills/tinystruct-patterns/references/testing.md +59 -0
  379. package/skills/token-budget-advisor/SKILL.md +133 -0
  380. package/skills/ui-demo/SKILL.md +464 -0
  381. package/skills/ui-to-vue/SKILL.md +134 -0
  382. package/skills/unified-notifications-ops/SKILL.md +186 -0
  383. package/skills/verification-loop/SKILL.md +125 -0
  384. package/skills/video-editing/SKILL.md +309 -0
  385. package/skills/videodb/SKILL.md +373 -0
  386. package/skills/videodb/reference/api-reference.md +550 -0
  387. package/skills/videodb/reference/capture-reference.md +407 -0
  388. package/skills/videodb/reference/capture.md +101 -0
  389. package/skills/videodb/reference/editor.md +443 -0
  390. package/skills/videodb/reference/generative.md +331 -0
  391. package/skills/videodb/reference/rtstream-reference.md +564 -0
  392. package/skills/videodb/reference/rtstream.md +65 -0
  393. package/skills/videodb/reference/search.md +230 -0
  394. package/skills/videodb/reference/streaming.md +406 -0
  395. package/skills/videodb/reference/use-cases.md +118 -0
  396. package/skills/videodb/scripts/ws_listener.py +282 -0
  397. package/skills/visa-doc-translate/README.md +86 -0
  398. package/skills/visa-doc-translate/SKILL.md +117 -0
  399. package/skills/vite-patterns/SKILL.md +448 -0
  400. package/skills/windows-desktop-e2e/SKILL.md +787 -0
  401. package/skills/workspace-surface-audit/SKILL.md +124 -0
  402. package/skills/x-api/SKILL.md +233 -0
@@ -0,0 +1,122 @@
1
+ # Reactive Forms
2
+
3
+ Reactive forms provide a model-driven approach to handling form inputs. They are built around observable streams and provide synchronous access to the data model, making them more scalable and testable than template-driven forms.
4
+
5
+ ## Core Classes
6
+
7
+ Reactive forms are built using these fundamental classes from `@angular/forms`:
8
+
9
+ - `FormControl`: Manages the value and validity of an individual input.
10
+ - `FormGroup`: Manages a group of controls (an object-like structure).
11
+ - `FormArray`: Manages a numerically indexed array of controls.
12
+ - `FormBuilder`: A service that provides factory methods for creating control instances.
13
+
14
+ ## Setup
15
+
16
+ Import `ReactiveFormsModule` into your component.
17
+
18
+ ```ts
19
+ import {Component, inject} from '@angular/core';
20
+ import {ReactiveFormsModule, FormGroup, FormControl, Validators, FormBuilder} from '@angular/forms';
21
+
22
+ @Component({
23
+ selector: 'app-profile-editor',
24
+ imports: [ReactiveFormsModule],
25
+ templateUrl: './profile-editor.component.html',
26
+ })
27
+ export class ProfileEditor {
28
+ private fb = inject(FormBuilder);
29
+
30
+ // Using FormBuilder for concise definition
31
+ profileForm = this.fb.group({
32
+ firstName: ['', Validators.required],
33
+ lastName: [''],
34
+ address: this.fb.group({
35
+ street: [''],
36
+ city: [''],
37
+ }),
38
+ aliases: this.fb.array([this.fb.control('')]),
39
+ });
40
+
41
+ onSubmit() {
42
+ console.warn(this.profileForm.value);
43
+ }
44
+ }
45
+ ```
46
+
47
+ ## Template Binding
48
+
49
+ Use directives to bind the model to the view:
50
+
51
+ - `[formGroup]`: Binds a `FormGroup` to a `<form>` or `<div>`.
52
+ - `formControlName`: Binds a named control within a group to an input.
53
+ - `formGroupName`: Binds a nested `FormGroup`.
54
+ - `formArrayName`: Binds a nested `FormArray`.
55
+ - `[formControl]`: Binds a standalone `FormControl`.
56
+
57
+ ```html
58
+ <form [formGroup]="profileForm" (ngSubmit)="onSubmit()">
59
+ <input type="text" formControlName="firstName" />
60
+
61
+ <div formGroupName="address">
62
+ <input type="text" formControlName="street" />
63
+ </div>
64
+
65
+ <div formArrayName="aliases">
66
+ @for (alias of aliases.controls; track $index) {
67
+ <input type="text" [formControlName]="$index" />
68
+ }
69
+ </div>
70
+
71
+ <button type="submit" [disabled]="!profileForm.valid">Submit</button>
72
+ </form>
73
+ ```
74
+
75
+ ## Accessing Controls
76
+
77
+ Use getters for easy access to controls, especially for `FormArray`.
78
+
79
+ ```ts
80
+ get aliases() {
81
+ return this.profileForm.get('aliases') as FormArray;
82
+ }
83
+
84
+ addAlias() {
85
+ this.aliases.push(this.fb.control(''));
86
+ }
87
+ ```
88
+
89
+ ## Updating Values
90
+
91
+ - `patchValue()`: Updates only the specified properties. Fails silently on structural mismatches.
92
+ - `setValue()`: Replaces the entire model. Strictly enforces the form structure.
93
+
94
+ ```ts
95
+ updateProfile() {
96
+ this.profileForm.patchValue({
97
+ firstName: 'Nancy',
98
+ address: { street: '123 Drew Street' }
99
+ });
100
+ }
101
+ ```
102
+
103
+ ## Unified Change Events
104
+
105
+ Modern Angular (v18+) provides a single `events` observable on all controls to track value, status, pristine, touched, reset, and submit events.
106
+
107
+ ```ts
108
+ import {ValueChangeEvent, StatusChangeEvent} from '@angular/forms';
109
+
110
+ this.profileForm.events.subscribe((event) => {
111
+ if (event instanceof ValueChangeEvent) {
112
+ console.log('New value:', event.value);
113
+ }
114
+ });
115
+ ```
116
+
117
+ ## Manual State Management
118
+
119
+ - `markAsTouched()` / `markAllAsTouched()`: Useful for showing validation errors on submit.
120
+ - `markAsDirty()` / `markAsPristine()`: Tracks if the value has been modified.
121
+ - `updateValueAndValidity()`: Manually triggers recalculation of value and status.
122
+ - Options `{ emitEvent: false }` or `{ onlySelf: true }` can be passed to most methods to control propagation.
@@ -0,0 +1,44 @@
1
+ # Rendering Strategies
2
+
3
+ Angular supports multiple rendering strategies to optimize for SEO, performance, and interactivity.
4
+
5
+ ## 1. Client-Side Rendering (CSR)
6
+
7
+ **Default Strategy.** Content is rendered entirely in the browser.
8
+
9
+ - **Use case**: Interactive dashboards, internal tools.
10
+ - **Pros**: Simplest to configure, low server cost.
11
+ - **Cons**: Poor SEO, slower initial content visibility (must wait for JS).
12
+
13
+ ## 2. Static Site Generation (SSG / Prerendering)
14
+
15
+ Content is pre-rendered into static HTML files at **build time**.
16
+
17
+ - **Use case**: Marketing pages, blogs, documentation.
18
+ - **Pros**: Fastest initial load, excellent SEO, CDN-friendly.
19
+ - **Cons**: Requires rebuild for content updates, not for user-specific data.
20
+
21
+ ## 3. Server-Side Rendering (SSR)
22
+
23
+ Content is rendered on the server for the **initial request**. Subsequent navigations happen client-side (SPA style).
24
+
25
+ - **Use case**: E-commerce product pages, news sites, personalized dynamic content.
26
+ - **Pros**: Excellent SEO, fast initial content visibility.
27
+ - **Cons**: Requires a server (Node.js), higher server cost/latency.
28
+
29
+ ## Hydration
30
+
31
+ Hydration is the process of making server-rendered HTML interactive in the browser.
32
+
33
+ - **Full Hydration**: The entire app becomes interactive at once.
34
+ - **Incremental Hydration**: (Advanced) Parts become interactive as needed using `@defer` blocks.
35
+ - **Event Replay**: Captures and replays user events that happened before hydration finished.
36
+
37
+ ## Decision Matrix
38
+
39
+ | Requirement | Strategy |
40
+ | :------------------------------ | :------------------- |
41
+ | **SEO + Static Content** | SSG |
42
+ | **SEO + Dynamic Content** | SSR |
43
+ | **No SEO + High Interactivity** | CSR |
44
+ | **Mixed** | Hybrid (Route-based) |
@@ -0,0 +1,77 @@
1
+ # Async Reactivity with `resource`
2
+
3
+ > [!IMPORTANT]
4
+ > The `resource` API is currently experimental in Angular.
5
+
6
+ A `Resource` incorporates asynchronous data fetching into Angular's signal-based reactivity. It executes an async loader function whenever its dependencies change, exposing the status and result as synchronous signals.
7
+
8
+ ## Basic Usage
9
+
10
+ The `resource` function accepts an options object with two main properties:
11
+
12
+ 1. `params`: A reactive computation (like `computed`). When signals read here change, the resource re-fetches.
13
+ 2. `loader`: An async function that fetches data based on the parameters.
14
+
15
+ ```ts
16
+ import { Component, resource, signal, computed } from '@angular/core';
17
+
18
+ @Component({...})
19
+ export class UserProfile {
20
+ userId = signal('123');
21
+
22
+ userResource = resource({
23
+ // Reactively tracking userId
24
+ params: () => ({ id: this.userId() }),
25
+
26
+ // Executes whenever params change
27
+ loader: async ({ params, abortSignal }) => {
28
+ const response = await fetch(`/api/users/${params.id}`, { signal: abortSignal });
29
+ if (!response.ok) throw new Error('Network error');
30
+ return response.json();
31
+ }
32
+ });
33
+
34
+ // Use the resource value in computed signals
35
+ userName = computed(() => {
36
+ if (this.userResource.hasValue()) {
37
+ return this.userResource.value()?.name;
38
+ } else {
39
+ return 'Loading...';
40
+ }
41
+ });
42
+ }
43
+ ```
44
+
45
+ ## Aborting Requests
46
+
47
+ If the `params` signal changes while a previous loader is still running, the `Resource` will attempt to abort the outstanding request using the provided `abortSignal`. **Always pass `abortSignal` to your `fetch` calls.**
48
+
49
+ ## Reloading Data
50
+
51
+ You can imperatively force the resource to re-run the loader without the params changing by calling `.reload()`.
52
+
53
+ ```ts
54
+ this.userResource.reload();
55
+ ```
56
+
57
+ ## Resource Status Signals
58
+
59
+ The `Resource` object provides several signals to read its current state:
60
+
61
+ - `value()`: The resolved data, or `undefined`.
62
+ - `hasValue()`: Type-guard boolean. `true` if a value exists.
63
+ - `isLoading()`: Boolean indicating if the loader is currently running.
64
+ - `error()`: The error thrown by the loader, or `undefined`.
65
+ - `status()`: A string constant representing the exact state (`'idle'`, `'loading'`, `'resolved'`, `'error'`, `'reloading'`, `'local'`).
66
+
67
+ ## Local Mutation
68
+
69
+ You can optimistically update the resource's value directly. This changes the status to `'local'`.
70
+
71
+ ```ts
72
+ this.userResource.value.set({name: 'Optimistic Update'});
73
+ ```
74
+
75
+ ## Reactive Data Fetching with `httpResource`
76
+
77
+ If you are using Angular's `HttpClient`, prefer using `httpResource`. It is a specialized wrapper that leverages the Angular HTTP stack (including interceptors) while providing the same signal-based resource API.
@@ -0,0 +1,56 @@
1
+ # Route Transition Animations
2
+
3
+ Angular Router supports the browser's **View Transitions API** for smooth visual transitions between routes.
4
+
5
+ ## Enabling View Transitions
6
+
7
+ Add `withViewTransitions()` to your router configuration.
8
+
9
+ ```ts
10
+ provideRouter(routes, withViewTransitions());
11
+ ```
12
+
13
+ This is a **progressive enhancement**. In browsers that don't support the API, the router will still work but without the transition animation.
14
+
15
+ ## How it Works
16
+
17
+ 1. Browser takes a screenshot of the old state.
18
+ 2. Router updates the DOM (activates new component).
19
+ 3. Browser takes a screenshot of the new state.
20
+ 4. Browser animates between the two states.
21
+
22
+ ## Customizing with CSS
23
+
24
+ Transitions are customized in **global CSS files** (not component-scoped CSS).
25
+
26
+ Use the `::view-transition-old()` and `::view-transition-new()` pseudo-elements.
27
+
28
+ ```css
29
+ /* Example: Cross-fade + Slide */
30
+ ::view-transition-old(root) {
31
+ animation: 90ms cubic-bezier(0.4, 0, 1, 1) both fade-out;
32
+ }
33
+ ::view-transition-new(root) {
34
+ animation: 210ms cubic-bezier(0, 0, 0.2, 1) 90ms both fade-in;
35
+ }
36
+ ```
37
+
38
+ ## Advanced Control
39
+
40
+ Use `onViewTransitionCreated` to skip transitions or customize behavior based on the navigation context.
41
+
42
+ ```ts
43
+ withViewTransitions({
44
+ onViewTransitionCreated: ({transition, from, to}) => {
45
+ // Skip animation for specific routes
46
+ if (to.url === '/no-animation') {
47
+ transition.skipTransition();
48
+ }
49
+ },
50
+ });
51
+ ```
52
+
53
+ ## Best Practices
54
+
55
+ - **Global Styles**: Always define transition animations in `styles.css` to avoid view encapsulation issues.
56
+ - **View Transition Names**: Assign unique `view-transition-name` to elements that should transition smoothly across routes (e.g., a header image).
@@ -0,0 +1,52 @@
1
+ # Route Guards
2
+
3
+ Route guards control whether a user can navigate to or leave a route.
4
+
5
+ ## Types of Guards
6
+
7
+ - **`CanActivate`**: Can the user access this route? (e.g., Auth check).
8
+ - **`CanActivateChild`**: Can the user access children of this route?
9
+ - **`CanDeactivate`**: Can the user leave this route? (e.g., Unsaved changes).
10
+ - **`CanMatch`**: Should this route even be considered for matching? (e.g., Feature flags). If it returns `false`, the router continues checking other routes.
11
+
12
+ ## Creating a Guard
13
+
14
+ Guards are typically functional since Angular 15.
15
+
16
+ ```ts
17
+ export const authGuard: CanActivateFn = (route, state) => {
18
+ const authService = inject(AuthService);
19
+ const router = inject(Router);
20
+
21
+ if (authService.isLoggedIn()) {
22
+ return true;
23
+ }
24
+
25
+ // Redirect to login
26
+ return router.parseUrl('/login');
27
+ };
28
+ ```
29
+
30
+ ## Applying Guards
31
+
32
+ Add them to the route configuration as an array. They execute in order.
33
+
34
+ ```ts
35
+ {
36
+ path: 'admin',
37
+ component: Admin,
38
+ canActivate: [authGuard],
39
+ canActivateChild: [adminChildGuard],
40
+ canDeactivate: [unsavedChangesGuard]
41
+ }
42
+ ```
43
+
44
+ ## Return Values
45
+
46
+ - `boolean`: `true` to allow, `false` to block.
47
+ - `UrlTree` or `RedirectCommand`: Redirect to a different route.
48
+ - `Observable` or `Promise`: Resolves to the above types.
49
+
50
+ ## Security Note
51
+
52
+ **Client-side guards are NOT a substitute for server-side security.** Always verify permissions on the server.
@@ -0,0 +1,45 @@
1
+ # Router Lifecycle and Events
2
+
3
+ Angular Router emits events through the `Router.events` observable, allowing you to track the navigation lifecycle from start to finish.
4
+
5
+ ## Common Router Events (Chronological)
6
+
7
+ 1. **`NavigationStart`**: Navigation begins.
8
+ 2. **`RoutesRecognized`**: Router matches the URL to a route.
9
+ 3. **`GuardsCheckStart` / `End`**: Evaluation of `canActivate`, `canMatch`, etc.
10
+ 4. **`ResolveStart` / `End`**: Data resolution phase (fetching data via resolvers).
11
+ 5. **`NavigationEnd`**: Navigation completed successfully.
12
+ 6. **`NavigationCancel`**: Navigation canceled (e.g., guard returned `false`).
13
+ 7. **`NavigationError`**: Navigation failed (e.g., error in resolver).
14
+
15
+ ## Subscribing to Events
16
+
17
+ Inject the `Router` and filter the `events` observable.
18
+
19
+ ```ts
20
+ import {Router, NavigationStart, NavigationEnd} from '@angular/router';
21
+
22
+ export class MyService {
23
+ private router = inject(Router);
24
+
25
+ constructor() {
26
+ this.router.events.pipe(filter((e) => e instanceof NavigationEnd)).subscribe((event) => {
27
+ console.log('Navigated to:', event.url);
28
+ });
29
+ }
30
+ }
31
+ ```
32
+
33
+ ## Debugging
34
+
35
+ Enable detailed console logging of all routing events during application bootstrap.
36
+
37
+ ```ts
38
+ provideRouter(routes, withDebugTracing());
39
+ ```
40
+
41
+ ## Common Use Cases
42
+
43
+ - **Loading Indicators**: Show a spinner when `NavigationStart` fires and hide it on `NavigationEnd`/`Cancel`/`Error`.
44
+ - **Analytics**: Track page views by listening for `NavigationEnd`.
45
+ - **Scroll Management**: Respond to `Scroll` events for custom scroll behavior.
@@ -0,0 +1,87 @@
1
+ # Testing with the RouterTestingHarness
2
+
3
+ When testing components that involve routing, it is crucial **not to mock the Router or related services**. Instead, use the `RouterTestingHarness`, which provides a robust and reliable way to test routing logic in an environment that closely mirrors a real application.
4
+
5
+ Using the harness ensures you are testing the actual router configuration, guards, and resolvers, leading to more meaningful tests.
6
+
7
+ ## Setting Up for Router Testing
8
+
9
+ The `RouterTestingHarness` is the primary tool for testing routing scenarios. You also need to provide your test routes using the `provideRouter` function in your `TestBed` configuration.
10
+
11
+ ### Example Setup
12
+
13
+ ```ts
14
+ import {TestBed} from '@angular/core/testing';
15
+ import {provideRouter} from '@angular/router';
16
+ import {RouterTestingHarness} from '@angular/router/testing';
17
+ import {Dashboard} from './dashboard.component';
18
+ import {HeroDetail} from './hero-detail.component';
19
+
20
+ describe('Dashboard Component Routing', () => {
21
+ let harness: RouterTestingHarness;
22
+
23
+ beforeEach(async () => {
24
+ // 1. Configure TestBed with test routes
25
+ await TestBed.configureTestingModule({
26
+ providers: [
27
+ // Use provideRouter with your test-specific routes
28
+ provideRouter([
29
+ {path: '', component: Dashboard},
30
+ {path: 'heroes/:id', component: HeroDetail},
31
+ ]),
32
+ ],
33
+ }).compileComponents();
34
+
35
+ // 2. Create the RouterTestingHarness
36
+ harness = await RouterTestingHarness.create();
37
+ });
38
+ });
39
+ ```
40
+
41
+ ### Key Concepts
42
+
43
+ 1. **`provideRouter([...])`**: Provide a test-specific routing configuration. This should include the routes necessary for the component-under-test to function correctly.
44
+ 2. **`RouterTestingHarness.create()`**: Asynchronously creates and initializes the harness and performs an initial navigation to the root URL (`/`).
45
+
46
+ ## Writing Router Tests
47
+
48
+ Once the harness is created, you can use it to drive navigation and make assertions on the state of the router and the activated components.
49
+
50
+ ### Example: Testing Navigation
51
+
52
+ ```ts
53
+ it('should navigate to a hero detail when a hero is selected', async () => {
54
+ // 1. Navigate to the initial component and get its instance
55
+ const dashboard = await harness.navigateByUrl('/', Dashboard);
56
+
57
+ // Suppose the dashboard has a method to select a hero
58
+ const heroToSelect = {id: 42, name: 'Test Hero'};
59
+ dashboard.selectHero(heroToSelect);
60
+
61
+ // Wait for stability after the action that triggers navigation
62
+ await harness.fixture.whenStable();
63
+
64
+ // 2. Assert on the URL
65
+ expect(harness.router.url).toEqual('/heroes/42');
66
+
67
+ // 3. Get the activated component after navigation
68
+ const heroDetail = await harness.getHarness(HeroDetail);
69
+
70
+ // 4. Assert on the state of the new component
71
+ expect(await heroDetail.componentInstance.hero.name).toBe('Test Hero');
72
+ });
73
+
74
+ it('should get the activated component directly', async () => {
75
+ // Navigate and get the component instance in one step
76
+ const dashboardInstance = await harness.navigateByUrl('/', Dashboard);
77
+
78
+ expect(dashboardInstance).toBeInstanceOf(Dashboard);
79
+ });
80
+ ```
81
+
82
+ ### Best Practices
83
+
84
+ - **Navigate with the Harness:** Always use `harness.navigateByUrl()` to simulate navigation. This method returns a promise that resolves with the instance of the activated component.
85
+ - **Access the Router State:** Use `harness.router` to access the live router instance and assert on its state (e.g., `harness.router.url`).
86
+ - **Get Activated Components:** Use `harness.getHarness(ComponentType)` to get an instance of a component harness for the currently activated routed component, or `harness.routeDebugElement` to get the `DebugElement`.
87
+ - **Wait for Stability:** After performing an action that causes navigation, always `await harness.fixture.whenStable()` to ensure the routing is complete before making assertions.
@@ -0,0 +1,68 @@
1
+ # Show Routes with Outlets
2
+
3
+ The `RouterOutlet` directive is a placeholder where Angular renders the component for the current URL.
4
+
5
+ ## Basic Usage
6
+
7
+ Include `<router-outlet />` in your template. Angular inserts the routed component as a sibling immediately following the outlet.
8
+
9
+ ```html
10
+ <app-header /> <router-outlet />
11
+ <!-- Route content appears here -->
12
+ <app-footer />
13
+ ```
14
+
15
+ ## Nested Outlets
16
+
17
+ Child routes require their own `<router-outlet />` within the parent component's template.
18
+
19
+ ```ts
20
+ // Parent component template
21
+ <h1>Settings</h1>
22
+ <router-outlet /> <!-- Child components like Profile or Security render here -->
23
+ ```
24
+
25
+ ## Named Outlets (Secondary Routes)
26
+
27
+ Pages can have multiple outlets. Assign a `name` to an outlet to target it specifically. The default name is `'primary'`.
28
+
29
+ ```html
30
+ <router-outlet />
31
+ <!-- Primary -->
32
+ <router-outlet name="sidebar" />
33
+ <!-- Secondary -->
34
+ ```
35
+
36
+ Define the `outlet` in the route config:
37
+
38
+ ```ts
39
+ {
40
+ path: 'chat',
41
+ component: Chat,
42
+ outlet: 'sidebar'
43
+ }
44
+ ```
45
+
46
+ ## Outlet Lifecycle Events
47
+
48
+ `RouterOutlet` emits events when components are changed:
49
+
50
+ - `activate`: New component instantiated.
51
+ - `deactivate`: Component destroyed.
52
+ - `attach` / `detach`: Used with `RouteReuseStrategy`.
53
+
54
+ ```html
55
+ <router-outlet (activate)="onActivate($event)" />
56
+ ```
57
+
58
+ ## Passing Data via `routerOutletData`
59
+
60
+ You can pass contextual data to the routed component using the `routerOutletData` input. The component accesses this via the `ROUTER_OUTLET_DATA` injection token as a signal.
61
+
62
+ ```ts
63
+ // In Parent
64
+ <router-outlet [routerOutletData]="{ theme: 'dark' }" />
65
+
66
+ // In Routed Component
67
+ outletData = inject(ROUTER_OUTLET_DATA) as Signal<{ theme: string }>;
68
+ ```