ai-qakit 1.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (875) hide show
  1. package/README.md +240 -0
  2. package/dist/cli.d.ts +2 -0
  3. package/dist/cli.js +208 -0
  4. package/dist/commands/clean.d.ts +10 -0
  5. package/dist/commands/clean.js +53 -0
  6. package/dist/commands/init.d.ts +20 -0
  7. package/dist/commands/init.js +195 -0
  8. package/dist/index.d.ts +3 -0
  9. package/dist/index.js +2 -0
  10. package/dist/utils/file-operations.d.ts +18 -0
  11. package/dist/utils/file-operations.js +79 -0
  12. package/dist/utils/git.d.ts +4 -0
  13. package/dist/utils/git.js +27 -0
  14. package/dist/utils/index.d.ts +5 -0
  15. package/dist/utils/index.js +5 -0
  16. package/dist/utils/logger.d.ts +22 -0
  17. package/dist/utils/logger.js +23 -0
  18. package/dist/utils/manifest.d.ts +37 -0
  19. package/dist/utils/manifest.js +120 -0
  20. package/dist/utils/package.d.ts +19 -0
  21. package/dist/utils/package.js +47 -0
  22. package/package.json +61 -0
  23. package/templates/.antigravity/agents/qa-agents.yaml +50 -0
  24. package/templates/.antigravity/prompts/qa-prompts.md +56 -0
  25. package/templates/.claude/.scoutignore +33 -0
  26. package/templates/.claude/CHANGELOG.md +587 -0
  27. package/templates/.claude/CLAUDE.md +335 -0
  28. package/templates/.claude/README.md +428 -0
  29. package/templates/.claude/TROUBLESHOOTING.md +789 -0
  30. package/templates/.claude/agents/accessibility-tester.md +29 -0
  31. package/templates/.claude/agents/api-tester.md +29 -0
  32. package/templates/.claude/agents/automation-engineer.md +30 -0
  33. package/templates/.claude/agents/brainstormer.md +123 -0
  34. package/templates/.claude/agents/bug-hunter.md +30 -0
  35. package/templates/.claude/agents/claude-optimizer.md +221 -0
  36. package/templates/.claude/agents/code-reviewer.md +176 -0
  37. package/templates/.claude/agents/code-simplifier.md +103 -0
  38. package/templates/.claude/agents/coder.md +163 -0
  39. package/templates/.claude/agents/context-manager.md +110 -0
  40. package/templates/.claude/agents/cunningham.md +134 -0
  41. package/templates/.claude/agents/database-admin.md +112 -0
  42. package/templates/.claude/agents/debugger.md +156 -0
  43. package/templates/.claude/agents/docs-manager.md +181 -0
  44. package/templates/.claude/agents/e2e-tester.md +30 -0
  45. package/templates/.claude/agents/performance-engineer.md +48 -0
  46. package/templates/.claude/agents/performance-tester.md +29 -0
  47. package/templates/.claude/agents/planner.md +72 -0
  48. package/templates/.claude/agents/project-manager.md +152 -0
  49. package/templates/.claude/agents/qa-scout.md +29 -0
  50. package/templates/.claude/agents/quality-engineer.md +48 -0
  51. package/templates/.claude/agents/readme-writer.md +67 -0
  52. package/templates/.claude/agents/researcher.md +57 -0
  53. package/templates/.claude/agents/scout.md +125 -0
  54. package/templates/.claude/agents/security-agent.md +564 -0
  55. package/templates/.claude/agents/security-tester.md +29 -0
  56. package/templates/.claude/agents/storage-path-convention.md +102 -0
  57. package/templates/.claude/agents/tattletale-reporter.md +77 -0
  58. package/templates/.claude/agents/test-architect.md +32 -0
  59. package/templates/.claude/agents/test-reviewer.md +29 -0
  60. package/templates/.claude/agents/tester.md +286 -0
  61. package/templates/.claude/agents/typescript-pro.md +280 -0
  62. package/templates/.claude/agents/ui-ux-designer.md +256 -0
  63. package/templates/.claude/commands/devkit/analyze.md +92 -0
  64. package/templates/.claude/commands/devkit/ask.md +269 -0
  65. package/templates/.claude/commands/devkit/backend/create-api.md +220 -0
  66. package/templates/.claude/commands/devkit/backend/create-migration.md +130 -0
  67. package/templates/.claude/commands/devkit/backend/create-schema.md +158 -0
  68. package/templates/.claude/commands/devkit/backend/design-graphql-api.md +302 -0
  69. package/templates/.claude/commands/devkit/backend/design-rest-api.md +192 -0
  70. package/templates/.claude/commands/devkit/config/bootstrap.md +137 -0
  71. package/templates/.claude/commands/devkit/config/init-backend.md +233 -0
  72. package/templates/.claude/commands/devkit/config/init-frontend.md +911 -0
  73. package/templates/.claude/commands/devkit/create-test.md +165 -0
  74. package/templates/.claude/commands/devkit/debug.md +481 -0
  75. package/templates/.claude/commands/devkit/docs/capture-knowledge.md +424 -0
  76. package/templates/.claude/commands/devkit/docs/init.md +203 -0
  77. package/templates/.claude/commands/devkit/docs/summarize.md +33 -0
  78. package/templates/.claude/commands/devkit/docs/update.md +207 -0
  79. package/templates/.claude/commands/devkit/fix/fast.md +22 -0
  80. package/templates/.claude/commands/devkit/fix/hard.md +44 -0
  81. package/templates/.claude/commands/devkit/fix.md +16 -0
  82. package/templates/.claude/commands/devkit/frontend/create-api-integration.md +507 -0
  83. package/templates/.claude/commands/devkit/frontend/create-component.md +461 -0
  84. package/templates/.claude/commands/devkit/frontend/create-form.md +804 -0
  85. package/templates/.claude/commands/devkit/frontend/create-page.md +484 -0
  86. package/templates/.claude/commands/devkit/frontend/create-storybook.md +899 -0
  87. package/templates/.claude/commands/devkit/frontend/create-table.md +1035 -0
  88. package/templates/.claude/commands/devkit/help.md +148 -0
  89. package/templates/.claude/commands/devkit/refactor.md +510 -0
  90. package/templates/.claude/commands/devkit/research.md +394 -0
  91. package/templates/.claude/commands/devkit/review/code.md +349 -0
  92. package/templates/.claude/commands/devkit/review/codebase.md +51 -0
  93. package/templates/.claude/commands/devkit/scout.md +312 -0
  94. package/templates/.claude/commands/devkit/skill/add.md +29 -0
  95. package/templates/.claude/commands/devkit/skill/create.md +22 -0
  96. package/templates/.claude/commands/devkit/skill/optimize.md +34 -0
  97. package/templates/.claude/commands/devkit/solve.md +364 -0
  98. package/templates/.claude/commands/devkit/spec/brainstorm.md +309 -0
  99. package/templates/.claude/commands/devkit/spec/capture-requirement.md +202 -0
  100. package/templates/.claude/commands/devkit/spec/cook.md +157 -0
  101. package/templates/.claude/commands/devkit/spec/deep-capture-requirement.md +393 -0
  102. package/templates/.claude/commands/devkit/spec/implement.md +350 -0
  103. package/templates/.claude/commands/devkit/spec/plan.md +269 -0
  104. package/templates/.claude/commands/devkit/spec/task.md +156 -0
  105. package/templates/.claude/commands/devkit/spec/test.md +259 -0
  106. package/templates/.claude/commands/devkit/spec/update-plan.md +263 -0
  107. package/templates/.claude/commands/devkit/spec/update-requirement.md +239 -0
  108. package/templates/.claude/commands/devkit/spec-lite/do.md +280 -0
  109. package/templates/.claude/commands/devkit/spec-lite/plan.md +236 -0
  110. package/templates/.claude/commands/devkit/spec-lite/task.md +141 -0
  111. package/templates/.claude/commands/devkit/spec-lite/test.md +171 -0
  112. package/templates/.claude/commands/devkit/spec-lite/update-plan.md +154 -0
  113. package/templates/.claude/commands/qakit/a11y/audit.md +38 -0
  114. package/templates/.claude/commands/qakit/a11y/fix.md +22 -0
  115. package/templates/.claude/commands/qakit/analyze/full.md +459 -0
  116. package/templates/.claude/commands/qakit/analyze/quick.md +84 -0
  117. package/templates/.claude/commands/qakit/api/analyze.md +34 -0
  118. package/templates/.claude/commands/qakit/api/contract.md +22 -0
  119. package/templates/.claude/commands/qakit/api/generate.md +20 -0
  120. package/templates/.claude/commands/qakit/api/run.md +16 -0
  121. package/templates/.claude/commands/qakit/ask.md +57 -0
  122. package/templates/.claude/commands/qakit/automation/fix-flaky.md +233 -0
  123. package/templates/.claude/commands/qakit/automation/health-check.md +192 -0
  124. package/templates/.claude/commands/qakit/automation/maintenance.md +311 -0
  125. package/templates/.claude/commands/qakit/automation/scaffold-playwright.md +689 -0
  126. package/templates/.claude/commands/qakit/automation/scaffold-webdriverio.md +802 -0
  127. package/templates/.claude/commands/qakit/automation/scaffold.md +447 -0
  128. package/templates/.claude/commands/qakit/automation/update-deps.md +219 -0
  129. package/templates/.claude/commands/qakit/bug/investigate.md +96 -0
  130. package/templates/.claude/commands/qakit/bug/report.md +147 -0
  131. package/templates/.claude/commands/qakit/bug/reproduce.md +101 -0
  132. package/templates/.claude/commands/qakit/bug/triage.md +101 -0
  133. package/templates/.claude/commands/qakit/bug/verify.md +106 -0
  134. package/templates/.claude/commands/qakit/config/init-qa.md +107 -0
  135. package/templates/.claude/commands/qakit/confluence/fetch.md +192 -0
  136. package/templates/.claude/commands/qakit/confluence/search.md +201 -0
  137. package/templates/.claude/commands/qakit/docs/capture-test-knowledge.md +451 -0
  138. package/templates/.claude/commands/qakit/docs/update-changelog.md +207 -0
  139. package/templates/.claude/commands/qakit/docs/update-readme.md +296 -0
  140. package/templates/.claude/commands/qakit/e2e/generate.md +18 -0
  141. package/templates/.claude/commands/qakit/e2e/page-object.md +37 -0
  142. package/templates/.claude/commands/qakit/e2e/run.md +17 -0
  143. package/templates/.claude/commands/qakit/e2e/scenario.md +20 -0
  144. package/templates/.claude/commands/qakit/feature/create.md +178 -0
  145. package/templates/.claude/commands/qakit/feature/enrich-api.md +352 -0
  146. package/templates/.claude/commands/qakit/feature/enrich-tests.md +243 -0
  147. package/templates/.claude/commands/qakit/feature/enrich-ui.md +217 -0
  148. package/templates/.claude/commands/qakit/feature/enrich.md +246 -0
  149. package/templates/.claude/commands/qakit/feature/from-jira.md +184 -0
  150. package/templates/.claude/commands/qakit/feature/update.md +136 -0
  151. package/templates/.claude/commands/qakit/help.md +98 -0
  152. package/templates/.claude/commands/qakit/jira/analyze.md +329 -0
  153. package/templates/.claude/commands/qakit/jira/create-tests.md +319 -0
  154. package/templates/.claude/commands/qakit/kb/add-design.md +258 -0
  155. package/templates/.claude/commands/qakit/kb/capture.md +325 -0
  156. package/templates/.claude/commands/qakit/kb/clean.md +157 -0
  157. package/templates/.claude/commands/qakit/kb/dedupe.md +281 -0
  158. package/templates/.claude/commands/qakit/kb/init.md +234 -0
  159. package/templates/.claude/commands/qakit/kb/link.md +124 -0
  160. package/templates/.claude/commands/qakit/kb/list.md +185 -0
  161. package/templates/.claude/commands/qakit/kb/resolve.md +234 -0
  162. package/templates/.claude/commands/qakit/kb/search.md +202 -0
  163. package/templates/.claude/commands/qakit/kb/sync-confluence.md +474 -0
  164. package/templates/.claude/commands/qakit/metrics/coverage.md +46 -0
  165. package/templates/.claude/commands/qakit/metrics/dashboard.md +62 -0
  166. package/templates/.claude/commands/qakit/metrics/trends.md +42 -0
  167. package/templates/.claude/commands/qakit/perf/analyze.md +31 -0
  168. package/templates/.claude/commands/qakit/perf/plan.md +18 -0
  169. package/templates/.claude/commands/qakit/perf/run.md +17 -0
  170. package/templates/.claude/commands/qakit/perf/script.md +38 -0
  171. package/templates/.claude/commands/qakit/rca/analyze.md +166 -0
  172. package/templates/.claude/commands/qakit/regression/analyze.md +36 -0
  173. package/templates/.claude/commands/qakit/regression/report.md +30 -0
  174. package/templates/.claude/commands/qakit/regression/run.md +17 -0
  175. package/templates/.claude/commands/qakit/regression/select.md +34 -0
  176. package/templates/.claude/commands/qakit/research/deep.md +328 -0
  177. package/templates/.claude/commands/qakit/review/coverage.md +116 -0
  178. package/templates/.claude/commands/qakit/review/quality-gate.md +126 -0
  179. package/templates/.claude/commands/qakit/review/test-code.md +320 -0
  180. package/templates/.claude/commands/qakit/review/test-review.md +109 -0
  181. package/templates/.claude/commands/qakit/scout.md +195 -0
  182. package/templates/.claude/commands/qakit/setup/confluence.md +140 -0
  183. package/templates/.claude/commands/qakit/setup/jira.md +154 -0
  184. package/templates/.claude/commands/qakit/spec/analyze.md +46 -0
  185. package/templates/.claude/commands/qakit/spec/cook.md +344 -0
  186. package/templates/.claude/commands/qakit/spec/execute.md +38 -0
  187. package/templates/.claude/commands/qakit/spec/plan.md +46 -0
  188. package/templates/.claude/commands/qakit/spec/report.md +40 -0
  189. package/templates/.claude/commands/qakit/spec/task.md +40 -0
  190. package/templates/.claude/commands/qakit/test/create-test-case.md +151 -0
  191. package/templates/.claude/commands/qakit/test/create-test-suite.md +84 -0
  192. package/templates/.claude/commands/qakit/test/generate-api-tests.md +82 -0
  193. package/templates/.claude/commands/qakit/test/generate-data.md +114 -0
  194. package/templates/.claude/commands/qakit/test/generate-e2e.md +99 -0
  195. package/templates/.claude/commands/qakit/test/generate-ui-tests.md +97 -0
  196. package/templates/.claude/commands/qakit/testmo/report.md +22 -0
  197. package/templates/.claude/commands/qakit/testmo/sync.md +31 -0
  198. package/templates/.claude/doc-templates/bug-report-template.md +247 -0
  199. package/templates/.claude/doc-templates/code-standards.md +486 -0
  200. package/templates/.claude/doc-templates/codebase-summary.md +426 -0
  201. package/templates/.claude/doc-templates/development-rules.md +553 -0
  202. package/templates/.claude/doc-templates/feature-spec-template.md +167 -0
  203. package/templates/.claude/doc-templates/performance-report-template.md +49 -0
  204. package/templates/.claude/doc-templates/project-overview-pdr.md +494 -0
  205. package/templates/.claude/doc-templates/quality-report-template.md +44 -0
  206. package/templates/.claude/doc-templates/regression-report-template.md +41 -0
  207. package/templates/.claude/doc-templates/system-architecture.md +615 -0
  208. package/templates/.claude/doc-templates/technical-documents.md +127 -0
  209. package/templates/.claude/doc-templates/test-case-template.md +198 -0
  210. package/templates/.claude/doc-templates/test-plan-template.md +366 -0
  211. package/templates/.claude/doc-templates/test-summary-report.md +401 -0
  212. package/templates/.claude/hooks/dev-rules-reminder.cjs +101 -0
  213. package/templates/.claude/hooks/dev-rules-reminder.js +96 -0
  214. package/templates/.claude/hooks/executable_force-agent-skills-eval.sh +38 -0
  215. package/templates/.claude/hooks/scout-block/scout-block.ps1 +92 -0
  216. package/templates/.claude/hooks/scout-block/scout-block.sh +119 -0
  217. package/templates/.claude/hooks/scout-block.cjs +100 -0
  218. package/templates/.claude/hooks/scout-block.js +104 -0
  219. package/templates/.claude/repomix.config.json +34 -0
  220. package/templates/.claude/rules/01-core-principles.md +81 -0
  221. package/templates/.claude/rules/02-naming-and-constants.md +115 -0
  222. package/templates/.claude/rules/03-function-design.md +167 -0
  223. package/templates/.claude/rules/04-error-handling.md +83 -0
  224. package/templates/.claude/rules/05-testing.md +86 -0
  225. package/templates/.claude/rules/06-code-quality.md +107 -0
  226. package/templates/.claude/rules/07-architecture.md +105 -0
  227. package/templates/.claude/rules/08-performance-security.md +93 -0
  228. package/templates/.claude/rules/index.md +77 -0
  229. package/templates/.claude/scripts/README.md +153 -0
  230. package/templates/.claude/scripts/commands_data.yaml +336 -0
  231. package/templates/.claude/scripts/generate_catalogs.py +163 -0
  232. package/templates/.claude/scripts/helper.py +723 -0
  233. package/templates/.claude/scripts/scan_commands.py +101 -0
  234. package/templates/.claude/scripts/scan_skills.py +187 -0
  235. package/templates/.claude/scripts/skills_data.yaml +348 -0
  236. package/templates/.claude/settings.json +54 -0
  237. package/templates/.claude/settings.local.README.md +650 -0
  238. package/templates/.claude/settings.local.json +41 -0
  239. package/templates/.claude/setup/dependencies/setup-claude-mem.ps1 +534 -0
  240. package/templates/.claude/setup/dependencies/setup-claude-mem.sh +477 -0
  241. package/templates/.claude/setup/dependencies/setup-mcp-servers.ps1 +562 -0
  242. package/templates/.claude/setup/dependencies/setup-mcp-servers.sh +511 -0
  243. package/templates/.claude/setup/jira-env.example.sh +22 -0
  244. package/templates/.claude/setup/setup.ps1 +240 -0
  245. package/templates/.claude/setup/setup.sh +222 -0
  246. package/templates/.claude/skills/accessibility-testing/SKILL.md +34 -0
  247. package/templates/.claude/skills/aesthetic/SKILL.md +121 -0
  248. package/templates/.claude/skills/aesthetic/assets/design-guideline-template.md +163 -0
  249. package/templates/.claude/skills/aesthetic/assets/design-story-template.md +135 -0
  250. package/templates/.claude/skills/aesthetic/references/design-principles.md +62 -0
  251. package/templates/.claude/skills/aesthetic/references/design-resources.md +75 -0
  252. package/templates/.claude/skills/aesthetic/references/micro-interactions.md +53 -0
  253. package/templates/.claude/skills/aesthetic/references/storytelling-design.md +50 -0
  254. package/templates/.claude/skills/aesthetic/skill-creator/LICENSE.txt +202 -0
  255. package/templates/.claude/skills/aesthetic/skill-creator/SKILL.md +266 -0
  256. package/templates/.claude/skills/aesthetic/skill-creator/scripts/init_skill.py +303 -0
  257. package/templates/.claude/skills/aesthetic/skill-creator/scripts/package_skill.py +110 -0
  258. package/templates/.claude/skills/aesthetic/skill-creator/scripts/quick_validate.py +65 -0
  259. package/templates/.claude/skills/agent_skills_spec.md +51 -0
  260. package/templates/.claude/skills/ai-multimodal/.env.example +185 -0
  261. package/templates/.claude/skills/ai-multimodal/SKILL.md +69 -0
  262. package/templates/.claude/skills/ai-multimodal/references/audio-processing.md +386 -0
  263. package/templates/.claude/skills/ai-multimodal/references/image-generation.md +722 -0
  264. package/templates/.claude/skills/ai-multimodal/references/video-analysis.md +515 -0
  265. package/templates/.claude/skills/ai-multimodal/references/video-generation.md +457 -0
  266. package/templates/.claude/skills/ai-multimodal/references/vision-understanding.md +492 -0
  267. package/templates/.claude/skills/ai-multimodal/scripts/check_setup.py +299 -0
  268. package/templates/.claude/skills/ai-multimodal/scripts/document_converter.py +395 -0
  269. package/templates/.claude/skills/ai-multimodal/scripts/gemini_batch_process.py +1067 -0
  270. package/templates/.claude/skills/ai-multimodal/scripts/media_optimizer.py +506 -0
  271. package/templates/.claude/skills/ai-multimodal/scripts/requirements.txt +26 -0
  272. package/templates/.claude/skills/ai-multimodal/scripts/tests/requirements.txt +20 -0
  273. package/templates/.claude/skills/ai-multimodal/scripts/tests/test_document_converter.py +74 -0
  274. package/templates/.claude/skills/ai-multimodal/scripts/tests/test_gemini_batch_process.py +362 -0
  275. package/templates/.claude/skills/ai-multimodal/scripts/tests/test_media_optimizer.py +373 -0
  276. package/templates/.claude/skills/api-design-principles/SKILL.md +527 -0
  277. package/templates/.claude/skills/api-design-principles/assets/api-design-checklist.md +136 -0
  278. package/templates/.claude/skills/api-design-principles/assets/rest-api-template.py +165 -0
  279. package/templates/.claude/skills/api-design-principles/references/graphql-schema-design.md +566 -0
  280. package/templates/.claude/skills/api-design-principles/references/rest-best-practices.md +385 -0
  281. package/templates/.claude/skills/api-testing/SKILL.md +24 -0
  282. package/templates/.claude/skills/backend-development/SKILL.md +95 -0
  283. package/templates/.claude/skills/backend-development/references/backend-api-design.md +495 -0
  284. package/templates/.claude/skills/backend-development/references/backend-architecture.md +454 -0
  285. package/templates/.claude/skills/backend-development/references/backend-code-quality.md +659 -0
  286. package/templates/.claude/skills/backend-development/references/backend-debugging.md +904 -0
  287. package/templates/.claude/skills/backend-development/references/backend-devops.md +494 -0
  288. package/templates/.claude/skills/backend-development/references/backend-mindset.md +387 -0
  289. package/templates/.claude/skills/backend-development/references/backend-performance.md +397 -0
  290. package/templates/.claude/skills/backend-development/references/backend-security.md +290 -0
  291. package/templates/.claude/skills/backend-development/references/backend-technologies.md +256 -0
  292. package/templates/.claude/skills/backend-development/references/backend-testing.md +429 -0
  293. package/templates/.claude/skills/bug-investigation/SKILL.md +24 -0
  294. package/templates/.claude/skills/chrome-devtools/SKILL.md +472 -0
  295. package/templates/.claude/skills/chrome-devtools/references/cdp-domains.md +694 -0
  296. package/templates/.claude/skills/chrome-devtools/references/performance-guide.md +940 -0
  297. package/templates/.claude/skills/chrome-devtools/references/puppeteer-reference.md +953 -0
  298. package/templates/.claude/skills/chrome-devtools/scripts/README.md +228 -0
  299. package/templates/.claude/skills/chrome-devtools/scripts/__tests__/selector.test.js +210 -0
  300. package/templates/.claude/skills/chrome-devtools/scripts/aria-snapshot.js +362 -0
  301. package/templates/.claude/skills/chrome-devtools/scripts/click.js +83 -0
  302. package/templates/.claude/skills/chrome-devtools/scripts/console.js +79 -0
  303. package/templates/.claude/skills/chrome-devtools/scripts/evaluate.js +53 -0
  304. package/templates/.claude/skills/chrome-devtools/scripts/fill.js +76 -0
  305. package/templates/.claude/skills/chrome-devtools/scripts/install-deps.sh +181 -0
  306. package/templates/.claude/skills/chrome-devtools/scripts/install.sh +83 -0
  307. package/templates/.claude/skills/chrome-devtools/scripts/lib/browser.js +217 -0
  308. package/templates/.claude/skills/chrome-devtools/scripts/lib/selector.js +178 -0
  309. package/templates/.claude/skills/chrome-devtools/scripts/navigate.js +54 -0
  310. package/templates/.claude/skills/chrome-devtools/scripts/network.js +106 -0
  311. package/templates/.claude/skills/chrome-devtools/scripts/package.json +16 -0
  312. package/templates/.claude/skills/chrome-devtools/scripts/performance.js +149 -0
  313. package/templates/.claude/skills/chrome-devtools/scripts/screenshot.js +194 -0
  314. package/templates/.claude/skills/chrome-devtools/scripts/select-ref.js +131 -0
  315. package/templates/.claude/skills/chrome-devtools/scripts/snapshot.js +135 -0
  316. package/templates/.claude/skills/claude-code-analyzer/SKILL.md +299 -0
  317. package/templates/.claude/skills/claude-code-analyzer/references/best-practices.md +290 -0
  318. package/templates/.claude/skills/claude-code-analyzer/scripts/analyze-claude-md.sh +239 -0
  319. package/templates/.claude/skills/claude-code-analyzer/scripts/analyze.sh +274 -0
  320. package/templates/.claude/skills/claude-code-analyzer/scripts/fetch-features.sh +69 -0
  321. package/templates/.claude/skills/claude-code-analyzer/scripts/github-discovery.sh +178 -0
  322. package/templates/.claude/skills/code-review/SKILL.md +155 -0
  323. package/templates/.claude/skills/code-review/references/code-review-reception.md +209 -0
  324. package/templates/.claude/skills/code-review/references/human-code-review-practices.md +370 -0
  325. package/templates/.claude/skills/code-review/references/requesting-code-review.md +105 -0
  326. package/templates/.claude/skills/code-review/references/verification-before-completion.md +139 -0
  327. package/templates/.claude/skills/command-development/README.md +272 -0
  328. package/templates/.claude/skills/command-development/SKILL.md +834 -0
  329. package/templates/.claude/skills/command-development/examples/plugin-commands.md +557 -0
  330. package/templates/.claude/skills/command-development/examples/simple-commands.md +504 -0
  331. package/templates/.claude/skills/command-development/references/advanced-workflows.md +722 -0
  332. package/templates/.claude/skills/command-development/references/documentation-patterns.md +739 -0
  333. package/templates/.claude/skills/command-development/references/frontmatter-reference.md +463 -0
  334. package/templates/.claude/skills/command-development/references/interactive-commands.md +920 -0
  335. package/templates/.claude/skills/command-development/references/marketplace-considerations.md +904 -0
  336. package/templates/.claude/skills/command-development/references/plugin-features-reference.md +609 -0
  337. package/templates/.claude/skills/command-development/references/testing-strategies.md +702 -0
  338. package/templates/.claude/skills/confluence-integration/confluence-integration.md +260 -0
  339. package/templates/.claude/skills/databases/SKILL.md +232 -0
  340. package/templates/.claude/skills/databases/references/mongodb-aggregation.md +447 -0
  341. package/templates/.claude/skills/databases/references/mongodb-atlas.md +465 -0
  342. package/templates/.claude/skills/databases/references/mongodb-crud.md +408 -0
  343. package/templates/.claude/skills/databases/references/mongodb-indexing.md +442 -0
  344. package/templates/.claude/skills/databases/references/postgresql-administration.md +594 -0
  345. package/templates/.claude/skills/databases/references/postgresql-performance.md +527 -0
  346. package/templates/.claude/skills/databases/references/postgresql-psql-cli.md +467 -0
  347. package/templates/.claude/skills/databases/references/postgresql-queries.md +475 -0
  348. package/templates/.claude/skills/databases/scripts/db_backup.py +502 -0
  349. package/templates/.claude/skills/databases/scripts/db_migrate.py +414 -0
  350. package/templates/.claude/skills/databases/scripts/db_performance_check.py +444 -0
  351. package/templates/.claude/skills/databases/scripts/dot_coverage +0 -0
  352. package/templates/.claude/skills/databases/scripts/requirements.txt +20 -0
  353. package/templates/.claude/skills/databases/scripts/tests/coverage-db.json +1 -0
  354. package/templates/.claude/skills/databases/scripts/tests/requirements.txt +4 -0
  355. package/templates/.claude/skills/databases/scripts/tests/test_db_backup.py +340 -0
  356. package/templates/.claude/skills/databases/scripts/tests/test_db_migrate.py +277 -0
  357. package/templates/.claude/skills/databases/scripts/tests/test_db_performance_check.py +370 -0
  358. package/templates/.claude/skills/debugging/SKILL.md +84 -0
  359. package/templates/.claude/skills/debugging/references/defense-in-depth.md +124 -0
  360. package/templates/.claude/skills/debugging/references/root-cause-tracing.md +122 -0
  361. package/templates/.claude/skills/debugging/references/systematic-debugging.md +102 -0
  362. package/templates/.claude/skills/debugging/references/verification.md +123 -0
  363. package/templates/.claude/skills/debugging/scripts/find-polluter.sh +63 -0
  364. package/templates/.claude/skills/debugging/scripts/find-polluter.test.md +102 -0
  365. package/templates/.claude/skills/docs-discovery/COMPARISON.md +313 -0
  366. package/templates/.claude/skills/docs-discovery/README.md +53 -0
  367. package/templates/.claude/skills/docs-discovery/REFACTORING_SUMMARY.md +144 -0
  368. package/templates/.claude/skills/docs-discovery/SKILL.md +64 -0
  369. package/templates/.claude/skills/docs-discovery/archive/dot_env.example +15 -0
  370. package/templates/.claude/skills/docs-discovery/archive/package.json +24 -0
  371. package/templates/.claude/skills/docs-discovery/archive/references/advanced.md +79 -0
  372. package/templates/.claude/skills/docs-discovery/archive/references/context7-patterns.md +68 -0
  373. package/templates/.claude/skills/docs-discovery/archive/references/errors.md +68 -0
  374. package/templates/.claude/skills/docs-discovery/archive/scripts/analyze-llms-txt.js +211 -0
  375. package/templates/.claude/skills/docs-discovery/archive/scripts/detect-topic.js +172 -0
  376. package/templates/.claude/skills/docs-discovery/archive/scripts/fetch-docs.js +213 -0
  377. package/templates/.claude/skills/docs-discovery/archive/scripts/tests/run-tests.js +72 -0
  378. package/templates/.claude/skills/docs-discovery/archive/scripts/tests/test-analyze-llms.js +119 -0
  379. package/templates/.claude/skills/docs-discovery/archive/scripts/tests/test-detect-topic.js +112 -0
  380. package/templates/.claude/skills/docs-discovery/archive/scripts/tests/test-fetch-docs.js +84 -0
  381. package/templates/.claude/skills/docs-discovery/archive/scripts/utils/env-loader.js +94 -0
  382. package/templates/.claude/skills/docs-discovery/archive/workflows/library-search.md +87 -0
  383. package/templates/.claude/skills/docs-discovery/archive/workflows/repo-analysis.md +91 -0
  384. package/templates/.claude/skills/docs-discovery/archive/workflows/topic-search.md +77 -0
  385. package/templates/.claude/skills/docs-seeker/.env.example +15 -0
  386. package/templates/.claude/skills/docs-seeker/SKILL.md +97 -0
  387. package/templates/.claude/skills/docs-seeker/package.json +24 -0
  388. package/templates/.claude/skills/docs-seeker/references/advanced.md +79 -0
  389. package/templates/.claude/skills/docs-seeker/references/context7-patterns.md +68 -0
  390. package/templates/.claude/skills/docs-seeker/references/errors.md +68 -0
  391. package/templates/.claude/skills/docs-seeker/scripts/analyze-llms-txt.js +211 -0
  392. package/templates/.claude/skills/docs-seeker/scripts/detect-topic.js +172 -0
  393. package/templates/.claude/skills/docs-seeker/scripts/fetch-docs.js +213 -0
  394. package/templates/.claude/skills/docs-seeker/scripts/tests/run-tests.js +72 -0
  395. package/templates/.claude/skills/docs-seeker/scripts/tests/test-analyze-llms.js +119 -0
  396. package/templates/.claude/skills/docs-seeker/scripts/tests/test-detect-topic.js +112 -0
  397. package/templates/.claude/skills/docs-seeker/scripts/tests/test-fetch-docs.js +84 -0
  398. package/templates/.claude/skills/docs-seeker/scripts/utils/env-loader.js +94 -0
  399. package/templates/.claude/skills/docs-seeker/workflows/library-search.md +87 -0
  400. package/templates/.claude/skills/docs-seeker/workflows/repo-analysis.md +91 -0
  401. package/templates/.claude/skills/docs-seeker/workflows/topic-search.md +77 -0
  402. package/templates/.claude/skills/document-skills/docx/LICENSE.txt +30 -0
  403. package/templates/.claude/skills/document-skills/docx/SKILL.md +197 -0
  404. package/templates/.claude/skills/document-skills/docx/docx-js.md +350 -0
  405. package/templates/.claude/skills/document-skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/dml-chart.xsd +1499 -0
  406. package/templates/.claude/skills/document-skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/dml-chartDrawing.xsd +146 -0
  407. package/templates/.claude/skills/document-skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/dml-diagram.xsd +1085 -0
  408. package/templates/.claude/skills/document-skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/dml-lockedCanvas.xsd +11 -0
  409. package/templates/.claude/skills/document-skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/dml-main.xsd +3081 -0
  410. package/templates/.claude/skills/document-skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/dml-picture.xsd +23 -0
  411. package/templates/.claude/skills/document-skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/dml-spreadsheetDrawing.xsd +185 -0
  412. package/templates/.claude/skills/document-skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/dml-wordprocessingDrawing.xsd +287 -0
  413. package/templates/.claude/skills/document-skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/pml.xsd +1676 -0
  414. package/templates/.claude/skills/document-skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-additionalCharacteristics.xsd +28 -0
  415. package/templates/.claude/skills/document-skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-bibliography.xsd +144 -0
  416. package/templates/.claude/skills/document-skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-commonSimpleTypes.xsd +174 -0
  417. package/templates/.claude/skills/document-skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-customXmlDataProperties.xsd +25 -0
  418. package/templates/.claude/skills/document-skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-customXmlSchemaProperties.xsd +18 -0
  419. package/templates/.claude/skills/document-skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesCustom.xsd +59 -0
  420. package/templates/.claude/skills/document-skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesExtended.xsd +56 -0
  421. package/templates/.claude/skills/document-skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesVariantTypes.xsd +195 -0
  422. package/templates/.claude/skills/document-skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-math.xsd +582 -0
  423. package/templates/.claude/skills/document-skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-relationshipReference.xsd +25 -0
  424. package/templates/.claude/skills/document-skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/sml.xsd +4439 -0
  425. package/templates/.claude/skills/document-skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/vml-main.xsd +570 -0
  426. package/templates/.claude/skills/document-skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/vml-officeDrawing.xsd +509 -0
  427. package/templates/.claude/skills/document-skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/vml-presentationDrawing.xsd +12 -0
  428. package/templates/.claude/skills/document-skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/vml-spreadsheetDrawing.xsd +108 -0
  429. package/templates/.claude/skills/document-skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/vml-wordprocessingDrawing.xsd +96 -0
  430. package/templates/.claude/skills/document-skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/wml.xsd +3646 -0
  431. package/templates/.claude/skills/document-skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/xml.xsd +116 -0
  432. package/templates/.claude/skills/document-skills/docx/ooxml/schemas/ecma/fouth-edition/opc-contentTypes.xsd +42 -0
  433. package/templates/.claude/skills/document-skills/docx/ooxml/schemas/ecma/fouth-edition/opc-coreProperties.xsd +50 -0
  434. package/templates/.claude/skills/document-skills/docx/ooxml/schemas/ecma/fouth-edition/opc-digSig.xsd +49 -0
  435. package/templates/.claude/skills/document-skills/docx/ooxml/schemas/ecma/fouth-edition/opc-relationships.xsd +33 -0
  436. package/templates/.claude/skills/document-skills/docx/ooxml/schemas/mce/mc.xsd +75 -0
  437. package/templates/.claude/skills/document-skills/docx/ooxml/schemas/microsoft/wml-2010.xsd +560 -0
  438. package/templates/.claude/skills/document-skills/docx/ooxml/schemas/microsoft/wml-2012.xsd +67 -0
  439. package/templates/.claude/skills/document-skills/docx/ooxml/schemas/microsoft/wml-2018.xsd +14 -0
  440. package/templates/.claude/skills/document-skills/docx/ooxml/schemas/microsoft/wml-cex-2018.xsd +20 -0
  441. package/templates/.claude/skills/document-skills/docx/ooxml/schemas/microsoft/wml-cid-2016.xsd +13 -0
  442. package/templates/.claude/skills/document-skills/docx/ooxml/schemas/microsoft/wml-sdtdatahash-2020.xsd +4 -0
  443. package/templates/.claude/skills/document-skills/docx/ooxml/schemas/microsoft/wml-symex-2015.xsd +8 -0
  444. package/templates/.claude/skills/document-skills/docx/ooxml/scripts/pack.py +159 -0
  445. package/templates/.claude/skills/document-skills/docx/ooxml/scripts/unpack.py +29 -0
  446. package/templates/.claude/skills/document-skills/docx/ooxml/scripts/validate.py +69 -0
  447. package/templates/.claude/skills/document-skills/docx/ooxml/scripts/validation/__init__.py +15 -0
  448. package/templates/.claude/skills/document-skills/docx/ooxml/scripts/validation/base.py +951 -0
  449. package/templates/.claude/skills/document-skills/docx/ooxml/scripts/validation/docx.py +274 -0
  450. package/templates/.claude/skills/document-skills/docx/ooxml/scripts/validation/pptx.py +315 -0
  451. package/templates/.claude/skills/document-skills/docx/ooxml/scripts/validation/redlining.py +279 -0
  452. package/templates/.claude/skills/document-skills/docx/ooxml.md +610 -0
  453. package/templates/.claude/skills/document-skills/docx/scripts/__init__.py +1 -0
  454. package/templates/.claude/skills/document-skills/docx/scripts/document.py +1276 -0
  455. package/templates/.claude/skills/document-skills/docx/scripts/templates/comments.xml +3 -0
  456. package/templates/.claude/skills/document-skills/docx/scripts/templates/commentsExtended.xml +3 -0
  457. package/templates/.claude/skills/document-skills/docx/scripts/templates/commentsExtensible.xml +3 -0
  458. package/templates/.claude/skills/document-skills/docx/scripts/templates/commentsIds.xml +3 -0
  459. package/templates/.claude/skills/document-skills/docx/scripts/templates/people.xml +3 -0
  460. package/templates/.claude/skills/document-skills/docx/scripts/utilities.py +374 -0
  461. package/templates/.claude/skills/document-skills/pdf/LICENSE.txt +30 -0
  462. package/templates/.claude/skills/document-skills/pdf/SKILL.md +294 -0
  463. package/templates/.claude/skills/document-skills/pdf/forms.md +205 -0
  464. package/templates/.claude/skills/document-skills/pdf/reference.md +612 -0
  465. package/templates/.claude/skills/document-skills/pdf/scripts/check_bounding_boxes.py +70 -0
  466. package/templates/.claude/skills/document-skills/pdf/scripts/check_bounding_boxes_test.py +226 -0
  467. package/templates/.claude/skills/document-skills/pdf/scripts/check_fillable_fields.py +12 -0
  468. package/templates/.claude/skills/document-skills/pdf/scripts/convert_pdf_to_images.py +35 -0
  469. package/templates/.claude/skills/document-skills/pdf/scripts/create_validation_image.py +41 -0
  470. package/templates/.claude/skills/document-skills/pdf/scripts/extract_form_field_info.py +152 -0
  471. package/templates/.claude/skills/document-skills/pdf/scripts/fill_fillable_fields.py +114 -0
  472. package/templates/.claude/skills/document-skills/pdf/scripts/fill_pdf_form_with_annotations.py +108 -0
  473. package/templates/.claude/skills/document-skills/pptx/LICENSE.txt +30 -0
  474. package/templates/.claude/skills/document-skills/pptx/SKILL.md +484 -0
  475. package/templates/.claude/skills/document-skills/pptx/html2pptx.md +625 -0
  476. package/templates/.claude/skills/document-skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/dml-chart.xsd +1499 -0
  477. package/templates/.claude/skills/document-skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/dml-chartDrawing.xsd +146 -0
  478. package/templates/.claude/skills/document-skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/dml-diagram.xsd +1085 -0
  479. package/templates/.claude/skills/document-skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/dml-lockedCanvas.xsd +11 -0
  480. package/templates/.claude/skills/document-skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/dml-main.xsd +3081 -0
  481. package/templates/.claude/skills/document-skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/dml-picture.xsd +23 -0
  482. package/templates/.claude/skills/document-skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/dml-spreadsheetDrawing.xsd +185 -0
  483. package/templates/.claude/skills/document-skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/dml-wordprocessingDrawing.xsd +287 -0
  484. package/templates/.claude/skills/document-skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/pml.xsd +1676 -0
  485. package/templates/.claude/skills/document-skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-additionalCharacteristics.xsd +28 -0
  486. package/templates/.claude/skills/document-skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-bibliography.xsd +144 -0
  487. package/templates/.claude/skills/document-skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-commonSimpleTypes.xsd +174 -0
  488. package/templates/.claude/skills/document-skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-customXmlDataProperties.xsd +25 -0
  489. package/templates/.claude/skills/document-skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-customXmlSchemaProperties.xsd +18 -0
  490. package/templates/.claude/skills/document-skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesCustom.xsd +59 -0
  491. package/templates/.claude/skills/document-skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesExtended.xsd +56 -0
  492. package/templates/.claude/skills/document-skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesVariantTypes.xsd +195 -0
  493. package/templates/.claude/skills/document-skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-math.xsd +582 -0
  494. package/templates/.claude/skills/document-skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-relationshipReference.xsd +25 -0
  495. package/templates/.claude/skills/document-skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/sml.xsd +4439 -0
  496. package/templates/.claude/skills/document-skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/vml-main.xsd +570 -0
  497. package/templates/.claude/skills/document-skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/vml-officeDrawing.xsd +509 -0
  498. package/templates/.claude/skills/document-skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/vml-presentationDrawing.xsd +12 -0
  499. package/templates/.claude/skills/document-skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/vml-spreadsheetDrawing.xsd +108 -0
  500. package/templates/.claude/skills/document-skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/vml-wordprocessingDrawing.xsd +96 -0
  501. package/templates/.claude/skills/document-skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/wml.xsd +3646 -0
  502. package/templates/.claude/skills/document-skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/xml.xsd +116 -0
  503. package/templates/.claude/skills/document-skills/pptx/ooxml/schemas/ecma/fouth-edition/opc-contentTypes.xsd +42 -0
  504. package/templates/.claude/skills/document-skills/pptx/ooxml/schemas/ecma/fouth-edition/opc-coreProperties.xsd +50 -0
  505. package/templates/.claude/skills/document-skills/pptx/ooxml/schemas/ecma/fouth-edition/opc-digSig.xsd +49 -0
  506. package/templates/.claude/skills/document-skills/pptx/ooxml/schemas/ecma/fouth-edition/opc-relationships.xsd +33 -0
  507. package/templates/.claude/skills/document-skills/pptx/ooxml/schemas/mce/mc.xsd +75 -0
  508. package/templates/.claude/skills/document-skills/pptx/ooxml/schemas/microsoft/wml-2010.xsd +560 -0
  509. package/templates/.claude/skills/document-skills/pptx/ooxml/schemas/microsoft/wml-2012.xsd +67 -0
  510. package/templates/.claude/skills/document-skills/pptx/ooxml/schemas/microsoft/wml-2018.xsd +14 -0
  511. package/templates/.claude/skills/document-skills/pptx/ooxml/schemas/microsoft/wml-cex-2018.xsd +20 -0
  512. package/templates/.claude/skills/document-skills/pptx/ooxml/schemas/microsoft/wml-cid-2016.xsd +13 -0
  513. package/templates/.claude/skills/document-skills/pptx/ooxml/schemas/microsoft/wml-sdtdatahash-2020.xsd +4 -0
  514. package/templates/.claude/skills/document-skills/pptx/ooxml/schemas/microsoft/wml-symex-2015.xsd +8 -0
  515. package/templates/.claude/skills/document-skills/pptx/ooxml/scripts/pack.py +159 -0
  516. package/templates/.claude/skills/document-skills/pptx/ooxml/scripts/unpack.py +29 -0
  517. package/templates/.claude/skills/document-skills/pptx/ooxml/scripts/validate.py +69 -0
  518. package/templates/.claude/skills/document-skills/pptx/ooxml/scripts/validation/__init__.py +15 -0
  519. package/templates/.claude/skills/document-skills/pptx/ooxml/scripts/validation/base.py +951 -0
  520. package/templates/.claude/skills/document-skills/pptx/ooxml/scripts/validation/docx.py +274 -0
  521. package/templates/.claude/skills/document-skills/pptx/ooxml/scripts/validation/pptx.py +315 -0
  522. package/templates/.claude/skills/document-skills/pptx/ooxml/scripts/validation/redlining.py +279 -0
  523. package/templates/.claude/skills/document-skills/pptx/ooxml.md +427 -0
  524. package/templates/.claude/skills/document-skills/pptx/scripts/html2pptx.js +979 -0
  525. package/templates/.claude/skills/document-skills/pptx/scripts/inventory.py +1020 -0
  526. package/templates/.claude/skills/document-skills/pptx/scripts/rearrange.py +231 -0
  527. package/templates/.claude/skills/document-skills/pptx/scripts/replace.py +385 -0
  528. package/templates/.claude/skills/document-skills/pptx/scripts/thumbnail.py +450 -0
  529. package/templates/.claude/skills/document-skills/xlsx/LICENSE.txt +30 -0
  530. package/templates/.claude/skills/document-skills/xlsx/SKILL.md +289 -0
  531. package/templates/.claude/skills/document-skills/xlsx/recalc.py +178 -0
  532. package/templates/.claude/skills/frontend-development/SKILL.md +208 -0
  533. package/templates/.claude/skills/frontend-development/references/accessibility.md +720 -0
  534. package/templates/.claude/skills/frontend-development/references/data-fetching.md +412 -0
  535. package/templates/.claude/skills/frontend-development/references/forms.md +809 -0
  536. package/templates/.claude/skills/frontend-development/references/fsd-architecture.md +442 -0
  537. package/templates/.claude/skills/frontend-development/references/graphql-apollo.md +731 -0
  538. package/templates/.claude/skills/frontend-development/references/performance.md +417 -0
  539. package/templates/.claude/skills/frontend-development/references/react-patterns.md +451 -0
  540. package/templates/.claude/skills/frontend-development/references/routing.md +436 -0
  541. package/templates/.claude/skills/frontend-development/references/state-management.md +510 -0
  542. package/templates/.claude/skills/frontend-development/references/tailwind-css.md +397 -0
  543. package/templates/.claude/skills/frontend-development/references/testing.md +630 -0
  544. package/templates/.claude/skills/frontend-development/references/typescript-standards.md +363 -0
  545. package/templates/.claude/skills/frontend-development/references/ui-libraries.md +586 -0
  546. package/templates/.claude/skills/infra-engineer/SKILL.md +642 -0
  547. package/templates/.claude/skills/infra-engineer/dot_env.example +76 -0
  548. package/templates/.claude/skills/infra-engineer/references/aws-overview.md +171 -0
  549. package/templates/.claude/skills/infra-engineer/references/browser-rendering.md +305 -0
  550. package/templates/.claude/skills/infra-engineer/references/cicd-github-actions.md +439 -0
  551. package/templates/.claude/skills/infra-engineer/references/cloudflare-d1-kv.md +123 -0
  552. package/templates/.claude/skills/infra-engineer/references/cloudflare-platform.md +271 -0
  553. package/templates/.claude/skills/infra-engineer/references/cloudflare-r2-storage.md +280 -0
  554. package/templates/.claude/skills/infra-engineer/references/cloudflare-workers-advanced.md +312 -0
  555. package/templates/.claude/skills/infra-engineer/references/cloudflare-workers-apis.md +309 -0
  556. package/templates/.claude/skills/infra-engineer/references/cloudflare-workers-basics.md +418 -0
  557. package/templates/.claude/skills/infra-engineer/references/devsecops-basics.md +361 -0
  558. package/templates/.claude/skills/infra-engineer/references/docker-basics.md +297 -0
  559. package/templates/.claude/skills/infra-engineer/references/docker-compose.md +292 -0
  560. package/templates/.claude/skills/infra-engineer/references/finops-basics.md +278 -0
  561. package/templates/.claude/skills/infra-engineer/references/gcloud-platform.md +297 -0
  562. package/templates/.claude/skills/infra-engineer/references/gcloud-services.md +304 -0
  563. package/templates/.claude/skills/infra-engineer/references/kubernetes-basics.md +295 -0
  564. package/templates/.claude/skills/infra-engineer/scripts/cloudflare_deploy.py +269 -0
  565. package/templates/.claude/skills/infra-engineer/scripts/docker_optimize.py +320 -0
  566. package/templates/.claude/skills/infra-engineer/scripts/requirements.txt +20 -0
  567. package/templates/.claude/skills/infra-engineer/scripts/tests/requirements.txt +3 -0
  568. package/templates/.claude/skills/infra-engineer/scripts/tests/test_cloudflare_deploy.py +285 -0
  569. package/templates/.claude/skills/infra-engineer/scripts/tests/test_docker_optimize.py +436 -0
  570. package/templates/.claude/skills/javascript-pro/SKILL.md +96 -0
  571. package/templates/.claude/skills/javascript-pro/references/async-patterns.md +96 -0
  572. package/templates/.claude/skills/javascript-pro/references/best-practices.md +98 -0
  573. package/templates/.claude/skills/javascript-pro/references/design-patterns.md +100 -0
  574. package/templates/.claude/skills/javascript-pro/references/error-handling.md +100 -0
  575. package/templates/.claude/skills/javascript-pro/references/functional-patterns.md +93 -0
  576. package/templates/.claude/skills/javascript-pro/references/modern-syntax.md +100 -0
  577. package/templates/.claude/skills/javascript-pro/references/performance.md +98 -0
  578. package/templates/.claude/skills/jira-integration/adf-parser.md +338 -0
  579. package/templates/.claude/skills/jira-integration/jira-integration.md +353 -0
  580. package/templates/.claude/skills/knowledge-base/knowledge-base.md +212 -0
  581. package/templates/.claude/skills/mobile-development/SKILL.md +212 -0
  582. package/templates/.claude/skills/mobile-development/references/mobile-android.md +604 -0
  583. package/templates/.claude/skills/mobile-development/references/mobile-best-practices.md +545 -0
  584. package/templates/.claude/skills/mobile-development/references/mobile-debugging.md +1089 -0
  585. package/templates/.claude/skills/mobile-development/references/mobile-frameworks.md +465 -0
  586. package/templates/.claude/skills/mobile-development/references/mobile-ios.md +496 -0
  587. package/templates/.claude/skills/mobile-development/references/mobile-mindset.md +544 -0
  588. package/templates/.claude/skills/mobile-testing/SKILL.md +24 -0
  589. package/templates/.claude/skills/performance-testing/SKILL.md +30 -0
  590. package/templates/.claude/skills/planning/SKILL.md +143 -0
  591. package/templates/.claude/skills/planning/references/codebase-understanding.md +62 -0
  592. package/templates/.claude/skills/planning/references/output-standards.md +87 -0
  593. package/templates/.claude/skills/planning/references/plan-organization.md +137 -0
  594. package/templates/.claude/skills/planning/references/research-phase.md +47 -0
  595. package/templates/.claude/skills/planning/references/solution-design.md +63 -0
  596. package/templates/.claude/skills/playwright/SKILL.md +303 -0
  597. package/templates/.claude/skills/playwright/examples/auth.fixture.ts +172 -0
  598. package/templates/.claude/skills/playwright/examples/login.page.ts +232 -0
  599. package/templates/.claude/skills/playwright/references/config.md +391 -0
  600. package/templates/.claude/skills/problem-solving/SKILL.md +96 -0
  601. package/templates/.claude/skills/problem-solving/references/attribution.md +69 -0
  602. package/templates/.claude/skills/problem-solving/references/collision-zone-thinking.md +79 -0
  603. package/templates/.claude/skills/problem-solving/references/inversion-exercise.md +91 -0
  604. package/templates/.claude/skills/problem-solving/references/meta-pattern-recognition.md +87 -0
  605. package/templates/.claude/skills/problem-solving/references/scale-game.md +95 -0
  606. package/templates/.claude/skills/problem-solving/references/simplification-cascades.md +80 -0
  607. package/templates/.claude/skills/problem-solving/references/when-stuck.md +72 -0
  608. package/templates/.claude/skills/prompt-enhancer/SKILL.md +380 -0
  609. package/templates/.claude/skills/python-pro/SKILL.md +59 -0
  610. package/templates/.claude/skills/python-pro/references/async-patterns.md +96 -0
  611. package/templates/.claude/skills/python-pro/references/error-handling.md +84 -0
  612. package/templates/.claude/skills/python-pro/references/performance.md +71 -0
  613. package/templates/.claude/skills/python-pro/references/project-setup.md +78 -0
  614. package/templates/.claude/skills/python-pro/references/security.md +73 -0
  615. package/templates/.claude/skills/python-pro/references/testing.md +90 -0
  616. package/templates/.claude/skills/python-pro/references/type-system.md +88 -0
  617. package/templates/.claude/skills/qa-standards/SKILL.md +176 -0
  618. package/templates/.claude/skills/qa-standards/references/naming-conventions.md +262 -0
  619. package/templates/.claude/skills/quality-metrics/SKILL.md +27 -0
  620. package/templates/.claude/skills/repomix/SKILL.md +247 -0
  621. package/templates/.claude/skills/repomix/references/configuration.md +211 -0
  622. package/templates/.claude/skills/repomix/references/usage-patterns.md +232 -0
  623. package/templates/.claude/skills/repomix/scripts/README.md +179 -0
  624. package/templates/.claude/skills/repomix/scripts/repomix_batch.py +455 -0
  625. package/templates/.claude/skills/repomix/scripts/repos.example.json +15 -0
  626. package/templates/.claude/skills/repomix/scripts/requirements.txt +15 -0
  627. package/templates/.claude/skills/repomix/scripts/tests/test_repomix_batch.py +531 -0
  628. package/templates/.claude/skills/research/SKILL.md +168 -0
  629. package/templates/.claude/skills/sequential-thinking/.env.example +8 -0
  630. package/templates/.claude/skills/sequential-thinking/README.md +183 -0
  631. package/templates/.claude/skills/sequential-thinking/SKILL.md +94 -0
  632. package/templates/.claude/skills/sequential-thinking/package.json +31 -0
  633. package/templates/.claude/skills/sequential-thinking/references/advanced-strategies.md +79 -0
  634. package/templates/.claude/skills/sequential-thinking/references/advanced-techniques.md +76 -0
  635. package/templates/.claude/skills/sequential-thinking/references/core-patterns.md +95 -0
  636. package/templates/.claude/skills/sequential-thinking/references/examples-api.md +88 -0
  637. package/templates/.claude/skills/sequential-thinking/references/examples-architecture.md +94 -0
  638. package/templates/.claude/skills/sequential-thinking/references/examples-debug.md +90 -0
  639. package/templates/.claude/skills/sequential-thinking/scripts/format-thought.js +159 -0
  640. package/templates/.claude/skills/sequential-thinking/scripts/process-thought.js +236 -0
  641. package/templates/.claude/skills/sequential-thinking/tests/format-thought.test.js +133 -0
  642. package/templates/.claude/skills/sequential-thinking/tests/process-thought.test.js +215 -0
  643. package/templates/.claude/skills/test-automation/SKILL.md +93 -0
  644. package/templates/.claude/skills/test-automation/examples/page-object.ts +44 -0
  645. package/templates/.claude/skills/test-automation/references/frameworks.md +96 -0
  646. package/templates/.claude/skills/test-data-management/SKILL.md +24 -0
  647. package/templates/.claude/skills/test-design/SKILL.md +25 -0
  648. package/templates/.claude/skills/typescript-pro/SKILL.md +84 -0
  649. package/templates/.claude/skills/typescript-pro/references/advanced-patterns.md +100 -0
  650. package/templates/.claude/skills/typescript-pro/references/best-practices.md +96 -0
  651. package/templates/.claude/skills/typescript-pro/references/conditional-types.md +85 -0
  652. package/templates/.claude/skills/typescript-pro/references/generics.md +97 -0
  653. package/templates/.claude/skills/typescript-pro/references/mapped-types.md +99 -0
  654. package/templates/.claude/skills/typescript-pro/references/template-literals.md +85 -0
  655. package/templates/.claude/skills/typescript-pro/references/type-inference.md +94 -0
  656. package/templates/.claude/skills/typescript-pro/references/utility-types.md +96 -0
  657. package/templates/.claude/skills/ui-testing/SKILL.md +24 -0
  658. package/templates/.claude/skills/ui-ux-pro-max/SKILL.md +229 -0
  659. package/templates/.claude/skills/ui-ux-pro-max/data/charts.csv +26 -0
  660. package/templates/.claude/skills/ui-ux-pro-max/data/colors.csv +97 -0
  661. package/templates/.claude/skills/ui-ux-pro-max/data/landing.csv +31 -0
  662. package/templates/.claude/skills/ui-ux-pro-max/data/products.csv +97 -0
  663. package/templates/.claude/skills/ui-ux-pro-max/data/prompts.csv +24 -0
  664. package/templates/.claude/skills/ui-ux-pro-max/data/stacks/flutter.csv +53 -0
  665. package/templates/.claude/skills/ui-ux-pro-max/data/stacks/html-tailwind.csv +56 -0
  666. package/templates/.claude/skills/ui-ux-pro-max/data/stacks/nextjs.csv +53 -0
  667. package/templates/.claude/skills/ui-ux-pro-max/data/stacks/react-native.csv +52 -0
  668. package/templates/.claude/skills/ui-ux-pro-max/data/stacks/react.csv +54 -0
  669. package/templates/.claude/skills/ui-ux-pro-max/data/stacks/svelte.csv +54 -0
  670. package/templates/.claude/skills/ui-ux-pro-max/data/stacks/swiftui.csv +51 -0
  671. package/templates/.claude/skills/ui-ux-pro-max/data/stacks/vue.csv +50 -0
  672. package/templates/.claude/skills/ui-ux-pro-max/data/styles.csv +59 -0
  673. package/templates/.claude/skills/ui-ux-pro-max/data/typography.csv +58 -0
  674. package/templates/.claude/skills/ui-ux-pro-max/data/ux-guidelines.csv +100 -0
  675. package/templates/.claude/skills/ui-ux-pro-max/scripts/core.py +236 -0
  676. package/templates/.claude/skills/ui-ux-pro-max/scripts/search.py +61 -0
  677. package/templates/.claude/skills/webdriverio/SKILL.md +433 -0
  678. package/templates/.claude/skills/webdriverio/examples/mobile.page.ts +369 -0
  679. package/templates/.claude/skills/webdriverio/references/capabilities.md +377 -0
  680. package/templates/.claude/statusline.cjs +105 -0
  681. package/templates/.claude/statusline.ps1 +187 -0
  682. package/templates/.claude/statusline.sh +161 -0
  683. package/templates/.claude/workflows/api-testing-workflow.md +36 -0
  684. package/templates/.claude/workflows/bug-investigation-workflow.md +42 -0
  685. package/templates/.claude/workflows/development-rules.md +366 -0
  686. package/templates/.claude/workflows/documentation-management.md +128 -0
  687. package/templates/.claude/workflows/e2e-testing-workflow.md +36 -0
  688. package/templates/.claude/workflows/orchestration-protocol.md +16 -0
  689. package/templates/.claude/workflows/performance-testing-workflow.md +42 -0
  690. package/templates/.claude/workflows/primary-workflow.md +45 -0
  691. package/templates/.claude/workflows/qa-primary-workflow.md +48 -0
  692. package/templates/.claude/workflows/qa-rules.md +42 -0
  693. package/templates/.claude/workflows/regression-testing-workflow.md +36 -0
  694. package/templates/.claude/workflows/test-driven-qa-workflow.md +37 -0
  695. package/templates/.codex/config.toml.template +29 -0
  696. package/templates/.codex/prompts/qa-commands.md +32 -0
  697. package/templates/.codex/prompts/test-generation.md +29 -0
  698. package/templates/.cursor/CHANGELOG.md +540 -0
  699. package/templates/.cursor/README.md +261 -0
  700. package/templates/.cursor/commands/devkit/ask.md +71 -0
  701. package/templates/.cursor/commands/devkit/backend/create-api.md +207 -0
  702. package/templates/.cursor/commands/devkit/backend/create-migration.md +169 -0
  703. package/templates/.cursor/commands/devkit/backend/create-schema.md +183 -0
  704. package/templates/.cursor/commands/devkit/backend/design-graphql-api.md +287 -0
  705. package/templates/.cursor/commands/devkit/backend/design-rest-api.md +219 -0
  706. package/templates/.cursor/commands/devkit/config/init-backend.md +219 -0
  707. package/templates/.cursor/commands/devkit/config/init-frontend.md +114 -0
  708. package/templates/.cursor/commands/devkit/create-api-integration.md +196 -0
  709. package/templates/.cursor/commands/devkit/create-component.md +104 -0
  710. package/templates/.cursor/commands/devkit/create-form.md +189 -0
  711. package/templates/.cursor/commands/devkit/create-page.md +111 -0
  712. package/templates/.cursor/commands/devkit/create-storybook.md +235 -0
  713. package/templates/.cursor/commands/devkit/create-table.md +251 -0
  714. package/templates/.cursor/commands/devkit/create-test.md +174 -0
  715. package/templates/.cursor/commands/devkit/debug.md +192 -0
  716. package/templates/.cursor/commands/devkit/docs/capture-knowledge.md +252 -0
  717. package/templates/.cursor/commands/devkit/docs/init.md +153 -0
  718. package/templates/.cursor/commands/devkit/docs/summarize.md +82 -0
  719. package/templates/.cursor/commands/devkit/docs/update.md +174 -0
  720. package/templates/.cursor/commands/devkit/fix.md +24 -0
  721. package/templates/.cursor/commands/devkit/help.md +148 -0
  722. package/templates/.cursor/commands/devkit/refactor.md +476 -0
  723. package/templates/.cursor/commands/devkit/research.md +135 -0
  724. package/templates/.cursor/commands/devkit/review/code.md +297 -0
  725. package/templates/.cursor/commands/devkit/review/codebase.md +37 -0
  726. package/templates/.cursor/commands/devkit/scout.md +103 -0
  727. package/templates/.cursor/commands/devkit/solve.md +355 -0
  728. package/templates/.cursor/commands/devkit/spec/brainstorm.md +184 -0
  729. package/templates/.cursor/commands/devkit/spec/capture-requirement.md +164 -0
  730. package/templates/.cursor/commands/devkit/spec/cook.md +101 -0
  731. package/templates/.cursor/commands/devkit/spec/deep-capture-requirement.md +149 -0
  732. package/templates/.cursor/commands/devkit/spec/implement.md +354 -0
  733. package/templates/.cursor/commands/devkit/spec/plan.md +317 -0
  734. package/templates/.cursor/commands/devkit/spec/task.md +150 -0
  735. package/templates/.cursor/commands/devkit/spec/test.md +203 -0
  736. package/templates/.cursor/commands/devkit/spec/update-plan.md +234 -0
  737. package/templates/.cursor/commands/devkit/spec/update-requirement.md +222 -0
  738. package/templates/.cursor/commands/devkit/spec-lite/do.md +154 -0
  739. package/templates/.cursor/commands/devkit/spec-lite/plan.md +197 -0
  740. package/templates/.cursor/commands/devkit/spec-lite/task.md +138 -0
  741. package/templates/.cursor/commands/devkit/spec-lite/test.md +129 -0
  742. package/templates/.cursor/commands/devkit/spec-lite/update-plan.md +133 -0
  743. package/templates/.cursor/commands/devkit/ui-ux-pro-max.md +226 -0
  744. package/templates/.cursor/doc-templates/code-standards.md +486 -0
  745. package/templates/.cursor/doc-templates/codebase-summary.md +426 -0
  746. package/templates/.cursor/doc-templates/development-rules.md +553 -0
  747. package/templates/.cursor/doc-templates/project-overview-pdr.md +494 -0
  748. package/templates/.cursor/doc-templates/system-architecture.md +615 -0
  749. package/templates/.cursor/doc-templates/technical-documents.md +127 -0
  750. package/templates/.cursor/repomix.config.json +34 -0
  751. package/templates/.cursor/rules/backend-development/backend-development.mdc +94 -0
  752. package/templates/.cursor/rules/backend-development/references/backend-api-design.md +495 -0
  753. package/templates/.cursor/rules/backend-development/references/backend-architecture.md +454 -0
  754. package/templates/.cursor/rules/backend-development/references/backend-code-quality.md +659 -0
  755. package/templates/.cursor/rules/backend-development/references/backend-debugging.md +904 -0
  756. package/templates/.cursor/rules/backend-development/references/backend-devops.md +494 -0
  757. package/templates/.cursor/rules/backend-development/references/backend-mindset.md +387 -0
  758. package/templates/.cursor/rules/backend-development/references/backend-performance.md +397 -0
  759. package/templates/.cursor/rules/backend-development/references/backend-security.md +290 -0
  760. package/templates/.cursor/rules/backend-development/references/backend-technologies.md +256 -0
  761. package/templates/.cursor/rules/backend-development/references/backend-testing.md +429 -0
  762. package/templates/.cursor/rules/brainstormer.mdc +147 -0
  763. package/templates/.cursor/rules/code-optimizer.mdc +132 -0
  764. package/templates/.cursor/rules/code-review/code-revew.mdc +144 -0
  765. package/templates/.cursor/rules/code-review/references/code-review-reception.md +209 -0
  766. package/templates/.cursor/rules/code-review/references/requesting-code-review.md +105 -0
  767. package/templates/.cursor/rules/code-review/references/verification-before-completion.md +139 -0
  768. package/templates/.cursor/rules/code-reviewer.mdc +85 -0
  769. package/templates/.cursor/rules/code-simplifier.mdc +121 -0
  770. package/templates/.cursor/rules/coder.mdc +86 -0
  771. package/templates/.cursor/rules/community-rules.mdc +38 -0
  772. package/templates/.cursor/rules/cunningham.mdc +114 -0
  773. package/templates/.cursor/rules/debugger.mdc +108 -0
  774. package/templates/.cursor/rules/development-rules.mdc +208 -0
  775. package/templates/.cursor/rules/docs-manager.mdc +121 -0
  776. package/templates/.cursor/rules/docs-seeker/docs-seeker.mdc +57 -0
  777. package/templates/.cursor/rules/docs-seeker/references/advanced.md +80 -0
  778. package/templates/.cursor/rules/docs-seeker/references/context7-patterns.md +69 -0
  779. package/templates/.cursor/rules/docs-seeker/references/errors.md +69 -0
  780. package/templates/.cursor/rules/docs-seeker/scripts/analyze-llms-txt.js +211 -0
  781. package/templates/.cursor/rules/docs-seeker/scripts/detect-topic.js +172 -0
  782. package/templates/.cursor/rules/docs-seeker/scripts/fetch-docs.js +213 -0
  783. package/templates/.cursor/rules/docs-seeker/scripts/tests/run-tests.js +72 -0
  784. package/templates/.cursor/rules/docs-seeker/scripts/tests/test-analyze-llms.js +119 -0
  785. package/templates/.cursor/rules/docs-seeker/scripts/tests/test-detect-topic.js +112 -0
  786. package/templates/.cursor/rules/docs-seeker/scripts/tests/test-fetch-docs.js +84 -0
  787. package/templates/.cursor/rules/docs-seeker/scripts/utils/env-loader.js +94 -0
  788. package/templates/.cursor/rules/docs-seeker/workflows/library-search.md +88 -0
  789. package/templates/.cursor/rules/docs-seeker/workflows/repo-analysis.md +92 -0
  790. package/templates/.cursor/rules/docs-seeker/workflows/topic-search.md +78 -0
  791. package/templates/.cursor/rules/frontend-development/frontend-development.mdc +131 -0
  792. package/templates/.cursor/rules/frontend-development/references/accessibility.md +719 -0
  793. package/templates/.cursor/rules/frontend-development/references/data-fetching.md +412 -0
  794. package/templates/.cursor/rules/frontend-development/references/forms.md +808 -0
  795. package/templates/.cursor/rules/frontend-development/references/fsd-architecture.md +442 -0
  796. package/templates/.cursor/rules/frontend-development/references/graphql-apollo.md +730 -0
  797. package/templates/.cursor/rules/frontend-development/references/performance.md +417 -0
  798. package/templates/.cursor/rules/frontend-development/references/react-patterns.md +451 -0
  799. package/templates/.cursor/rules/frontend-development/references/routing.md +436 -0
  800. package/templates/.cursor/rules/frontend-development/references/state-management.md +511 -0
  801. package/templates/.cursor/rules/frontend-development/references/tailwind-css.md +398 -0
  802. package/templates/.cursor/rules/frontend-development/references/testing.md +629 -0
  803. package/templates/.cursor/rules/frontend-development/references/typescript-standards.md +364 -0
  804. package/templates/.cursor/rules/frontend-development/references/ui-libraries.md +587 -0
  805. package/templates/.cursor/rules/javascript-pro/javascript-pro.mdc +98 -0
  806. package/templates/.cursor/rules/javascript-pro/references/async-patterns.md +96 -0
  807. package/templates/.cursor/rules/javascript-pro/references/best-practices.md +98 -0
  808. package/templates/.cursor/rules/javascript-pro/references/design-patterns.md +100 -0
  809. package/templates/.cursor/rules/javascript-pro/references/error-handling.md +100 -0
  810. package/templates/.cursor/rules/javascript-pro/references/functional-patterns.md +93 -0
  811. package/templates/.cursor/rules/javascript-pro/references/modern-syntax.md +100 -0
  812. package/templates/.cursor/rules/javascript-pro/references/performance.md +98 -0
  813. package/templates/.cursor/rules/planner.mdc +87 -0
  814. package/templates/.cursor/rules/problem-solving/problem-solving.mdc +96 -0
  815. package/templates/.cursor/rules/problem-solving/references/attribution.md +69 -0
  816. package/templates/.cursor/rules/problem-solving/references/collision-zone-thinking.md +79 -0
  817. package/templates/.cursor/rules/problem-solving/references/inversion-exercise.md +91 -0
  818. package/templates/.cursor/rules/problem-solving/references/meta-pattern-recognition.md +87 -0
  819. package/templates/.cursor/rules/problem-solving/references/scale-game.md +95 -0
  820. package/templates/.cursor/rules/problem-solving/references/simplification-cascades.md +80 -0
  821. package/templates/.cursor/rules/problem-solving/references/when-stuck.md +72 -0
  822. package/templates/.cursor/rules/project-manager.mdc +116 -0
  823. package/templates/.cursor/rules/project-profile.mdc +54 -0
  824. package/templates/.cursor/rules/python-pro/python-pro.mdc +83 -0
  825. package/templates/.cursor/rules/python-pro/references/async-patterns.md +96 -0
  826. package/templates/.cursor/rules/python-pro/references/error-handling.md +84 -0
  827. package/templates/.cursor/rules/python-pro/references/performance.md +71 -0
  828. package/templates/.cursor/rules/python-pro/references/project-setup.md +78 -0
  829. package/templates/.cursor/rules/python-pro/references/security.md +73 -0
  830. package/templates/.cursor/rules/python-pro/references/testing.md +90 -0
  831. package/templates/.cursor/rules/python-pro/references/type-system.md +88 -0
  832. package/templates/.cursor/rules/qa-api-testing.mdc +25 -0
  833. package/templates/.cursor/rules/qa-automation.mdc +28 -0
  834. package/templates/.cursor/rules/qa-testing.mdc +28 -0
  835. package/templates/.cursor/rules/repomix/references/configuration.md +211 -0
  836. package/templates/.cursor/rules/repomix/references/usage-patterns.md +232 -0
  837. package/templates/.cursor/rules/repomix/repomix.mdc +248 -0
  838. package/templates/.cursor/rules/repomix/scripts/README.md +179 -0
  839. package/templates/.cursor/rules/repomix/scripts/repomix_batch.py +455 -0
  840. package/templates/.cursor/rules/repomix/scripts/repos.example.json +15 -0
  841. package/templates/.cursor/rules/repomix/scripts/requirements.txt +15 -0
  842. package/templates/.cursor/rules/repomix/scripts/tests/test_repomix_batch.py +531 -0
  843. package/templates/.cursor/rules/research/research.mdc +111 -0
  844. package/templates/.cursor/rules/researcher.mdc +54 -0
  845. package/templates/.cursor/rules/scout.mdc +105 -0
  846. package/templates/.cursor/rules/security-agent.mdc +122 -0
  847. package/templates/.cursor/rules/security.mdc +90 -0
  848. package/templates/.cursor/rules/sequential-thinking/references/advanced-strategies.md +80 -0
  849. package/templates/.cursor/rules/sequential-thinking/references/advanced-techniques.md +77 -0
  850. package/templates/.cursor/rules/sequential-thinking/references/core-patterns.md +96 -0
  851. package/templates/.cursor/rules/sequential-thinking/references/examples-api.md +89 -0
  852. package/templates/.cursor/rules/sequential-thinking/references/examples-architecture.md +95 -0
  853. package/templates/.cursor/rules/sequential-thinking/references/examples-debug.md +91 -0
  854. package/templates/.cursor/rules/sequential-thinking/scripts/format-thought.js +159 -0
  855. package/templates/.cursor/rules/sequential-thinking/scripts/process-thought.js +236 -0
  856. package/templates/.cursor/rules/sequential-thinking/sequential-thinking.mdc +86 -0
  857. package/templates/.cursor/rules/tattletale-reporter.mdc +64 -0
  858. package/templates/.cursor/rules/tester.mdc +221 -0
  859. package/templates/.cursor/rules/testing.mdc +215 -0
  860. package/templates/.cursor/rules/typescript-pro/references/advanced-patterns.md +100 -0
  861. package/templates/.cursor/rules/typescript-pro/references/best-practices.md +96 -0
  862. package/templates/.cursor/rules/typescript-pro/references/conditional-types.md +85 -0
  863. package/templates/.cursor/rules/typescript-pro/references/generics.md +97 -0
  864. package/templates/.cursor/rules/typescript-pro/references/mapped-types.md +99 -0
  865. package/templates/.cursor/rules/typescript-pro/references/template-literals.md +85 -0
  866. package/templates/.cursor/rules/typescript-pro/references/type-inference.md +94 -0
  867. package/templates/.cursor/rules/typescript-pro/references/utility-types.md +96 -0
  868. package/templates/.cursor/rules/typescript-pro/typescript-pro.mdc +101 -0
  869. package/templates/.cursor/rules/typescript-pro.mdc +129 -0
  870. package/templates/.cursor/rules/ui-ux-designer.mdc +117 -0
  871. package/templates/.cursor/scripts/helper.py +723 -0
  872. package/templates/.cursor/settings.json +5 -0
  873. package/templates/.kiro/steering/qa-standards.md +84 -0
  874. package/templates/.kiro/steering/test-patterns.md +62 -0
  875. package/templates/.kiro/steering/tool-integration.md +73 -0
@@ -0,0 +1,1067 @@
1
+ #!/usr/bin/env python3
2
+ """
3
+ Batch process multiple media files using Gemini API.
4
+
5
+ Supports all Gemini modalities:
6
+ - Audio: Transcription, analysis, summarization
7
+ - Image: Captioning, detection, OCR, analysis
8
+ - Video: Summarization, Q&A, scene detection
9
+ - Document: PDF extraction, structured output
10
+ - Generation: Image creation from text prompts
11
+ """
12
+
13
+ import argparse
14
+ import json
15
+ import os
16
+ import sys
17
+ import time
18
+ from pathlib import Path
19
+ from typing import List, Dict, Any, Optional
20
+ import csv
21
+ import shutil
22
+
23
+ # Import centralized environment resolver
24
+ sys.path.insert(0, str(Path.home() / '.claude' / 'scripts'))
25
+ try:
26
+ from resolve_env import resolve_env
27
+ CENTRALIZED_RESOLVER_AVAILABLE = True
28
+ except ImportError:
29
+ # Fallback if centralized resolver not available
30
+ CENTRALIZED_RESOLVER_AVAILABLE = False
31
+ try:
32
+ from dotenv import load_dotenv
33
+ except ImportError:
34
+ load_dotenv = None
35
+
36
+ try:
37
+ from google import genai
38
+ from google.genai import types
39
+ except ImportError:
40
+ print("Error: google-genai package not installed")
41
+ print("Install with: pip install google-genai")
42
+ sys.exit(1)
43
+
44
+
45
+ # Image generation model fallback chain (highest quality -> lowest cost)
46
+ # All image generation requires billing - no completely free option exists
47
+ # Fallback order: Imagen 4 -> Gemini 2.5 Flash Image (cheaper, still requires billing)
48
+ IMAGE_MODEL_FALLBACK = 'gemini-2.5-flash-image' # Cheaper fallback (~$0.039/image vs ~$0.02-0.04)
49
+ IMAGEN_MODELS = {
50
+ 'imagen-4.0-generate-001',
51
+ 'imagen-4.0-ultra-generate-001',
52
+ 'imagen-4.0-fast-generate-001',
53
+ }
54
+ # Video models have no fallback - Veo always requires billing
55
+
56
+
57
+ def find_api_key() -> Optional[str]:
58
+ """Find Gemini API key using centralized resolver or fallback.
59
+
60
+ Uses ~/.claude/scripts/resolve_env.py for consistent resolution across all skills.
61
+ Falls back to local resolution if centralized resolver not available.
62
+
63
+ Priority order (highest to lowest):
64
+ 1. process.env (runtime environment variables)
65
+ 2. PROJECT/.claude/skills/ai-multimodal/.env (skill-specific)
66
+ 3. PROJECT/.claude/skills/.env (shared skills)
67
+ 4. PROJECT/.claude/.env (project global)
68
+ 5. ~/.claude/skills/ai-multimodal/.env (user skill-specific)
69
+ 6. ~/.claude/skills/.env (user shared)
70
+ 7. ~/.claude/.env (user global)
71
+ """
72
+ if CENTRALIZED_RESOLVER_AVAILABLE:
73
+ # Use centralized resolver (recommended)
74
+ return resolve_env('GEMINI_API_KEY', skill='ai-multimodal')
75
+
76
+ # Fallback: Local resolution (legacy)
77
+ api_key = os.getenv('GEMINI_API_KEY')
78
+ if api_key:
79
+ return api_key
80
+
81
+ if load_dotenv:
82
+ script_dir = Path(__file__).parent
83
+ skill_dir = script_dir.parent
84
+ skills_dir = skill_dir.parent
85
+ claude_dir = skills_dir.parent
86
+
87
+ env_files = [
88
+ claude_dir / '.env',
89
+ skills_dir / '.env',
90
+ skill_dir / '.env',
91
+ ]
92
+
93
+ for env_file in env_files:
94
+ if env_file.exists():
95
+ load_dotenv(env_file, override=True)
96
+
97
+ api_key = os.getenv('GEMINI_API_KEY')
98
+ if api_key:
99
+ return api_key
100
+
101
+ return None
102
+
103
+
104
+ def get_default_model(task: str) -> str:
105
+ """Get default model for task from environment or fallback.
106
+
107
+ Priority:
108
+ 1. Environment variable for specific capability
109
+ 2. Legacy GEMINI_MODEL variable
110
+ 3. Hard-coded defaults
111
+ """
112
+ if task == 'generate': # Image generation
113
+ model = os.getenv('IMAGE_GEN_MODEL')
114
+ if model:
115
+ return model
116
+ # Fallback to legacy
117
+ model = os.getenv('GEMINI_IMAGE_GEN_MODEL')
118
+ if model:
119
+ return model
120
+ # Default to best quality (Imagen 4), with auto-fallback on billing error
121
+ return 'imagen-4.0-generate-001'
122
+
123
+ elif task == 'generate-video':
124
+ model = os.getenv('VIDEO_GEN_MODEL')
125
+ if model:
126
+ return model
127
+ return 'veo-3.1-generate-preview' # New default
128
+
129
+ elif task in ['analyze', 'transcribe', 'extract']:
130
+ model = os.getenv('MULTIMODAL_MODEL')
131
+ if model:
132
+ return model
133
+ # Fallback to legacy
134
+ model = os.getenv('GEMINI_MODEL')
135
+ if model:
136
+ return model
137
+ return 'gemini-2.5-flash' # Existing default
138
+
139
+ return 'gemini-2.5-flash'
140
+
141
+
142
+ def validate_model_task_combination(model: str, task: str) -> None:
143
+ """Validate model is compatible with task.
144
+
145
+ Raises:
146
+ ValueError: If combination is invalid
147
+ """
148
+ # Video generation requires Veo
149
+ if task == 'generate-video':
150
+ if not model.startswith('veo-'):
151
+ raise ValueError(
152
+ f"Video generation requires Veo model, got '{model}'\n"
153
+ f"Valid models: veo-3.1-generate-preview, veo-3.1-fast-generate-preview, "
154
+ f"veo-3.0-generate-001, veo-3.0-fast-generate-001"
155
+ )
156
+
157
+ # Image generation models
158
+ if task == 'generate':
159
+ valid_image_models = [
160
+ 'imagen-4.0-generate-001',
161
+ 'imagen-4.0-ultra-generate-001',
162
+ 'imagen-4.0-fast-generate-001',
163
+ 'gemini-3-pro-image-preview',
164
+ 'gemini-2.5-flash-image',
165
+ 'gemini-2.5-flash-image-preview',
166
+ ]
167
+ if model not in valid_image_models:
168
+ # Allow gemini models for analysis-based generation (backward compat)
169
+ if not model.startswith('gemini-'):
170
+ raise ValueError(
171
+ f"Image generation requires Imagen/Gemini image model, got '{model}'\n"
172
+ f"Valid models: {', '.join(valid_image_models)}"
173
+ )
174
+
175
+
176
+ def infer_task_from_file(file_path: str) -> str:
177
+ """Infer task type from file extension.
178
+
179
+ Returns:
180
+ 'transcribe' for audio files
181
+ 'analyze' for image/video/document files
182
+ """
183
+ ext = Path(file_path).suffix.lower()
184
+
185
+ audio_extensions = {'.mp3', '.wav', '.aac', '.flac', '.ogg', '.aiff', '.m4a'}
186
+ image_extensions = {'.jpg', '.jpeg', '.png', '.webp', '.heic', '.heif', '.gif', '.bmp'}
187
+ video_extensions = {'.mp4', '.mpeg', '.mov', '.avi', '.flv', '.mpg', '.webm', '.wmv', '.3gpp', '.mkv'}
188
+ document_extensions = {'.pdf', '.txt', '.html', '.md', '.doc', '.docx'}
189
+
190
+ if ext in audio_extensions:
191
+ return 'transcribe'
192
+ elif ext in image_extensions:
193
+ return 'analyze'
194
+ elif ext in video_extensions:
195
+ return 'analyze'
196
+ elif ext in document_extensions:
197
+ return 'extract'
198
+
199
+ # Default to analyze for unknown types
200
+ return 'analyze'
201
+
202
+
203
+ def get_mime_type(file_path: str) -> str:
204
+ """Determine MIME type from file extension."""
205
+ ext = Path(file_path).suffix.lower()
206
+
207
+ mime_types = {
208
+ # Audio
209
+ '.mp3': 'audio/mp3',
210
+ '.wav': 'audio/wav',
211
+ '.aac': 'audio/aac',
212
+ '.flac': 'audio/flac',
213
+ '.ogg': 'audio/ogg',
214
+ '.aiff': 'audio/aiff',
215
+ # Image
216
+ '.jpg': 'image/jpeg',
217
+ '.jpeg': 'image/jpeg',
218
+ '.png': 'image/png',
219
+ '.webp': 'image/webp',
220
+ '.heic': 'image/heic',
221
+ '.heif': 'image/heif',
222
+ # Video
223
+ '.mp4': 'video/mp4',
224
+ '.mpeg': 'video/mpeg',
225
+ '.mov': 'video/quicktime',
226
+ '.avi': 'video/x-msvideo',
227
+ '.flv': 'video/x-flv',
228
+ '.mpg': 'video/mpeg',
229
+ '.webm': 'video/webm',
230
+ '.wmv': 'video/x-ms-wmv',
231
+ '.3gpp': 'video/3gpp',
232
+ # Document
233
+ '.pdf': 'application/pdf',
234
+ '.txt': 'text/plain',
235
+ '.html': 'text/html',
236
+ '.md': 'text/markdown',
237
+ }
238
+
239
+ return mime_types.get(ext, 'application/octet-stream')
240
+
241
+
242
+ def upload_file(client: genai.Client, file_path: str, verbose: bool = False) -> Any:
243
+ """Upload file to Gemini File API."""
244
+ if verbose:
245
+ print(f"Uploading {file_path}...")
246
+
247
+ myfile = client.files.upload(file=file_path)
248
+
249
+ # Wait for processing (video/audio files need processing)
250
+ mime_type = get_mime_type(file_path)
251
+ if mime_type.startswith('video/') or mime_type.startswith('audio/'):
252
+ max_wait = 300 # 5 minutes
253
+ elapsed = 0
254
+ while myfile.state.name == 'PROCESSING' and elapsed < max_wait:
255
+ time.sleep(2)
256
+ myfile = client.files.get(name=myfile.name)
257
+ elapsed += 2
258
+ if verbose and elapsed % 10 == 0:
259
+ print(f" Processing... {elapsed}s")
260
+
261
+ if myfile.state.name == 'FAILED':
262
+ raise ValueError(f"File processing failed: {file_path}")
263
+
264
+ if myfile.state.name == 'PROCESSING':
265
+ raise TimeoutError(f"Processing timeout after {max_wait}s: {file_path}")
266
+
267
+ if verbose:
268
+ print(f" Uploaded: {myfile.name}")
269
+
270
+ return myfile
271
+
272
+
273
+ def _is_billing_error(error: Exception) -> bool:
274
+ """Check if error is due to billing/access restrictions."""
275
+ error_str = str(error).lower()
276
+ billing_indicators = [
277
+ 'billing',
278
+ 'billed users',
279
+ 'payment',
280
+ 'access denied',
281
+ 'not authorized',
282
+ 'permission denied',
283
+ ]
284
+ return any(indicator in error_str for indicator in billing_indicators)
285
+
286
+
287
+ def _is_free_tier_quota_error(error: Exception) -> bool:
288
+ """Check if error indicates free tier has zero quota for this model.
289
+
290
+ Free tier users have NO access to image/video generation models.
291
+ The API returns 'limit: 0' or 'RESOURCE_EXHAUSTED' with quota details.
292
+ """
293
+ error_str = str(error)
294
+ # Check for zero quota indicators
295
+ return (
296
+ 'RESOURCE_EXHAUSTED' in error_str and
297
+ ('limit: 0' in error_str or 'free_tier' in error_str.lower())
298
+ )
299
+
300
+
301
+ FREE_TIER_NO_ACCESS_MSG = """
302
+ [FREE TIER LIMITATION] Image/Video generation is NOT available on free tier.
303
+
304
+ Free tier users have zero quota (limit: 0) for:
305
+ - All Imagen models (imagen-4.0-*)
306
+ - All Veo models (veo-*)
307
+ - Gemini image models (gemini-*-image, gemini-*-image-preview)
308
+
309
+ To use image/video generation:
310
+ 1. Enable billing: https://aistudio.google.com/apikey
311
+ 2. Or use Google Cloud $300 free credits: https://cloud.google.com/free
312
+
313
+ STOP: Do not retry image/video generation on free tier - it will always fail.
314
+ """.strip()
315
+
316
+
317
+ def generate_image_imagen4(
318
+ client,
319
+ prompt: str,
320
+ model: str,
321
+ num_images: int = 1,
322
+ aspect_ratio: str = '1:1',
323
+ size: str = '1K',
324
+ verbose: bool = False
325
+ ) -> Dict[str, Any]:
326
+ """Generate image using Imagen 4 models.
327
+
328
+ Returns special status 'billing_required' if model needs billing,
329
+ allowing caller to fallback to free-tier generate_content API.
330
+ """
331
+ try:
332
+ # Build config based on model (Fast doesn't support imageSize)
333
+ config_params = {
334
+ 'numberOfImages': num_images,
335
+ 'aspectRatio': aspect_ratio
336
+ }
337
+
338
+ # Only Standard and Ultra support imageSize parameter
339
+ if 'fast' not in model.lower() and model.startswith('imagen-'):
340
+ config_params['imageSize'] = size
341
+
342
+ gen_config = types.GenerateImagesConfig(**config_params)
343
+
344
+ if verbose:
345
+ print(f" Generating with: {model}")
346
+ print(f" Config: {num_images} images, {aspect_ratio}", end='')
347
+ if 'fast' not in model.lower() and model.startswith('imagen-'):
348
+ print(f", {size}")
349
+ else:
350
+ print()
351
+
352
+ response = client.models.generate_images(
353
+ model=model,
354
+ prompt=prompt,
355
+ config=gen_config
356
+ )
357
+
358
+ # Save images
359
+ generated_files = []
360
+ for i, generated_image in enumerate(response.generated_images):
361
+ # Find project root
362
+ script_dir = Path(__file__).parent
363
+ project_root = script_dir
364
+ for parent in [script_dir] + list(script_dir.parents):
365
+ if (parent / '.git').exists() or (parent / '.claude').exists():
366
+ project_root = parent
367
+ break
368
+
369
+ output_dir = project_root / 'docs' / 'assets'
370
+ output_dir.mkdir(parents=True, exist_ok=True)
371
+ output_file = output_dir / f"imagen4_generated_{int(time.time())}_{i}.png"
372
+
373
+ with open(output_file, 'wb') as f:
374
+ f.write(generated_image.image.image_bytes)
375
+ generated_files.append(str(output_file))
376
+
377
+ if verbose:
378
+ print(f" Saved: {output_file}")
379
+
380
+ return {
381
+ 'status': 'success',
382
+ 'generated_images': generated_files,
383
+ 'model': model
384
+ }
385
+
386
+ except Exception as e:
387
+ # Return special status for billing errors so caller can fallback
388
+ if _is_billing_error(e) and model in IMAGEN_MODELS:
389
+ return {
390
+ 'status': 'billing_required',
391
+ 'original_model': model,
392
+ 'error': str(e)
393
+ }
394
+
395
+ if verbose:
396
+ print(f" Error: {str(e)}")
397
+ import traceback
398
+ traceback.print_exc()
399
+ return {
400
+ 'status': 'error',
401
+ 'error': str(e)
402
+ }
403
+
404
+
405
+ def generate_video_veo(
406
+ client,
407
+ prompt: str,
408
+ model: str,
409
+ resolution: str = '1080p',
410
+ aspect_ratio: str = '16:9',
411
+ reference_images: Optional[List[str]] = None,
412
+ verbose: bool = False
413
+ ) -> Dict[str, Any]:
414
+ """Generate video using Veo models.
415
+
416
+ For image-to-video with first/last frames (Veo 3.1):
417
+ - First reference image becomes the opening frame (image parameter)
418
+ - Second reference image becomes the closing frame (last_frame config)
419
+ - Model interpolates between them to create smooth video
420
+ """
421
+ try:
422
+ # Build config with snake_case for Python SDK
423
+ config_params = {
424
+ 'aspect_ratio': aspect_ratio,
425
+ 'resolution': resolution
426
+ }
427
+
428
+ # Prepare first frame and last frame images
429
+ first_frame = None
430
+ last_frame = None
431
+
432
+ if reference_images:
433
+ import mimetypes
434
+
435
+ def load_image(img_path_str: str) -> types.Image:
436
+ """Load image file as types.Image with bytes and mime type."""
437
+ img_path = Path(img_path_str)
438
+ image_bytes = img_path.read_bytes()
439
+ mime_type, _ = mimetypes.guess_type(str(img_path))
440
+ if not mime_type:
441
+ mime_type = 'image/png'
442
+ return types.Image(
443
+ image_bytes=image_bytes,
444
+ mime_type=mime_type
445
+ )
446
+
447
+ # First image = opening frame
448
+ if len(reference_images) >= 1:
449
+ first_frame = load_image(reference_images[0])
450
+
451
+ # Second image = closing frame (last_frame in config)
452
+ if len(reference_images) >= 2:
453
+ last_frame = load_image(reference_images[1])
454
+ config_params['last_frame'] = last_frame
455
+
456
+ gen_config = types.GenerateVideosConfig(**config_params)
457
+
458
+ if verbose:
459
+ print(f" Generating video with Veo: {model}")
460
+ print(f" Config: {resolution}, {aspect_ratio}")
461
+ if first_frame:
462
+ print(f" First frame: provided")
463
+ if last_frame:
464
+ print(f" Last frame: provided (interpolation mode)")
465
+
466
+ start = time.time()
467
+
468
+ if verbose:
469
+ print(f" Starting video generation (this may take 11s-6min)...")
470
+
471
+ # Call generate_videos with image parameter for first frame
472
+ operation = client.models.generate_videos(
473
+ model=model,
474
+ prompt=prompt,
475
+ image=first_frame, # First frame as opening image
476
+ config=gen_config
477
+ )
478
+
479
+ # Poll operation until complete
480
+ poll_count = 0
481
+ while not operation.done:
482
+ poll_count += 1
483
+ if verbose and poll_count % 3 == 0: # Update every 30s
484
+ elapsed = time.time() - start
485
+ print(f" Still generating... ({elapsed:.0f}s elapsed)")
486
+ time.sleep(10)
487
+ operation = client.operations.get(operation)
488
+
489
+ duration = time.time() - start
490
+
491
+ # Access generated video from operation response
492
+ generated_video = operation.response.generated_videos[0]
493
+
494
+ # Download the video file first
495
+ client.files.download(file=generated_video.video)
496
+
497
+ # Save video
498
+ script_dir = Path(__file__).parent
499
+ project_root = script_dir
500
+ for parent in [script_dir] + list(script_dir.parents):
501
+ if (parent / '.git').exists() or (parent / '.claude').exists():
502
+ project_root = parent
503
+ break
504
+
505
+ output_dir = project_root / 'docs' / 'assets'
506
+ output_dir.mkdir(parents=True, exist_ok=True)
507
+ output_file = output_dir / f"veo_generated_{int(time.time())}.mp4"
508
+
509
+ # Now save to file
510
+ generated_video.video.save(str(output_file))
511
+
512
+ file_size = output_file.stat().st_size / (1024 * 1024) # MB
513
+
514
+ if verbose:
515
+ print(f" Generated in {duration:.1f}s")
516
+ print(f" File size: {file_size:.2f} MB")
517
+ print(f" Saved: {output_file}")
518
+
519
+ return {
520
+ 'status': 'success',
521
+ 'generated_video': str(output_file),
522
+ 'generation_time': duration,
523
+ 'file_size_mb': file_size,
524
+ 'model': model
525
+ }
526
+
527
+ except Exception as e:
528
+ if verbose:
529
+ print(f" Error: {str(e)}")
530
+ import traceback
531
+ traceback.print_exc()
532
+ return {
533
+ 'status': 'error',
534
+ 'error': str(e)
535
+ }
536
+
537
+
538
+ def process_file(
539
+ client: genai.Client,
540
+ file_path: Optional[str],
541
+ prompt: str,
542
+ model: str,
543
+ task: str,
544
+ format_output: str,
545
+ aspect_ratio: Optional[str] = None,
546
+ verbose: bool = False,
547
+ max_retries: int = 3
548
+ ) -> Dict[str, Any]:
549
+ """Process a single file with retry logic."""
550
+
551
+ for attempt in range(max_retries):
552
+ try:
553
+ # For generation tasks without input files
554
+ if task == 'generate' and not file_path:
555
+ content = [prompt]
556
+ else:
557
+ # Process input file
558
+ file_path = Path(file_path)
559
+ # Determine if we need File API
560
+ file_size = file_path.stat().st_size
561
+ use_file_api = file_size > 20 * 1024 * 1024 # >20MB
562
+
563
+ if use_file_api:
564
+ # Upload to File API
565
+ myfile = upload_file(client, str(file_path), verbose)
566
+ content = [prompt, myfile]
567
+ else:
568
+ # Inline data
569
+ with open(file_path, 'rb') as f:
570
+ file_bytes = f.read()
571
+
572
+ mime_type = get_mime_type(str(file_path))
573
+ content = [
574
+ prompt,
575
+ types.Part.from_bytes(data=file_bytes, mime_type=mime_type)
576
+ ]
577
+
578
+ # Configure request
579
+ config_args = {}
580
+ if task == 'generate':
581
+ config_args['response_modalities'] = ['Image'] # Capital I per API spec
582
+ if aspect_ratio:
583
+ # Nest aspect_ratio in image_config per API spec
584
+ config_args['image_config'] = types.ImageConfig(
585
+ aspect_ratio=aspect_ratio
586
+ )
587
+
588
+ if format_output == 'json':
589
+ config_args['response_mime_type'] = 'application/json'
590
+
591
+ config = types.GenerateContentConfig(**config_args) if config_args else None
592
+
593
+ # Generate content
594
+ response = client.models.generate_content(
595
+ model=model,
596
+ contents=content,
597
+ config=config
598
+ )
599
+
600
+ # Extract response
601
+ result = {
602
+ 'file': str(file_path) if file_path else 'generated',
603
+ 'status': 'success',
604
+ 'response': response.text if hasattr(response, 'text') else None
605
+ }
606
+
607
+ # Handle image output
608
+ if task == 'generate' and hasattr(response, 'candidates'):
609
+ for i, part in enumerate(response.candidates[0].content.parts):
610
+ if part.inline_data:
611
+ # Determine output directory - use project root docs/assets
612
+ if file_path:
613
+ output_dir = Path(file_path).parent
614
+ base_name = Path(file_path).stem
615
+ else:
616
+ # Find project root (look for .git or .claude directory)
617
+ script_dir = Path(__file__).parent
618
+ project_root = script_dir
619
+ for parent in [script_dir] + list(script_dir.parents):
620
+ if (parent / '.git').exists() or (parent / '.claude').exists():
621
+ project_root = parent
622
+ break
623
+
624
+ output_dir = project_root / 'docs' / 'assets'
625
+ output_dir.mkdir(parents=True, exist_ok=True)
626
+ base_name = "generated"
627
+
628
+ output_file = output_dir / f"{base_name}_generated_{i}.png"
629
+ with open(output_file, 'wb') as f:
630
+ f.write(part.inline_data.data)
631
+ result['generated_image'] = str(output_file)
632
+ if verbose:
633
+ print(f" Saved image to: {output_file}")
634
+
635
+ return result
636
+
637
+ except Exception as e:
638
+ # Don't retry on billing/free tier errors - they won't resolve
639
+ if _is_billing_error(e) or _is_free_tier_quota_error(e):
640
+ return {
641
+ 'file': str(file_path) if file_path else 'generated',
642
+ 'status': 'error',
643
+ 'error': str(e)
644
+ }
645
+
646
+ if attempt == max_retries - 1:
647
+ return {
648
+ 'file': str(file_path) if file_path else 'generated',
649
+ 'status': 'error',
650
+ 'error': str(e)
651
+ }
652
+
653
+ wait_time = 2 ** attempt
654
+ if verbose:
655
+ print(f" Retry {attempt + 1} after {wait_time}s: {e}")
656
+ time.sleep(wait_time)
657
+
658
+
659
+ def batch_process(
660
+ files: List[str],
661
+ prompt: str,
662
+ model: str,
663
+ task: str,
664
+ format_output: str,
665
+ aspect_ratio: Optional[str] = None,
666
+ num_images: int = 1,
667
+ size: str = '1K',
668
+ resolution: str = '1080p',
669
+ reference_images: Optional[List[str]] = None,
670
+ output_file: Optional[str] = None,
671
+ verbose: bool = False,
672
+ dry_run: bool = False
673
+ ) -> List[Dict[str, Any]]:
674
+ """Batch process multiple files."""
675
+ api_key = find_api_key()
676
+ if not api_key:
677
+ print("Error: GEMINI_API_KEY not found")
678
+ print("\nSetup options:")
679
+ print("1. Run setup checker: python scripts/check_setup.py")
680
+ print("2. Show hierarchy: python ~/.claude/scripts/resolve_env.py --show-hierarchy --skill ai-multimodal")
681
+ print("3. Quick setup: export GEMINI_API_KEY='your-key'")
682
+ print("4. Create .env: cd ~/.claude/skills/ai-multimodal && cp .env.example .env")
683
+ sys.exit(1)
684
+
685
+ if dry_run:
686
+ print("DRY RUN MODE - No API calls will be made")
687
+ print(f"Files to process: {len(files)}")
688
+ print(f"Model: {model}")
689
+ print(f"Task: {task}")
690
+ print(f"Prompt: {prompt}")
691
+ return []
692
+
693
+ client = genai.Client(api_key=api_key)
694
+ results = []
695
+
696
+ # For generation tasks without input files, process once
697
+ if task == 'generate' and not files:
698
+ if verbose:
699
+ print(f"\nGenerating image from prompt...")
700
+
701
+ # Use Imagen 4 API for imagen models
702
+ if model.startswith('imagen-') or model in IMAGEN_MODELS:
703
+ result = generate_image_imagen4(
704
+ client=client,
705
+ prompt=prompt,
706
+ model=model,
707
+ num_images=num_images,
708
+ aspect_ratio=aspect_ratio or '1:1',
709
+ size=size,
710
+ verbose=verbose
711
+ )
712
+
713
+ # Silent fallback to cheaper model if Imagen billing required
714
+ if result.get('status') == 'billing_required':
715
+ if verbose:
716
+ print(f" Falling back to: {IMAGE_MODEL_FALLBACK}")
717
+ result = process_file(
718
+ client=client,
719
+ file_path=None,
720
+ prompt=prompt,
721
+ model=IMAGE_MODEL_FALLBACK,
722
+ task=task,
723
+ format_output=format_output,
724
+ aspect_ratio=aspect_ratio,
725
+ verbose=verbose
726
+ )
727
+ # Check if free tier (zero quota) - stop immediately with clear message
728
+ error_str = result.get('error', '')
729
+ if result.get('status') == 'error':
730
+ if _is_free_tier_quota_error(Exception(error_str)):
731
+ result['error'] = FREE_TIER_NO_ACCESS_MSG
732
+ elif _is_billing_error(Exception(error_str)):
733
+ result['error'] = (
734
+ "Image generation requires billing. Enable billing at: "
735
+ "https://aistudio.google.com/apikey or use Google Cloud credits."
736
+ )
737
+ else:
738
+ # Legacy Flash Image or other models via generate_content API
739
+ result = process_file(
740
+ client=client,
741
+ file_path=None,
742
+ prompt=prompt,
743
+ model=model,
744
+ task=task,
745
+ format_output=format_output,
746
+ aspect_ratio=aspect_ratio,
747
+ verbose=verbose
748
+ )
749
+ # Check for free tier error
750
+ if result.get('status') == 'error':
751
+ error_str = result.get('error', '')
752
+ if _is_free_tier_quota_error(Exception(error_str)):
753
+ result['error'] = FREE_TIER_NO_ACCESS_MSG
754
+
755
+ results.append(result)
756
+
757
+ if verbose:
758
+ status = result.get('status', 'unknown')
759
+ print(f" Status: {status}")
760
+
761
+ elif task == 'generate-video' and not files:
762
+ if verbose:
763
+ print(f"\nGenerating video from prompt...")
764
+
765
+ result = generate_video_veo(
766
+ client=client,
767
+ prompt=prompt,
768
+ model=model,
769
+ resolution=resolution,
770
+ aspect_ratio=aspect_ratio or '16:9',
771
+ reference_images=reference_images,
772
+ verbose=verbose
773
+ )
774
+
775
+ # Check for free tier error - video gen has NO free tier access
776
+ if result.get('status') == 'error':
777
+ error_str = result.get('error', '')
778
+ if _is_free_tier_quota_error(Exception(error_str)) or _is_billing_error(Exception(error_str)):
779
+ result['error'] = FREE_TIER_NO_ACCESS_MSG
780
+
781
+ results.append(result)
782
+
783
+ if verbose:
784
+ status = result.get('status', 'unknown')
785
+ print(f" Status: {status}")
786
+ else:
787
+ # Process input files
788
+ for i, file_path in enumerate(files, 1):
789
+ if verbose:
790
+ print(f"\n[{i}/{len(files)}] Processing: {file_path}")
791
+
792
+ result = process_file(
793
+ client=client,
794
+ file_path=file_path,
795
+ prompt=prompt,
796
+ model=model,
797
+ task=task,
798
+ format_output=format_output,
799
+ aspect_ratio=aspect_ratio,
800
+ verbose=verbose
801
+ )
802
+
803
+ results.append(result)
804
+
805
+ if verbose:
806
+ status = result.get('status', 'unknown')
807
+ print(f" Status: {status}")
808
+
809
+ # Save results
810
+ if output_file:
811
+ save_results(results, output_file, format_output)
812
+
813
+ return results
814
+
815
+
816
+ def print_results(results: List[Dict[str, Any]], task: str) -> None:
817
+ """Print results to stdout for LLM workflows.
818
+
819
+ Always prints actual results (not just success/fail counts) so LLMs
820
+ can continue processing based on the output.
821
+ """
822
+ if not results:
823
+ return
824
+
825
+ print("\n=== RESULTS ===\n")
826
+
827
+ for result in results:
828
+ file_name = result.get('file', 'generated')
829
+ status = result.get('status', 'unknown')
830
+
831
+ print(f"[{file_name}]")
832
+ print(f"Status: {status}")
833
+
834
+ if status == 'success':
835
+ # Print task-specific output
836
+ if task in ['analyze', 'transcribe', 'extract']:
837
+ response = result.get('response')
838
+ if response:
839
+ print(f"Result:\n{response}")
840
+
841
+ elif task == 'generate':
842
+ # Image generation
843
+ generated_images = result.get('generated_images', [])
844
+ if generated_images:
845
+ print(f"Generated images: {len(generated_images)}")
846
+ for img in generated_images:
847
+ print(f" - {img}")
848
+ else:
849
+ generated_image = result.get('generated_image')
850
+ if generated_image:
851
+ print(f"Generated image: {generated_image}")
852
+
853
+ elif task == 'generate-video':
854
+ generated_video = result.get('generated_video')
855
+ if generated_video:
856
+ print(f"Generated video: {generated_video}")
857
+ gen_time = result.get('generation_time')
858
+ if gen_time:
859
+ print(f"Generation time: {gen_time:.1f}s")
860
+ file_size = result.get('file_size_mb')
861
+ if file_size:
862
+ print(f"File size: {file_size:.2f} MB")
863
+
864
+ elif status == 'error':
865
+ error = result.get('error', 'Unknown error')
866
+ print(f"Error: {error}")
867
+
868
+ print() # Blank line between results
869
+
870
+
871
+ def save_results(results: List[Dict[str, Any]], output_file: str, format_output: str):
872
+ """Save results to file."""
873
+ output_path = Path(output_file)
874
+
875
+ # Special handling for image generation - if output has image extension, copy the generated image
876
+ image_extensions = {'.png', '.jpg', '.jpeg', '.webp', '.gif', '.bmp'}
877
+ video_extensions = {'.mp4', '.mov', '.avi', '.webm'}
878
+
879
+ if output_path.suffix.lower() in image_extensions and len(results) == 1:
880
+ # Ensure output directory exists
881
+ output_path.parent.mkdir(parents=True, exist_ok=True)
882
+
883
+ # Check for multiple generated images
884
+ generated_images = results[0].get('generated_images')
885
+ if generated_images:
886
+ # Copy first image to the specified output location
887
+ shutil.copy2(generated_images[0], output_path)
888
+ return
889
+
890
+ # Legacy single image field
891
+ generated_image = results[0].get('generated_image')
892
+ if generated_image:
893
+ shutil.copy2(generated_image, output_path)
894
+ return
895
+ else:
896
+ # Don't write text reports to image files - save error as .txt instead
897
+ output_path = output_path.with_suffix('.error.txt')
898
+ output_path.parent.mkdir(parents=True, exist_ok=True) # Ensure directory exists
899
+ print(f"Warning: Generation failed, saving error report to: {output_path}")
900
+
901
+ if output_path.suffix.lower() in video_extensions and len(results) == 1:
902
+ # Ensure output directory exists
903
+ output_path.parent.mkdir(parents=True, exist_ok=True)
904
+
905
+ generated_video = results[0].get('generated_video')
906
+ if generated_video:
907
+ shutil.copy2(generated_video, output_path)
908
+ return
909
+ else:
910
+ output_path = output_path.with_suffix('.error.txt')
911
+ output_path.parent.mkdir(parents=True, exist_ok=True)
912
+ print(f"Warning: Video generation failed, saving error report to: {output_path}")
913
+
914
+ if format_output == 'json':
915
+ with open(output_path, 'w', encoding='utf-8') as f:
916
+ json.dump(results, f, indent=2)
917
+ elif format_output == 'csv':
918
+ with open(output_path, 'w', newline='', encoding='utf-8') as f:
919
+ fieldnames = ['file', 'status', 'response', 'error']
920
+ writer = csv.DictWriter(f, fieldnames=fieldnames)
921
+ writer.writeheader()
922
+ for result in results:
923
+ writer.writerow({
924
+ 'file': result.get('file', ''),
925
+ 'status': result.get('status', ''),
926
+ 'response': result.get('response', ''),
927
+ 'error': result.get('error', '')
928
+ })
929
+ else: # markdown
930
+ with open(output_path, 'w', encoding='utf-8') as f:
931
+ f.write("# Batch Processing Results\n\n")
932
+ for i, result in enumerate(results, 1):
933
+ f.write(f"## {i}. {result.get('file', 'Unknown')}\n\n")
934
+ f.write(f"**Status**: {result.get('status', 'unknown')}\n\n")
935
+ if result.get('response'):
936
+ f.write(f"**Response**:\n\n{result['response']}\n\n")
937
+ if result.get('error'):
938
+ f.write(f"**Error**: {result['error']}\n\n")
939
+
940
+
941
+ def main():
942
+ parser = argparse.ArgumentParser(
943
+ description='Batch process media files with Gemini API',
944
+ formatter_class=argparse.RawDescriptionHelpFormatter,
945
+ epilog="""
946
+ Examples:
947
+ # Transcribe multiple audio files
948
+ %(prog)s --files *.mp3 --task transcribe --model gemini-2.5-flash
949
+
950
+ # Analyze images
951
+ %(prog)s --files *.jpg --task analyze --prompt "Describe this image" \\
952
+ --model gemini-2.5-flash
953
+
954
+ # Process PDFs to JSON
955
+ %(prog)s --files *.pdf --task extract --prompt "Extract data as JSON" \\
956
+ --format json --output results.json
957
+
958
+ # Generate images
959
+ %(prog)s --task generate --prompt "A mountain landscape" \\
960
+ --model gemini-2.5-flash-image --aspect-ratio 16:9
961
+ """
962
+ )
963
+
964
+ parser.add_argument('--files', nargs='*', help='Input files to process')
965
+ parser.add_argument('--task',
966
+ choices=['transcribe', 'analyze', 'extract', 'generate', 'generate-video'],
967
+ help='Task to perform (auto-detected from file type if not specified)')
968
+ parser.add_argument('--prompt', help='Prompt for analysis/generation')
969
+ parser.add_argument('--model',
970
+ help='Model to use (default: auto-detected from task and env vars)')
971
+ parser.add_argument('--format', dest='format_output', default='text',
972
+ choices=['text', 'json', 'csv', 'markdown'],
973
+ help='Output format (default: text)')
974
+
975
+ # Image generation options
976
+ parser.add_argument('--aspect-ratio', choices=['1:1', '16:9', '9:16', '4:3', '3:4'],
977
+ help='Aspect ratio for image/video generation')
978
+ parser.add_argument('--num-images', type=int, default=1,
979
+ help='Number of images to generate (1-4, default: 1)')
980
+ parser.add_argument('--size', choices=['1K', '2K'], default='1K',
981
+ help='Image size for Imagen 4 (default: 1K)')
982
+
983
+ # Video generation options
984
+ parser.add_argument('--resolution', choices=['720p', '1080p'], default='1080p',
985
+ help='Video resolution (default: 1080p)')
986
+ parser.add_argument('--reference-images', nargs='+',
987
+ help='Reference images for video generation (max 3)')
988
+
989
+ parser.add_argument('--output', help='Output file for results')
990
+ parser.add_argument('--verbose', '-v', action='store_true',
991
+ help='Verbose output')
992
+ parser.add_argument('--dry-run', action='store_true',
993
+ help='Show what would be done without making API calls')
994
+
995
+ args = parser.parse_args()
996
+
997
+ # Auto-detect task from file type if not specified
998
+ if not args.task:
999
+ if args.files and len(args.files) > 0:
1000
+ args.task = infer_task_from_file(args.files[0])
1001
+ if args.verbose:
1002
+ print(f"Auto-detected task: {args.task} (from file extension)")
1003
+ else:
1004
+ parser.error("--task required when no input files provided")
1005
+
1006
+ # Auto-detect model if not specified
1007
+ if not args.model:
1008
+ args.model = get_default_model(args.task)
1009
+ if args.verbose:
1010
+ print(f"Auto-detected model: {args.model}")
1011
+
1012
+ # Validate model/task combination
1013
+ try:
1014
+ validate_model_task_combination(args.model, args.task)
1015
+ except ValueError as e:
1016
+ parser.error(str(e))
1017
+
1018
+ # Validate arguments
1019
+ if args.task not in ['generate', 'generate-video'] and not args.files:
1020
+ parser.error("--files required for non-generation tasks")
1021
+
1022
+ if args.task in ['generate', 'generate-video'] and not args.prompt:
1023
+ parser.error("--prompt required for generation tasks")
1024
+
1025
+ if args.task not in ['generate', 'generate-video'] and not args.prompt:
1026
+ # Set default prompts
1027
+ if args.task == 'transcribe':
1028
+ args.prompt = 'Generate a transcript with timestamps'
1029
+ elif args.task == 'analyze':
1030
+ args.prompt = 'Analyze this content'
1031
+ elif args.task == 'extract':
1032
+ args.prompt = 'Extract key information'
1033
+
1034
+ # Process files
1035
+ files = args.files or []
1036
+ results = batch_process(
1037
+ files=files,
1038
+ prompt=args.prompt,
1039
+ model=args.model,
1040
+ task=args.task,
1041
+ format_output=args.format_output,
1042
+ aspect_ratio=args.aspect_ratio,
1043
+ num_images=args.num_images,
1044
+ size=args.size,
1045
+ resolution=args.resolution,
1046
+ reference_images=args.reference_images,
1047
+ output_file=args.output,
1048
+ verbose=args.verbose,
1049
+ dry_run=args.dry_run
1050
+ )
1051
+
1052
+ # Print results and summary
1053
+ if not args.dry_run and results:
1054
+ # Always print actual results for LLM workflows
1055
+ print_results(results, args.task)
1056
+
1057
+ # Print summary
1058
+ success = sum(1 for r in results if r.get('status') == 'success')
1059
+ failed = len(results) - success
1060
+ print(f"{'='*50}")
1061
+ print(f"Summary: {len(results)} processed, {success} success, {failed} failed")
1062
+ if args.output:
1063
+ print(f"Results saved to: {args.output}")
1064
+
1065
+
1066
+ if __name__ == '__main__':
1067
+ main()