@ruaruababa/vibe-kit 1.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CATALOG.md +317 -0
- package/README.md +121 -0
- package/aliases.json +65 -0
- package/bin/vibe.js +2 -0
- package/bundles.json +265 -0
- package/catalog.json +1560 -0
- package/dist/antigravity-skills/bin/cli.js +438 -0
- package/dist/antigravity-skills/lib/skill-utils.js +158 -0
- package/dist/antigravity-skills/scripts/build-catalog.js +305 -0
- package/dist/antigravity-skills/scripts/normalize-frontmatter.js +144 -0
- package/dist/antigravity-skills/scripts/validate-skills.js +230 -0
- package/dist/bin/vibe.js +2 -0
- package/dist/dist/src/cli/index.js +26 -0
- package/dist/lib/skill-utils.js +158 -0
- package/dist/scripts/build-catalog.js +50 -0
- package/dist/scripts/normalize-frontmatter.js +144 -0
- package/dist/scripts/validate-skills.js +56 -0
- package/dist/src/cli/index.js +146 -0
- package/dist/src/types/index.js +13 -0
- package/dist/src/utils/fs.js +1 -0
- package/package.json +43 -0
- package/skills/accessibility-compliance-accessibility-audit/SKILL.md +42 -0
- package/skills/accessibility-compliance-accessibility-audit/resources/implementation-playbook.md +502 -0
- package/skills/agent-orchestration-improve-agent/SKILL.md +349 -0
- package/skills/agent-orchestration-multi-agent-optimize/SKILL.md +239 -0
- package/skills/agent-orchestrator/SKILL.md +24 -0
- package/skills/ai-engineer/SKILL.md +171 -0
- package/skills/airflow-dag-patterns/SKILL.md +41 -0
- package/skills/airflow-dag-patterns/resources/implementation-playbook.md +509 -0
- package/skills/angular-migration/SKILL.md +428 -0
- package/skills/anti-reversing-techniques/SKILL.md +42 -0
- package/skills/anti-reversing-techniques/resources/implementation-playbook.md +539 -0
- package/skills/api-design-principles/SKILL.md +37 -0
- package/skills/api-design-principles/assets/api-design-checklist.md +155 -0
- package/skills/api-design-principles/assets/rest-api-template.py +182 -0
- package/skills/api-design-principles/references/graphql-schema-design.md +583 -0
- package/skills/api-design-principles/references/rest-best-practices.md +408 -0
- package/skills/api-design-principles/resources/implementation-playbook.md +513 -0
- package/skills/api-documenter/SKILL.md +184 -0
- package/skills/api-testing-observability-api-mock/SKILL.md +46 -0
- package/skills/api-testing-observability-api-mock/resources/implementation-playbook.md +1327 -0
- package/skills/application-performance-performance-optimization/SKILL.md +154 -0
- package/skills/architect-review/SKILL.md +174 -0
- package/skills/architecture-decision-records/SKILL.md +441 -0
- package/skills/architecture-patterns/SKILL.md +37 -0
- package/skills/architecture-patterns/resources/implementation-playbook.md +479 -0
- package/skills/arm-cortex-expert/SKILL.md +306 -0
- package/skills/async-python-patterns/SKILL.md +39 -0
- package/skills/async-python-patterns/resources/implementation-playbook.md +678 -0
- package/skills/attack-tree-construction/SKILL.md +38 -0
- package/skills/attack-tree-construction/resources/implementation-playbook.md +671 -0
- package/skills/auth-implementation-patterns/SKILL.md +39 -0
- package/skills/auth-implementation-patterns/resources/implementation-playbook.md +618 -0
- package/skills/backend-architect/SKILL.md +333 -0
- package/skills/backend-development-feature-development/SKILL.md +180 -0
- package/skills/backend-security-coder/SKILL.md +156 -0
- package/skills/backtesting-frameworks/SKILL.md +39 -0
- package/skills/backtesting-frameworks/resources/implementation-playbook.md +647 -0
- package/skills/bash-defensive-patterns/SKILL.md +43 -0
- package/skills/bash-defensive-patterns/resources/implementation-playbook.md +517 -0
- package/skills/bash-pro/SKILL.md +310 -0
- package/skills/bats-testing-patterns/SKILL.md +34 -0
- package/skills/bats-testing-patterns/resources/implementation-playbook.md +614 -0
- package/skills/bazel-build-optimization/SKILL.md +397 -0
- package/skills/billing-automation/SKILL.md +42 -0
- package/skills/billing-automation/resources/implementation-playbook.md +544 -0
- package/skills/binary-analysis-patterns/SKILL.md +450 -0
- package/skills/blockchain-developer/SKILL.md +208 -0
- package/skills/business-analyst/SKILL.md +182 -0
- package/skills/c-pro/SKILL.md +56 -0
- package/skills/c4-architecture-c4-architecture/SKILL.md +389 -0
- package/skills/c4-code/SKILL.md +244 -0
- package/skills/c4-component/SKILL.md +153 -0
- package/skills/c4-container/SKILL.md +171 -0
- package/skills/c4-context/SKILL.md +150 -0
- package/skills/changelog-automation/SKILL.md +38 -0
- package/skills/changelog-automation/resources/implementation-playbook.md +538 -0
- package/skills/cicd-automation-workflow-automate/SKILL.md +51 -0
- package/skills/cicd-automation-workflow-automate/resources/implementation-playbook.md +1333 -0
- package/skills/clean-markdown/SKILL.md +23 -0
- package/skills/cloud-architect/SKILL.md +135 -0
- package/skills/code-documentation-code-explain/SKILL.md +46 -0
- package/skills/code-documentation-code-explain/resources/implementation-playbook.md +802 -0
- package/skills/code-documentation-doc-generate/SKILL.md +48 -0
- package/skills/code-documentation-doc-generate/resources/implementation-playbook.md +640 -0
- package/skills/code-refactoring-context-restore/SKILL.md +179 -0
- package/skills/code-refactoring-refactor-clean/SKILL.md +51 -0
- package/skills/code-refactoring-refactor-clean/resources/implementation-playbook.md +879 -0
- package/skills/code-refactoring-tech-debt/SKILL.md +386 -0
- package/skills/code-review-ai-ai-review/SKILL.md +450 -0
- package/skills/code-review-excellence/SKILL.md +40 -0
- package/skills/code-review-excellence/resources/implementation-playbook.md +515 -0
- package/skills/code-reviewer/SKILL.md +178 -0
- package/skills/codebase-cleanup-deps-audit/SKILL.md +51 -0
- package/skills/codebase-cleanup-deps-audit/resources/implementation-playbook.md +766 -0
- package/skills/codebase-cleanup-refactor-clean/SKILL.md +51 -0
- package/skills/codebase-cleanup-refactor-clean/resources/implementation-playbook.md +879 -0
- package/skills/codebase-cleanup-tech-debt/SKILL.md +386 -0
- package/skills/competitive-landscape/SKILL.md +34 -0
- package/skills/competitive-landscape/resources/implementation-playbook.md +494 -0
- package/skills/comprehensive-review-full-review/SKILL.md +146 -0
- package/skills/comprehensive-review-pr-enhance/SKILL.md +46 -0
- package/skills/comprehensive-review-pr-enhance/resources/implementation-playbook.md +691 -0
- package/skills/conductor-implement/SKILL.md +388 -0
- package/skills/conductor-manage/SKILL.md +39 -0
- package/skills/conductor-manage/resources/implementation-playbook.md +1120 -0
- package/skills/conductor-new-track/SKILL.md +433 -0
- package/skills/conductor-revert/SKILL.md +372 -0
- package/skills/conductor-setup/SKILL.md +426 -0
- package/skills/conductor-status/SKILL.md +338 -0
- package/skills/conductor-validator/SKILL.md +62 -0
- package/skills/content-marketer/SKILL.md +170 -0
- package/skills/context-driven-development/SKILL.md +400 -0
- package/skills/context-management-context-restore/SKILL.md +179 -0
- package/skills/context-management-context-save/SKILL.md +177 -0
- package/skills/context-manager/SKILL.md +185 -0
- package/skills/cost-optimization/SKILL.md +286 -0
- package/skills/cpp-pro/SKILL.md +59 -0
- package/skills/cqrs-implementation/SKILL.md +35 -0
- package/skills/cqrs-implementation/resources/implementation-playbook.md +540 -0
- package/skills/csharp-pro/SKILL.md +59 -0
- package/skills/customer-support/SKILL.md +170 -0
- package/skills/data-engineer/SKILL.md +224 -0
- package/skills/data-engineering-data-driven-feature/SKILL.md +182 -0
- package/skills/data-engineering-data-pipeline/SKILL.md +201 -0
- package/skills/data-quality-frameworks/SKILL.md +40 -0
- package/skills/data-quality-frameworks/resources/implementation-playbook.md +573 -0
- package/skills/data-scientist/SKILL.md +199 -0
- package/skills/data-storytelling/SKILL.md +465 -0
- package/skills/database-admin/SKILL.md +165 -0
- package/skills/database-architect/SKILL.md +268 -0
- package/skills/database-cloud-optimization-cost-optimize/SKILL.md +44 -0
- package/skills/database-cloud-optimization-cost-optimize/resources/implementation-playbook.md +1441 -0
- package/skills/database-migration/SKILL.md +436 -0
- package/skills/database-migrations-migration-observability/SKILL.md +420 -0
- package/skills/database-migrations-sql-migrations/SKILL.md +53 -0
- package/skills/database-migrations-sql-migrations/resources/implementation-playbook.md +499 -0
- package/skills/database-optimizer/SKILL.md +167 -0
- package/skills/dbt-transformation-patterns/SKILL.md +34 -0
- package/skills/dbt-transformation-patterns/resources/implementation-playbook.md +547 -0
- package/skills/debugger/SKILL.md +49 -0
- package/skills/debugging-strategies/SKILL.md +34 -0
- package/skills/debugging-strategies/resources/implementation-playbook.md +511 -0
- package/skills/debugging-toolkit-smart-debug/SKILL.md +197 -0
- package/skills/defi-protocol-templates/SKILL.md +466 -0
- package/skills/dependency-management-deps-audit/SKILL.md +44 -0
- package/skills/dependency-management-deps-audit/resources/implementation-playbook.md +766 -0
- package/skills/dependency-upgrade/SKILL.md +421 -0
- package/skills/deployment-engineer/SKILL.md +170 -0
- package/skills/deployment-pipeline-design/SKILL.md +371 -0
- package/skills/deployment-validation-config-validate/SKILL.md +496 -0
- package/skills/devops-troubleshooter/SKILL.md +161 -0
- package/skills/distributed-debugging-debug-trace/SKILL.md +44 -0
- package/skills/distributed-debugging-debug-trace/resources/implementation-playbook.md +1307 -0
- package/skills/distributed-tracing/SKILL.md +450 -0
- package/skills/django-pro/SKILL.md +180 -0
- package/skills/docs-architect/SKILL.md +98 -0
- package/skills/documentation-generation-doc-generate/SKILL.md +48 -0
- package/skills/documentation-generation-doc-generate/resources/implementation-playbook.md +640 -0
- package/skills/dotnet-architect/SKILL.md +197 -0
- package/skills/dotnet-backend-patterns/SKILL.md +37 -0
- package/skills/dotnet-backend-patterns/assets/repository-template.cs +523 -0
- package/skills/dotnet-backend-patterns/assets/service-template.cs +336 -0
- package/skills/dotnet-backend-patterns/references/dapper-patterns.md +544 -0
- package/skills/dotnet-backend-patterns/references/ef-core-best-practices.md +355 -0
- package/skills/dotnet-backend-patterns/resources/implementation-playbook.md +799 -0
- package/skills/dummy-skill/SKILL.md +5 -0
- package/skills/dx-optimizer/SKILL.md +83 -0
- package/skills/e2e-testing-patterns/SKILL.md +41 -0
- package/skills/e2e-testing-patterns/resources/implementation-playbook.md +531 -0
- package/skills/elixir-pro/SKILL.md +59 -0
- package/skills/embedding-strategies/SKILL.md +491 -0
- package/skills/employment-contract-templates/SKILL.md +39 -0
- package/skills/employment-contract-templates/resources/implementation-playbook.md +493 -0
- package/skills/error-debugging-error-analysis/SKILL.md +47 -0
- package/skills/error-debugging-error-analysis/resources/implementation-playbook.md +1143 -0
- package/skills/error-debugging-error-trace/SKILL.md +43 -0
- package/skills/error-debugging-error-trace/resources/implementation-playbook.md +1361 -0
- package/skills/error-debugging-multi-agent-review/SKILL.md +216 -0
- package/skills/error-detective/SKILL.md +53 -0
- package/skills/error-diagnostics-error-analysis/SKILL.md +47 -0
- package/skills/error-diagnostics-error-analysis/resources/implementation-playbook.md +1143 -0
- package/skills/error-diagnostics-error-trace/SKILL.md +48 -0
- package/skills/error-diagnostics-error-trace/resources/implementation-playbook.md +1371 -0
- package/skills/error-diagnostics-smart-debug/SKILL.md +197 -0
- package/skills/error-handling-patterns/SKILL.md +35 -0
- package/skills/error-handling-patterns/resources/implementation-playbook.md +635 -0
- package/skills/event-sourcing-architect/SKILL.md +58 -0
- package/skills/event-store-design/SKILL.md +449 -0
- package/skills/fastapi-pro/SKILL.md +192 -0
- package/skills/fastapi-templates/SKILL.md +32 -0
- package/skills/fastapi-templates/resources/implementation-playbook.md +566 -0
- package/skills/final-test/SKILL.md +5 -0
- package/skills/firmware-analyst/SKILL.md +320 -0
- package/skills/flutter-expert/SKILL.md +200 -0
- package/skills/framework-migration-code-migrate/SKILL.md +48 -0
- package/skills/framework-migration-code-migrate/resources/implementation-playbook.md +1052 -0
- package/skills/framework-migration-deps-upgrade/SKILL.md +48 -0
- package/skills/framework-migration-deps-upgrade/resources/implementation-playbook.md +755 -0
- package/skills/framework-migration-legacy-modernize/SKILL.md +132 -0
- package/skills/frontend-developer/SKILL.md +171 -0
- package/skills/frontend-mobile-development-component-scaffold/SKILL.md +403 -0
- package/skills/frontend-mobile-security-xss-scan/SKILL.md +322 -0
- package/skills/frontend-security-coder/SKILL.md +170 -0
- package/skills/full-stack-orchestration-full-stack-feature/SKILL.md +135 -0
- package/skills/gdpr-data-handling/SKILL.md +33 -0
- package/skills/gdpr-data-handling/resources/implementation-playbook.md +615 -0
- package/skills/git-advanced-workflows/SKILL.md +412 -0
- package/skills/git-pr-workflows-git-workflow/SKILL.md +140 -0
- package/skills/git-pr-workflows-onboard/SKILL.md +416 -0
- package/skills/git-pr-workflows-pr-enhance/SKILL.md +48 -0
- package/skills/git-pr-workflows-pr-enhance/resources/implementation-playbook.md +701 -0
- package/skills/github-actions-templates/SKILL.md +345 -0
- package/skills/gitlab-ci-patterns/SKILL.md +283 -0
- package/skills/gitops-workflow/SKILL.md +303 -0
- package/skills/gitops-workflow/references/argocd-setup.md +134 -0
- package/skills/gitops-workflow/references/sync-policies.md +131 -0
- package/skills/go-concurrency-patterns/SKILL.md +33 -0
- package/skills/go-concurrency-patterns/resources/implementation-playbook.md +654 -0
- package/skills/godot-gdscript-patterns/SKILL.md +33 -0
- package/skills/godot-gdscript-patterns/resources/implementation-playbook.md +804 -0
- package/skills/golang-pro/SKILL.md +179 -0
- package/skills/grafana-dashboards/SKILL.md +381 -0
- package/skills/graphql-architect/SKILL.md +182 -0
- package/skills/haskell-pro/SKILL.md +56 -0
- package/skills/helm-chart-scaffolding/SKILL.md +34 -0
- package/skills/helm-chart-scaffolding/assets/Chart.yaml.template +42 -0
- package/skills/helm-chart-scaffolding/assets/values.yaml.template +185 -0
- package/skills/helm-chart-scaffolding/references/chart-structure.md +500 -0
- package/skills/helm-chart-scaffolding/resources/implementation-playbook.md +543 -0
- package/skills/helm-chart-scaffolding/scripts/validate-chart.sh +244 -0
- package/skills/hr-pro/SKILL.md +126 -0
- package/skills/hybrid-cloud-architect/SKILL.md +168 -0
- package/skills/hybrid-cloud-networking/SKILL.md +238 -0
- package/skills/hybrid-search-implementation/SKILL.md +32 -0
- package/skills/hybrid-search-implementation/resources/implementation-playbook.md +567 -0
- package/skills/incident-responder/SKILL.md +213 -0
- package/skills/incident-response-incident-response/SKILL.md +168 -0
- package/skills/incident-response-smart-fix/SKILL.md +29 -0
- package/skills/incident-response-smart-fix/resources/implementation-playbook.md +838 -0
- package/skills/incident-runbook-templates/SKILL.md +395 -0
- package/skills/ios-developer/SKILL.md +219 -0
- package/skills/istio-traffic-management/SKILL.md +337 -0
- package/skills/java-pro/SKILL.md +177 -0
- package/skills/javascript-pro/SKILL.md +57 -0
- package/skills/javascript-testing-patterns/SKILL.md +35 -0
- package/skills/javascript-testing-patterns/resources/implementation-playbook.md +1024 -0
- package/skills/javascript-typescript-typescript-scaffold/SKILL.md +361 -0
- package/skills/julia-pro/SKILL.md +209 -0
- package/skills/k8s-manifest-generator/SKILL.md +35 -0
- package/skills/k8s-manifest-generator/assets/configmap-template.yaml +296 -0
- package/skills/k8s-manifest-generator/assets/deployment-template.yaml +203 -0
- package/skills/k8s-manifest-generator/assets/service-template.yaml +171 -0
- package/skills/k8s-manifest-generator/references/deployment-spec.md +753 -0
- package/skills/k8s-manifest-generator/references/service-spec.md +724 -0
- package/skills/k8s-manifest-generator/resources/implementation-playbook.md +510 -0
- package/skills/k8s-security-policies/SKILL.md +346 -0
- package/skills/k8s-security-policies/assets/network-policy-template.yaml +177 -0
- package/skills/k8s-security-policies/references/rbac-patterns.md +187 -0
- package/skills/kpi-dashboard-design/SKILL.md +440 -0
- package/skills/kubernetes-architect/SKILL.md +170 -0
- package/skills/langchain-architecture/SKILL.md +350 -0
- package/skills/legacy-modernizer/SKILL.md +53 -0
- package/skills/legal-advisor/SKILL.md +70 -0
- package/skills/linkerd-patterns/SKILL.md +321 -0
- package/skills/llm-application-dev-ai-assistant/SKILL.md +35 -0
- package/skills/llm-application-dev-ai-assistant/resources/implementation-playbook.md +1236 -0
- package/skills/llm-application-dev-langchain-agent/SKILL.md +246 -0
- package/skills/llm-application-dev-prompt-optimize/SKILL.md +37 -0
- package/skills/llm-application-dev-prompt-optimize/resources/implementation-playbook.md +591 -0
- package/skills/llm-evaluation/SKILL.md +483 -0
- package/skills/machine-learning-ops-ml-pipeline/SKILL.md +314 -0
- package/skills/malware-analyst/SKILL.md +247 -0
- package/skills/market-sizing-analysis/SKILL.md +425 -0
- package/skills/market-sizing-analysis/examples/saas-market-sizing.md +349 -0
- package/skills/market-sizing-analysis/references/data-sources.md +360 -0
- package/skills/memory-forensics/SKILL.md +491 -0
- package/skills/memory-safety-patterns/SKILL.md +33 -0
- package/skills/memory-safety-patterns/resources/implementation-playbook.md +603 -0
- package/skills/mermaid-expert/SKILL.md +59 -0
- package/skills/microservices-patterns/SKILL.md +35 -0
- package/skills/microservices-patterns/resources/implementation-playbook.md +607 -0
- package/skills/minecraft-bukkit-pro/SKILL.md +126 -0
- package/skills/ml-engineer/SKILL.md +168 -0
- package/skills/ml-pipeline-workflow/SKILL.md +257 -0
- package/skills/mlops-engineer/SKILL.md +219 -0
- package/skills/mobile-developer/SKILL.md +205 -0
- package/skills/mobile-security-coder/SKILL.md +184 -0
- package/skills/modern-javascript-patterns/SKILL.md +35 -0
- package/skills/modern-javascript-patterns/resources/implementation-playbook.md +910 -0
- package/skills/monorepo-architect/SKILL.md +61 -0
- package/skills/monorepo-management/SKILL.md +35 -0
- package/skills/monorepo-management/resources/implementation-playbook.md +621 -0
- package/skills/mtls-configuration/SKILL.md +359 -0
- package/skills/multi-cloud-architecture/SKILL.md +189 -0
- package/skills/multi-platform-apps-multi-platform/SKILL.md +203 -0
- package/skills/network-engineer/SKILL.md +169 -0
- package/skills/nextjs-app-router-patterns/SKILL.md +33 -0
- package/skills/nextjs-app-router-patterns/resources/implementation-playbook.md +543 -0
- package/skills/nft-standards/SKILL.md +395 -0
- package/skills/node-expert/SKILL.md +23 -0
- package/skills/nodejs-backend-patterns/SKILL.md +35 -0
- package/skills/nodejs-backend-patterns/resources/implementation-playbook.md +1019 -0
- package/skills/nx-workspace-patterns/SKILL.md +464 -0
- package/skills/observability-engineer/SKILL.md +237 -0
- package/skills/observability-monitoring-monitor-setup/SKILL.md +48 -0
- package/skills/observability-monitoring-monitor-setup/resources/implementation-playbook.md +505 -0
- package/skills/observability-monitoring-slo-implement/SKILL.md +43 -0
- package/skills/observability-monitoring-slo-implement/resources/implementation-playbook.md +1077 -0
- package/skills/on-call-handoff-patterns/SKILL.md +453 -0
- package/skills/openapi-spec-generation/SKILL.md +33 -0
- package/skills/openapi-spec-generation/resources/implementation-playbook.md +1027 -0
- package/skills/payment-integration/SKILL.md +77 -0
- package/skills/paypal-integration/SKILL.md +479 -0
- package/skills/pci-compliance/SKILL.md +478 -0
- package/skills/performance-engineer/SKILL.md +180 -0
- package/skills/performance-testing-review-ai-review/SKILL.md +450 -0
- package/skills/performance-testing-review-multi-agent-review/SKILL.md +216 -0
- package/skills/php-pro/SKILL.md +63 -0
- package/skills/posix-shell-pro/SKILL.md +304 -0
- package/skills/postgresql/SKILL.md +230 -0
- package/skills/postmortem-writing/SKILL.md +386 -0
- package/skills/projection-patterns/SKILL.md +33 -0
- package/skills/projection-patterns/resources/implementation-playbook.md +501 -0
- package/skills/prometheus-configuration/SKILL.md +404 -0
- package/skills/prompt-engineer/SKILL.md +272 -0
- package/skills/prompt-engineering-patterns/SKILL.md +213 -0
- package/skills/prompt-engineering-patterns/assets/few-shot-examples.json +106 -0
- package/skills/prompt-engineering-patterns/assets/prompt-template-library.md +246 -0
- package/skills/prompt-engineering-patterns/references/chain-of-thought.md +399 -0
- package/skills/prompt-engineering-patterns/references/few-shot-learning.md +369 -0
- package/skills/prompt-engineering-patterns/references/prompt-optimization.md +414 -0
- package/skills/prompt-engineering-patterns/references/prompt-templates.md +470 -0
- package/skills/prompt-engineering-patterns/references/system-prompts.md +189 -0
- package/skills/prompt-engineering-patterns/scripts/optimize-prompt.py +279 -0
- package/skills/protocol-reverse-engineering/SKILL.md +29 -0
- package/skills/protocol-reverse-engineering/resources/implementation-playbook.md +509 -0
- package/skills/python-development-python-scaffold/SKILL.md +331 -0
- package/skills/python-packaging/SKILL.md +36 -0
- package/skills/python-packaging/resources/implementation-playbook.md +869 -0
- package/skills/python-performance-optimization/SKILL.md +36 -0
- package/skills/python-performance-optimization/resources/implementation-playbook.md +868 -0
- package/skills/python-pro/SKILL.md +158 -0
- package/skills/python-testing-patterns/SKILL.md +37 -0
- package/skills/python-testing-patterns/resources/implementation-playbook.md +906 -0
- package/skills/quant-analyst/SKILL.md +53 -0
- package/skills/rag-implementation/SKILL.md +421 -0
- package/skills/react-modernization/SKILL.md +34 -0
- package/skills/react-modernization/resources/implementation-playbook.md +512 -0
- package/skills/react-native-architecture/SKILL.md +33 -0
- package/skills/react-native-architecture/resources/implementation-playbook.md +670 -0
- package/skills/react-state-management/SKILL.md +441 -0
- package/skills/reference-builder/SKILL.md +188 -0
- package/skills/reverse-engineer/SKILL.md +173 -0
- package/skills/risk-manager/SKILL.md +61 -0
- package/skills/risk-metrics-calculation/SKILL.md +33 -0
- package/skills/risk-metrics-calculation/resources/implementation-playbook.md +554 -0
- package/skills/ruby-pro/SKILL.md +56 -0
- package/skills/rust-async-patterns/SKILL.md +33 -0
- package/skills/rust-async-patterns/resources/implementation-playbook.md +516 -0
- package/skills/rust-pro/SKILL.md +178 -0
- package/skills/saga-orchestration/SKILL.md +496 -0
- package/skills/sales-automator/SKILL.md +55 -0
- package/skills/sast-configuration/SKILL.md +212 -0
- package/skills/scala-pro/SKILL.md +82 -0
- package/skills/screen-reader-testing/SKILL.md +33 -0
- package/skills/screen-reader-testing/resources/implementation-playbook.md +544 -0
- package/skills/search-specialist/SKILL.md +80 -0
- package/skills/secrets-management/SKILL.md +364 -0
- package/skills/security-auditor/SKILL.md +169 -0
- package/skills/security-compliance-compliance-check/SKILL.md +55 -0
- package/skills/security-compliance-compliance-check/resources/implementation-playbook.md +963 -0
- package/skills/security-requirement-extraction/SKILL.md +33 -0
- package/skills/security-requirement-extraction/resources/implementation-playbook.md +676 -0
- package/skills/security-scanning-security-dependencies/SKILL.md +43 -0
- package/skills/security-scanning-security-dependencies/resources/implementation-playbook.md +544 -0
- package/skills/security-scanning-security-hardening/SKILL.md +147 -0
- package/skills/security-scanning-security-sast/SKILL.md +495 -0
- package/skills/seo-authority-builder/SKILL.md +136 -0
- package/skills/seo-cannibalization-detector/SKILL.md +123 -0
- package/skills/seo-content-auditor/SKILL.md +83 -0
- package/skills/seo-content-planner/SKILL.md +108 -0
- package/skills/seo-content-refresher/SKILL.md +118 -0
- package/skills/seo-content-writer/SKILL.md +96 -0
- package/skills/seo-keyword-strategist/SKILL.md +95 -0
- package/skills/seo-meta-optimizer/SKILL.md +92 -0
- package/skills/seo-snippet-hunter/SKILL.md +114 -0
- package/skills/seo-structure-architect/SKILL.md +108 -0
- package/skills/service-mesh-expert/SKILL.md +58 -0
- package/skills/service-mesh-observability/SKILL.md +395 -0
- package/skills/shellcheck-configuration/SKILL.md +466 -0
- package/skills/similarity-search-patterns/SKILL.md +33 -0
- package/skills/similarity-search-patterns/resources/implementation-playbook.md +557 -0
- package/skills/slo-implementation/SKILL.md +341 -0
- package/skills/solidity-security/SKILL.md +34 -0
- package/skills/solidity-security/resources/implementation-playbook.md +524 -0
- package/skills/spark-optimization/SKILL.md +427 -0
- package/skills/sql-optimization-patterns/SKILL.md +35 -0
- package/skills/sql-optimization-patterns/resources/implementation-playbook.md +504 -0
- package/skills/sql-pro/SKILL.md +173 -0
- package/skills/startup-analyst/SKILL.md +328 -0
- package/skills/startup-business-analyst-business-case/SKILL.md +487 -0
- package/skills/startup-business-analyst-financial-projections/SKILL.md +353 -0
- package/skills/startup-business-analyst-market-opportunity/SKILL.md +240 -0
- package/skills/startup-financial-modeling/SKILL.md +467 -0
- package/skills/startup-metrics-framework/SKILL.md +34 -0
- package/skills/startup-metrics-framework/resources/implementation-playbook.md +500 -0
- package/skills/stride-analysis-patterns/SKILL.md +33 -0
- package/skills/stride-analysis-patterns/resources/implementation-playbook.md +655 -0
- package/skills/stripe-integration/SKILL.md +454 -0
- package/skills/systems-programming-rust-project/SKILL.md +440 -0
- package/skills/tailwind-design-system/SKILL.md +33 -0
- package/skills/tailwind-design-system/resources/implementation-playbook.md +665 -0
- package/skills/tdd-orchestrator/SKILL.md +205 -0
- package/skills/tdd-workflows-tdd-cycle/SKILL.md +221 -0
- package/skills/tdd-workflows-tdd-green/SKILL.md +73 -0
- package/skills/tdd-workflows-tdd-green/resources/implementation-playbook.md +870 -0
- package/skills/tdd-workflows-tdd-red/SKILL.md +164 -0
- package/skills/tdd-workflows-tdd-refactor/SKILL.md +187 -0
- package/skills/team-collaboration-issue/SKILL.md +37 -0
- package/skills/team-collaboration-issue/resources/implementation-playbook.md +640 -0
- package/skills/team-collaboration-standup-notes/SKILL.md +44 -0
- package/skills/team-collaboration-standup-notes/resources/implementation-playbook.md +768 -0
- package/skills/team-composition-analysis/SKILL.md +413 -0
- package/skills/temporal-python-pro/SKILL.md +370 -0
- package/skills/temporal-python-testing/SKILL.md +170 -0
- package/skills/temporal-python-testing/resources/integration-testing.md +455 -0
- package/skills/temporal-python-testing/resources/local-setup.md +553 -0
- package/skills/temporal-python-testing/resources/replay-testing.md +462 -0
- package/skills/temporal-python-testing/resources/unit-testing.md +328 -0
- package/skills/terraform-module-library/SKILL.md +261 -0
- package/skills/terraform-module-library/references/aws-modules.md +63 -0
- package/skills/terraform-specialist/SKILL.md +166 -0
- package/skills/test-automator/SKILL.md +224 -0
- package/skills/threat-mitigation-mapping/SKILL.md +33 -0
- package/skills/threat-mitigation-mapping/resources/implementation-playbook.md +744 -0
- package/skills/threat-modeling-expert/SKILL.md +60 -0
- package/skills/track-management/SKILL.md +38 -0
- package/skills/track-management/resources/implementation-playbook.md +591 -0
- package/skills/turborepo-caching/SKILL.md +419 -0
- package/skills/tutorial-engineer/SKILL.md +139 -0
- package/skills/typescript-advanced-types/SKILL.md +35 -0
- package/skills/typescript-advanced-types/resources/implementation-playbook.md +716 -0
- package/skills/typescript-pro/SKILL.md +55 -0
- package/skills/ui-minimal/SKILL.md +23 -0
- package/skills/ui-ux-designer/SKILL.md +209 -0
- package/skills/ui-visual-validator/SKILL.md +214 -0
- package/skills/unit-testing-test-generate/SKILL.md +319 -0
- package/skills/unity-developer/SKILL.md +230 -0
- package/skills/unity-ecs-patterns/SKILL.md +33 -0
- package/skills/unity-ecs-patterns/resources/implementation-playbook.md +625 -0
- package/skills/uv-package-manager/SKILL.md +37 -0
- package/skills/uv-package-manager/resources/implementation-playbook.md +830 -0
- package/skills/vector-database-engineer/SKILL.md +60 -0
- package/skills/vector-index-tuning/SKILL.md +42 -0
- package/skills/vector-index-tuning/resources/implementation-playbook.md +507 -0
- package/skills/wcag-audit-patterns/SKILL.md +41 -0
- package/skills/wcag-audit-patterns/resources/implementation-playbook.md +541 -0
- package/skills/web3-testing/SKILL.md +427 -0
- package/skills/workflow-orchestration-patterns/SKILL.md +333 -0
- package/skills/workflow-patterns/SKILL.md +38 -0
- package/skills/workflow-patterns/resources/implementation-playbook.md +621 -0
|
@@ -0,0 +1,512 @@
|
|
|
1
|
+
# React Modernization Implementation Playbook
|
|
2
|
+
|
|
3
|
+
This file contains detailed patterns, checklists, and code samples referenced by the skill.
|
|
4
|
+
|
|
5
|
+
# React Modernization
|
|
6
|
+
|
|
7
|
+
Master React version upgrades, class to hooks migration, concurrent features adoption, and codemods for automated transformation.
|
|
8
|
+
|
|
9
|
+
## When to Use This Skill
|
|
10
|
+
|
|
11
|
+
- Upgrading React applications to latest versions
|
|
12
|
+
- Migrating class components to functional components with hooks
|
|
13
|
+
- Adopting concurrent React features (Suspense, transitions)
|
|
14
|
+
- Applying codemods for automated refactoring
|
|
15
|
+
- Modernizing state management patterns
|
|
16
|
+
- Updating to TypeScript
|
|
17
|
+
- Improving performance with React 18+ features
|
|
18
|
+
|
|
19
|
+
## Version Upgrade Path
|
|
20
|
+
|
|
21
|
+
### React 16 → 17 → 18
|
|
22
|
+
|
|
23
|
+
**Breaking Changes by Version:**
|
|
24
|
+
|
|
25
|
+
**React 17:**
|
|
26
|
+
- Event delegation changes
|
|
27
|
+
- No event pooling
|
|
28
|
+
- Effect cleanup timing
|
|
29
|
+
- JSX transform (no React import needed)
|
|
30
|
+
|
|
31
|
+
**React 18:**
|
|
32
|
+
- Automatic batching
|
|
33
|
+
- Concurrent rendering
|
|
34
|
+
- Strict Mode changes (double invocation)
|
|
35
|
+
- New root API
|
|
36
|
+
- Suspense on server
|
|
37
|
+
|
|
38
|
+
## Class to Hooks Migration
|
|
39
|
+
|
|
40
|
+
### State Management
|
|
41
|
+
```javascript
|
|
42
|
+
// Before: Class component
|
|
43
|
+
class Counter extends React.Component {
|
|
44
|
+
constructor(props) {
|
|
45
|
+
super(props);
|
|
46
|
+
this.state = {
|
|
47
|
+
count: 0,
|
|
48
|
+
name: ''
|
|
49
|
+
};
|
|
50
|
+
}
|
|
51
|
+
|
|
52
|
+
increment = () => {
|
|
53
|
+
this.setState({ count: this.state.count + 1 });
|
|
54
|
+
}
|
|
55
|
+
|
|
56
|
+
render() {
|
|
57
|
+
return (
|
|
58
|
+
<div>
|
|
59
|
+
<p>Count: {this.state.count}</p>
|
|
60
|
+
<button onClick={this.increment}>Increment</button>
|
|
61
|
+
</div>
|
|
62
|
+
);
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
|
|
66
|
+
// After: Functional component with hooks
|
|
67
|
+
function Counter() {
|
|
68
|
+
const [count, setCount] = useState(0);
|
|
69
|
+
const [name, setName] = useState('');
|
|
70
|
+
|
|
71
|
+
const increment = () => {
|
|
72
|
+
setCount(count + 1);
|
|
73
|
+
};
|
|
74
|
+
|
|
75
|
+
return (
|
|
76
|
+
<div>
|
|
77
|
+
<p>Count: {count}</p>
|
|
78
|
+
<button onClick={increment}>Increment</button>
|
|
79
|
+
</div>
|
|
80
|
+
);
|
|
81
|
+
}
|
|
82
|
+
```
|
|
83
|
+
|
|
84
|
+
### Lifecycle Methods to Hooks
|
|
85
|
+
```javascript
|
|
86
|
+
// Before: Lifecycle methods
|
|
87
|
+
class DataFetcher extends React.Component {
|
|
88
|
+
state = { data: null, loading: true };
|
|
89
|
+
|
|
90
|
+
componentDidMount() {
|
|
91
|
+
this.fetchData();
|
|
92
|
+
}
|
|
93
|
+
|
|
94
|
+
componentDidUpdate(prevProps) {
|
|
95
|
+
if (prevProps.id !== this.props.id) {
|
|
96
|
+
this.fetchData();
|
|
97
|
+
}
|
|
98
|
+
}
|
|
99
|
+
|
|
100
|
+
componentWillUnmount() {
|
|
101
|
+
this.cancelRequest();
|
|
102
|
+
}
|
|
103
|
+
|
|
104
|
+
fetchData = async () => {
|
|
105
|
+
const data = await fetch(`/api/${this.props.id}`);
|
|
106
|
+
this.setState({ data, loading: false });
|
|
107
|
+
};
|
|
108
|
+
|
|
109
|
+
cancelRequest = () => {
|
|
110
|
+
// Cleanup
|
|
111
|
+
};
|
|
112
|
+
|
|
113
|
+
render() {
|
|
114
|
+
if (this.state.loading) return <div>Loading...</div>;
|
|
115
|
+
return <div>{this.state.data}</div>;
|
|
116
|
+
}
|
|
117
|
+
}
|
|
118
|
+
|
|
119
|
+
// After: useEffect hook
|
|
120
|
+
function DataFetcher({ id }) {
|
|
121
|
+
const [data, setData] = useState(null);
|
|
122
|
+
const [loading, setLoading] = useState(true);
|
|
123
|
+
|
|
124
|
+
useEffect(() => {
|
|
125
|
+
let cancelled = false;
|
|
126
|
+
|
|
127
|
+
const fetchData = async () => {
|
|
128
|
+
try {
|
|
129
|
+
const response = await fetch(`/api/${id}`);
|
|
130
|
+
const result = await response.json();
|
|
131
|
+
|
|
132
|
+
if (!cancelled) {
|
|
133
|
+
setData(result);
|
|
134
|
+
setLoading(false);
|
|
135
|
+
}
|
|
136
|
+
} catch (error) {
|
|
137
|
+
if (!cancelled) {
|
|
138
|
+
console.error(error);
|
|
139
|
+
}
|
|
140
|
+
}
|
|
141
|
+
};
|
|
142
|
+
|
|
143
|
+
fetchData();
|
|
144
|
+
|
|
145
|
+
// Cleanup function
|
|
146
|
+
return () => {
|
|
147
|
+
cancelled = true;
|
|
148
|
+
};
|
|
149
|
+
}, [id]); // Re-run when id changes
|
|
150
|
+
|
|
151
|
+
if (loading) return <div>Loading...</div>;
|
|
152
|
+
return <div>{data}</div>;
|
|
153
|
+
}
|
|
154
|
+
```
|
|
155
|
+
|
|
156
|
+
### Context and HOCs to Hooks
|
|
157
|
+
```javascript
|
|
158
|
+
// Before: Context consumer and HOC
|
|
159
|
+
const ThemeContext = React.createContext();
|
|
160
|
+
|
|
161
|
+
class ThemedButton extends React.Component {
|
|
162
|
+
static contextType = ThemeContext;
|
|
163
|
+
|
|
164
|
+
render() {
|
|
165
|
+
return (
|
|
166
|
+
<button style={{ background: this.context.theme }}>
|
|
167
|
+
{this.props.children}
|
|
168
|
+
</button>
|
|
169
|
+
);
|
|
170
|
+
}
|
|
171
|
+
}
|
|
172
|
+
|
|
173
|
+
// After: useContext hook
|
|
174
|
+
function ThemedButton({ children }) {
|
|
175
|
+
const { theme } = useContext(ThemeContext);
|
|
176
|
+
|
|
177
|
+
return (
|
|
178
|
+
<button style={{ background: theme }}>
|
|
179
|
+
{children}
|
|
180
|
+
</button>
|
|
181
|
+
);
|
|
182
|
+
}
|
|
183
|
+
|
|
184
|
+
// Before: HOC for data fetching
|
|
185
|
+
function withUser(Component) {
|
|
186
|
+
return class extends React.Component {
|
|
187
|
+
state = { user: null };
|
|
188
|
+
|
|
189
|
+
componentDidMount() {
|
|
190
|
+
fetchUser().then(user => this.setState({ user }));
|
|
191
|
+
}
|
|
192
|
+
|
|
193
|
+
render() {
|
|
194
|
+
return <Component {...this.props} user={this.state.user} />;
|
|
195
|
+
}
|
|
196
|
+
};
|
|
197
|
+
}
|
|
198
|
+
|
|
199
|
+
// After: Custom hook
|
|
200
|
+
function useUser() {
|
|
201
|
+
const [user, setUser] = useState(null);
|
|
202
|
+
|
|
203
|
+
useEffect(() => {
|
|
204
|
+
fetchUser().then(setUser);
|
|
205
|
+
}, []);
|
|
206
|
+
|
|
207
|
+
return user;
|
|
208
|
+
}
|
|
209
|
+
|
|
210
|
+
function UserProfile() {
|
|
211
|
+
const user = useUser();
|
|
212
|
+
if (!user) return <div>Loading...</div>;
|
|
213
|
+
return <div>{user.name}</div>;
|
|
214
|
+
}
|
|
215
|
+
```
|
|
216
|
+
|
|
217
|
+
## React 18 Concurrent Features
|
|
218
|
+
|
|
219
|
+
### New Root API
|
|
220
|
+
```javascript
|
|
221
|
+
// Before: React 17
|
|
222
|
+
import ReactDOM from 'react-dom';
|
|
223
|
+
|
|
224
|
+
ReactDOM.render(<App />, document.getElementById('root'));
|
|
225
|
+
|
|
226
|
+
// After: React 18
|
|
227
|
+
import { createRoot } from 'react-dom/client';
|
|
228
|
+
|
|
229
|
+
const root = createRoot(document.getElementById('root'));
|
|
230
|
+
root.render(<App />);
|
|
231
|
+
```
|
|
232
|
+
|
|
233
|
+
### Automatic Batching
|
|
234
|
+
```javascript
|
|
235
|
+
// React 18: All updates are batched
|
|
236
|
+
function handleClick() {
|
|
237
|
+
setCount(c => c + 1);
|
|
238
|
+
setFlag(f => !f);
|
|
239
|
+
// Only one re-render (batched)
|
|
240
|
+
}
|
|
241
|
+
|
|
242
|
+
// Even in async:
|
|
243
|
+
setTimeout(() => {
|
|
244
|
+
setCount(c => c + 1);
|
|
245
|
+
setFlag(f => !f);
|
|
246
|
+
// Still batched in React 18!
|
|
247
|
+
}, 1000);
|
|
248
|
+
|
|
249
|
+
// Opt out if needed
|
|
250
|
+
import { flushSync } from 'react-dom';
|
|
251
|
+
|
|
252
|
+
flushSync(() => {
|
|
253
|
+
setCount(c => c + 1);
|
|
254
|
+
});
|
|
255
|
+
// Re-render happens here
|
|
256
|
+
setFlag(f => !f);
|
|
257
|
+
// Another re-render
|
|
258
|
+
```
|
|
259
|
+
|
|
260
|
+
### Transitions
|
|
261
|
+
```javascript
|
|
262
|
+
import { useState, useTransition } from 'react';
|
|
263
|
+
|
|
264
|
+
function SearchResults() {
|
|
265
|
+
const [query, setQuery] = useState('');
|
|
266
|
+
const [results, setResults] = useState([]);
|
|
267
|
+
const [isPending, startTransition] = useTransition();
|
|
268
|
+
|
|
269
|
+
const handleChange = (e) => {
|
|
270
|
+
// Urgent: Update input immediately
|
|
271
|
+
setQuery(e.target.value);
|
|
272
|
+
|
|
273
|
+
// Non-urgent: Update results (can be interrupted)
|
|
274
|
+
startTransition(() => {
|
|
275
|
+
setResults(searchResults(e.target.value));
|
|
276
|
+
});
|
|
277
|
+
};
|
|
278
|
+
|
|
279
|
+
return (
|
|
280
|
+
<>
|
|
281
|
+
<input value={query} onChange={handleChange} />
|
|
282
|
+
{isPending && <Spinner />}
|
|
283
|
+
<Results data={results} />
|
|
284
|
+
</>
|
|
285
|
+
);
|
|
286
|
+
}
|
|
287
|
+
```
|
|
288
|
+
|
|
289
|
+
### Suspense for Data Fetching
|
|
290
|
+
```javascript
|
|
291
|
+
import { Suspense } from 'react';
|
|
292
|
+
|
|
293
|
+
// Resource-based data fetching (with React 18)
|
|
294
|
+
const resource = fetchProfileData();
|
|
295
|
+
|
|
296
|
+
function ProfilePage() {
|
|
297
|
+
return (
|
|
298
|
+
<Suspense fallback={<Loading />}>
|
|
299
|
+
<ProfileDetails />
|
|
300
|
+
<Suspense fallback={<Loading />}>
|
|
301
|
+
<ProfileTimeline />
|
|
302
|
+
</Suspense>
|
|
303
|
+
</Suspense>
|
|
304
|
+
);
|
|
305
|
+
}
|
|
306
|
+
|
|
307
|
+
function ProfileDetails() {
|
|
308
|
+
// This will suspend if data not ready
|
|
309
|
+
const user = resource.user.read();
|
|
310
|
+
return <h1>{user.name}</h1>;
|
|
311
|
+
}
|
|
312
|
+
|
|
313
|
+
function ProfileTimeline() {
|
|
314
|
+
const posts = resource.posts.read();
|
|
315
|
+
return <Timeline posts={posts} />;
|
|
316
|
+
}
|
|
317
|
+
```
|
|
318
|
+
|
|
319
|
+
## Codemods for Automation
|
|
320
|
+
|
|
321
|
+
### Run React Codemods
|
|
322
|
+
```bash
|
|
323
|
+
# Install jscodeshift
|
|
324
|
+
npm install -g jscodeshift
|
|
325
|
+
|
|
326
|
+
# React 16.9 codemod (rename unsafe lifecycle methods)
|
|
327
|
+
npx react-codeshift <transform> <path>
|
|
328
|
+
|
|
329
|
+
# Example: Rename UNSAFE_ methods
|
|
330
|
+
npx react-codeshift --parser=tsx \
|
|
331
|
+
--transform=react-codeshift/transforms/rename-unsafe-lifecycles.js \
|
|
332
|
+
src/
|
|
333
|
+
|
|
334
|
+
# Update to new JSX Transform (React 17+)
|
|
335
|
+
npx react-codeshift --parser=tsx \
|
|
336
|
+
--transform=react-codeshift/transforms/new-jsx-transform.js \
|
|
337
|
+
src/
|
|
338
|
+
|
|
339
|
+
# Class to Hooks (third-party)
|
|
340
|
+
npx codemod react/hooks/convert-class-to-function src/
|
|
341
|
+
```
|
|
342
|
+
|
|
343
|
+
### Custom Codemod Example
|
|
344
|
+
```javascript
|
|
345
|
+
// custom-codemod.js
|
|
346
|
+
module.exports = function(file, api) {
|
|
347
|
+
const j = api.jscodeshift;
|
|
348
|
+
const root = j(file.source);
|
|
349
|
+
|
|
350
|
+
// Find setState calls
|
|
351
|
+
root.find(j.CallExpression, {
|
|
352
|
+
callee: {
|
|
353
|
+
type: 'MemberExpression',
|
|
354
|
+
property: { name: 'setState' }
|
|
355
|
+
}
|
|
356
|
+
}).forEach(path => {
|
|
357
|
+
// Transform to useState
|
|
358
|
+
// ... transformation logic
|
|
359
|
+
});
|
|
360
|
+
|
|
361
|
+
return root.toSource();
|
|
362
|
+
};
|
|
363
|
+
|
|
364
|
+
// Run: jscodeshift -t custom-codemod.js src/
|
|
365
|
+
```
|
|
366
|
+
|
|
367
|
+
## Performance Optimization
|
|
368
|
+
|
|
369
|
+
### useMemo and useCallback
|
|
370
|
+
```javascript
|
|
371
|
+
function ExpensiveComponent({ items, filter }) {
|
|
372
|
+
// Memoize expensive calculation
|
|
373
|
+
const filteredItems = useMemo(() => {
|
|
374
|
+
return items.filter(item => item.category === filter);
|
|
375
|
+
}, [items, filter]);
|
|
376
|
+
|
|
377
|
+
// Memoize callback to prevent child re-renders
|
|
378
|
+
const handleClick = useCallback((id) => {
|
|
379
|
+
console.log('Clicked:', id);
|
|
380
|
+
}, []); // No dependencies, never changes
|
|
381
|
+
|
|
382
|
+
return (
|
|
383
|
+
<List items={filteredItems} onClick={handleClick} />
|
|
384
|
+
);
|
|
385
|
+
}
|
|
386
|
+
|
|
387
|
+
// Child component with memo
|
|
388
|
+
const List = React.memo(({ items, onClick }) => {
|
|
389
|
+
return items.map(item => (
|
|
390
|
+
<Item key={item.id} item={item} onClick={onClick} />
|
|
391
|
+
));
|
|
392
|
+
});
|
|
393
|
+
```
|
|
394
|
+
|
|
395
|
+
### Code Splitting
|
|
396
|
+
```javascript
|
|
397
|
+
import { lazy, Suspense } from 'react';
|
|
398
|
+
|
|
399
|
+
// Lazy load components
|
|
400
|
+
const Dashboard = lazy(() => import('./Dashboard'));
|
|
401
|
+
const Settings = lazy(() => import('./Settings'));
|
|
402
|
+
|
|
403
|
+
function App() {
|
|
404
|
+
return (
|
|
405
|
+
<Suspense fallback={<Loading />}>
|
|
406
|
+
<Routes>
|
|
407
|
+
<Route path="/dashboard" element={<Dashboard />} />
|
|
408
|
+
<Route path="/settings" element={<Settings />} />
|
|
409
|
+
</Routes>
|
|
410
|
+
</Suspense>
|
|
411
|
+
);
|
|
412
|
+
}
|
|
413
|
+
```
|
|
414
|
+
|
|
415
|
+
## TypeScript Migration
|
|
416
|
+
|
|
417
|
+
```typescript
|
|
418
|
+
// Before: JavaScript
|
|
419
|
+
function Button({ onClick, children }) {
|
|
420
|
+
return <button onClick={onClick}>{children}</button>;
|
|
421
|
+
}
|
|
422
|
+
|
|
423
|
+
// After: TypeScript
|
|
424
|
+
interface ButtonProps {
|
|
425
|
+
onClick: () => void;
|
|
426
|
+
children: React.ReactNode;
|
|
427
|
+
}
|
|
428
|
+
|
|
429
|
+
function Button({ onClick, children }: ButtonProps) {
|
|
430
|
+
return <button onClick={onClick}>{children}</button>;
|
|
431
|
+
}
|
|
432
|
+
|
|
433
|
+
// Generic components
|
|
434
|
+
interface ListProps<T> {
|
|
435
|
+
items: T[];
|
|
436
|
+
renderItem: (item: T) => React.ReactNode;
|
|
437
|
+
}
|
|
438
|
+
|
|
439
|
+
function List<T>({ items, renderItem }: ListProps<T>) {
|
|
440
|
+
return <>{items.map(renderItem)}</>;
|
|
441
|
+
}
|
|
442
|
+
```
|
|
443
|
+
|
|
444
|
+
## Migration Checklist
|
|
445
|
+
|
|
446
|
+
```markdown
|
|
447
|
+
### Pre-Migration
|
|
448
|
+
- [ ] Update dependencies incrementally (not all at once)
|
|
449
|
+
- [ ] Review breaking changes in release notes
|
|
450
|
+
- [ ] Set up testing suite
|
|
451
|
+
- [ ] Create feature branch
|
|
452
|
+
|
|
453
|
+
### Class → Hooks Migration
|
|
454
|
+
- [ ] Identify class components to migrate
|
|
455
|
+
- [ ] Start with leaf components (no children)
|
|
456
|
+
- [ ] Convert state to useState
|
|
457
|
+
- [ ] Convert lifecycle to useEffect
|
|
458
|
+
- [ ] Convert context to useContext
|
|
459
|
+
- [ ] Extract custom hooks
|
|
460
|
+
- [ ] Test thoroughly
|
|
461
|
+
|
|
462
|
+
### React 18 Upgrade
|
|
463
|
+
- [ ] Update to React 17 first (if needed)
|
|
464
|
+
- [ ] Update react and react-dom to 18
|
|
465
|
+
- [ ] Update @types/react if using TypeScript
|
|
466
|
+
- [ ] Change to createRoot API
|
|
467
|
+
- [ ] Test with StrictMode (double invocation)
|
|
468
|
+
- [ ] Address concurrent rendering issues
|
|
469
|
+
- [ ] Adopt Suspense/Transitions where beneficial
|
|
470
|
+
|
|
471
|
+
### Performance
|
|
472
|
+
- [ ] Identify performance bottlenecks
|
|
473
|
+
- [ ] Add React.memo where appropriate
|
|
474
|
+
- [ ] Use useMemo/useCallback for expensive operations
|
|
475
|
+
- [ ] Implement code splitting
|
|
476
|
+
- [ ] Optimize re-renders
|
|
477
|
+
|
|
478
|
+
### Testing
|
|
479
|
+
- [ ] Update test utilities (React Testing Library)
|
|
480
|
+
- [ ] Test with React 18 features
|
|
481
|
+
- [ ] Check for warnings in console
|
|
482
|
+
- [ ] Performance testing
|
|
483
|
+
```
|
|
484
|
+
|
|
485
|
+
## Resources
|
|
486
|
+
|
|
487
|
+
- **references/breaking-changes.md**: Version-specific breaking changes
|
|
488
|
+
- **references/codemods.md**: Codemod usage guide
|
|
489
|
+
- **references/hooks-migration.md**: Comprehensive hooks patterns
|
|
490
|
+
- **references/concurrent-features.md**: React 18 concurrent features
|
|
491
|
+
- **assets/codemod-config.json**: Codemod configurations
|
|
492
|
+
- **assets/migration-checklist.md**: Step-by-step checklist
|
|
493
|
+
- **scripts/apply-codemods.sh**: Automated codemod script
|
|
494
|
+
|
|
495
|
+
## Best Practices
|
|
496
|
+
|
|
497
|
+
1. **Incremental Migration**: Don't migrate everything at once
|
|
498
|
+
2. **Test Thoroughly**: Comprehensive testing at each step
|
|
499
|
+
3. **Use Codemods**: Automate repetitive transformations
|
|
500
|
+
4. **Start Simple**: Begin with leaf components
|
|
501
|
+
5. **Leverage StrictMode**: Catch issues early
|
|
502
|
+
6. **Monitor Performance**: Measure before and after
|
|
503
|
+
7. **Document Changes**: Keep migration log
|
|
504
|
+
|
|
505
|
+
## Common Pitfalls
|
|
506
|
+
|
|
507
|
+
- Forgetting useEffect dependencies
|
|
508
|
+
- Over-using useMemo/useCallback
|
|
509
|
+
- Not handling cleanup in useEffect
|
|
510
|
+
- Mixing class and functional patterns
|
|
511
|
+
- Ignoring StrictMode warnings
|
|
512
|
+
- Breaking change assumptions
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: react-native-architecture
|
|
3
|
+
description: Build production React Native apps with Expo, navigation, native modules, offline sync, and cross-platform patterns. Use when developing mobile apps, implementing native integrations, or architecting React Native projects.
|
|
4
|
+
---
|
|
5
|
+
|
|
6
|
+
# React Native Architecture
|
|
7
|
+
|
|
8
|
+
Production-ready patterns for React Native development with Expo, including navigation, state management, native modules, and offline-first architecture.
|
|
9
|
+
|
|
10
|
+
## Use this skill when
|
|
11
|
+
|
|
12
|
+
- Starting a new React Native or Expo project
|
|
13
|
+
- Implementing complex navigation patterns
|
|
14
|
+
- Integrating native modules and platform APIs
|
|
15
|
+
- Building offline-first mobile applications
|
|
16
|
+
- Optimizing React Native performance
|
|
17
|
+
- Setting up CI/CD for mobile releases
|
|
18
|
+
|
|
19
|
+
## Do not use this skill when
|
|
20
|
+
|
|
21
|
+
- The task is unrelated to react native architecture
|
|
22
|
+
- You need a different domain or tool outside this scope
|
|
23
|
+
|
|
24
|
+
## Instructions
|
|
25
|
+
|
|
26
|
+
- Clarify goals, constraints, and required inputs.
|
|
27
|
+
- Apply relevant best practices and validate outcomes.
|
|
28
|
+
- Provide actionable steps and verification.
|
|
29
|
+
- If detailed examples are required, open `resources/implementation-playbook.md`.
|
|
30
|
+
|
|
31
|
+
## Resources
|
|
32
|
+
|
|
33
|
+
- `resources/implementation-playbook.md` for detailed patterns and examples.
|