@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.
Files changed (415) hide show
  1. package/License +21 -0
  2. package/README.md +142 -0
  3. package/bin/index.js +5 -0
  4. package/dist/index.js +1 -0
  5. package/package.json +65 -0
  6. package/templates/claude/agents/brainstormer.md +113 -0
  7. package/templates/claude/agents/code-reviewer.md +157 -0
  8. package/templates/claude/agents/copywriter.md +110 -0
  9. package/templates/claude/agents/database-admin.md +92 -0
  10. package/templates/claude/agents/debugger.md +137 -0
  11. package/templates/claude/agents/docs-manager.md +208 -0
  12. package/templates/claude/agents/fullstack-developer.md +95 -0
  13. package/templates/claude/agents/git-manager.md +394 -0
  14. package/templates/claude/agents/journal-writer.md +113 -0
  15. package/templates/claude/agents/mcp-manager.md +89 -0
  16. package/templates/claude/agents/planner.md +108 -0
  17. package/templates/claude/agents/project-manager.md +125 -0
  18. package/templates/claude/agents/registry.json +304 -0
  19. package/templates/claude/agents/researcher.md +37 -0
  20. package/templates/claude/agents/scout-external.md +140 -0
  21. package/templates/claude/agents/scout.md +106 -0
  22. package/templates/claude/agents/tester.md +105 -0
  23. package/templates/claude/agents/ui-ux-designer.md +208 -0
  24. package/templates/claude/commands/ask.md +56 -0
  25. package/templates/claude/commands/bootstrap/auto/fast.md +106 -0
  26. package/templates/claude/commands/bootstrap/auto/parallel.md +64 -0
  27. package/templates/claude/commands/bootstrap/auto.md +110 -0
  28. package/templates/claude/commands/bootstrap.md +130 -0
  29. package/templates/claude/commands/brainstorm.md +75 -0
  30. package/templates/claude/commands/code/auto.md +198 -0
  31. package/templates/claude/commands/code/no-test.md +172 -0
  32. package/templates/claude/commands/code/parallel.md +100 -0
  33. package/templates/claude/commands/code.md +197 -0
  34. package/templates/claude/commands/coding-level.md +37 -0
  35. package/templates/claude/commands/content/cro.md +41 -0
  36. package/templates/claude/commands/content/enhance.md +12 -0
  37. package/templates/claude/commands/content/fast.md +11 -0
  38. package/templates/claude/commands/content/good.md +14 -0
  39. package/templates/claude/commands/cook/auto/fast.md +26 -0
  40. package/templates/claude/commands/cook/auto/parallel.md +49 -0
  41. package/templates/claude/commands/cook/auto.md +15 -0
  42. package/templates/claude/commands/cook.md +101 -0
  43. package/templates/claude/commands/debug.md +13 -0
  44. package/templates/claude/commands/docs/init.md +37 -0
  45. package/templates/claude/commands/docs/summarize.md +22 -0
  46. package/templates/claude/commands/docs/update.md +78 -0
  47. package/templates/claude/commands/fix/ci.md +17 -0
  48. package/templates/claude/commands/fix/fast.md +18 -0
  49. package/templates/claude/commands/fix/hard.md +35 -0
  50. package/templates/claude/commands/fix/logs.md +26 -0
  51. package/templates/claude/commands/fix/parallel.md +54 -0
  52. package/templates/claude/commands/fix/test.md +20 -0
  53. package/templates/claude/commands/fix/types.md +9 -0
  54. package/templates/claude/commands/fix/ui.md +33 -0
  55. package/templates/claude/commands/fix.md +43 -0
  56. package/templates/claude/commands/git/cm.md +5 -0
  57. package/templates/claude/commands/git/cp.md +4 -0
  58. package/templates/claude/commands/git/merge.md +40 -0
  59. package/templates/claude/commands/git/pr.md +50 -0
  60. package/templates/claude/commands/journal.md +7 -0
  61. package/templates/claude/commands/kanban.md +99 -0
  62. package/templates/claude/commands/plan/archive.md +57 -0
  63. package/templates/claude/commands/plan/ci.md +33 -0
  64. package/templates/claude/commands/plan/cro.md +67 -0
  65. package/templates/claude/commands/plan/fast.md +66 -0
  66. package/templates/claude/commands/plan/hard.md +92 -0
  67. package/templates/claude/commands/plan/parallel.md +129 -0
  68. package/templates/claude/commands/plan/two.md +45 -0
  69. package/templates/claude/commands/plan/validate.md +117 -0
  70. package/templates/claude/commands/plan.md +30 -0
  71. package/templates/claude/commands/preview.md +87 -0
  72. package/templates/claude/commands/registry.json +313 -0
  73. package/templates/claude/commands/review/codebase/parallel.md +122 -0
  74. package/templates/claude/commands/review/codebase.md +47 -0
  75. package/templates/claude/commands/scout/ext.md +35 -0
  76. package/templates/claude/commands/scout.md +28 -0
  77. package/templates/claude/commands/skill/add.md +36 -0
  78. package/templates/claude/commands/skill/create.md +29 -0
  79. package/templates/claude/commands/skill/fix-logs.md +22 -0
  80. package/templates/claude/commands/skill/optimize/auto.md +25 -0
  81. package/templates/claude/commands/skill/optimize.md +34 -0
  82. package/templates/claude/commands/skill/plan.md +45 -0
  83. package/templates/claude/commands/test/ui.md +91 -0
  84. package/templates/claude/commands/test.md +8 -0
  85. package/templates/claude/commands/use-mcp.md +34 -0
  86. package/templates/claude/commands/watzup.md +8 -0
  87. package/templates/claude/commands/worktree.md +126 -0
  88. package/templates/claude/hooks/dev-rules-reminder.cjs +258 -0
  89. package/templates/claude/hooks/docs/README.md +42 -0
  90. package/templates/claude/hooks/lib/cctk-config-utils.cjs +751 -0
  91. package/templates/claude/hooks/lib/cctk-paths.cjs +106 -0
  92. package/templates/claude/hooks/lib/context-tracker.cjs +346 -0
  93. package/templates/claude/hooks/privacy-block.cjs +289 -0
  94. package/templates/claude/hooks/registry.json +77 -0
  95. package/templates/claude/hooks/scout-block/broad-pattern-detector.cjs +293 -0
  96. package/templates/claude/hooks/scout-block/error-formatter.cjs +156 -0
  97. package/templates/claude/hooks/scout-block/path-extractor.cjs +359 -0
  98. package/templates/claude/hooks/scout-block/pattern-matcher.cjs +184 -0
  99. package/templates/claude/hooks/scout-block/vendor/ignore.js +626 -0
  100. package/templates/claude/hooks/scout-block.cjs +167 -0
  101. package/templates/claude/hooks/session-end.cjs +35 -0
  102. package/templates/claude/hooks/session-init.cjs +214 -0
  103. package/templates/claude/hooks/subagent-init.cjs +161 -0
  104. package/templates/claude/hooks/write-compact-marker.cjs +153 -0
  105. package/templates/claude/output-styles/coding-level-1.md +148 -0
  106. package/templates/claude/output-styles/coding-level-2.md +159 -0
  107. package/templates/claude/output-styles/coding-level-3.md +91 -0
  108. package/templates/claude/scripts/README.md +33 -0
  109. package/templates/claude/scripts/generate-catalogs.cjs +318 -0
  110. package/templates/claude/scripts/registry.json +48 -0
  111. package/templates/claude/scripts/set-active-plan.cjs +45 -0
  112. package/templates/claude/scripts/validate-docs.cjs +447 -0
  113. package/templates/claude/scripts/worktree.cjs +658 -0
  114. package/templates/claude/skills/README.md +112 -0
  115. package/templates/claude/skills/ai-artist/SKILL.md +75 -0
  116. package/templates/claude/skills/ai-artist/references/advanced-techniques.md +184 -0
  117. package/templates/claude/skills/ai-artist/references/domain-code.md +66 -0
  118. package/templates/claude/skills/ai-artist/references/domain-data.md +72 -0
  119. package/templates/claude/skills/ai-artist/references/domain-marketing.md +66 -0
  120. package/templates/claude/skills/ai-artist/references/domain-patterns.md +33 -0
  121. package/templates/claude/skills/ai-artist/references/domain-writing.md +68 -0
  122. package/templates/claude/skills/ai-artist/references/image-prompting.md +141 -0
  123. package/templates/claude/skills/ai-artist/references/llm-prompting.md +165 -0
  124. package/templates/claude/skills/ai-artist/references/nano-banana.md +59 -0
  125. package/templates/claude/skills/ai-artist/references/reasoning-techniques.md +201 -0
  126. package/templates/claude/skills/backend-development/SKILL.md +95 -0
  127. package/templates/claude/skills/backend-development/references/backend-api-design.md +495 -0
  128. package/templates/claude/skills/backend-development/references/backend-architecture.md +454 -0
  129. package/templates/claude/skills/backend-development/references/backend-authentication.md +338 -0
  130. package/templates/claude/skills/backend-development/references/backend-code-quality.md +659 -0
  131. package/templates/claude/skills/backend-development/references/backend-debugging.md +904 -0
  132. package/templates/claude/skills/backend-development/references/backend-devops.md +494 -0
  133. package/templates/claude/skills/backend-development/references/backend-mindset.md +387 -0
  134. package/templates/claude/skills/backend-development/references/backend-performance.md +397 -0
  135. package/templates/claude/skills/backend-development/references/backend-security.md +290 -0
  136. package/templates/claude/skills/backend-development/references/backend-technologies.md +256 -0
  137. package/templates/claude/skills/backend-development/references/backend-testing.md +429 -0
  138. package/templates/claude/skills/better-auth/SKILL.md +204 -0
  139. package/templates/claude/skills/better-auth/references/advanced-features.md +553 -0
  140. package/templates/claude/skills/better-auth/references/database-integration.md +577 -0
  141. package/templates/claude/skills/better-auth/references/email-password-auth.md +416 -0
  142. package/templates/claude/skills/better-auth/references/oauth-providers.md +430 -0
  143. package/templates/claude/skills/better-auth/scripts/better_auth_init.py +521 -0
  144. package/templates/claude/skills/chrome-devtools/SKILL.md +473 -0
  145. package/templates/claude/skills/chrome-devtools/references/cdp-domains.md +694 -0
  146. package/templates/claude/skills/chrome-devtools/references/performance-guide.md +940 -0
  147. package/templates/claude/skills/chrome-devtools/references/puppeteer-reference.md +953 -0
  148. package/templates/claude/skills/chrome-devtools/scripts/README.md +288 -0
  149. package/templates/claude/skills/chrome-devtools/scripts/aria-snapshot.js +368 -0
  150. package/templates/claude/skills/chrome-devtools/scripts/click.js +92 -0
  151. package/templates/claude/skills/chrome-devtools/scripts/console.js +85 -0
  152. package/templates/claude/skills/chrome-devtools/scripts/evaluate.js +59 -0
  153. package/templates/claude/skills/chrome-devtools/scripts/fill.js +84 -0
  154. package/templates/claude/skills/chrome-devtools/scripts/inject-auth.js +247 -0
  155. package/templates/claude/skills/chrome-devtools/scripts/install-deps.sh +11 -0
  156. package/templates/claude/skills/chrome-devtools/scripts/install.sh +36 -0
  157. package/templates/claude/skills/chrome-devtools/scripts/lib/browser.js +335 -0
  158. package/templates/claude/skills/chrome-devtools/scripts/lib/selector.js +183 -0
  159. package/templates/claude/skills/chrome-devtools/scripts/navigate.js +60 -0
  160. package/templates/claude/skills/chrome-devtools/scripts/network.js +113 -0
  161. package/templates/claude/skills/chrome-devtools/scripts/package.json +16 -0
  162. package/templates/claude/skills/chrome-devtools/scripts/performance.js +159 -0
  163. package/templates/claude/skills/chrome-devtools/scripts/screenshot.js +212 -0
  164. package/templates/claude/skills/chrome-devtools/scripts/select-ref.js +151 -0
  165. package/templates/claude/skills/chrome-devtools/scripts/snapshot.js +143 -0
  166. package/templates/claude/skills/chrome-devtools/scripts/ws-debug.js +47 -0
  167. package/templates/claude/skills/chrome-devtools/scripts/ws-full-debug.js +115 -0
  168. package/templates/claude/skills/claude-code/references/advanced-features.md +399 -0
  169. package/templates/claude/skills/claude-code/references/agent-skills.md +399 -0
  170. package/templates/claude/skills/claude-code/references/api-reference.md +498 -0
  171. package/templates/claude/skills/claude-code/references/best-practices.md +447 -0
  172. package/templates/claude/skills/claude-code/references/cicd-integration.md +428 -0
  173. package/templates/claude/skills/claude-code/references/common-workflows.md +107 -0
  174. package/templates/claude/skills/claude-code/references/configuration.md +480 -0
  175. package/templates/claude/skills/claude-code/references/enterprise-features.md +472 -0
  176. package/templates/claude/skills/claude-code/references/getting-started.md +244 -0
  177. package/templates/claude/skills/claude-code/references/hooks-and-plugins.md +444 -0
  178. package/templates/claude/skills/claude-code/references/hooks-comprehensive.md +622 -0
  179. package/templates/claude/skills/claude-code/references/ide-integration.md +316 -0
  180. package/templates/claude/skills/claude-code/references/mcp-integration.md +386 -0
  181. package/templates/claude/skills/claude-code/references/slash-commands.md +460 -0
  182. package/templates/claude/skills/claude-code/references/troubleshooting.md +455 -0
  183. package/templates/claude/skills/claude-code/skill.md +60 -0
  184. package/templates/claude/skills/code-review/SKILL.md +143 -0
  185. package/templates/claude/skills/code-review/references/code-review-reception.md +209 -0
  186. package/templates/claude/skills/code-review/references/requesting-code-review.md +105 -0
  187. package/templates/claude/skills/code-review/references/verification-before-completion.md +139 -0
  188. package/templates/claude/skills/context-engineering/SKILL.md +86 -0
  189. package/templates/claude/skills/context-engineering/references/context-compression.md +84 -0
  190. package/templates/claude/skills/context-engineering/references/context-degradation.md +93 -0
  191. package/templates/claude/skills/context-engineering/references/context-fundamentals.md +75 -0
  192. package/templates/claude/skills/context-engineering/references/context-optimization.md +82 -0
  193. package/templates/claude/skills/context-engineering/references/evaluation.md +89 -0
  194. package/templates/claude/skills/context-engineering/references/memory-systems.md +88 -0
  195. package/templates/claude/skills/context-engineering/references/multi-agent-patterns.md +90 -0
  196. package/templates/claude/skills/context-engineering/references/project-development.md +97 -0
  197. package/templates/claude/skills/context-engineering/references/tool-design.md +86 -0
  198. package/templates/claude/skills/context-engineering/scripts/compression_evaluator.py +329 -0
  199. package/templates/claude/skills/context-engineering/scripts/context_analyzer.py +294 -0
  200. package/templates/claude/skills/databases/SKILL.md +232 -0
  201. package/templates/claude/skills/databases/references/mongodb-aggregation.md +447 -0
  202. package/templates/claude/skills/databases/references/mongodb-atlas.md +465 -0
  203. package/templates/claude/skills/databases/references/mongodb-crud.md +408 -0
  204. package/templates/claude/skills/databases/references/mongodb-indexing.md +442 -0
  205. package/templates/claude/skills/databases/references/postgresql-administration.md +594 -0
  206. package/templates/claude/skills/databases/references/postgresql-performance.md +527 -0
  207. package/templates/claude/skills/databases/references/postgresql-psql-cli.md +467 -0
  208. package/templates/claude/skills/databases/references/postgresql-queries.md +475 -0
  209. package/templates/claude/skills/databases/scripts/db_backup.py +502 -0
  210. package/templates/claude/skills/databases/scripts/db_migrate.py +414 -0
  211. package/templates/claude/skills/databases/scripts/db_performance_check.py +445 -0
  212. package/templates/claude/skills/debugging/SKILL.md +84 -0
  213. package/templates/claude/skills/debugging/references/defense-in-depth.md +124 -0
  214. package/templates/claude/skills/debugging/references/root-cause-tracing.md +122 -0
  215. package/templates/claude/skills/debugging/references/systematic-debugging.md +102 -0
  216. package/templates/claude/skills/debugging/references/verification.md +123 -0
  217. package/templates/claude/skills/debugging/scripts/find-polluter.sh +63 -0
  218. package/templates/claude/skills/debugging/scripts/find-polluter.test.md +102 -0
  219. package/templates/claude/skills/devops/SKILL.md +293 -0
  220. package/templates/claude/skills/devops/references/browser-rendering.md +305 -0
  221. package/templates/claude/skills/devops/references/cloudflare-d1-kv.md +123 -0
  222. package/templates/claude/skills/devops/references/cloudflare-platform.md +271 -0
  223. package/templates/claude/skills/devops/references/cloudflare-r2-storage.md +280 -0
  224. package/templates/claude/skills/devops/references/cloudflare-workers-advanced.md +312 -0
  225. package/templates/claude/skills/devops/references/cloudflare-workers-apis.md +309 -0
  226. package/templates/claude/skills/devops/references/cloudflare-workers-basics.md +418 -0
  227. package/templates/claude/skills/devops/references/docker-basics.md +297 -0
  228. package/templates/claude/skills/devops/references/docker-compose.md +292 -0
  229. package/templates/claude/skills/devops/references/gcloud-platform.md +307 -0
  230. package/templates/claude/skills/devops/references/gcloud-services.md +304 -0
  231. package/templates/claude/skills/devops/scripts/cloudflare_deploy.py +269 -0
  232. package/templates/claude/skills/devops/scripts/docker_optimize.py +320 -0
  233. package/templates/claude/skills/docs-seeker/SKILL.md +95 -0
  234. package/templates/claude/skills/docs-seeker/package.json +24 -0
  235. package/templates/claude/skills/docs-seeker/references/advanced.md +78 -0
  236. package/templates/claude/skills/docs-seeker/references/context7-patterns.md +68 -0
  237. package/templates/claude/skills/docs-seeker/references/errors.md +68 -0
  238. package/templates/claude/skills/docs-seeker/scripts/analyze-llms-txt.js +245 -0
  239. package/templates/claude/skills/docs-seeker/scripts/detect-topic.js +172 -0
  240. package/templates/claude/skills/docs-seeker/scripts/fetch-docs.js +212 -0
  241. package/templates/claude/skills/docs-seeker/workflows/library-search.md +87 -0
  242. package/templates/claude/skills/docs-seeker/workflows/repo-analysis.md +91 -0
  243. package/templates/claude/skills/docs-seeker/workflows/topic-search.md +77 -0
  244. package/templates/claude/skills/frontend-design/SKILL.md +85 -0
  245. package/templates/claude/skills/frontend-design/references/analysis-best-practices.md +80 -0
  246. package/templates/claude/skills/frontend-design/references/analysis-prompts.md +141 -0
  247. package/templates/claude/skills/frontend-design/references/analysis-techniques.md +118 -0
  248. package/templates/claude/skills/frontend-design/references/animejs.md +396 -0
  249. package/templates/claude/skills/frontend-design/references/design-extraction-overview.md +71 -0
  250. package/templates/claude/skills/frontend-design/references/extraction-best-practices.md +141 -0
  251. package/templates/claude/skills/frontend-design/references/extraction-output-templates.md +162 -0
  252. package/templates/claude/skills/frontend-design/references/extraction-prompts.md +127 -0
  253. package/templates/claude/skills/frontend-design/references/technical-accessibility.md +119 -0
  254. package/templates/claude/skills/frontend-design/references/technical-best-practices.md +97 -0
  255. package/templates/claude/skills/frontend-design/references/technical-optimization.md +44 -0
  256. package/templates/claude/skills/frontend-design/references/technical-overview.md +90 -0
  257. package/templates/claude/skills/frontend-design/references/technical-workflows.md +150 -0
  258. package/templates/claude/skills/frontend-design/references/visual-analysis-overview.md +95 -0
  259. package/templates/claude/skills/frontend-development/SKILL.md +399 -0
  260. package/templates/claude/skills/frontend-development/resources/common-patterns.md +331 -0
  261. package/templates/claude/skills/frontend-development/resources/complete-examples.md +872 -0
  262. package/templates/claude/skills/frontend-development/resources/component-patterns.md +502 -0
  263. package/templates/claude/skills/frontend-development/resources/data-fetching.md +767 -0
  264. package/templates/claude/skills/frontend-development/resources/file-organization.md +502 -0
  265. package/templates/claude/skills/frontend-development/resources/loading-and-error-states.md +501 -0
  266. package/templates/claude/skills/frontend-development/resources/performance.md +406 -0
  267. package/templates/claude/skills/frontend-development/resources/routing-guide.md +364 -0
  268. package/templates/claude/skills/frontend-development/resources/styling-guide.md +428 -0
  269. package/templates/claude/skills/frontend-development/resources/typescript-standards.md +418 -0
  270. package/templates/claude/skills/markdown-novel-viewer/SKILL.md +272 -0
  271. package/templates/claude/skills/markdown-novel-viewer/assets/directory-browser.css +215 -0
  272. package/templates/claude/skills/markdown-novel-viewer/assets/favicon.png +0 -0
  273. package/templates/claude/skills/markdown-novel-viewer/assets/novel-theme.css +872 -0
  274. package/templates/claude/skills/markdown-novel-viewer/assets/reader.js +378 -0
  275. package/templates/claude/skills/markdown-novel-viewer/assets/template.html +85 -0
  276. package/templates/claude/skills/markdown-novel-viewer/package.json +15 -0
  277. package/templates/claude/skills/markdown-novel-viewer/scripts/lib/http-server.cjs +434 -0
  278. package/templates/claude/skills/markdown-novel-viewer/scripts/lib/markdown-renderer.cjs +335 -0
  279. package/templates/claude/skills/markdown-novel-viewer/scripts/lib/plan-navigator.cjs +509 -0
  280. package/templates/claude/skills/markdown-novel-viewer/scripts/lib/port-finder.cjs +49 -0
  281. package/templates/claude/skills/markdown-novel-viewer/scripts/lib/process-mgr.cjs +150 -0
  282. package/templates/claude/skills/markdown-novel-viewer/scripts/server.cjs +398 -0
  283. package/templates/claude/skills/mcp-builder/SKILL.md +328 -0
  284. package/templates/claude/skills/mcp-builder/reference/evaluation.md +602 -0
  285. package/templates/claude/skills/mcp-builder/reference/mcp_best_practices.md +915 -0
  286. package/templates/claude/skills/mcp-builder/reference/node_mcp_server.md +916 -0
  287. package/templates/claude/skills/mcp-builder/reference/python_mcp_server.md +752 -0
  288. package/templates/claude/skills/mcp-builder/scripts/connections.py +151 -0
  289. package/templates/claude/skills/mcp-builder/scripts/evaluation.py +381 -0
  290. package/templates/claude/skills/mcp-builder/scripts/example_evaluation.xml +22 -0
  291. package/templates/claude/skills/mcp-builder/scripts/requirements.txt +2 -0
  292. package/templates/claude/skills/mcp-management/README.md +219 -0
  293. package/templates/claude/skills/mcp-management/SKILL.md +209 -0
  294. package/templates/claude/skills/mcp-management/assets/tools.json +3146 -0
  295. package/templates/claude/skills/mcp-management/references/configuration.md +114 -0
  296. package/templates/claude/skills/mcp-management/references/gemini-cli-integration.md +209 -0
  297. package/templates/claude/skills/mcp-management/references/mcp-protocol.md +116 -0
  298. package/templates/claude/skills/mcp-management/scripts/.env.example +10 -0
  299. package/templates/claude/skills/mcp-management/scripts/cli.ts +202 -0
  300. package/templates/claude/skills/mcp-management/scripts/mcp-client.ts +247 -0
  301. package/templates/claude/skills/mcp-management/scripts/package.json +20 -0
  302. package/templates/claude/skills/mcp-management/scripts/tsconfig.json +15 -0
  303. package/templates/claude/skills/media-processing/SKILL.md +91 -0
  304. package/templates/claude/skills/media-processing/references/common-workflows.md +132 -0
  305. package/templates/claude/skills/media-processing/references/ffmpeg-encoding.md +358 -0
  306. package/templates/claude/skills/media-processing/references/ffmpeg-filters.md +503 -0
  307. package/templates/claude/skills/media-processing/references/ffmpeg-streaming.md +395 -0
  308. package/templates/claude/skills/media-processing/references/format-compatibility.md +375 -0
  309. package/templates/claude/skills/media-processing/references/imagemagick-batch.md +612 -0
  310. package/templates/claude/skills/media-processing/references/imagemagick-editing.md +623 -0
  311. package/templates/claude/skills/media-processing/references/rmbg-background-removal.md +66 -0
  312. package/templates/claude/skills/media-processing/references/troubleshooting.md +109 -0
  313. package/templates/claude/skills/media-processing/scripts/README.md +102 -0
  314. package/templates/claude/skills/media-processing/scripts/batch-remove-background.sh +124 -0
  315. package/templates/claude/skills/media-processing/scripts/batch_resize.py +342 -0
  316. package/templates/claude/skills/media-processing/scripts/media_convert.py +311 -0
  317. package/templates/claude/skills/media-processing/scripts/remove-background.sh +96 -0
  318. package/templates/claude/skills/media-processing/scripts/remove-bg-node.js +181 -0
  319. package/templates/claude/skills/mermaidjs-v11/SKILL.md +115 -0
  320. package/templates/claude/skills/mermaidjs-v11/references/cli-usage.md +228 -0
  321. package/templates/claude/skills/mermaidjs-v11/references/configuration.md +232 -0
  322. package/templates/claude/skills/mermaidjs-v11/references/diagram-types.md +315 -0
  323. package/templates/claude/skills/mermaidjs-v11/references/examples.md +344 -0
  324. package/templates/claude/skills/mermaidjs-v11/references/integration.md +310 -0
  325. package/templates/claude/skills/planning/SKILL.md +115 -0
  326. package/templates/claude/skills/planning/references/codebase-understanding.md +62 -0
  327. package/templates/claude/skills/planning/references/output-standards.md +127 -0
  328. package/templates/claude/skills/planning/references/plan-organization.md +150 -0
  329. package/templates/claude/skills/planning/references/research-phase.md +49 -0
  330. package/templates/claude/skills/planning/references/solution-design.md +63 -0
  331. package/templates/claude/skills/plans-kanban/SKILL.md +157 -0
  332. package/templates/claude/skills/plans-kanban/assets/dashboard-template.html +119 -0
  333. package/templates/claude/skills/plans-kanban/assets/dashboard.css +1594 -0
  334. package/templates/claude/skills/plans-kanban/assets/dashboard.js +659 -0
  335. package/templates/claude/skills/plans-kanban/assets/favicon.png +0 -0
  336. package/templates/claude/skills/plans-kanban/package.json +13 -0
  337. package/templates/claude/skills/plans-kanban/scripts/lib/dashboard-renderer.cjs +941 -0
  338. package/templates/claude/skills/plans-kanban/scripts/lib/http-server.cjs +310 -0
  339. package/templates/claude/skills/plans-kanban/scripts/lib/plan-metadata-extractor.cjs +489 -0
  340. package/templates/claude/skills/plans-kanban/scripts/lib/plan-parser.cjs +194 -0
  341. package/templates/claude/skills/plans-kanban/scripts/lib/plan-scanner.cjs +277 -0
  342. package/templates/claude/skills/plans-kanban/scripts/lib/port-finder.cjs +49 -0
  343. package/templates/claude/skills/plans-kanban/scripts/lib/process-mgr.cjs +128 -0
  344. package/templates/claude/skills/plans-kanban/scripts/server.cjs +249 -0
  345. package/templates/claude/skills/problem-solving/SKILL.md +96 -0
  346. package/templates/claude/skills/problem-solving/references/attribution.md +69 -0
  347. package/templates/claude/skills/problem-solving/references/collision-zone-thinking.md +79 -0
  348. package/templates/claude/skills/problem-solving/references/inversion-exercise.md +91 -0
  349. package/templates/claude/skills/problem-solving/references/meta-pattern-recognition.md +87 -0
  350. package/templates/claude/skills/problem-solving/references/scale-game.md +95 -0
  351. package/templates/claude/skills/problem-solving/references/simplification-cascades.md +80 -0
  352. package/templates/claude/skills/problem-solving/references/when-stuck.md +72 -0
  353. package/templates/claude/skills/registry.json +258 -0
  354. package/templates/claude/skills/repomix/SKILL.md +247 -0
  355. package/templates/claude/skills/repomix/references/configuration.md +211 -0
  356. package/templates/claude/skills/repomix/references/usage-patterns.md +232 -0
  357. package/templates/claude/skills/repomix/scripts/README.md +179 -0
  358. package/templates/claude/skills/repomix/scripts/repomix_batch.py +455 -0
  359. package/templates/claude/skills/repomix/scripts/repos.example.json +15 -0
  360. package/templates/claude/skills/research/SKILL.md +168 -0
  361. package/templates/claude/skills/sequential-thinking/.env.example +8 -0
  362. package/templates/claude/skills/sequential-thinking/README.md +183 -0
  363. package/templates/claude/skills/sequential-thinking/SKILL.md +94 -0
  364. package/templates/claude/skills/sequential-thinking/package.json +31 -0
  365. package/templates/claude/skills/sequential-thinking/references/advanced-strategies.md +79 -0
  366. package/templates/claude/skills/sequential-thinking/references/advanced-techniques.md +76 -0
  367. package/templates/claude/skills/sequential-thinking/references/core-patterns.md +95 -0
  368. package/templates/claude/skills/sequential-thinking/references/examples-api.md +88 -0
  369. package/templates/claude/skills/sequential-thinking/references/examples-architecture.md +94 -0
  370. package/templates/claude/skills/sequential-thinking/references/examples-debug.md +90 -0
  371. package/templates/claude/skills/sequential-thinking/scripts/format-thought.js +182 -0
  372. package/templates/claude/skills/sequential-thinking/scripts/process-thought.js +252 -0
  373. package/templates/claude/skills/skill-creator/LICENSE.txt +202 -0
  374. package/templates/claude/skills/skill-creator/SKILL.md +266 -0
  375. package/templates/claude/skills/skill-creator/references/agent-skills-spec.md +51 -0
  376. package/templates/claude/skills/skill-creator/scripts/encoding_utils.py +21 -0
  377. package/templates/claude/skills/skill-creator/scripts/init_skill.py +304 -0
  378. package/templates/claude/skills/skill-creator/scripts/package_skill.py +110 -0
  379. package/templates/claude/skills/skill-creator/scripts/quick_validate.py +66 -0
  380. package/templates/claude/skills/template-skill/SKILL.md +6 -0
  381. package/templates/claude/skills/vitest/SKILL.md +595 -0
  382. package/templates/claude/skills/vitest/references/async-patterns.md +82 -0
  383. package/templates/claude/skills/vitest/references/mock-patterns.md +78 -0
  384. package/templates/claude/skills/vitest/references/monorepo-setup.md +185 -0
  385. package/templates/claude/skills/vitest/references/turborepo-setup.md +332 -0
  386. package/templates/claude/skills/web-frameworks/SKILL.md +324 -0
  387. package/templates/claude/skills/web-frameworks/references/nextjs-app-router.md +465 -0
  388. package/templates/claude/skills/web-frameworks/references/nextjs-data-fetching.md +459 -0
  389. package/templates/claude/skills/web-frameworks/references/nextjs-optimization.md +511 -0
  390. package/templates/claude/skills/web-frameworks/references/nextjs-server-components.md +495 -0
  391. package/templates/claude/skills/web-frameworks/references/remix-icon-integration.md +603 -0
  392. package/templates/claude/skills/web-frameworks/references/turborepo-caching.md +551 -0
  393. package/templates/claude/skills/web-frameworks/references/turborepo-pipelines.md +517 -0
  394. package/templates/claude/skills/web-frameworks/references/turborepo-setup.md +542 -0
  395. package/templates/claude/skills/web-frameworks/scripts/nextjs_init.py +547 -0
  396. package/templates/claude/skills/web-frameworks/scripts/turborepo_migrate.py +394 -0
  397. package/templates/claude/workflows/development-rules.md +40 -0
  398. package/templates/claude/workflows/documentation-management.md +121 -0
  399. package/templates/claude/workflows/orchestration-protocol.md +16 -0
  400. package/templates/claude/workflows/primary-workflow.md +45 -0
  401. package/templates/claude/workflows/registry.json +37 -0
  402. package/templates/common/.cct.json +41 -0
  403. package/templates/common/.cctkignore +22 -0
  404. package/templates/common/.env.example +39 -0
  405. package/templates/common/.mcp.json.example +16 -0
  406. package/templates/common/metadata.json +15 -0
  407. package/templates/common/settings.json +79 -0
  408. package/templates/common/statusline.cjs +271 -0
  409. package/templates/config/.repomixignore +22 -0
  410. package/templates/config/AGENTS.md +55 -0
  411. package/templates/config/CLAUDE.md +87 -0
  412. package/templates/plans/bug-fix-template.md +69 -0
  413. package/templates/plans/feature-implementation-template.md +84 -0
  414. package/templates/plans/refactor-template.md +82 -0
  415. 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