create-hq 5.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 (310) hide show
  1. package/dist/deps.d.ts +4 -0
  2. package/dist/deps.d.ts.map +1 -0
  3. package/dist/deps.js +65 -0
  4. package/dist/deps.js.map +1 -0
  5. package/dist/git.d.ts +3 -0
  6. package/dist/git.d.ts.map +1 -0
  7. package/dist/git.js +19 -0
  8. package/dist/git.js.map +1 -0
  9. package/dist/index.d.ts +3 -0
  10. package/dist/index.d.ts.map +1 -0
  11. package/dist/index.js +23 -0
  12. package/dist/index.js.map +1 -0
  13. package/dist/scaffold.d.ts +8 -0
  14. package/dist/scaffold.d.ts.map +1 -0
  15. package/dist/scaffold.js +130 -0
  16. package/dist/scaffold.js.map +1 -0
  17. package/dist/ui.d.ts +7 -0
  18. package/dist/ui.d.ts.map +1 -0
  19. package/dist/ui.js +36 -0
  20. package/dist/ui.js.map +1 -0
  21. package/package.json +41 -0
  22. package/template/.claude/CLAUDE.md +202 -0
  23. package/template/.claude/commands/checkpoint.md +127 -0
  24. package/template/.claude/commands/cleanup.md +307 -0
  25. package/template/.claude/commands/execute-task.md +440 -0
  26. package/template/.claude/commands/exit-plan.md +41 -0
  27. package/template/.claude/commands/handoff.md +97 -0
  28. package/template/.claude/commands/learn.md +218 -0
  29. package/template/.claude/commands/metrics.md +118 -0
  30. package/template/.claude/commands/newworker.md +162 -0
  31. package/template/.claude/commands/nexttask.md +67 -0
  32. package/template/.claude/commands/prd.md +238 -0
  33. package/template/.claude/commands/reanchor.md +51 -0
  34. package/template/.claude/commands/remember.md +126 -0
  35. package/template/.claude/commands/run-project.md +348 -0
  36. package/template/.claude/commands/run.md +110 -0
  37. package/template/.claude/commands/search-reindex.md +62 -0
  38. package/template/.claude/commands/search.md +100 -0
  39. package/template/.claude/commands/setup.md +381 -0
  40. package/template/.claude/scripts/pure-ralph-loop.ps1 +312 -0
  41. package/template/.claude/scripts/pure-ralph-loop.sh +859 -0
  42. package/template/CHANGELOG.md +220 -0
  43. package/template/LICENSE +21 -0
  44. package/template/MIGRATION.md +259 -0
  45. package/template/README.md +368 -0
  46. package/template/data/journal/.gitkeep +0 -0
  47. package/template/docs/images/ascii-banner-options.md +122 -0
  48. package/template/docs/images/hq-banner.svg +105 -0
  49. package/template/knowledge/Ralph/01-overview.md +71 -0
  50. package/template/knowledge/Ralph/02-core-concepts.md +114 -0
  51. package/template/knowledge/Ralph/03-how-ralph-works.md +184 -0
  52. package/template/knowledge/Ralph/04-back-pressure.md +222 -0
  53. package/template/knowledge/Ralph/05-specifications.md +210 -0
  54. package/template/knowledge/Ralph/06-agents-md.md +222 -0
  55. package/template/knowledge/Ralph/07-implementation.md +316 -0
  56. package/template/knowledge/Ralph/08-economics.md +182 -0
  57. package/template/knowledge/Ralph/09-resources.md +145 -0
  58. package/template/knowledge/Ralph/10-claude-code-workflow.md +212 -0
  59. package/template/knowledge/Ralph/11-team-training-guide.md +383 -0
  60. package/template/knowledge/Ralph/README.md +40 -0
  61. package/template/knowledge/ai-security-framework/CONTRIBUTING.md +139 -0
  62. package/template/knowledge/ai-security-framework/GLOSSARY.md +176 -0
  63. package/template/knowledge/ai-security-framework/LICENSE +21 -0
  64. package/template/knowledge/ai-security-framework/QUICK-START.md +172 -0
  65. package/template/knowledge/ai-security-framework/README.md +232 -0
  66. package/template/knowledge/ai-security-framework/checklists/browser-security.md +301 -0
  67. package/template/knowledge/ai-security-framework/checklists/credential-isolation.md +322 -0
  68. package/template/knowledge/ai-security-framework/checklists/incident-response.md +288 -0
  69. package/template/knowledge/ai-security-framework/checklists/pre-flight.md +249 -0
  70. package/template/knowledge/ai-security-framework/checklists/weekly-audit.md +159 -0
  71. package/template/knowledge/ai-security-framework/configs/audit-logging.md +372 -0
  72. package/template/knowledge/ai-security-framework/configs/kill-switches.md +354 -0
  73. package/template/knowledge/ai-security-framework/docs/01-core-principles.md +256 -0
  74. package/template/knowledge/ai-security-framework/docs/02-threat-landscape.md +326 -0
  75. package/template/knowledge/ai-security-framework/docs/03-security-posture.md +250 -0
  76. package/template/knowledge/ai-security-framework/templates/agents-security.md +233 -0
  77. package/template/knowledge/design-styles/README.md +42 -0
  78. package/template/knowledge/design-styles/american-industrial.md +136 -0
  79. package/template/knowledge/design-styles/ethereal-abstract.md +133 -0
  80. package/template/knowledge/design-styles/liminal-portal.md +111 -0
  81. package/template/knowledge/design-styles/swipes/american-industrial/G-3m4YPW0AADdu2.jpeg +0 -0
  82. package/template/knowledge/design-styles/swipes/american-industrial/G-JJlt5WwAABK3K.png +0 -0
  83. package/template/knowledge/design-styles/swipes/american-industrial/G-JJmj5W0AEbJ-7.png +0 -0
  84. package/template/knowledge/design-styles/swipes/american-industrial/G59fgNuXkAAKLJQ (1).jpeg +0 -0
  85. package/template/knowledge/design-styles/swipes/american-industrial/G59fgNuXkAAKLJQ.jpeg +0 -0
  86. package/template/knowledge/design-styles/swipes/american-industrial/G7fVkn3WEAAM-ST.jpeg +0 -0
  87. package/template/knowledge/design-styles/swipes/american-industrial/G8ECO5JWEAIksyn.png +0 -0
  88. package/template/knowledge/design-styles/swipes/american-industrial/G9-3GQSWoAA8eqZ.png +0 -0
  89. package/template/knowledge/design-styles/swipes/american-industrial/G9xEOqrXkAEZRcs.png +0 -0
  90. package/template/knowledge/design-styles/swipes/american-industrial/G_MVeJrXQAA8sx4.jpeg +0 -0
  91. package/template/knowledge/design-styles/swipes/american-industrial/G_RSkmGXkAAgAVZ.png +0 -0
  92. package/template/knowledge/design-styles/swipes/american-industrial/README.md +31 -0
  93. package/template/knowledge/design-styles/swipes/american-industrial/qyqtg7Dq.png +0 -0
  94. package/template/knowledge/dev-team/README.md +35 -0
  95. package/template/knowledge/dev-team/patterns/README.md +34 -0
  96. package/template/knowledge/dev-team/patterns/frontend/react-best-practices.md +178 -0
  97. package/template/knowledge/dev-team/troubleshooting/README.md +31 -0
  98. package/template/knowledge/dev-team/workflows/README.md +49 -0
  99. package/template/knowledge/hq/checkpoint-schema.json +51 -0
  100. package/template/knowledge/hq/index-md-spec.md +74 -0
  101. package/template/knowledge/hq/thread-schema.md +153 -0
  102. package/template/knowledge/hq-core/checkpoint-schema.json +51 -0
  103. package/template/knowledge/hq-core/index-md-spec.md +74 -0
  104. package/template/knowledge/hq-core/thread-schema.md +153 -0
  105. package/template/knowledge/loom/README.md +51 -0
  106. package/template/knowledge/loom/architecture.md +125 -0
  107. package/template/knowledge/loom/code-style.md +169 -0
  108. package/template/knowledge/loom/llm-proxy.md +132 -0
  109. package/template/knowledge/loom/state-machine.md +131 -0
  110. package/template/knowledge/loom/thread-system.md +117 -0
  111. package/template/knowledge/loom/tools.md +94 -0
  112. package/template/knowledge/loom/weaver.md +96 -0
  113. package/template/knowledge/loom/web-frontend.md +131 -0
  114. package/template/knowledge/projects/README.md +72 -0
  115. package/template/knowledge/projects/templates/README.template.md +28 -0
  116. package/template/knowledge/workers/README.md +195 -0
  117. package/template/knowledge/workers/ralph-loop-pattern.md +157 -0
  118. package/template/knowledge/workers/skill-schema.md +182 -0
  119. package/template/knowledge/workers/state-machine.md +102 -0
  120. package/template/knowledge/workers/templates/base-worker.yaml +73 -0
  121. package/template/knowledge/workers/templates/code-worker.yaml +85 -0
  122. package/template/knowledge/workers/templates/skill.yaml +49 -0
  123. package/template/knowledge/workers/templates/social-worker.yaml +70 -0
  124. package/template/modules/examples/full-manifest.yaml +92 -0
  125. package/template/modules/examples/minimal.yaml +14 -0
  126. package/template/modules/modules.yaml +59 -0
  127. package/template/projects/.gitkeep +0 -0
  128. package/template/projects/incorporate-workers-into-pure-ralph/prd.json +88 -0
  129. package/template/projects/pure-ralph-branch-isolation/README.md +114 -0
  130. package/template/projects/pure-ralph-branch-isolation/prd.json +123 -0
  131. package/template/projects/purist-ralph-loop/README.md +148 -0
  132. package/template/projects/purist-ralph-loop/prd.json +135 -0
  133. package/template/projects/ralph-test/prd.json +50 -0
  134. package/template/prompts/pure-ralph-base.md +551 -0
  135. package/template/settings/.gitkeep +0 -0
  136. package/template/settings/pure-ralph.json +42 -0
  137. package/template/social-content/drafts/INDEX.md +21 -0
  138. package/template/social-content/drafts/linkedin/.gitkeep +1 -0
  139. package/template/social-content/drafts/x/.gitkeep +1 -0
  140. package/template/social-content/images/.gitkeep +1 -0
  141. package/template/starter-projects/code-worker/README.md +97 -0
  142. package/template/starter-projects/code-worker/prd.json +45 -0
  143. package/template/starter-projects/personal-assistant/README.md +42 -0
  144. package/template/starter-projects/personal-assistant/prd.json +43 -0
  145. package/template/starter-projects/social-media/README.md +60 -0
  146. package/template/starter-projects/social-media/prd.json +43 -0
  147. package/template/workers/content-brand/README.md +59 -0
  148. package/template/workers/content-brand/skills/messaging-alignment.md +91 -0
  149. package/template/workers/content-brand/skills/tone-check.md +76 -0
  150. package/template/workers/content-brand/skills/voice-analysis.md +68 -0
  151. package/template/workers/content-brand/worker.yaml +81 -0
  152. package/template/workers/content-legal/README.md +80 -0
  153. package/template/workers/content-legal/skills/claim-substantiation.md +150 -0
  154. package/template/workers/content-legal/skills/compliance-scan.md +123 -0
  155. package/template/workers/content-legal/skills/disclaimer-check.md +146 -0
  156. package/template/workers/content-legal/worker.yaml +118 -0
  157. package/template/workers/content-product/README.md +77 -0
  158. package/template/workers/content-product/skills/claim-verification.md +96 -0
  159. package/template/workers/content-product/skills/feature-accuracy.md +117 -0
  160. package/template/workers/content-product/skills/stats-check.md +128 -0
  161. package/template/workers/content-product/worker.yaml +97 -0
  162. package/template/workers/content-sales/README.md +70 -0
  163. package/template/workers/content-sales/skills/conversion-analysis.md +96 -0
  164. package/template/workers/content-sales/skills/cta-audit.md +107 -0
  165. package/template/workers/content-sales/skills/value-prop-check.md +114 -0
  166. package/template/workers/content-sales/worker.yaml +93 -0
  167. package/template/workers/content-shared/cli.ts +242 -0
  168. package/template/workers/content-shared/index.ts +234 -0
  169. package/template/workers/content-shared/lib/accuracy-analyzer.ts +661 -0
  170. package/template/workers/content-shared/lib/analyze.ts +370 -0
  171. package/template/workers/content-shared/lib/brand-analyzer.ts +526 -0
  172. package/template/workers/content-shared/lib/cms-integration.ts +446 -0
  173. package/template/workers/content-shared/lib/compliance-analyzer.ts +655 -0
  174. package/template/workers/content-shared/lib/conversion-analyzer.ts +555 -0
  175. package/template/workers/content-shared/lib/github-integration.ts +582 -0
  176. package/template/workers/content-shared/lib/output.ts +373 -0
  177. package/template/workers/content-shared/lib/parser.ts +771 -0
  178. package/template/workers/content-shared/lib/priority.ts +439 -0
  179. package/template/workers/content-shared/lib/recommendations.ts +512 -0
  180. package/template/workers/content-shared/lib/reporter.ts +749 -0
  181. package/template/workers/content-shared/lib/restructure.ts +664 -0
  182. package/template/workers/content-shared/lib/scorer.ts +140 -0
  183. package/template/workers/content-shared/lib/types.ts +227 -0
  184. package/template/workers/content-shared/lib/variants.ts +595 -0
  185. package/template/workers/content-shared/package.json +51 -0
  186. package/template/workers/content-shared/pnpm-lock.yaml +39 -0
  187. package/template/workers/content-shared/test/sample-page.json +115 -0
  188. package/template/workers/content-shared/tsconfig.json +20 -0
  189. package/template/workers/dev-team/README.md +166 -0
  190. package/template/workers/dev-team/_template.yaml +70 -0
  191. package/template/workers/dev-team/architect/package.json +27 -0
  192. package/template/workers/dev-team/architect/skills/api-design.md +89 -0
  193. package/template/workers/dev-team/architect/skills/refactor-plan.md +96 -0
  194. package/template/workers/dev-team/architect/skills/system-design.md +100 -0
  195. package/template/workers/dev-team/architect/src/index.ts +49 -0
  196. package/template/workers/dev-team/architect/src/mcp-server.ts +122 -0
  197. package/template/workers/dev-team/architect/src/skills/api-design.ts +316 -0
  198. package/template/workers/dev-team/architect/src/skills/refactor-plan.ts +264 -0
  199. package/template/workers/dev-team/architect/src/skills/system-design.ts +212 -0
  200. package/template/workers/dev-team/architect/tsconfig.json +19 -0
  201. package/template/workers/dev-team/architect/worker.yaml +128 -0
  202. package/template/workers/dev-team/backend-dev/package-lock.json +1252 -0
  203. package/template/workers/dev-team/backend-dev/package.json +27 -0
  204. package/template/workers/dev-team/backend-dev/skills/implement-endpoint.md +70 -0
  205. package/template/workers/dev-team/backend-dev/skills/implement-service.md +62 -0
  206. package/template/workers/dev-team/backend-dev/src/index.ts +51 -0
  207. package/template/workers/dev-team/backend-dev/src/mcp-server.ts +109 -0
  208. package/template/workers/dev-team/backend-dev/src/skills/implement-endpoint.ts +122 -0
  209. package/template/workers/dev-team/backend-dev/src/skills/implement-service.ts +126 -0
  210. package/template/workers/dev-team/backend-dev/tsconfig.json +19 -0
  211. package/template/workers/dev-team/backend-dev/worker.yaml +128 -0
  212. package/template/workers/dev-team/code-reviewer/package-lock.json +1080 -0
  213. package/template/workers/dev-team/code-reviewer/package.json +24 -0
  214. package/template/workers/dev-team/code-reviewer/skills/merge-to-production.md +61 -0
  215. package/template/workers/dev-team/code-reviewer/skills/merge-to-staging.md +54 -0
  216. package/template/workers/dev-team/code-reviewer/skills/request-changes.md +63 -0
  217. package/template/workers/dev-team/code-reviewer/skills/review-pr.md +77 -0
  218. package/template/workers/dev-team/code-reviewer/src/index.ts +56 -0
  219. package/template/workers/dev-team/code-reviewer/src/mcp-server.ts +101 -0
  220. package/template/workers/dev-team/code-reviewer/tsconfig.json +19 -0
  221. package/template/workers/dev-team/code-reviewer/worker.yaml +90 -0
  222. package/template/workers/dev-team/database-dev/package.json +22 -0
  223. package/template/workers/dev-team/database-dev/skills/create-schema.md +48 -0
  224. package/template/workers/dev-team/database-dev/src/index.ts +50 -0
  225. package/template/workers/dev-team/database-dev/src/mcp-server.ts +76 -0
  226. package/template/workers/dev-team/database-dev/tsconfig.json +18 -0
  227. package/template/workers/dev-team/database-dev/worker.yaml +90 -0
  228. package/template/workers/dev-team/frontend-dev/package.json +22 -0
  229. package/template/workers/dev-team/frontend-dev/skills/create-component.md +26 -0
  230. package/template/workers/dev-team/frontend-dev/src/index.ts +50 -0
  231. package/template/workers/dev-team/frontend-dev/src/mcp-server.ts +77 -0
  232. package/template/workers/dev-team/frontend-dev/tsconfig.json +18 -0
  233. package/template/workers/dev-team/frontend-dev/worker.yaml +132 -0
  234. package/template/workers/dev-team/infra-dev/package.json +24 -0
  235. package/template/workers/dev-team/infra-dev/skills/add-monitoring.md +73 -0
  236. package/template/workers/dev-team/infra-dev/skills/configure-deployment.md +80 -0
  237. package/template/workers/dev-team/infra-dev/skills/create-dockerfile.md +62 -0
  238. package/template/workers/dev-team/infra-dev/skills/setup-cicd.md +63 -0
  239. package/template/workers/dev-team/infra-dev/src/index.ts +55 -0
  240. package/template/workers/dev-team/infra-dev/src/mcp-server.ts +82 -0
  241. package/template/workers/dev-team/infra-dev/tsconfig.json +19 -0
  242. package/template/workers/dev-team/infra-dev/worker.yaml +92 -0
  243. package/template/workers/dev-team/knowledge-curator/package.json +24 -0
  244. package/template/workers/dev-team/knowledge-curator/skills/curate-troubleshooting.md +63 -0
  245. package/template/workers/dev-team/knowledge-curator/skills/process-learnings.md +61 -0
  246. package/template/workers/dev-team/knowledge-curator/skills/sync-documentation.md +76 -0
  247. package/template/workers/dev-team/knowledge-curator/skills/update-patterns.md +63 -0
  248. package/template/workers/dev-team/knowledge-curator/src/index.ts +53 -0
  249. package/template/workers/dev-team/knowledge-curator/src/mcp-server.ts +92 -0
  250. package/template/workers/dev-team/knowledge-curator/tsconfig.json +19 -0
  251. package/template/workers/dev-team/knowledge-curator/worker.yaml +80 -0
  252. package/template/workers/dev-team/motion-designer/package.json +22 -0
  253. package/template/workers/dev-team/motion-designer/skills/add-animation.md +25 -0
  254. package/template/workers/dev-team/motion-designer/skills/generate-image.md +36 -0
  255. package/template/workers/dev-team/motion-designer/src/index.ts +63 -0
  256. package/template/workers/dev-team/motion-designer/src/mcp-server.ts +79 -0
  257. package/template/workers/dev-team/motion-designer/tsconfig.json +18 -0
  258. package/template/workers/dev-team/motion-designer/worker.yaml +84 -0
  259. package/template/workers/dev-team/product-planner/queue.json +4 -0
  260. package/template/workers/dev-team/product-planner/worker.yaml +220 -0
  261. package/template/workers/dev-team/project-manager/package-lock.json +1252 -0
  262. package/template/workers/dev-team/project-manager/package.json +27 -0
  263. package/template/workers/dev-team/project-manager/skills/create-prd.md +66 -0
  264. package/template/workers/dev-team/project-manager/skills/next-issue.md +51 -0
  265. package/template/workers/dev-team/project-manager/skills/project-status.md +59 -0
  266. package/template/workers/dev-team/project-manager/skills/update-learnings.md +65 -0
  267. package/template/workers/dev-team/project-manager/src/index.ts +54 -0
  268. package/template/workers/dev-team/project-manager/src/mcp-server.ts +207 -0
  269. package/template/workers/dev-team/project-manager/src/skills/create-prd.ts +86 -0
  270. package/template/workers/dev-team/project-manager/src/skills/next-issue.ts +137 -0
  271. package/template/workers/dev-team/project-manager/src/skills/project-status.ts +131 -0
  272. package/template/workers/dev-team/project-manager/src/skills/update-learnings.ts +94 -0
  273. package/template/workers/dev-team/project-manager/tsconfig.json +19 -0
  274. package/template/workers/dev-team/project-manager/worker.yaml +96 -0
  275. package/template/workers/dev-team/qa-tester/package.json +24 -0
  276. package/template/workers/dev-team/qa-tester/skills/create-demo-account.md +36 -0
  277. package/template/workers/dev-team/qa-tester/skills/run-tests.md +36 -0
  278. package/template/workers/dev-team/qa-tester/skills/write-test.md +27 -0
  279. package/template/workers/dev-team/qa-tester/src/index.ts +61 -0
  280. package/template/workers/dev-team/qa-tester/src/mcp-server.ts +88 -0
  281. package/template/workers/dev-team/qa-tester/tsconfig.json +18 -0
  282. package/template/workers/dev-team/qa-tester/worker.yaml +116 -0
  283. package/template/workers/dev-team/task-executor/package-lock.json +1252 -0
  284. package/template/workers/dev-team/task-executor/package.json +27 -0
  285. package/template/workers/dev-team/task-executor/skills/analyze-issue.md +101 -0
  286. package/template/workers/dev-team/task-executor/skills/execute.md +133 -0
  287. package/template/workers/dev-team/task-executor/skills/report-learnings.md +106 -0
  288. package/template/workers/dev-team/task-executor/skills/validate-completion.md +121 -0
  289. package/template/workers/dev-team/task-executor/src/index.ts +54 -0
  290. package/template/workers/dev-team/task-executor/src/mcp-server.ts +139 -0
  291. package/template/workers/dev-team/task-executor/src/skills/analyze-issue.ts +219 -0
  292. package/template/workers/dev-team/task-executor/src/skills/execute.ts +132 -0
  293. package/template/workers/dev-team/task-executor/src/skills/report-learnings.ts +119 -0
  294. package/template/workers/dev-team/task-executor/src/skills/validate-completion.ts +142 -0
  295. package/template/workers/dev-team/task-executor/tsconfig.json +19 -0
  296. package/template/workers/dev-team/task-executor/worker.yaml +110 -0
  297. package/template/workers/registry.yaml +171 -0
  298. package/template/workers/security-scanner/README.md +73 -0
  299. package/template/workers/security-scanner/skills/pre-deploy-check.md +205 -0
  300. package/template/workers/security-scanner/worker.yaml +26 -0
  301. package/template/workspace/checkpoints/.gitkeep +0 -0
  302. package/template/workspace/content-ideas/inbox.jsonl +0 -0
  303. package/template/workspace/drafts/.gitkeep +0 -0
  304. package/template/workspace/learnings/.gitkeep +3 -0
  305. package/template/workspace/orchestrator/.gitkeep +0 -0
  306. package/template/workspace/ralph-test/COMPLETE.md +18 -0
  307. package/template/workspace/ralph-test/hello.txt +2 -0
  308. package/template/workspace/reports/.gitkeep +0 -0
  309. package/template/workspace/scratch/.gitkeep +0 -0
  310. package/template/workspace/threads/.gitkeep +3 -0
@@ -0,0 +1,373 @@
1
+ /**
2
+ * Unified Output Manager
3
+ * Coordinates output across reports, GitHub, and CMS
4
+ */
5
+
6
+ import type { FullAnalysis } from './types.js';
7
+ import type { Suggestion } from './recommendations.js';
8
+ import { generateSuggestions } from './recommendations.js';
9
+ import {
10
+ generateFullReport,
11
+ generateExecutiveSummary,
12
+ writeReport,
13
+ generateReportPath,
14
+ type ReportConfig,
15
+ DEFAULT_REPORT_CONFIG,
16
+ } from './reporter.js';
17
+ import {
18
+ createIssuesFromAnalysis,
19
+ createPRFromSuggestions,
20
+ generateGitHubIssueCommand,
21
+ generateCommitMessage,
22
+ type GitHubConfig,
23
+ type GitHubIssue,
24
+ type GitHubPR,
25
+ DEFAULT_GITHUB_CONFIG,
26
+ } from './github-integration.js';
27
+ import {
28
+ createCMSClient,
29
+ createDryRunCMSClient,
30
+ toCMSSuggestions,
31
+ type CMSClientConfig,
32
+ type CMSBatchResult,
33
+ } from './cms-integration.js';
34
+
35
+ // ============================================
36
+ // Types
37
+ // ============================================
38
+
39
+ export interface OutputConfig {
40
+ /** Path for markdown reports */
41
+ reportPath: string;
42
+ /** Worker name for report filenames */
43
+ workerName: string;
44
+ /** Enable GitHub issue/PR generation */
45
+ enableGitHub: boolean;
46
+ /** GitHub configuration */
47
+ githubConfig?: Partial<GitHubConfig>;
48
+ /** Enable CMS submission */
49
+ enableCMS: boolean;
50
+ /** CMS configuration */
51
+ cmsConfig?: CMSClientConfig;
52
+ /** Maximum issues to create */
53
+ maxIssues: number;
54
+ /** Only high-priority items */
55
+ highPriorityOnly: boolean;
56
+ /** Dry run mode (no actual submissions) */
57
+ dryRun: boolean;
58
+ }
59
+
60
+ export const DEFAULT_OUTPUT_CONFIG: OutputConfig = {
61
+ reportPath: 'workspace/reports/content',
62
+ workerName: 'content-worker',
63
+ enableGitHub: false,
64
+ githubConfig: undefined,
65
+ enableCMS: false,
66
+ cmsConfig: undefined,
67
+ maxIssues: 10,
68
+ highPriorityOnly: false,
69
+ dryRun: true,
70
+ };
71
+
72
+ export interface OutputResult {
73
+ /** Path to generated report */
74
+ reportPath: string;
75
+ /** Number of GitHub issues created/prepared */
76
+ issuesCreated: number;
77
+ /** GitHub issues (for dry run review) */
78
+ issues?: GitHubIssue[];
79
+ /** GitHub PR (if generated) */
80
+ pr?: GitHubPR;
81
+ /** Number of CMS suggestions submitted */
82
+ suggestionsSubmitted: number;
83
+ /** CMS submission result */
84
+ cmsResult?: CMSBatchResult;
85
+ /** Any errors encountered */
86
+ errors: string[];
87
+ }
88
+
89
+ // ============================================
90
+ // Main Output Functions
91
+ // ============================================
92
+
93
+ /**
94
+ * Process analysis and generate all outputs
95
+ */
96
+ export async function processAnalysisOutput(
97
+ analysis: FullAnalysis,
98
+ config: Partial<OutputConfig> = {}
99
+ ): Promise<OutputResult> {
100
+ const cfg = { ...DEFAULT_OUTPUT_CONFIG, ...config };
101
+ const errors: string[] = [];
102
+
103
+ // Generate suggestions from analysis
104
+ let suggestions = generateSuggestions(analysis);
105
+
106
+ // Filter to high priority if configured
107
+ if (cfg.highPriorityOnly) {
108
+ suggestions = suggestions.filter(s => s.impact === 'high');
109
+ }
110
+
111
+ // 1. Generate and save report
112
+ let reportPath = '';
113
+ try {
114
+ const reportContent = generateFullReport(analysis);
115
+ const fullReportPath = generateReportPath(cfg.workerName, analysis.page, cfg.reportPath);
116
+ const dir = cfg.reportPath;
117
+ const filename = fullReportPath.split('/').pop() ?? `${analysis.page}.md`;
118
+ reportPath = writeReport(reportContent, filename, dir);
119
+ } catch (error) {
120
+ errors.push(`Report generation failed: ${error instanceof Error ? error.message : 'Unknown error'}`);
121
+ }
122
+
123
+ // 2. Generate GitHub issues
124
+ let issuesCreated = 0;
125
+ let issues: GitHubIssue[] = [];
126
+ if (cfg.enableGitHub && suggestions.length > 0) {
127
+ try {
128
+ issues = createIssuesFromAnalysis(
129
+ analysis,
130
+ suggestions,
131
+ cfg.maxIssues,
132
+ cfg.githubConfig
133
+ );
134
+ issuesCreated = issues.length;
135
+
136
+ if (!cfg.dryRun) {
137
+ // In non-dry-run mode, we would execute the gh commands
138
+ // For now, we just prepare the commands
139
+ console.log(`[GitHub] Prepared ${issues.length} issues for creation`);
140
+ for (const issue of issues) {
141
+ const cmd = generateGitHubIssueCommand(issue, cfg.githubConfig);
142
+ console.log(`[GitHub] Command: ${cmd}`);
143
+ }
144
+ }
145
+ } catch (error) {
146
+ errors.push(`GitHub issue generation failed: ${error instanceof Error ? error.message : 'Unknown error'}`);
147
+ }
148
+ }
149
+
150
+ // 3. Submit to CMS
151
+ let suggestionsSubmitted = 0;
152
+ let cmsResult: CMSBatchResult | undefined;
153
+ if (cfg.enableCMS && suggestions.length > 0) {
154
+ try {
155
+ const client = cfg.dryRun
156
+ ? createDryRunCMSClient()
157
+ : createCMSClient(cfg.cmsConfig ?? { baseUrl: '' });
158
+
159
+ const cmsSuggestions = toCMSSuggestions(suggestions);
160
+ cmsResult = await client.submitSuggestions(cmsSuggestions);
161
+ suggestionsSubmitted = cmsResult.submitted;
162
+ } catch (error) {
163
+ errors.push(`CMS submission failed: ${error instanceof Error ? error.message : 'Unknown error'}`);
164
+ }
165
+ }
166
+
167
+ return {
168
+ reportPath,
169
+ issuesCreated,
170
+ issues: cfg.dryRun ? issues : undefined,
171
+ suggestionsSubmitted,
172
+ cmsResult,
173
+ errors,
174
+ };
175
+ }
176
+
177
+ /**
178
+ * Batch process multiple pages
179
+ */
180
+ export async function processMultiplePages(
181
+ analyses: FullAnalysis[],
182
+ config: Partial<OutputConfig> = {}
183
+ ): Promise<OutputResult[]> {
184
+ const results: OutputResult[] = [];
185
+
186
+ for (const analysis of analyses) {
187
+ const result = await processAnalysisOutput(analysis, config);
188
+ results.push(result);
189
+ }
190
+
191
+ // Also generate executive summary
192
+ const cfg = { ...DEFAULT_OUTPUT_CONFIG, ...config };
193
+ try {
194
+ const summaryContent = generateExecutiveSummary(analyses);
195
+ const date = new Date().toISOString().split('T')[0];
196
+ const filename = `${date}-${cfg.workerName}-executive-summary.md`;
197
+ writeReport(summaryContent, filename, cfg.reportPath);
198
+ } catch (error) {
199
+ console.error('Failed to generate executive summary:', error);
200
+ }
201
+
202
+ return results;
203
+ }
204
+
205
+ /**
206
+ * Generate PR from approved suggestions
207
+ */
208
+ export async function generatePRFromApprovedSuggestions(
209
+ suggestions: Suggestion[],
210
+ pageContents: Map<string, { path: string; content: string }>,
211
+ config: Partial<OutputConfig> = {}
212
+ ): Promise<{ pr: GitHubPR; commitMessage: string }> {
213
+ const cfg = { ...DEFAULT_OUTPUT_CONFIG, ...config };
214
+
215
+ const pr = createPRFromSuggestions(suggestions, pageContents, cfg.githubConfig);
216
+ const commitMessage = generateCommitMessage(suggestions);
217
+
218
+ return { pr, commitMessage };
219
+ }
220
+
221
+ // ============================================
222
+ // Output Summary
223
+ // ============================================
224
+
225
+ /**
226
+ * Generate summary of output results
227
+ */
228
+ export function summarizeOutputResults(results: OutputResult[]): string {
229
+ const lines: string[] = [];
230
+
231
+ lines.push('# Output Summary');
232
+ lines.push('');
233
+
234
+ // Totals
235
+ const totalReports = results.filter(r => r.reportPath).length;
236
+ const totalIssues = results.reduce((sum, r) => sum + r.issuesCreated, 0);
237
+ const totalSubmitted = results.reduce((sum, r) => sum + r.suggestionsSubmitted, 0);
238
+ const totalErrors = results.reduce((sum, r) => sum + r.errors.length, 0);
239
+
240
+ lines.push('## Totals');
241
+ lines.push('');
242
+ lines.push(`- Reports generated: ${totalReports}`);
243
+ lines.push(`- GitHub issues prepared: ${totalIssues}`);
244
+ lines.push(`- CMS suggestions submitted: ${totalSubmitted}`);
245
+ lines.push(`- Errors: ${totalErrors}`);
246
+ lines.push('');
247
+
248
+ // Per-page details
249
+ lines.push('## Details');
250
+ lines.push('');
251
+
252
+ for (const result of results) {
253
+ lines.push(`### ${result.reportPath.split('/').pop() ?? 'Unknown'}`);
254
+ lines.push(`- Issues: ${result.issuesCreated}`);
255
+ lines.push(`- CMS: ${result.suggestionsSubmitted}`);
256
+ if (result.errors.length > 0) {
257
+ lines.push(`- Errors: ${result.errors.join(', ')}`);
258
+ }
259
+ lines.push('');
260
+ }
261
+
262
+ return lines.join('\n');
263
+ }
264
+
265
+ /**
266
+ * Format output result for JSON export
267
+ */
268
+ export function formatOutputResultJSON(result: OutputResult): object {
269
+ return {
270
+ summary: `Generated report and ${result.issuesCreated} issues`,
271
+ files_created: result.reportPath ? [result.reportPath] : [],
272
+ files_modified: [],
273
+ key_decisions: [
274
+ result.issuesCreated > 0 ? `Created ${result.issuesCreated} GitHub issues` : null,
275
+ result.suggestionsSubmitted > 0 ? `Submitted ${result.suggestionsSubmitted} CMS suggestions` : null,
276
+ ].filter(Boolean),
277
+ back_pressure: {
278
+ typecheck: result.errors.length === 0 ? 'pass' : 'fail',
279
+ },
280
+ };
281
+ }
282
+
283
+ // ============================================
284
+ // Quick Actions
285
+ // ============================================
286
+
287
+ /**
288
+ * Quick action: Generate report only
289
+ */
290
+ export async function reportOnly(
291
+ analysis: FullAnalysis,
292
+ outputPath: string = DEFAULT_OUTPUT_CONFIG.reportPath,
293
+ workerName: string = DEFAULT_OUTPUT_CONFIG.workerName
294
+ ): Promise<string> {
295
+ const result = await processAnalysisOutput(analysis, {
296
+ reportPath: outputPath,
297
+ workerName,
298
+ enableGitHub: false,
299
+ enableCMS: false,
300
+ });
301
+ return result.reportPath;
302
+ }
303
+
304
+ /**
305
+ * Quick action: Generate issues only (dry run)
306
+ */
307
+ export async function issuesOnly(
308
+ analysis: FullAnalysis,
309
+ maxIssues: number = 10,
310
+ githubConfig?: Partial<GitHubConfig>
311
+ ): Promise<GitHubIssue[]> {
312
+ const result = await processAnalysisOutput(analysis, {
313
+ enableGitHub: true,
314
+ enableCMS: false,
315
+ maxIssues,
316
+ githubConfig,
317
+ dryRun: true,
318
+ });
319
+ return result.issues ?? [];
320
+ }
321
+
322
+ /**
323
+ * Quick action: Submit to CMS only
324
+ */
325
+ export async function cmsOnly(
326
+ analysis: FullAnalysis,
327
+ cmsConfig: CMSClientConfig,
328
+ dryRun: boolean = true
329
+ ): Promise<CMSBatchResult | undefined> {
330
+ const result = await processAnalysisOutput(analysis, {
331
+ enableGitHub: false,
332
+ enableCMS: true,
333
+ cmsConfig,
334
+ dryRun,
335
+ });
336
+ return result.cmsResult;
337
+ }
338
+
339
+ // ============================================
340
+ // Pipeline Integration
341
+ // ============================================
342
+
343
+ /**
344
+ * Full pipeline: Analyze, suggest, and output
345
+ */
346
+ export async function runFullPipeline(
347
+ analyses: FullAnalysis[],
348
+ config: Partial<OutputConfig> = {}
349
+ ): Promise<{
350
+ results: OutputResult[];
351
+ summary: string;
352
+ json: object;
353
+ }> {
354
+ const results = await processMultiplePages(analyses, config);
355
+ const summary = summarizeOutputResults(results);
356
+
357
+ // Aggregate JSON output
358
+ const json = {
359
+ summary: `Processed ${analyses.length} pages`,
360
+ files_created: results.map(r => r.reportPath).filter(Boolean),
361
+ files_modified: [],
362
+ key_decisions: [
363
+ `Generated ${results.length} reports`,
364
+ `Prepared ${results.reduce((s, r) => s + r.issuesCreated, 0)} GitHub issues`,
365
+ `Submitted ${results.reduce((s, r) => s + r.suggestionsSubmitted, 0)} CMS suggestions`,
366
+ ],
367
+ back_pressure: {
368
+ typecheck: results.every(r => r.errors.length === 0) ? 'pass' : 'fail',
369
+ },
370
+ };
371
+
372
+ return { results, summary, json };
373
+ }