@macpaw/cctk 1.0.0-beta.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/License +21 -0
- package/README.md +142 -0
- package/bin/index.js +5 -0
- package/dist/index.js +1 -0
- package/package.json +65 -0
- package/templates/claude/agents/brainstormer.md +113 -0
- package/templates/claude/agents/code-reviewer.md +157 -0
- package/templates/claude/agents/copywriter.md +110 -0
- package/templates/claude/agents/database-admin.md +92 -0
- package/templates/claude/agents/debugger.md +137 -0
- package/templates/claude/agents/docs-manager.md +208 -0
- package/templates/claude/agents/fullstack-developer.md +95 -0
- package/templates/claude/agents/git-manager.md +394 -0
- package/templates/claude/agents/journal-writer.md +113 -0
- package/templates/claude/agents/mcp-manager.md +89 -0
- package/templates/claude/agents/planner.md +108 -0
- package/templates/claude/agents/project-manager.md +125 -0
- package/templates/claude/agents/registry.json +304 -0
- package/templates/claude/agents/researcher.md +37 -0
- package/templates/claude/agents/scout-external.md +140 -0
- package/templates/claude/agents/scout.md +106 -0
- package/templates/claude/agents/tester.md +105 -0
- package/templates/claude/agents/ui-ux-designer.md +208 -0
- package/templates/claude/commands/ask.md +56 -0
- package/templates/claude/commands/bootstrap/auto/fast.md +106 -0
- package/templates/claude/commands/bootstrap/auto/parallel.md +64 -0
- package/templates/claude/commands/bootstrap/auto.md +110 -0
- package/templates/claude/commands/bootstrap.md +130 -0
- package/templates/claude/commands/brainstorm.md +75 -0
- package/templates/claude/commands/code/auto.md +198 -0
- package/templates/claude/commands/code/no-test.md +172 -0
- package/templates/claude/commands/code/parallel.md +100 -0
- package/templates/claude/commands/code.md +197 -0
- package/templates/claude/commands/coding-level.md +37 -0
- package/templates/claude/commands/content/cro.md +41 -0
- package/templates/claude/commands/content/enhance.md +12 -0
- package/templates/claude/commands/content/fast.md +11 -0
- package/templates/claude/commands/content/good.md +14 -0
- package/templates/claude/commands/cook/auto/fast.md +26 -0
- package/templates/claude/commands/cook/auto/parallel.md +49 -0
- package/templates/claude/commands/cook/auto.md +15 -0
- package/templates/claude/commands/cook.md +101 -0
- package/templates/claude/commands/debug.md +13 -0
- package/templates/claude/commands/docs/init.md +37 -0
- package/templates/claude/commands/docs/summarize.md +22 -0
- package/templates/claude/commands/docs/update.md +78 -0
- package/templates/claude/commands/fix/ci.md +17 -0
- package/templates/claude/commands/fix/fast.md +18 -0
- package/templates/claude/commands/fix/hard.md +35 -0
- package/templates/claude/commands/fix/logs.md +26 -0
- package/templates/claude/commands/fix/parallel.md +54 -0
- package/templates/claude/commands/fix/test.md +20 -0
- package/templates/claude/commands/fix/types.md +9 -0
- package/templates/claude/commands/fix/ui.md +33 -0
- package/templates/claude/commands/fix.md +43 -0
- package/templates/claude/commands/git/cm.md +5 -0
- package/templates/claude/commands/git/cp.md +4 -0
- package/templates/claude/commands/git/merge.md +40 -0
- package/templates/claude/commands/git/pr.md +50 -0
- package/templates/claude/commands/journal.md +7 -0
- package/templates/claude/commands/kanban.md +99 -0
- package/templates/claude/commands/plan/archive.md +57 -0
- package/templates/claude/commands/plan/ci.md +33 -0
- package/templates/claude/commands/plan/cro.md +67 -0
- package/templates/claude/commands/plan/fast.md +66 -0
- package/templates/claude/commands/plan/hard.md +92 -0
- package/templates/claude/commands/plan/parallel.md +129 -0
- package/templates/claude/commands/plan/two.md +45 -0
- package/templates/claude/commands/plan/validate.md +117 -0
- package/templates/claude/commands/plan.md +30 -0
- package/templates/claude/commands/preview.md +87 -0
- package/templates/claude/commands/registry.json +313 -0
- package/templates/claude/commands/review/codebase/parallel.md +122 -0
- package/templates/claude/commands/review/codebase.md +47 -0
- package/templates/claude/commands/scout/ext.md +35 -0
- package/templates/claude/commands/scout.md +28 -0
- package/templates/claude/commands/skill/add.md +36 -0
- package/templates/claude/commands/skill/create.md +29 -0
- package/templates/claude/commands/skill/fix-logs.md +22 -0
- package/templates/claude/commands/skill/optimize/auto.md +25 -0
- package/templates/claude/commands/skill/optimize.md +34 -0
- package/templates/claude/commands/skill/plan.md +45 -0
- package/templates/claude/commands/test/ui.md +91 -0
- package/templates/claude/commands/test.md +8 -0
- package/templates/claude/commands/use-mcp.md +34 -0
- package/templates/claude/commands/watzup.md +8 -0
- package/templates/claude/commands/worktree.md +126 -0
- package/templates/claude/hooks/dev-rules-reminder.cjs +258 -0
- package/templates/claude/hooks/docs/README.md +42 -0
- package/templates/claude/hooks/lib/cctk-config-utils.cjs +751 -0
- package/templates/claude/hooks/lib/cctk-paths.cjs +106 -0
- package/templates/claude/hooks/lib/context-tracker.cjs +346 -0
- package/templates/claude/hooks/privacy-block.cjs +289 -0
- package/templates/claude/hooks/registry.json +77 -0
- package/templates/claude/hooks/scout-block/broad-pattern-detector.cjs +293 -0
- package/templates/claude/hooks/scout-block/error-formatter.cjs +156 -0
- package/templates/claude/hooks/scout-block/path-extractor.cjs +359 -0
- package/templates/claude/hooks/scout-block/pattern-matcher.cjs +184 -0
- package/templates/claude/hooks/scout-block/vendor/ignore.js +626 -0
- package/templates/claude/hooks/scout-block.cjs +167 -0
- package/templates/claude/hooks/session-end.cjs +35 -0
- package/templates/claude/hooks/session-init.cjs +214 -0
- package/templates/claude/hooks/subagent-init.cjs +161 -0
- package/templates/claude/hooks/write-compact-marker.cjs +153 -0
- package/templates/claude/output-styles/coding-level-1.md +148 -0
- package/templates/claude/output-styles/coding-level-2.md +159 -0
- package/templates/claude/output-styles/coding-level-3.md +91 -0
- package/templates/claude/scripts/README.md +33 -0
- package/templates/claude/scripts/generate-catalogs.cjs +318 -0
- package/templates/claude/scripts/registry.json +48 -0
- package/templates/claude/scripts/set-active-plan.cjs +45 -0
- package/templates/claude/scripts/validate-docs.cjs +447 -0
- package/templates/claude/scripts/worktree.cjs +658 -0
- package/templates/claude/skills/README.md +112 -0
- package/templates/claude/skills/ai-artist/SKILL.md +75 -0
- package/templates/claude/skills/ai-artist/references/advanced-techniques.md +184 -0
- package/templates/claude/skills/ai-artist/references/domain-code.md +66 -0
- package/templates/claude/skills/ai-artist/references/domain-data.md +72 -0
- package/templates/claude/skills/ai-artist/references/domain-marketing.md +66 -0
- package/templates/claude/skills/ai-artist/references/domain-patterns.md +33 -0
- package/templates/claude/skills/ai-artist/references/domain-writing.md +68 -0
- package/templates/claude/skills/ai-artist/references/image-prompting.md +141 -0
- package/templates/claude/skills/ai-artist/references/llm-prompting.md +165 -0
- package/templates/claude/skills/ai-artist/references/nano-banana.md +59 -0
- package/templates/claude/skills/ai-artist/references/reasoning-techniques.md +201 -0
- package/templates/claude/skills/backend-development/SKILL.md +95 -0
- package/templates/claude/skills/backend-development/references/backend-api-design.md +495 -0
- package/templates/claude/skills/backend-development/references/backend-architecture.md +454 -0
- package/templates/claude/skills/backend-development/references/backend-authentication.md +338 -0
- package/templates/claude/skills/backend-development/references/backend-code-quality.md +659 -0
- package/templates/claude/skills/backend-development/references/backend-debugging.md +904 -0
- package/templates/claude/skills/backend-development/references/backend-devops.md +494 -0
- package/templates/claude/skills/backend-development/references/backend-mindset.md +387 -0
- package/templates/claude/skills/backend-development/references/backend-performance.md +397 -0
- package/templates/claude/skills/backend-development/references/backend-security.md +290 -0
- package/templates/claude/skills/backend-development/references/backend-technologies.md +256 -0
- package/templates/claude/skills/backend-development/references/backend-testing.md +429 -0
- package/templates/claude/skills/better-auth/SKILL.md +204 -0
- package/templates/claude/skills/better-auth/references/advanced-features.md +553 -0
- package/templates/claude/skills/better-auth/references/database-integration.md +577 -0
- package/templates/claude/skills/better-auth/references/email-password-auth.md +416 -0
- package/templates/claude/skills/better-auth/references/oauth-providers.md +430 -0
- package/templates/claude/skills/better-auth/scripts/better_auth_init.py +521 -0
- package/templates/claude/skills/chrome-devtools/SKILL.md +473 -0
- package/templates/claude/skills/chrome-devtools/references/cdp-domains.md +694 -0
- package/templates/claude/skills/chrome-devtools/references/performance-guide.md +940 -0
- package/templates/claude/skills/chrome-devtools/references/puppeteer-reference.md +953 -0
- package/templates/claude/skills/chrome-devtools/scripts/README.md +288 -0
- package/templates/claude/skills/chrome-devtools/scripts/aria-snapshot.js +368 -0
- package/templates/claude/skills/chrome-devtools/scripts/click.js +92 -0
- package/templates/claude/skills/chrome-devtools/scripts/console.js +85 -0
- package/templates/claude/skills/chrome-devtools/scripts/evaluate.js +59 -0
- package/templates/claude/skills/chrome-devtools/scripts/fill.js +84 -0
- package/templates/claude/skills/chrome-devtools/scripts/inject-auth.js +247 -0
- package/templates/claude/skills/chrome-devtools/scripts/install-deps.sh +11 -0
- package/templates/claude/skills/chrome-devtools/scripts/install.sh +36 -0
- package/templates/claude/skills/chrome-devtools/scripts/lib/browser.js +335 -0
- package/templates/claude/skills/chrome-devtools/scripts/lib/selector.js +183 -0
- package/templates/claude/skills/chrome-devtools/scripts/navigate.js +60 -0
- package/templates/claude/skills/chrome-devtools/scripts/network.js +113 -0
- package/templates/claude/skills/chrome-devtools/scripts/package.json +16 -0
- package/templates/claude/skills/chrome-devtools/scripts/performance.js +159 -0
- package/templates/claude/skills/chrome-devtools/scripts/screenshot.js +212 -0
- package/templates/claude/skills/chrome-devtools/scripts/select-ref.js +151 -0
- package/templates/claude/skills/chrome-devtools/scripts/snapshot.js +143 -0
- package/templates/claude/skills/chrome-devtools/scripts/ws-debug.js +47 -0
- package/templates/claude/skills/chrome-devtools/scripts/ws-full-debug.js +115 -0
- package/templates/claude/skills/claude-code/references/advanced-features.md +399 -0
- package/templates/claude/skills/claude-code/references/agent-skills.md +399 -0
- package/templates/claude/skills/claude-code/references/api-reference.md +498 -0
- package/templates/claude/skills/claude-code/references/best-practices.md +447 -0
- package/templates/claude/skills/claude-code/references/cicd-integration.md +428 -0
- package/templates/claude/skills/claude-code/references/common-workflows.md +107 -0
- package/templates/claude/skills/claude-code/references/configuration.md +480 -0
- package/templates/claude/skills/claude-code/references/enterprise-features.md +472 -0
- package/templates/claude/skills/claude-code/references/getting-started.md +244 -0
- package/templates/claude/skills/claude-code/references/hooks-and-plugins.md +444 -0
- package/templates/claude/skills/claude-code/references/hooks-comprehensive.md +622 -0
- package/templates/claude/skills/claude-code/references/ide-integration.md +316 -0
- package/templates/claude/skills/claude-code/references/mcp-integration.md +386 -0
- package/templates/claude/skills/claude-code/references/slash-commands.md +460 -0
- package/templates/claude/skills/claude-code/references/troubleshooting.md +455 -0
- package/templates/claude/skills/claude-code/skill.md +60 -0
- package/templates/claude/skills/code-review/SKILL.md +143 -0
- package/templates/claude/skills/code-review/references/code-review-reception.md +209 -0
- package/templates/claude/skills/code-review/references/requesting-code-review.md +105 -0
- package/templates/claude/skills/code-review/references/verification-before-completion.md +139 -0
- package/templates/claude/skills/context-engineering/SKILL.md +86 -0
- package/templates/claude/skills/context-engineering/references/context-compression.md +84 -0
- package/templates/claude/skills/context-engineering/references/context-degradation.md +93 -0
- package/templates/claude/skills/context-engineering/references/context-fundamentals.md +75 -0
- package/templates/claude/skills/context-engineering/references/context-optimization.md +82 -0
- package/templates/claude/skills/context-engineering/references/evaluation.md +89 -0
- package/templates/claude/skills/context-engineering/references/memory-systems.md +88 -0
- package/templates/claude/skills/context-engineering/references/multi-agent-patterns.md +90 -0
- package/templates/claude/skills/context-engineering/references/project-development.md +97 -0
- package/templates/claude/skills/context-engineering/references/tool-design.md +86 -0
- package/templates/claude/skills/context-engineering/scripts/compression_evaluator.py +329 -0
- package/templates/claude/skills/context-engineering/scripts/context_analyzer.py +294 -0
- package/templates/claude/skills/databases/SKILL.md +232 -0
- package/templates/claude/skills/databases/references/mongodb-aggregation.md +447 -0
- package/templates/claude/skills/databases/references/mongodb-atlas.md +465 -0
- package/templates/claude/skills/databases/references/mongodb-crud.md +408 -0
- package/templates/claude/skills/databases/references/mongodb-indexing.md +442 -0
- package/templates/claude/skills/databases/references/postgresql-administration.md +594 -0
- package/templates/claude/skills/databases/references/postgresql-performance.md +527 -0
- package/templates/claude/skills/databases/references/postgresql-psql-cli.md +467 -0
- package/templates/claude/skills/databases/references/postgresql-queries.md +475 -0
- package/templates/claude/skills/databases/scripts/db_backup.py +502 -0
- package/templates/claude/skills/databases/scripts/db_migrate.py +414 -0
- package/templates/claude/skills/databases/scripts/db_performance_check.py +445 -0
- package/templates/claude/skills/debugging/SKILL.md +84 -0
- package/templates/claude/skills/debugging/references/defense-in-depth.md +124 -0
- package/templates/claude/skills/debugging/references/root-cause-tracing.md +122 -0
- package/templates/claude/skills/debugging/references/systematic-debugging.md +102 -0
- package/templates/claude/skills/debugging/references/verification.md +123 -0
- package/templates/claude/skills/debugging/scripts/find-polluter.sh +63 -0
- package/templates/claude/skills/debugging/scripts/find-polluter.test.md +102 -0
- package/templates/claude/skills/devops/SKILL.md +293 -0
- package/templates/claude/skills/devops/references/browser-rendering.md +305 -0
- package/templates/claude/skills/devops/references/cloudflare-d1-kv.md +123 -0
- package/templates/claude/skills/devops/references/cloudflare-platform.md +271 -0
- package/templates/claude/skills/devops/references/cloudflare-r2-storage.md +280 -0
- package/templates/claude/skills/devops/references/cloudflare-workers-advanced.md +312 -0
- package/templates/claude/skills/devops/references/cloudflare-workers-apis.md +309 -0
- package/templates/claude/skills/devops/references/cloudflare-workers-basics.md +418 -0
- package/templates/claude/skills/devops/references/docker-basics.md +297 -0
- package/templates/claude/skills/devops/references/docker-compose.md +292 -0
- package/templates/claude/skills/devops/references/gcloud-platform.md +307 -0
- package/templates/claude/skills/devops/references/gcloud-services.md +304 -0
- package/templates/claude/skills/devops/scripts/cloudflare_deploy.py +269 -0
- package/templates/claude/skills/devops/scripts/docker_optimize.py +320 -0
- package/templates/claude/skills/docs-seeker/SKILL.md +95 -0
- package/templates/claude/skills/docs-seeker/package.json +24 -0
- package/templates/claude/skills/docs-seeker/references/advanced.md +78 -0
- package/templates/claude/skills/docs-seeker/references/context7-patterns.md +68 -0
- package/templates/claude/skills/docs-seeker/references/errors.md +68 -0
- package/templates/claude/skills/docs-seeker/scripts/analyze-llms-txt.js +245 -0
- package/templates/claude/skills/docs-seeker/scripts/detect-topic.js +172 -0
- package/templates/claude/skills/docs-seeker/scripts/fetch-docs.js +212 -0
- package/templates/claude/skills/docs-seeker/workflows/library-search.md +87 -0
- package/templates/claude/skills/docs-seeker/workflows/repo-analysis.md +91 -0
- package/templates/claude/skills/docs-seeker/workflows/topic-search.md +77 -0
- package/templates/claude/skills/frontend-design/SKILL.md +85 -0
- package/templates/claude/skills/frontend-design/references/analysis-best-practices.md +80 -0
- package/templates/claude/skills/frontend-design/references/analysis-prompts.md +141 -0
- package/templates/claude/skills/frontend-design/references/analysis-techniques.md +118 -0
- package/templates/claude/skills/frontend-design/references/animejs.md +396 -0
- package/templates/claude/skills/frontend-design/references/design-extraction-overview.md +71 -0
- package/templates/claude/skills/frontend-design/references/extraction-best-practices.md +141 -0
- package/templates/claude/skills/frontend-design/references/extraction-output-templates.md +162 -0
- package/templates/claude/skills/frontend-design/references/extraction-prompts.md +127 -0
- package/templates/claude/skills/frontend-design/references/technical-accessibility.md +119 -0
- package/templates/claude/skills/frontend-design/references/technical-best-practices.md +97 -0
- package/templates/claude/skills/frontend-design/references/technical-optimization.md +44 -0
- package/templates/claude/skills/frontend-design/references/technical-overview.md +90 -0
- package/templates/claude/skills/frontend-design/references/technical-workflows.md +150 -0
- package/templates/claude/skills/frontend-design/references/visual-analysis-overview.md +95 -0
- package/templates/claude/skills/frontend-development/SKILL.md +399 -0
- package/templates/claude/skills/frontend-development/resources/common-patterns.md +331 -0
- package/templates/claude/skills/frontend-development/resources/complete-examples.md +872 -0
- package/templates/claude/skills/frontend-development/resources/component-patterns.md +502 -0
- package/templates/claude/skills/frontend-development/resources/data-fetching.md +767 -0
- package/templates/claude/skills/frontend-development/resources/file-organization.md +502 -0
- package/templates/claude/skills/frontend-development/resources/loading-and-error-states.md +501 -0
- package/templates/claude/skills/frontend-development/resources/performance.md +406 -0
- package/templates/claude/skills/frontend-development/resources/routing-guide.md +364 -0
- package/templates/claude/skills/frontend-development/resources/styling-guide.md +428 -0
- package/templates/claude/skills/frontend-development/resources/typescript-standards.md +418 -0
- package/templates/claude/skills/markdown-novel-viewer/SKILL.md +272 -0
- package/templates/claude/skills/markdown-novel-viewer/assets/directory-browser.css +215 -0
- package/templates/claude/skills/markdown-novel-viewer/assets/favicon.png +0 -0
- package/templates/claude/skills/markdown-novel-viewer/assets/novel-theme.css +872 -0
- package/templates/claude/skills/markdown-novel-viewer/assets/reader.js +378 -0
- package/templates/claude/skills/markdown-novel-viewer/assets/template.html +85 -0
- package/templates/claude/skills/markdown-novel-viewer/package.json +15 -0
- package/templates/claude/skills/markdown-novel-viewer/scripts/lib/http-server.cjs +434 -0
- package/templates/claude/skills/markdown-novel-viewer/scripts/lib/markdown-renderer.cjs +335 -0
- package/templates/claude/skills/markdown-novel-viewer/scripts/lib/plan-navigator.cjs +509 -0
- package/templates/claude/skills/markdown-novel-viewer/scripts/lib/port-finder.cjs +49 -0
- package/templates/claude/skills/markdown-novel-viewer/scripts/lib/process-mgr.cjs +150 -0
- package/templates/claude/skills/markdown-novel-viewer/scripts/server.cjs +398 -0
- package/templates/claude/skills/mcp-builder/SKILL.md +328 -0
- package/templates/claude/skills/mcp-builder/reference/evaluation.md +602 -0
- package/templates/claude/skills/mcp-builder/reference/mcp_best_practices.md +915 -0
- package/templates/claude/skills/mcp-builder/reference/node_mcp_server.md +916 -0
- package/templates/claude/skills/mcp-builder/reference/python_mcp_server.md +752 -0
- package/templates/claude/skills/mcp-builder/scripts/connections.py +151 -0
- package/templates/claude/skills/mcp-builder/scripts/evaluation.py +381 -0
- package/templates/claude/skills/mcp-builder/scripts/example_evaluation.xml +22 -0
- package/templates/claude/skills/mcp-builder/scripts/requirements.txt +2 -0
- package/templates/claude/skills/mcp-management/README.md +219 -0
- package/templates/claude/skills/mcp-management/SKILL.md +209 -0
- package/templates/claude/skills/mcp-management/assets/tools.json +3146 -0
- package/templates/claude/skills/mcp-management/references/configuration.md +114 -0
- package/templates/claude/skills/mcp-management/references/gemini-cli-integration.md +209 -0
- package/templates/claude/skills/mcp-management/references/mcp-protocol.md +116 -0
- package/templates/claude/skills/mcp-management/scripts/.env.example +10 -0
- package/templates/claude/skills/mcp-management/scripts/cli.ts +202 -0
- package/templates/claude/skills/mcp-management/scripts/mcp-client.ts +247 -0
- package/templates/claude/skills/mcp-management/scripts/package.json +20 -0
- package/templates/claude/skills/mcp-management/scripts/tsconfig.json +15 -0
- package/templates/claude/skills/media-processing/SKILL.md +91 -0
- package/templates/claude/skills/media-processing/references/common-workflows.md +132 -0
- package/templates/claude/skills/media-processing/references/ffmpeg-encoding.md +358 -0
- package/templates/claude/skills/media-processing/references/ffmpeg-filters.md +503 -0
- package/templates/claude/skills/media-processing/references/ffmpeg-streaming.md +395 -0
- package/templates/claude/skills/media-processing/references/format-compatibility.md +375 -0
- package/templates/claude/skills/media-processing/references/imagemagick-batch.md +612 -0
- package/templates/claude/skills/media-processing/references/imagemagick-editing.md +623 -0
- package/templates/claude/skills/media-processing/references/rmbg-background-removal.md +66 -0
- package/templates/claude/skills/media-processing/references/troubleshooting.md +109 -0
- package/templates/claude/skills/media-processing/scripts/README.md +102 -0
- package/templates/claude/skills/media-processing/scripts/batch-remove-background.sh +124 -0
- package/templates/claude/skills/media-processing/scripts/batch_resize.py +342 -0
- package/templates/claude/skills/media-processing/scripts/media_convert.py +311 -0
- package/templates/claude/skills/media-processing/scripts/remove-background.sh +96 -0
- package/templates/claude/skills/media-processing/scripts/remove-bg-node.js +181 -0
- package/templates/claude/skills/mermaidjs-v11/SKILL.md +115 -0
- package/templates/claude/skills/mermaidjs-v11/references/cli-usage.md +228 -0
- package/templates/claude/skills/mermaidjs-v11/references/configuration.md +232 -0
- package/templates/claude/skills/mermaidjs-v11/references/diagram-types.md +315 -0
- package/templates/claude/skills/mermaidjs-v11/references/examples.md +344 -0
- package/templates/claude/skills/mermaidjs-v11/references/integration.md +310 -0
- package/templates/claude/skills/planning/SKILL.md +115 -0
- package/templates/claude/skills/planning/references/codebase-understanding.md +62 -0
- package/templates/claude/skills/planning/references/output-standards.md +127 -0
- package/templates/claude/skills/planning/references/plan-organization.md +150 -0
- package/templates/claude/skills/planning/references/research-phase.md +49 -0
- package/templates/claude/skills/planning/references/solution-design.md +63 -0
- package/templates/claude/skills/plans-kanban/SKILL.md +157 -0
- package/templates/claude/skills/plans-kanban/assets/dashboard-template.html +119 -0
- package/templates/claude/skills/plans-kanban/assets/dashboard.css +1594 -0
- package/templates/claude/skills/plans-kanban/assets/dashboard.js +659 -0
- package/templates/claude/skills/plans-kanban/assets/favicon.png +0 -0
- package/templates/claude/skills/plans-kanban/package.json +13 -0
- package/templates/claude/skills/plans-kanban/scripts/lib/dashboard-renderer.cjs +941 -0
- package/templates/claude/skills/plans-kanban/scripts/lib/http-server.cjs +310 -0
- package/templates/claude/skills/plans-kanban/scripts/lib/plan-metadata-extractor.cjs +489 -0
- package/templates/claude/skills/plans-kanban/scripts/lib/plan-parser.cjs +194 -0
- package/templates/claude/skills/plans-kanban/scripts/lib/plan-scanner.cjs +277 -0
- package/templates/claude/skills/plans-kanban/scripts/lib/port-finder.cjs +49 -0
- package/templates/claude/skills/plans-kanban/scripts/lib/process-mgr.cjs +128 -0
- package/templates/claude/skills/plans-kanban/scripts/server.cjs +249 -0
- package/templates/claude/skills/problem-solving/SKILL.md +96 -0
- package/templates/claude/skills/problem-solving/references/attribution.md +69 -0
- package/templates/claude/skills/problem-solving/references/collision-zone-thinking.md +79 -0
- package/templates/claude/skills/problem-solving/references/inversion-exercise.md +91 -0
- package/templates/claude/skills/problem-solving/references/meta-pattern-recognition.md +87 -0
- package/templates/claude/skills/problem-solving/references/scale-game.md +95 -0
- package/templates/claude/skills/problem-solving/references/simplification-cascades.md +80 -0
- package/templates/claude/skills/problem-solving/references/when-stuck.md +72 -0
- package/templates/claude/skills/registry.json +258 -0
- package/templates/claude/skills/repomix/SKILL.md +247 -0
- package/templates/claude/skills/repomix/references/configuration.md +211 -0
- package/templates/claude/skills/repomix/references/usage-patterns.md +232 -0
- package/templates/claude/skills/repomix/scripts/README.md +179 -0
- package/templates/claude/skills/repomix/scripts/repomix_batch.py +455 -0
- package/templates/claude/skills/repomix/scripts/repos.example.json +15 -0
- package/templates/claude/skills/research/SKILL.md +168 -0
- package/templates/claude/skills/sequential-thinking/.env.example +8 -0
- package/templates/claude/skills/sequential-thinking/README.md +183 -0
- package/templates/claude/skills/sequential-thinking/SKILL.md +94 -0
- package/templates/claude/skills/sequential-thinking/package.json +31 -0
- package/templates/claude/skills/sequential-thinking/references/advanced-strategies.md +79 -0
- package/templates/claude/skills/sequential-thinking/references/advanced-techniques.md +76 -0
- package/templates/claude/skills/sequential-thinking/references/core-patterns.md +95 -0
- package/templates/claude/skills/sequential-thinking/references/examples-api.md +88 -0
- package/templates/claude/skills/sequential-thinking/references/examples-architecture.md +94 -0
- package/templates/claude/skills/sequential-thinking/references/examples-debug.md +90 -0
- package/templates/claude/skills/sequential-thinking/scripts/format-thought.js +182 -0
- package/templates/claude/skills/sequential-thinking/scripts/process-thought.js +252 -0
- package/templates/claude/skills/skill-creator/LICENSE.txt +202 -0
- package/templates/claude/skills/skill-creator/SKILL.md +266 -0
- package/templates/claude/skills/skill-creator/references/agent-skills-spec.md +51 -0
- package/templates/claude/skills/skill-creator/scripts/encoding_utils.py +21 -0
- package/templates/claude/skills/skill-creator/scripts/init_skill.py +304 -0
- package/templates/claude/skills/skill-creator/scripts/package_skill.py +110 -0
- package/templates/claude/skills/skill-creator/scripts/quick_validate.py +66 -0
- package/templates/claude/skills/template-skill/SKILL.md +6 -0
- package/templates/claude/skills/vitest/SKILL.md +595 -0
- package/templates/claude/skills/vitest/references/async-patterns.md +82 -0
- package/templates/claude/skills/vitest/references/mock-patterns.md +78 -0
- package/templates/claude/skills/vitest/references/monorepo-setup.md +185 -0
- package/templates/claude/skills/vitest/references/turborepo-setup.md +332 -0
- package/templates/claude/skills/web-frameworks/SKILL.md +324 -0
- package/templates/claude/skills/web-frameworks/references/nextjs-app-router.md +465 -0
- package/templates/claude/skills/web-frameworks/references/nextjs-data-fetching.md +459 -0
- package/templates/claude/skills/web-frameworks/references/nextjs-optimization.md +511 -0
- package/templates/claude/skills/web-frameworks/references/nextjs-server-components.md +495 -0
- package/templates/claude/skills/web-frameworks/references/remix-icon-integration.md +603 -0
- package/templates/claude/skills/web-frameworks/references/turborepo-caching.md +551 -0
- package/templates/claude/skills/web-frameworks/references/turborepo-pipelines.md +517 -0
- package/templates/claude/skills/web-frameworks/references/turborepo-setup.md +542 -0
- package/templates/claude/skills/web-frameworks/scripts/nextjs_init.py +547 -0
- package/templates/claude/skills/web-frameworks/scripts/turborepo_migrate.py +394 -0
- package/templates/claude/workflows/development-rules.md +40 -0
- package/templates/claude/workflows/documentation-management.md +121 -0
- package/templates/claude/workflows/orchestration-protocol.md +16 -0
- package/templates/claude/workflows/primary-workflow.md +45 -0
- package/templates/claude/workflows/registry.json +37 -0
- package/templates/common/.cct.json +41 -0
- package/templates/common/.cctkignore +22 -0
- package/templates/common/.env.example +39 -0
- package/templates/common/.mcp.json.example +16 -0
- package/templates/common/metadata.json +15 -0
- package/templates/common/settings.json +79 -0
- package/templates/common/statusline.cjs +271 -0
- package/templates/config/.repomixignore +22 -0
- package/templates/config/AGENTS.md +55 -0
- package/templates/config/CLAUDE.md +87 -0
- package/templates/plans/bug-fix-template.md +69 -0
- package/templates/plans/feature-implementation-template.md +84 -0
- package/templates/plans/refactor-template.md +82 -0
- package/templates/plans/template-usage-guide.md +58 -0
|
@@ -0,0 +1,473 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: chrome-devtools
|
|
3
|
+
description: Browser automation, debugging, and performance analysis using Puppeteer CLI scripts. Use for automating browsers, taking screenshots, analyzing performance, monitoring network traffic, web scraping, form automation, and JavaScript debugging.
|
|
4
|
+
license: Apache-2.0
|
|
5
|
+
version: 1.1.0
|
|
6
|
+
---
|
|
7
|
+
|
|
8
|
+
# Chrome DevTools Agent Skill
|
|
9
|
+
|
|
10
|
+
Browser automation via Puppeteer scripts with persistent sessions. All scripts output JSON.
|
|
11
|
+
|
|
12
|
+
## Skill Location
|
|
13
|
+
|
|
14
|
+
Skills can exist in **project-scope** or **user-scope**. Priority: project-scope > user-scope.
|
|
15
|
+
|
|
16
|
+
```bash
|
|
17
|
+
# Detect skill location (no cd needed - scripts use __dirname for paths)
|
|
18
|
+
SKILL_DIR=""
|
|
19
|
+
if [ -d ".claude/skills/chrome-devtools/scripts" ]; then
|
|
20
|
+
SKILL_DIR=".claude/skills/chrome-devtools/scripts"
|
|
21
|
+
elif [ -d "$HOME/.claude/skills/chrome-devtools/scripts" ]; then
|
|
22
|
+
SKILL_DIR="$HOME/.claude/skills/chrome-devtools/scripts"
|
|
23
|
+
fi
|
|
24
|
+
# Run scripts with full path: node "$SKILL_DIR/script.js" --args
|
|
25
|
+
```
|
|
26
|
+
|
|
27
|
+
## Choosing Your Approach
|
|
28
|
+
|
|
29
|
+
| Scenario | Approach |
|
|
30
|
+
|----------|----------|
|
|
31
|
+
| **Source-available sites** | Read source code first, write selectors directly |
|
|
32
|
+
| **Unknown layouts** | Use `aria-snapshot.js` for semantic discovery |
|
|
33
|
+
| **Visual inspection** | Take screenshots to verify rendering |
|
|
34
|
+
| **Debug issues** | Collect console logs, analyze with session storage |
|
|
35
|
+
| **Accessibility audit** | Use ARIA snapshot for semantic structure analysis |
|
|
36
|
+
|
|
37
|
+
## Automation Browsing Running Mode
|
|
38
|
+
|
|
39
|
+
- Detect current OS and launch browser as headless only when running on Linux, WSL, or CI environments.
|
|
40
|
+
- For macOS, browser always runs in headed mode for better debugging.
|
|
41
|
+
- Run multiple scripts/sessions in parallel to simulate real user interactions.
|
|
42
|
+
- Run multiple scripts/sessions in parallel to simulate different device types (mobile, tablet, desktop).
|
|
43
|
+
- Skills can exist in **project-scope** or **user-scope**. Priority: project-scope > user-scope.
|
|
44
|
+
|
|
45
|
+
## ARIA Snapshot (Element Discovery)
|
|
46
|
+
|
|
47
|
+
When page structure is unknown, use `aria-snapshot.js` to get a YAML-formatted accessibility tree with semantic roles, accessible names, states, and stable element references.
|
|
48
|
+
|
|
49
|
+
### Get ARIA Snapshot
|
|
50
|
+
|
|
51
|
+
```bash
|
|
52
|
+
# Generate ARIA snapshot and output to stdout
|
|
53
|
+
node "$SKILL_DIR/aria-snapshot.js" --url https://example.com
|
|
54
|
+
|
|
55
|
+
# Save to file in snapshots directory
|
|
56
|
+
node "$SKILL_DIR/aria-snapshot.js" --url https://example.com --output ./.claude/chrome-devtools/snapshots/page.yaml
|
|
57
|
+
```
|
|
58
|
+
|
|
59
|
+
### Example YAML Output
|
|
60
|
+
|
|
61
|
+
```yaml
|
|
62
|
+
- banner:
|
|
63
|
+
- link "Hacker News" [ref=e1]
|
|
64
|
+
/url: https://news.ycombinator.com
|
|
65
|
+
- navigation:
|
|
66
|
+
- link "new" [ref=e2]
|
|
67
|
+
- link "past" [ref=e3]
|
|
68
|
+
- link "comments" [ref=e4]
|
|
69
|
+
- main:
|
|
70
|
+
- list:
|
|
71
|
+
- listitem:
|
|
72
|
+
- link "Show HN: My new project" [ref=e8]
|
|
73
|
+
- text: "128 points by user 3 hours ago"
|
|
74
|
+
- contentinfo:
|
|
75
|
+
- textbox [ref=e10]
|
|
76
|
+
/placeholder: "Search"
|
|
77
|
+
```
|
|
78
|
+
|
|
79
|
+
### Interpreting ARIA Notation
|
|
80
|
+
|
|
81
|
+
| Notation | Meaning |
|
|
82
|
+
|----------|---------|
|
|
83
|
+
| `[ref=eN]` | Stable identifier for interactive elements |
|
|
84
|
+
| `[checked]` | Checkbox/radio is selected |
|
|
85
|
+
| `[disabled]` | Element is inactive |
|
|
86
|
+
| `[expanded]` | Accordion/dropdown is open |
|
|
87
|
+
| `[level=N]` | Heading hierarchy (1-6) |
|
|
88
|
+
| `/url:` | Link destination |
|
|
89
|
+
| `/placeholder:` | Input placeholder text |
|
|
90
|
+
| `/value:` | Current input value |
|
|
91
|
+
|
|
92
|
+
### Interact by Ref
|
|
93
|
+
|
|
94
|
+
Skills can exist in **project-scope** or **user-scope**. Priority: project-scope > user-scope.
|
|
95
|
+
Use `select-ref.js` to interact with elements by their ref:
|
|
96
|
+
|
|
97
|
+
```bash
|
|
98
|
+
# Click element with ref e5
|
|
99
|
+
node "$SKILL_DIR/select-ref.js" --ref e5 --action click
|
|
100
|
+
|
|
101
|
+
# Fill input with ref e10
|
|
102
|
+
node "$SKILL_DIR/select-ref.js" --ref e10 --action fill --value "search query"
|
|
103
|
+
|
|
104
|
+
# Get text content
|
|
105
|
+
node "$SKILL_DIR/select-ref.js" --ref e8 --action text
|
|
106
|
+
|
|
107
|
+
# Screenshot specific element
|
|
108
|
+
node "$SKILL_DIR/select-ref.js" --ref e1 --action screenshot --output ./logo.png
|
|
109
|
+
|
|
110
|
+
# Focus element
|
|
111
|
+
node "$SKILL_DIR/select-ref.js" --ref e10 --action focus
|
|
112
|
+
|
|
113
|
+
# Hover over element
|
|
114
|
+
node "$SKILL_DIR/select-ref.js" --ref e5 --action hover
|
|
115
|
+
```
|
|
116
|
+
|
|
117
|
+
### Store Snapshots
|
|
118
|
+
|
|
119
|
+
Skills can exist in **project-scope** or **user-scope**. Priority: project-scope > user-scope.
|
|
120
|
+
Store snapshots for analysis in `<project>/.claude/chrome-devtools/snapshots/`:
|
|
121
|
+
|
|
122
|
+
```bash
|
|
123
|
+
# Create snapshots directory
|
|
124
|
+
mkdir -p .claude/chrome-devtools/snapshots
|
|
125
|
+
|
|
126
|
+
# Capture and store with timestamp
|
|
127
|
+
SESSION="$(date +%Y%m%d-%H%M%S)"
|
|
128
|
+
node "$SKILL_DIR/aria-snapshot.js" --url https://example.com --output .claude/chrome-devtools/snapshots/$SESSION.yaml
|
|
129
|
+
```
|
|
130
|
+
|
|
131
|
+
### Workflow: Unknown Page Structure
|
|
132
|
+
|
|
133
|
+
1. **Get snapshot** to discover elements:
|
|
134
|
+
```bash
|
|
135
|
+
node "$SKILL_DIR/aria-snapshot.js" --url https://example.com
|
|
136
|
+
```
|
|
137
|
+
|
|
138
|
+
2. **Identify target** from YAML output (e.g., `[ref=e5]` for a button)
|
|
139
|
+
|
|
140
|
+
3. **Interact by ref**:
|
|
141
|
+
```bash
|
|
142
|
+
node "$SKILL_DIR/select-ref.js" --ref e5 --action click
|
|
143
|
+
```
|
|
144
|
+
|
|
145
|
+
4. **Verify result** with screenshot or new snapshot:
|
|
146
|
+
```bash
|
|
147
|
+
node "$SKILL_DIR/screenshot.js" --output ./result.png
|
|
148
|
+
```
|
|
149
|
+
|
|
150
|
+
## Local HTML Files
|
|
151
|
+
|
|
152
|
+
Skills can exist in **project-scope** or **user-scope**. Priority: project-scope > user-scope.
|
|
153
|
+
**IMPORTANT**: Never browse local HTML files via `file://` protocol. Always serve via local server:
|
|
154
|
+
**Why**: `file://` protocol blocks many browser features (CORS, ES modules, fetch API, service workers). Local server ensures proper HTTP behavior.
|
|
155
|
+
|
|
156
|
+
```bash
|
|
157
|
+
# Option 1: npx serve (recommended)
|
|
158
|
+
npx serve ./dist -p 3000 &
|
|
159
|
+
node "$SKILL_DIR/navigate.js" --url http://localhost:3000
|
|
160
|
+
|
|
161
|
+
# Option 2: Python http.server
|
|
162
|
+
python -m http.server 3000 --directory ./dist &
|
|
163
|
+
node "$SKILL_DIR/navigate.js" --url http://localhost:3000
|
|
164
|
+
```
|
|
165
|
+
|
|
166
|
+
**Note**: when port 3000 is busy, find an available port with `lsof -i :3000` and use a different one.
|
|
167
|
+
|
|
168
|
+
## Quick Start
|
|
169
|
+
|
|
170
|
+
```bash
|
|
171
|
+
# Install dependencies (one-time setup)
|
|
172
|
+
npm install --prefix "$SKILL_DIR"
|
|
173
|
+
|
|
174
|
+
# Test (browser stays running for session reuse)
|
|
175
|
+
node "$SKILL_DIR/navigate.js" --url https://example.com
|
|
176
|
+
# Output: {"success": true, "url": "...", "title": "..."}
|
|
177
|
+
```
|
|
178
|
+
|
|
179
|
+
**Linux/WSL only**: Run `"$SKILL_DIR/install-deps.sh"` first for Chrome system libraries.
|
|
180
|
+
|
|
181
|
+
## Session Persistence
|
|
182
|
+
|
|
183
|
+
Browser state persists across script executions via WebSocket endpoint file (`.browser-session.json`).
|
|
184
|
+
|
|
185
|
+
**Default behavior**: Scripts disconnect but keep browser running for session reuse.
|
|
186
|
+
|
|
187
|
+
```bash
|
|
188
|
+
# First script: launches browser, navigates, disconnects (browser stays running)
|
|
189
|
+
node "$SKILL_DIR/navigate.js" --url https://example.com/login
|
|
190
|
+
|
|
191
|
+
# Subsequent scripts: connect to existing browser, reuse page state
|
|
192
|
+
node "$SKILL_DIR/fill.js" --selector "#email" --value "user@example.com"
|
|
193
|
+
node "$SKILL_DIR/fill.js" --selector "#password" --value "secret"
|
|
194
|
+
node "$SKILL_DIR/click.js" --selector "button[type=submit]"
|
|
195
|
+
|
|
196
|
+
# Close browser when done
|
|
197
|
+
node "$SKILL_DIR/navigate.js" --url about:blank --close true
|
|
198
|
+
```
|
|
199
|
+
|
|
200
|
+
**Session management**:
|
|
201
|
+
- `--close true`: Close browser and clear session
|
|
202
|
+
- Default (no flag): Keep browser running for next script
|
|
203
|
+
|
|
204
|
+
## Available Scripts
|
|
205
|
+
|
|
206
|
+
Skills can exist in **project-scope** or **user-scope**. Priority: project-scope > user-scope.
|
|
207
|
+
All in `.claude/skills/chrome-devtools/scripts/`:
|
|
208
|
+
|
|
209
|
+
| Script | Purpose |
|
|
210
|
+
|--------|---------|
|
|
211
|
+
| `navigate.js` | Navigate to URLs |
|
|
212
|
+
| `screenshot.js` | Capture screenshots (auto-compress >5MB via Sharp) |
|
|
213
|
+
| `click.js` | Click elements |
|
|
214
|
+
| `fill.js` | Fill form fields |
|
|
215
|
+
| `evaluate.js` | Execute JS in page context |
|
|
216
|
+
| `snapshot.js` | Extract interactive elements (JSON format) |
|
|
217
|
+
| `aria-snapshot.js` | Get ARIA accessibility tree (YAML format with refs) |
|
|
218
|
+
| `select-ref.js` | Interact with elements by ref from ARIA snapshot |
|
|
219
|
+
| `console.js` | Monitor console messages/errors |
|
|
220
|
+
| `network.js` | Track HTTP requests/responses |
|
|
221
|
+
| `performance.js` | Measure Core Web Vitals |
|
|
222
|
+
| `ws-debug.js` | Debug WebSocket connections (basic) |
|
|
223
|
+
| `ws-full-debug.js` | Debug WebSocket with full events/frames |
|
|
224
|
+
|
|
225
|
+
## Workflow Loop
|
|
226
|
+
|
|
227
|
+
1. **Execute** focused script for single task
|
|
228
|
+
2. **Observe** JSON output
|
|
229
|
+
3. **Assess** completion status
|
|
230
|
+
4. **Decide** next action
|
|
231
|
+
5. **Repeat** until done
|
|
232
|
+
|
|
233
|
+
## Writing Custom Test Scripts
|
|
234
|
+
|
|
235
|
+
Skills can exist in **project-scope** or **user-scope**. Priority: project-scope > user-scope.
|
|
236
|
+
For complex automation, write scripts to `<project>/.claude/chrome-devtools/tmp/`:
|
|
237
|
+
|
|
238
|
+
```bash
|
|
239
|
+
# Create tmp directory for test scripts
|
|
240
|
+
mkdir -p $SKILL_DIR/.claude/chrome-devtools/tmp
|
|
241
|
+
|
|
242
|
+
# Write a test script
|
|
243
|
+
cat > $SKILL_DIR/.claude/chrome-devtools/tmp/login-test.js << 'EOF'
|
|
244
|
+
import { getBrowser, getPage, disconnectBrowser, outputJSON } from '../scripts/lib/browser.js';
|
|
245
|
+
|
|
246
|
+
async function loginTest() {
|
|
247
|
+
const browser = await getBrowser();
|
|
248
|
+
const page = await getPage(browser);
|
|
249
|
+
|
|
250
|
+
await page.goto('https://example.com/login');
|
|
251
|
+
await page.type('#email', 'user@example.com');
|
|
252
|
+
await page.type('#password', 'secret');
|
|
253
|
+
await page.click('button[type=submit]');
|
|
254
|
+
await page.waitForNavigation();
|
|
255
|
+
|
|
256
|
+
outputJSON({
|
|
257
|
+
success: true,
|
|
258
|
+
url: page.url(),
|
|
259
|
+
title: await page.title()
|
|
260
|
+
});
|
|
261
|
+
|
|
262
|
+
await disconnectBrowser();
|
|
263
|
+
}
|
|
264
|
+
|
|
265
|
+
loginTest();
|
|
266
|
+
EOF
|
|
267
|
+
|
|
268
|
+
# Run the test
|
|
269
|
+
node $SKILL_DIR/.claude/chrome-devtools/tmp/login-test.js
|
|
270
|
+
```
|
|
271
|
+
|
|
272
|
+
**Key principles for custom scripts**:
|
|
273
|
+
- Single-purpose: one script, one task
|
|
274
|
+
- Always call `disconnectBrowser()` at the end (keeps browser running)
|
|
275
|
+
- Use `closeBrowser()` only when ending session completely
|
|
276
|
+
- Output JSON for easy parsing
|
|
277
|
+
- Plain JavaScript only in `page.evaluate()` callbacks
|
|
278
|
+
|
|
279
|
+
## Screenshots
|
|
280
|
+
|
|
281
|
+
Skills can exist in **project-scope** or **user-scope**. Priority: project-scope > user-scope.
|
|
282
|
+
Store screenshots for analysis in `<project>/.claude/chrome-devtools/screenshots/`:
|
|
283
|
+
|
|
284
|
+
```bash
|
|
285
|
+
# Basic screenshot
|
|
286
|
+
node "$SKILL_DIR/screenshot.js" --url https://example.com --output ./.claude/chrome-devtools/screenshots/page.png
|
|
287
|
+
|
|
288
|
+
# Full page
|
|
289
|
+
node "$SKILL_DIR/screenshot.js" --url https://example.com --output ./.claude/chrome-devtools/screenshots/page.png --full-page true
|
|
290
|
+
|
|
291
|
+
# Specific element
|
|
292
|
+
node "$SKILL_DIR/screenshot.js" --url https://example.com --selector ".main-content" --output ./.claude/chrome-devtools/screenshots/element.png
|
|
293
|
+
```
|
|
294
|
+
|
|
295
|
+
### Auto-Compression (Sharp)
|
|
296
|
+
|
|
297
|
+
Screenshots >5MB auto-compress using Sharp (4-5x faster than ImageMagick):
|
|
298
|
+
|
|
299
|
+
```bash
|
|
300
|
+
# Default: compress if >5MB
|
|
301
|
+
node "$SKILL_DIR/screenshot.js" --url https://example.com --output ./.claude/chrome-devtools/screenshots/page.png
|
|
302
|
+
|
|
303
|
+
# Custom threshold (3MB)
|
|
304
|
+
node "$SKILL_DIR/screenshot.js" --url https://example.com --output ./.claude/chrome-devtools/screenshots/page.png --max-size 3
|
|
305
|
+
|
|
306
|
+
# Disable compression
|
|
307
|
+
node "$SKILL_DIR/screenshot.js" --url https://example.com --output ./.claude/chrome-devtools/screenshots/page.png --no-compress
|
|
308
|
+
```
|
|
309
|
+
|
|
310
|
+
Store screenshots for analysis in `<project>/.claude/chrome-devtools/screenshots/`.
|
|
311
|
+
|
|
312
|
+
## Console Log Collection & Analysis
|
|
313
|
+
|
|
314
|
+
Skills can exist in **project-scope** or **user-scope**. Priority: project-scope > user-scope.
|
|
315
|
+
|
|
316
|
+
### Capture Logs
|
|
317
|
+
|
|
318
|
+
```bash
|
|
319
|
+
# Capture all logs for 10 seconds
|
|
320
|
+
node "$SKILL_DIR/console.js" --url https://example.com --duration 10000
|
|
321
|
+
|
|
322
|
+
# Filter by type
|
|
323
|
+
node "$SKILL_DIR/console.js" --url https://example.com --types error,warn --duration 5000
|
|
324
|
+
```
|
|
325
|
+
|
|
326
|
+
### Session Storage Pattern
|
|
327
|
+
|
|
328
|
+
Store logs for analysis in `<project>/.claude/chrome-devtools/logs/<session>/`:
|
|
329
|
+
|
|
330
|
+
```bash
|
|
331
|
+
# Create session directory
|
|
332
|
+
SESSION="$(date +%Y%m%d-%H%M%S)"
|
|
333
|
+
mkdir -p .claude/chrome-devtools/logs/$SESSION
|
|
334
|
+
|
|
335
|
+
# Capture and store
|
|
336
|
+
node "$SKILL_DIR/console.js" --url https://example.com --duration 10000 > .claude/chrome-devtools/logs/$SESSION/console.json
|
|
337
|
+
node "$SKILL_DIR/network.js" --url https://example.com > .claude/chrome-devtools/logs/$SESSION/network.json
|
|
338
|
+
|
|
339
|
+
# View errors
|
|
340
|
+
jq '.messages[] | select(.type=="error")' .claude/chrome-devtools/logs/$SESSION/console.json
|
|
341
|
+
```
|
|
342
|
+
|
|
343
|
+
### Root Cause Analysis
|
|
344
|
+
|
|
345
|
+
```bash
|
|
346
|
+
# 1. Check for JavaScript errors
|
|
347
|
+
node "$SKILL_DIR/console.js" --url https://example.com --types error,pageerror --duration 5000 | jq '.messages'
|
|
348
|
+
|
|
349
|
+
# 2. Correlate with network failures
|
|
350
|
+
node "$SKILL_DIR/network.js" --url https://example.com | jq '.requests[] | select(.response.status >= 400)'
|
|
351
|
+
|
|
352
|
+
# 3. Check specific error stack traces
|
|
353
|
+
node "$SKILL_DIR/console.js" --url https://example.com --types error --duration 5000 | jq '.messages[].stack'
|
|
354
|
+
```
|
|
355
|
+
|
|
356
|
+
## Finding Elements
|
|
357
|
+
|
|
358
|
+
Skills can exist in **project-scope** or **user-scope**. Priority: project-scope > user-scope.
|
|
359
|
+
Use `snapshot.js` to discover selectors before interacting:
|
|
360
|
+
|
|
361
|
+
```bash
|
|
362
|
+
# Get all interactive elements
|
|
363
|
+
node "$SKILL_DIR/snapshot.js" --url https://example.com | jq '.elements[] | {tagName, text, selector}'
|
|
364
|
+
|
|
365
|
+
# Find buttons
|
|
366
|
+
node "$SKILL_DIR/snapshot.js" --url https://example.com | jq '.elements[] | select(.tagName=="button")'
|
|
367
|
+
|
|
368
|
+
# Find by text content
|
|
369
|
+
node "$SKILL_DIR/snapshot.js" --url https://example.com | jq '.elements[] | select(.text | contains("Submit"))'
|
|
370
|
+
```
|
|
371
|
+
|
|
372
|
+
## Error Recovery
|
|
373
|
+
|
|
374
|
+
Skills can exist in **project-scope** or **user-scope**. Priority: project-scope > user-scope.
|
|
375
|
+
If script fails:
|
|
376
|
+
|
|
377
|
+
```bash
|
|
378
|
+
# 1. Capture current state (without navigating to preserve state)
|
|
379
|
+
node "$SKILL_DIR/screenshot.js" --output ./.claude/skills/chrome-devtools/screenshots/debug.png
|
|
380
|
+
|
|
381
|
+
# 2. Get console errors
|
|
382
|
+
node "$SKILL_DIR/console.js" --url about:blank --types error --duration 1000
|
|
383
|
+
|
|
384
|
+
# 3. Discover correct selector
|
|
385
|
+
node "$SKILL_DIR/snapshot.js" | jq '.elements[] | select(.text | contains("Submit"))'
|
|
386
|
+
|
|
387
|
+
# 4. Try XPath if CSS fails
|
|
388
|
+
node "$SKILL_DIR/click.js" --selector "//button[contains(text(),'Submit')]"
|
|
389
|
+
```
|
|
390
|
+
|
|
391
|
+
## Common Patterns
|
|
392
|
+
|
|
393
|
+
### Web Scraping
|
|
394
|
+
```bash
|
|
395
|
+
node "$SKILL_DIR/evaluate.js" --url https://example.com --script "
|
|
396
|
+
Array.from(document.querySelectorAll('.item')).map(el => ({
|
|
397
|
+
title: el.querySelector('h2')?.textContent,
|
|
398
|
+
link: el.querySelector('a')?.href
|
|
399
|
+
}))
|
|
400
|
+
" | jq '.result'
|
|
401
|
+
```
|
|
402
|
+
|
|
403
|
+
### Form Automation
|
|
404
|
+
```bash
|
|
405
|
+
node "$SKILL_DIR/navigate.js" --url https://example.com/form
|
|
406
|
+
node "$SKILL_DIR/fill.js" --selector "#search" --value "query"
|
|
407
|
+
node "$SKILL_DIR/click.js" --selector "button[type=submit]"
|
|
408
|
+
```
|
|
409
|
+
|
|
410
|
+
### Performance Testing
|
|
411
|
+
```bash
|
|
412
|
+
node "$SKILL_DIR/performance.js" --url https://example.com | jq '.vitals'
|
|
413
|
+
```
|
|
414
|
+
|
|
415
|
+
## Script Options
|
|
416
|
+
|
|
417
|
+
All scripts support:
|
|
418
|
+
- `--headless false` - Show browser window
|
|
419
|
+
- `--close true` - Close browser completely (default: stay running)
|
|
420
|
+
- `--timeout 30000` - Set timeout (ms)
|
|
421
|
+
- `--wait-until networkidle2` - Wait strategy
|
|
422
|
+
Skills can exist in **project-scope** or **user-scope**. Priority: project-scope > user-scope.
|
|
423
|
+
|
|
424
|
+
## Troubleshooting
|
|
425
|
+
Skills can exist in **project-scope** or **user-scope**. Priority: project-scope > user-scope.
|
|
426
|
+
|
|
427
|
+
| Error | Solution |
|
|
428
|
+
|-------|----------|
|
|
429
|
+
| `Cannot find package 'puppeteer'` | Run `npm install` in scripts directory |
|
|
430
|
+
| `libnss3.so` missing (Linux) | Run `./install-deps.sh` |
|
|
431
|
+
| Element not found | Use `snapshot.js` to find correct selector |
|
|
432
|
+
| Script hangs | Use `--timeout 60000` or `--wait-until load` |
|
|
433
|
+
| Screenshot >5MB | Auto-compressed; use `--max-size 3` for lower |
|
|
434
|
+
| Session stale | Delete `.browser-session.json` and retry |
|
|
435
|
+
|
|
436
|
+
### Screenshot Analysis: Missing Images
|
|
437
|
+
|
|
438
|
+
If images don't appear in screenshots, they may be waiting for animation triggers:
|
|
439
|
+
|
|
440
|
+
1. **Scroll-triggered animations**: Scroll element into view first
|
|
441
|
+
```bash
|
|
442
|
+
node "$SKILL_DIR/evaluate.js" --script "document.querySelector('.lazy-image').scrollIntoView()"
|
|
443
|
+
# Wait for animation
|
|
444
|
+
node "$SKILL_DIR/evaluate.js" --script "await new Promise(r => setTimeout(r, 1000))"
|
|
445
|
+
node "$SKILL_DIR/screenshot.js" --output ./result.png
|
|
446
|
+
```
|
|
447
|
+
|
|
448
|
+
2. **Sequential animation queue**: Wait longer and retry
|
|
449
|
+
```bash
|
|
450
|
+
# First attempt
|
|
451
|
+
node "$SKILL_DIR/screenshot.js" --url http://localhost:3000 --output ./attempt1.png
|
|
452
|
+
|
|
453
|
+
# Wait for animations to complete
|
|
454
|
+
node "$SKILL_DIR/evaluate.js" --script "await new Promise(r => setTimeout(r, 2000))"
|
|
455
|
+
|
|
456
|
+
# Retry screenshot
|
|
457
|
+
node "$SKILL_DIR/screenshot.js" --output ./attempt2.png
|
|
458
|
+
```
|
|
459
|
+
|
|
460
|
+
3. **Intersection Observer animations**: Trigger by scrolling through page
|
|
461
|
+
```bash
|
|
462
|
+
node "$SKILL_DIR/evaluate.js" --script "window.scrollTo(0, document.body.scrollHeight)"
|
|
463
|
+
node "$SKILL_DIR/evaluate.js" --script "await new Promise(r => setTimeout(r, 1500))"
|
|
464
|
+
node "$SKILL_DIR/evaluate.js" --script "window.scrollTo(0, 0)"
|
|
465
|
+
node "$SKILL_DIR/screenshot.js" --output ./full-loaded.png --full-page true
|
|
466
|
+
```
|
|
467
|
+
|
|
468
|
+
## Reference Documentation
|
|
469
|
+
|
|
470
|
+
- `./references/cdp-domains.md` - Chrome DevTools Protocol domains
|
|
471
|
+
- `./references/puppeteer-reference.md` - Puppeteer API patterns
|
|
472
|
+
- `./references/performance-guide.md` - Core Web Vitals optimization
|
|
473
|
+
- `./scripts/README.md` - Detailed script options
|