@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.
- package/CHANGELOG.md +16 -0
- package/CODE_OF_CONDUCT.md +34 -0
- package/CONTRIBUTING.md +38 -0
- package/LICENSE +21 -0
- package/README.md +337 -0
- package/RELEASING.md +93 -0
- package/SECURITY.md +31 -0
- package/STRATEGY.md +26 -0
- package/bin/cli.js +547 -0
- package/lib/packs.js +184 -0
- package/package.json +38 -0
- package/python/app/__init__.py +0 -0
- package/python/app/__pycache__/__init__.cpython-312.pyc +0 -0
- package/python/app/__pycache__/auth.cpython-312.pyc +0 -0
- package/python/app/__pycache__/main.cpython-312.pyc +0 -0
- package/python/app/auth.py +63 -0
- package/python/app/cli.py +78 -0
- package/python/app/db_paths.py +26 -0
- package/python/app/events_cli.py +175 -0
- package/python/app/main.py +647 -0
- package/python/app/materialize.py +138 -0
- package/python/app/mcp_server.py +610 -0
- package/python/app/route_cli.py +117 -0
- package/python/requirements-dev.txt +1 -0
- package/python/requirements.txt +7 -0
- package/python/tests/test_db_paths.py +41 -0
- package/skills/accessibility/SKILL.md +145 -0
- package/skills/agent-architecture-audit/SKILL.md +256 -0
- package/skills/agent-eval/SKILL.md +144 -0
- package/skills/agent-harness-construction/SKILL.md +72 -0
- package/skills/agent-introspection-debugging/SKILL.md +152 -0
- package/skills/agent-payment-x402/SKILL.md +224 -0
- package/skills/agent-sort/SKILL.md +214 -0
- package/skills/agentic-engineering/SKILL.md +62 -0
- package/skills/agentic-os/SKILL.md +386 -0
- package/skills/ai-first-engineering/SKILL.md +50 -0
- package/skills/ai-regression-testing/SKILL.md +384 -0
- package/skills/android-clean-architecture/SKILL.md +338 -0
- package/skills/angular-developer/SKILL.md +153 -0
- package/skills/angular-developer/references/angular-animations.md +160 -0
- package/skills/angular-developer/references/angular-aria.md +410 -0
- package/skills/angular-developer/references/cli.md +86 -0
- package/skills/angular-developer/references/component-harnesses.md +59 -0
- package/skills/angular-developer/references/component-styling.md +91 -0
- package/skills/angular-developer/references/components.md +117 -0
- package/skills/angular-developer/references/creating-services.md +97 -0
- package/skills/angular-developer/references/data-resolvers.md +69 -0
- package/skills/angular-developer/references/define-routes.md +67 -0
- package/skills/angular-developer/references/defining-providers.md +72 -0
- package/skills/angular-developer/references/di-fundamentals.md +120 -0
- package/skills/angular-developer/references/e2e-testing.md +56 -0
- package/skills/angular-developer/references/effects.md +83 -0
- package/skills/angular-developer/references/hierarchical-injectors.md +43 -0
- package/skills/angular-developer/references/host-elements.md +80 -0
- package/skills/angular-developer/references/injection-context.md +63 -0
- package/skills/angular-developer/references/inputs.md +101 -0
- package/skills/angular-developer/references/linked-signal.md +59 -0
- package/skills/angular-developer/references/loading-strategies.md +61 -0
- package/skills/angular-developer/references/mcp.md +108 -0
- package/skills/angular-developer/references/navigate-to-routes.md +69 -0
- package/skills/angular-developer/references/outputs.md +86 -0
- package/skills/angular-developer/references/reactive-forms.md +122 -0
- package/skills/angular-developer/references/rendering-strategies.md +44 -0
- package/skills/angular-developer/references/resource.md +77 -0
- package/skills/angular-developer/references/route-animations.md +56 -0
- package/skills/angular-developer/references/route-guards.md +52 -0
- package/skills/angular-developer/references/router-lifecycle.md +45 -0
- package/skills/angular-developer/references/router-testing.md +87 -0
- package/skills/angular-developer/references/show-routes-with-outlets.md +68 -0
- package/skills/angular-developer/references/signal-forms.md +795 -0
- package/skills/angular-developer/references/signals-overview.md +94 -0
- package/skills/angular-developer/references/tailwind-css.md +69 -0
- package/skills/angular-developer/references/template-driven-forms.md +114 -0
- package/skills/angular-developer/references/testing-fundamentals.md +65 -0
- package/skills/api-connector-builder/SKILL.md +120 -0
- package/skills/api-design/SKILL.md +522 -0
- package/skills/architecture-decision-records/SKILL.md +178 -0
- package/skills/article-writing/SKILL.md +78 -0
- package/skills/automation-audit-ops/SKILL.md +141 -0
- package/skills/autonomous-agent-harness/SKILL.md +272 -0
- package/skills/autonomous-loops/SKILL.md +609 -0
- package/skills/backend-patterns/SKILL.md +560 -0
- package/skills/benchmark/SKILL.md +92 -0
- package/skills/blueprint/SKILL.md +104 -0
- package/skills/browser-qa/SKILL.md +86 -0
- package/skills/bun-runtime/SKILL.md +83 -0
- package/skills/canary-watch/SKILL.md +98 -0
- package/skills/carrier-relationship-management/SKILL.md +211 -0
- package/skills/cisco-ios-patterns/SKILL.md +163 -0
- package/skills/ck/SKILL.md +147 -0
- package/skills/ck/commands/forget.mjs +44 -0
- package/skills/ck/commands/info.mjs +24 -0
- package/skills/ck/commands/init.mjs +143 -0
- package/skills/ck/commands/list.mjs +40 -0
- package/skills/ck/commands/migrate.mjs +202 -0
- package/skills/ck/commands/resume.mjs +36 -0
- package/skills/ck/commands/save.mjs +210 -0
- package/skills/ck/commands/shared.mjs +387 -0
- package/skills/ck/hooks/session-start.mjs +224 -0
- package/skills/claude-devfleet/SKILL.md +103 -0
- package/skills/click-path-audit/SKILL.md +244 -0
- package/skills/clickhouse-io/SKILL.md +438 -0
- package/skills/code-tour/SKILL.md +235 -0
- package/skills/codebase-onboarding/SKILL.md +232 -0
- package/skills/coding-standards/SKILL.md +548 -0
- package/skills/compose-multiplatform-patterns/SKILL.md +298 -0
- package/skills/connections-optimizer/SKILL.md +188 -0
- package/skills/content-engine/SKILL.md +126 -0
- package/skills/content-hash-cache-pattern/SKILL.md +160 -0
- package/skills/context-budget/SKILL.md +134 -0
- package/skills/continuous-agent-loop/SKILL.md +44 -0
- package/skills/continuous-learning/SKILL.md +129 -0
- package/skills/continuous-learning/config.json +18 -0
- package/skills/continuous-learning/evaluate-session.sh +69 -0
- package/skills/continuous-learning-v2/SKILL.md +358 -0
- package/skills/continuous-learning-v2/agents/observer-loop.sh +322 -0
- package/skills/continuous-learning-v2/agents/observer.md +198 -0
- package/skills/continuous-learning-v2/agents/session-guardian.sh +150 -0
- package/skills/continuous-learning-v2/agents/start-observer.sh +248 -0
- package/skills/continuous-learning-v2/config.json +8 -0
- package/skills/continuous-learning-v2/hooks/observe.sh +476 -0
- package/skills/continuous-learning-v2/scripts/detect-project.sh +288 -0
- package/skills/continuous-learning-v2/scripts/instinct-cli.py +1519 -0
- package/skills/continuous-learning-v2/scripts/lib/homunculus-dir.sh +31 -0
- package/skills/continuous-learning-v2/scripts/migrate-homunculus.sh +62 -0
- package/skills/continuous-learning-v2/scripts/test_parse_instinct.py +1018 -0
- package/skills/cost-aware-llm-pipeline/SKILL.md +182 -0
- package/skills/cost-tracking/SKILL.md +147 -0
- package/skills/council/SKILL.md +202 -0
- package/skills/cpp-coding-standards/SKILL.md +722 -0
- package/skills/cpp-testing/SKILL.md +323 -0
- package/skills/crosspost/SKILL.md +110 -0
- package/skills/csharp-testing/SKILL.md +320 -0
- package/skills/customer-billing-ops/SKILL.md +139 -0
- package/skills/customs-trade-compliance/SKILL.md +262 -0
- package/skills/dart-flutter-patterns/SKILL.md +562 -0
- package/skills/dashboard-builder/SKILL.md +108 -0
- package/skills/data-scraper-agent/SKILL.md +764 -0
- package/skills/database-migrations/SKILL.md +428 -0
- package/skills/deep-research/SKILL.md +158 -0
- package/skills/defi-amm-security/SKILL.md +166 -0
- package/skills/deployment-patterns/SKILL.md +426 -0
- package/skills/design-system/SKILL.md +81 -0
- package/skills/django-celery/SKILL.md +456 -0
- package/skills/django-patterns/SKILL.md +733 -0
- package/skills/django-security/SKILL.md +592 -0
- package/skills/django-tdd/SKILL.md +728 -0
- package/skills/django-verification/SKILL.md +468 -0
- package/skills/dmux-workflows/SKILL.md +190 -0
- package/skills/docker-patterns/SKILL.md +363 -0
- package/skills/documentation-lookup/SKILL.md +89 -0
- package/skills/dotnet-patterns/SKILL.md +320 -0
- package/skills/e2e-testing/SKILL.md +325 -0
- package/skills/email-ops/SKILL.md +120 -0
- package/skills/energy-procurement/SKILL.md +227 -0
- package/skills/enterprise-agent-ops/SKILL.md +49 -0
- package/skills/error-handling/SKILL.md +375 -0
- package/skills/eval-harness/SKILL.md +269 -0
- package/skills/evm-token-decimals/SKILL.md +130 -0
- package/skills/exa-search/SKILL.md +106 -0
- package/skills/fal-ai-media/SKILL.md +287 -0
- package/skills/fastapi-patterns/SKILL.md +327 -0
- package/skills/finance-billing-ops/SKILL.md +126 -0
- package/skills/flox-environments/SKILL.md +496 -0
- package/skills/flutter-dart-code-review/SKILL.md +434 -0
- package/skills/foundation-models-on-device/SKILL.md +243 -0
- package/skills/frontend-design-direction/SKILL.md +92 -0
- package/skills/frontend-patterns/SKILL.md +641 -0
- package/skills/frontend-slides/SKILL.md +183 -0
- package/skills/frontend-slides/STYLE_PRESETS.md +330 -0
- package/skills/frontend-slides/animation-patterns.md +122 -0
- package/skills/frontend-slides/html-template.md +419 -0
- package/skills/frontend-slides/scripts/export-pdf.sh +418 -0
- package/skills/frontend-slides/scripts/extract-pptx.py +96 -0
- package/skills/frontend-slides/viewport-base.css +153 -0
- package/skills/fsharp-testing/SKILL.md +279 -0
- package/skills/gan-style-harness/SKILL.md +278 -0
- package/skills/gateguard/SKILL.md +125 -0
- package/skills/git-workflow/SKILL.md +714 -0
- package/skills/github-ops/SKILL.md +143 -0
- package/skills/golang-patterns/SKILL.md +673 -0
- package/skills/golang-testing/SKILL.md +719 -0
- package/skills/google-workspace-ops/SKILL.md +94 -0
- package/skills/healthcare-cdss-patterns/SKILL.md +245 -0
- package/skills/healthcare-emr-patterns/SKILL.md +159 -0
- package/skills/healthcare-eval-harness/SKILL.md +207 -0
- package/skills/healthcare-phi-compliance/SKILL.md +145 -0
- package/skills/hermes-imports/SKILL.md +87 -0
- package/skills/hexagonal-architecture/SKILL.md +275 -0
- package/skills/hipaa-compliance/SKILL.md +78 -0
- package/skills/homelab-network-readiness/SKILL.md +169 -0
- package/skills/homelab-network-setup/SKILL.md +129 -0
- package/skills/homelab-pihole-dns/SKILL.md +274 -0
- package/skills/homelab-vlan-segmentation/SKILL.md +311 -0
- package/skills/homelab-wireguard-vpn/SKILL.md +305 -0
- package/skills/hookify-rules/SKILL.md +128 -0
- package/skills/inventory-demand-planning/SKILL.md +246 -0
- package/skills/investor-materials/SKILL.md +95 -0
- package/skills/investor-outreach/SKILL.md +90 -0
- package/skills/ios-icon-gen/SKILL.md +157 -0
- package/skills/ios-icon-gen/scripts/generate_icons.swift +258 -0
- package/skills/ios-icon-gen/scripts/iconify_gen.sh +235 -0
- package/skills/iterative-retrieval/SKILL.md +209 -0
- package/skills/java-coding-standards/SKILL.md +382 -0
- package/skills/jira-integration/SKILL.md +292 -0
- package/skills/jpa-patterns/SKILL.md +150 -0
- package/skills/knowledge-ops/SKILL.md +153 -0
- package/skills/kotlin-coroutines-flows/SKILL.md +283 -0
- package/skills/kotlin-exposed-patterns/SKILL.md +718 -0
- package/skills/kotlin-ktor-patterns/SKILL.md +688 -0
- package/skills/kotlin-patterns/SKILL.md +710 -0
- package/skills/kotlin-testing/SKILL.md +823 -0
- package/skills/laravel-patterns/SKILL.md +414 -0
- package/skills/laravel-plugin-discovery/SKILL.md +228 -0
- package/skills/laravel-security/SKILL.md +284 -0
- package/skills/laravel-tdd/SKILL.md +282 -0
- package/skills/laravel-verification/SKILL.md +178 -0
- package/skills/lead-intelligence/SKILL.md +320 -0
- package/skills/lead-intelligence/agents/enrichment-agent.md +85 -0
- package/skills/lead-intelligence/agents/mutual-mapper.md +75 -0
- package/skills/lead-intelligence/agents/outreach-drafter.md +98 -0
- package/skills/lead-intelligence/agents/signal-scorer.md +60 -0
- package/skills/liquid-glass-design/SKILL.md +279 -0
- package/skills/llm-trading-agent-security/SKILL.md +146 -0
- package/skills/logistics-exception-management/SKILL.md +221 -0
- package/skills/make-interfaces-feel-better/SKILL.md +151 -0
- package/skills/manim-video/SKILL.md +88 -0
- package/skills/manim-video/assets/network_graph_scene.py +52 -0
- package/skills/market-research/SKILL.md +74 -0
- package/skills/mcp-server-patterns/SKILL.md +68 -0
- package/skills/messages-ops/SKILL.md +103 -0
- package/skills/mle-workflow/SKILL.md +345 -0
- package/skills/motion-advanced/SKILL.md +596 -0
- package/skills/motion-foundations/SKILL.md +299 -0
- package/skills/motion-patterns/SKILL.md +435 -0
- package/skills/motion-ui/SKILL.md +574 -0
- package/skills/mysql-patterns/SKILL.md +411 -0
- package/skills/nanoclaw-repl/SKILL.md +32 -0
- package/skills/nestjs-patterns/SKILL.md +229 -0
- package/skills/netmiko-ssh-automation/SKILL.md +173 -0
- package/skills/network-bgp-diagnostics/SKILL.md +167 -0
- package/skills/network-config-validation/SKILL.md +210 -0
- package/skills/network-interface-health/SKILL.md +152 -0
- package/skills/nextjs-turbopack/SKILL.md +43 -0
- package/skills/nodejs-keccak256/SKILL.md +102 -0
- package/skills/nutrient-document-processing/SKILL.md +166 -0
- package/skills/nuxt4-patterns/SKILL.md +99 -0
- package/skills/openclaw-persona-forge/SKILL.md +288 -0
- package/skills/openclaw-persona-forge/gacha.py +224 -0
- package/skills/openclaw-persona-forge/gacha.sh +5 -0
- package/skills/openclaw-persona-forge/references/avatar-style.md +124 -0
- package/skills/openclaw-persona-forge/references/boundary-rules.md +53 -0
- package/skills/openclaw-persona-forge/references/error-handling.md +53 -0
- package/skills/openclaw-persona-forge/references/identity-tension.md +48 -0
- package/skills/openclaw-persona-forge/references/naming-system.md +39 -0
- package/skills/openclaw-persona-forge/references/output-template.md +166 -0
- package/skills/opensource-pipeline/SKILL.md +254 -0
- package/skills/perl-patterns/SKILL.md +503 -0
- package/skills/perl-security/SKILL.md +502 -0
- package/skills/perl-testing/SKILL.md +474 -0
- package/skills/plan-orchestrate/SKILL.md +253 -0
- package/skills/plankton-code-quality/SKILL.md +236 -0
- package/skills/postgres-patterns/SKILL.md +146 -0
- package/skills/product-capability/SKILL.md +140 -0
- package/skills/product-lens/SKILL.md +91 -0
- package/skills/production-audit/SKILL.md +206 -0
- package/skills/production-scheduling/SKILL.md +237 -0
- package/skills/project-flow-ops/SKILL.md +110 -0
- package/skills/prompt-optimizer/SKILL.md +398 -0
- package/skills/python-patterns/SKILL.md +749 -0
- package/skills/python-testing/SKILL.md +815 -0
- package/skills/pytorch-patterns/SKILL.md +395 -0
- package/skills/quality-nonconformance/SKILL.md +259 -0
- package/skills/quarkus-patterns/SKILL.md +721 -0
- package/skills/quarkus-security/SKILL.md +466 -0
- package/skills/quarkus-tdd/SKILL.md +810 -0
- package/skills/quarkus-verification/SKILL.md +478 -0
- package/skills/ralphinho-rfc-pipeline/SKILL.md +66 -0
- package/skills/redis-patterns/SKILL.md +402 -0
- package/skills/regex-vs-llm-structured-text/SKILL.md +219 -0
- package/skills/remotion-video-creation/SKILL.md +43 -0
- package/skills/remotion-video-creation/rules/3d.md +86 -0
- package/skills/remotion-video-creation/rules/animations.md +29 -0
- package/skills/remotion-video-creation/rules/assets/charts-bar-chart.tsx +173 -0
- package/skills/remotion-video-creation/rules/assets/text-animations-typewriter.tsx +100 -0
- package/skills/remotion-video-creation/rules/assets/text-animations-word-highlight.tsx +108 -0
- package/skills/remotion-video-creation/rules/assets.md +78 -0
- package/skills/remotion-video-creation/rules/audio.md +172 -0
- package/skills/remotion-video-creation/rules/calculate-metadata.md +104 -0
- package/skills/remotion-video-creation/rules/can-decode.md +75 -0
- package/skills/remotion-video-creation/rules/charts.md +58 -0
- package/skills/remotion-video-creation/rules/compositions.md +146 -0
- package/skills/remotion-video-creation/rules/display-captions.md +126 -0
- package/skills/remotion-video-creation/rules/extract-frames.md +229 -0
- package/skills/remotion-video-creation/rules/fonts.md +152 -0
- package/skills/remotion-video-creation/rules/get-audio-duration.md +58 -0
- package/skills/remotion-video-creation/rules/get-video-dimensions.md +68 -0
- package/skills/remotion-video-creation/rules/get-video-duration.md +58 -0
- package/skills/remotion-video-creation/rules/gifs.md +138 -0
- package/skills/remotion-video-creation/rules/images.md +130 -0
- package/skills/remotion-video-creation/rules/import-srt-captions.md +67 -0
- package/skills/remotion-video-creation/rules/lottie.md +67 -0
- package/skills/remotion-video-creation/rules/measuring-dom-nodes.md +34 -0
- package/skills/remotion-video-creation/rules/measuring-text.md +143 -0
- package/skills/remotion-video-creation/rules/sequencing.md +106 -0
- package/skills/remotion-video-creation/rules/tailwind.md +11 -0
- package/skills/remotion-video-creation/rules/text-animations.md +20 -0
- package/skills/remotion-video-creation/rules/timing.md +179 -0
- package/skills/remotion-video-creation/rules/transcribe-captions.md +19 -0
- package/skills/remotion-video-creation/rules/transitions.md +122 -0
- package/skills/remotion-video-creation/rules/trimming.md +52 -0
- package/skills/remotion-video-creation/rules/videos.md +171 -0
- package/skills/repo-scan/SKILL.md +78 -0
- package/skills/research-ops/SKILL.md +111 -0
- package/skills/returns-reverse-logistics/SKILL.md +239 -0
- package/skills/rules-distill/SKILL.md +263 -0
- package/skills/rules-distill/scripts/scan-rules.sh +58 -0
- package/skills/rules-distill/scripts/scan-skills.sh +129 -0
- package/skills/rust-patterns/SKILL.md +498 -0
- package/skills/rust-testing/SKILL.md +499 -0
- package/skills/safety-guard/SKILL.md +74 -0
- package/skills/santa-method/SKILL.md +306 -0
- package/skills/scientific-db-pubmed-database/SKILL.md +175 -0
- package/skills/scientific-db-uspto-database/SKILL.md +177 -0
- package/skills/scientific-pkg-gget/SKILL.md +166 -0
- package/skills/scientific-thinking-literature-review/SKILL.md +192 -0
- package/skills/scientific-thinking-scholar-evaluation/SKILL.md +160 -0
- package/skills/search-first/SKILL.md +181 -0
- package/skills/security-bounty-hunter/SKILL.md +99 -0
- package/skills/security-review/SKILL.md +502 -0
- package/skills/security-review/cloud-infrastructure-security.md +361 -0
- package/skills/seo/SKILL.md +153 -0
- package/skills/skill-comply/SKILL.md +57 -0
- package/skills/skill-comply/fixtures/compliant_trace.jsonl +5 -0
- package/skills/skill-comply/fixtures/noncompliant_trace.jsonl +3 -0
- package/skills/skill-comply/fixtures/tdd_spec.yaml +44 -0
- package/skills/skill-comply/prompts/classifier.md +24 -0
- package/skills/skill-comply/prompts/scenario_generator.md +62 -0
- package/skills/skill-comply/prompts/spec_generator.md +42 -0
- package/skills/skill-comply/pyproject.toml +15 -0
- package/skills/skill-comply/scripts/__init__.py +0 -0
- package/skills/skill-comply/scripts/classifier.py +85 -0
- package/skills/skill-comply/scripts/grader.py +124 -0
- package/skills/skill-comply/scripts/parser.py +107 -0
- package/skills/skill-comply/scripts/report.py +170 -0
- package/skills/skill-comply/scripts/run.py +127 -0
- package/skills/skill-comply/scripts/runner.py +186 -0
- package/skills/skill-comply/scripts/scenario_generator.py +70 -0
- package/skills/skill-comply/scripts/spec_generator.py +72 -0
- package/skills/skill-comply/scripts/utils.py +13 -0
- package/skills/skill-comply/tests/test_grader.py +197 -0
- package/skills/skill-comply/tests/test_parser.py +90 -0
- package/skills/skill-comply/tests/test_runner.py +172 -0
- package/skills/skill-scout/SKILL.md +139 -0
- package/skills/skill-stocktake/SKILL.md +193 -0
- package/skills/skill-stocktake/scripts/quick-diff.sh +87 -0
- package/skills/skill-stocktake/scripts/save-results.sh +56 -0
- package/skills/skill-stocktake/scripts/scan.sh +170 -0
- package/skills/social-graph-ranker/SKILL.md +153 -0
- package/skills/springboot-patterns/SKILL.md +313 -0
- package/skills/springboot-security/SKILL.md +271 -0
- package/skills/springboot-tdd/SKILL.md +157 -0
- package/skills/springboot-verification/SKILL.md +230 -0
- package/skills/strategic-compact/SKILL.md +129 -0
- package/skills/strategic-compact/suggest-compact.sh +54 -0
- package/skills/swift-actor-persistence/SKILL.md +142 -0
- package/skills/swift-concurrency-6-2/SKILL.md +216 -0
- package/skills/swift-protocol-di-testing/SKILL.md +189 -0
- package/skills/swiftui-patterns/SKILL.md +259 -0
- package/skills/tdd-workflow/SKILL.md +462 -0
- package/skills/team-builder/SKILL.md +166 -0
- package/skills/terminal-ops/SKILL.md +108 -0
- package/skills/tinystruct-patterns/SKILL.md +130 -0
- package/skills/tinystruct-patterns/references/architecture.md +77 -0
- package/skills/tinystruct-patterns/references/data-handling.md +35 -0
- package/skills/tinystruct-patterns/references/routing.md +57 -0
- package/skills/tinystruct-patterns/references/system-usage.md +74 -0
- package/skills/tinystruct-patterns/references/testing.md +59 -0
- package/skills/token-budget-advisor/SKILL.md +133 -0
- package/skills/ui-demo/SKILL.md +464 -0
- package/skills/ui-to-vue/SKILL.md +134 -0
- package/skills/unified-notifications-ops/SKILL.md +186 -0
- package/skills/verification-loop/SKILL.md +125 -0
- package/skills/video-editing/SKILL.md +309 -0
- package/skills/videodb/SKILL.md +373 -0
- package/skills/videodb/reference/api-reference.md +550 -0
- package/skills/videodb/reference/capture-reference.md +407 -0
- package/skills/videodb/reference/capture.md +101 -0
- package/skills/videodb/reference/editor.md +443 -0
- package/skills/videodb/reference/generative.md +331 -0
- package/skills/videodb/reference/rtstream-reference.md +564 -0
- package/skills/videodb/reference/rtstream.md +65 -0
- package/skills/videodb/reference/search.md +230 -0
- package/skills/videodb/reference/streaming.md +406 -0
- package/skills/videodb/reference/use-cases.md +118 -0
- package/skills/videodb/scripts/ws_listener.py +282 -0
- package/skills/visa-doc-translate/README.md +86 -0
- package/skills/visa-doc-translate/SKILL.md +117 -0
- package/skills/vite-patterns/SKILL.md +448 -0
- package/skills/windows-desktop-e2e/SKILL.md +787 -0
- package/skills/workspace-surface-audit/SKILL.md +124 -0
- package/skills/x-api/SKILL.md +233 -0
|
@@ -0,0 +1,43 @@
|
|
|
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.
|
|
@@ -0,0 +1,80 @@
|
|
|
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
|
+
```
|
|
@@ -0,0 +1,63 @@
|
|
|
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
|
+
```
|
|
@@ -0,0 +1,101 @@
|
|
|
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`).
|
|
@@ -0,0 +1,59 @@
|
|
|
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.
|
|
@@ -0,0 +1,61 @@
|
|
|
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.
|
|
@@ -0,0 +1,108 @@
|
|
|
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
|
+
```
|
|
@@ -0,0 +1,69 @@
|
|
|
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`).
|
|
@@ -0,0 +1,86 @@
|
|
|
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`).
|