create-hq 6.0.0 → 10.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 (336) hide show
  1. package/dist/__tests__/deps.test.d.ts +2 -0
  2. package/dist/__tests__/deps.test.d.ts.map +1 -0
  3. package/dist/__tests__/deps.test.js +176 -0
  4. package/dist/__tests__/deps.test.js.map +1 -0
  5. package/dist/__tests__/platform.test.d.ts +2 -0
  6. package/dist/__tests__/platform.test.d.ts.map +1 -0
  7. package/dist/__tests__/platform.test.js +127 -0
  8. package/dist/__tests__/platform.test.js.map +1 -0
  9. package/dist/__tests__/scaffold.test.d.ts +2 -0
  10. package/dist/__tests__/scaffold.test.d.ts.map +1 -0
  11. package/dist/__tests__/scaffold.test.js +150 -0
  12. package/dist/__tests__/scaffold.test.js.map +1 -0
  13. package/dist/auth.d.ts +32 -0
  14. package/dist/auth.d.ts.map +1 -0
  15. package/dist/auth.js +156 -0
  16. package/dist/auth.js.map +1 -0
  17. package/dist/cloud-sync.d.ts +11 -0
  18. package/dist/cloud-sync.d.ts.map +1 -0
  19. package/dist/cloud-sync.js +25 -0
  20. package/dist/cloud-sync.js.map +1 -0
  21. package/dist/deps.d.ts +32 -2
  22. package/dist/deps.d.ts.map +1 -1
  23. package/dist/deps.js +182 -7
  24. package/dist/deps.js.map +1 -1
  25. package/dist/fetch-template.d.ts +14 -0
  26. package/dist/fetch-template.d.ts.map +1 -0
  27. package/dist/fetch-template.js +136 -0
  28. package/dist/fetch-template.js.map +1 -0
  29. package/dist/index.js +9 -7
  30. package/dist/index.js.map +1 -1
  31. package/dist/packages.d.ts +71 -0
  32. package/dist/packages.d.ts.map +1 -0
  33. package/dist/packages.js +332 -0
  34. package/dist/packages.js.map +1 -0
  35. package/dist/platform.d.ts +9 -0
  36. package/dist/platform.d.ts.map +1 -0
  37. package/dist/platform.js +69 -0
  38. package/dist/platform.js.map +1 -0
  39. package/dist/scaffold.d.ts +3 -2
  40. package/dist/scaffold.d.ts.map +1 -1
  41. package/dist/scaffold.js +109 -290
  42. package/dist/scaffold.js.map +1 -1
  43. package/dist/ui.d.ts +2 -3
  44. package/dist/ui.d.ts.map +1 -1
  45. package/dist/ui.js +90 -44
  46. package/dist/ui.js.map +1 -1
  47. package/package.json +49 -40
  48. package/template/.claude/CLAUDE.md +0 -202
  49. package/template/.claude/commands/checkpoint.md +0 -127
  50. package/template/.claude/commands/cleanup.md +0 -307
  51. package/template/.claude/commands/execute-task.md +0 -440
  52. package/template/.claude/commands/exit-plan.md +0 -41
  53. package/template/.claude/commands/handoff.md +0 -97
  54. package/template/.claude/commands/learn.md +0 -218
  55. package/template/.claude/commands/metrics.md +0 -118
  56. package/template/.claude/commands/newworker.md +0 -162
  57. package/template/.claude/commands/nexttask.md +0 -67
  58. package/template/.claude/commands/prd.md +0 -238
  59. package/template/.claude/commands/reanchor.md +0 -51
  60. package/template/.claude/commands/remember.md +0 -126
  61. package/template/.claude/commands/run-project.md +0 -348
  62. package/template/.claude/commands/run.md +0 -110
  63. package/template/.claude/commands/search-reindex.md +0 -62
  64. package/template/.claude/commands/search.md +0 -100
  65. package/template/.claude/commands/setup.md +0 -381
  66. package/template/.claude/scripts/pure-ralph-loop.ps1 +0 -312
  67. package/template/.claude/scripts/pure-ralph-loop.sh +0 -859
  68. package/template/CHANGELOG.md +0 -220
  69. package/template/LICENSE +0 -21
  70. package/template/MIGRATION.md +0 -259
  71. package/template/README.md +0 -368
  72. package/template/data/journal/.gitkeep +0 -0
  73. package/template/docs/images/ascii-banner-options.md +0 -122
  74. package/template/docs/images/hq-banner.svg +0 -105
  75. package/template/knowledge/Ralph/01-overview.md +0 -71
  76. package/template/knowledge/Ralph/02-core-concepts.md +0 -114
  77. package/template/knowledge/Ralph/03-how-ralph-works.md +0 -184
  78. package/template/knowledge/Ralph/04-back-pressure.md +0 -222
  79. package/template/knowledge/Ralph/05-specifications.md +0 -210
  80. package/template/knowledge/Ralph/06-agents-md.md +0 -222
  81. package/template/knowledge/Ralph/07-implementation.md +0 -316
  82. package/template/knowledge/Ralph/08-economics.md +0 -182
  83. package/template/knowledge/Ralph/09-resources.md +0 -145
  84. package/template/knowledge/Ralph/10-claude-code-workflow.md +0 -212
  85. package/template/knowledge/Ralph/11-team-training-guide.md +0 -383
  86. package/template/knowledge/Ralph/README.md +0 -40
  87. package/template/knowledge/ai-security-framework/CONTRIBUTING.md +0 -139
  88. package/template/knowledge/ai-security-framework/GLOSSARY.md +0 -176
  89. package/template/knowledge/ai-security-framework/LICENSE +0 -21
  90. package/template/knowledge/ai-security-framework/QUICK-START.md +0 -172
  91. package/template/knowledge/ai-security-framework/README.md +0 -232
  92. package/template/knowledge/ai-security-framework/checklists/browser-security.md +0 -301
  93. package/template/knowledge/ai-security-framework/checklists/credential-isolation.md +0 -322
  94. package/template/knowledge/ai-security-framework/checklists/incident-response.md +0 -288
  95. package/template/knowledge/ai-security-framework/checklists/pre-flight.md +0 -249
  96. package/template/knowledge/ai-security-framework/checklists/weekly-audit.md +0 -159
  97. package/template/knowledge/ai-security-framework/configs/audit-logging.md +0 -372
  98. package/template/knowledge/ai-security-framework/configs/kill-switches.md +0 -354
  99. package/template/knowledge/ai-security-framework/docs/01-core-principles.md +0 -256
  100. package/template/knowledge/ai-security-framework/docs/02-threat-landscape.md +0 -326
  101. package/template/knowledge/ai-security-framework/docs/03-security-posture.md +0 -250
  102. package/template/knowledge/ai-security-framework/templates/agents-security.md +0 -233
  103. package/template/knowledge/design-styles/README.md +0 -42
  104. package/template/knowledge/design-styles/american-industrial.md +0 -136
  105. package/template/knowledge/design-styles/ethereal-abstract.md +0 -133
  106. package/template/knowledge/design-styles/liminal-portal.md +0 -111
  107. package/template/knowledge/design-styles/swipes/american-industrial/G-3m4YPW0AADdu2.jpeg +0 -0
  108. package/template/knowledge/design-styles/swipes/american-industrial/G-JJlt5WwAABK3K.png +0 -0
  109. package/template/knowledge/design-styles/swipes/american-industrial/G-JJmj5W0AEbJ-7.png +0 -0
  110. package/template/knowledge/design-styles/swipes/american-industrial/G59fgNuXkAAKLJQ (1).jpeg +0 -0
  111. package/template/knowledge/design-styles/swipes/american-industrial/G59fgNuXkAAKLJQ.jpeg +0 -0
  112. package/template/knowledge/design-styles/swipes/american-industrial/G7fVkn3WEAAM-ST.jpeg +0 -0
  113. package/template/knowledge/design-styles/swipes/american-industrial/G8ECO5JWEAIksyn.png +0 -0
  114. package/template/knowledge/design-styles/swipes/american-industrial/G9-3GQSWoAA8eqZ.png +0 -0
  115. package/template/knowledge/design-styles/swipes/american-industrial/G9xEOqrXkAEZRcs.png +0 -0
  116. package/template/knowledge/design-styles/swipes/american-industrial/G_MVeJrXQAA8sx4.jpeg +0 -0
  117. package/template/knowledge/design-styles/swipes/american-industrial/G_RSkmGXkAAgAVZ.png +0 -0
  118. package/template/knowledge/design-styles/swipes/american-industrial/README.md +0 -31
  119. package/template/knowledge/design-styles/swipes/american-industrial/qyqtg7Dq.png +0 -0
  120. package/template/knowledge/dev-team/README.md +0 -35
  121. package/template/knowledge/dev-team/patterns/README.md +0 -34
  122. package/template/knowledge/dev-team/patterns/frontend/react-best-practices.md +0 -178
  123. package/template/knowledge/dev-team/troubleshooting/README.md +0 -31
  124. package/template/knowledge/dev-team/workflows/README.md +0 -49
  125. package/template/knowledge/hq/checkpoint-schema.json +0 -51
  126. package/template/knowledge/hq/index-md-spec.md +0 -74
  127. package/template/knowledge/hq/thread-schema.md +0 -153
  128. package/template/knowledge/hq-core/checkpoint-schema.json +0 -51
  129. package/template/knowledge/hq-core/index-md-spec.md +0 -74
  130. package/template/knowledge/hq-core/thread-schema.md +0 -153
  131. package/template/knowledge/loom/README.md +0 -51
  132. package/template/knowledge/loom/architecture.md +0 -125
  133. package/template/knowledge/loom/code-style.md +0 -169
  134. package/template/knowledge/loom/llm-proxy.md +0 -132
  135. package/template/knowledge/loom/state-machine.md +0 -131
  136. package/template/knowledge/loom/thread-system.md +0 -117
  137. package/template/knowledge/loom/tools.md +0 -94
  138. package/template/knowledge/loom/weaver.md +0 -96
  139. package/template/knowledge/loom/web-frontend.md +0 -131
  140. package/template/knowledge/projects/README.md +0 -72
  141. package/template/knowledge/projects/templates/README.template.md +0 -28
  142. package/template/knowledge/workers/README.md +0 -195
  143. package/template/knowledge/workers/ralph-loop-pattern.md +0 -157
  144. package/template/knowledge/workers/skill-schema.md +0 -182
  145. package/template/knowledge/workers/state-machine.md +0 -102
  146. package/template/knowledge/workers/templates/base-worker.yaml +0 -73
  147. package/template/knowledge/workers/templates/code-worker.yaml +0 -85
  148. package/template/knowledge/workers/templates/skill.yaml +0 -49
  149. package/template/knowledge/workers/templates/social-worker.yaml +0 -70
  150. package/template/modules/examples/full-manifest.yaml +0 -92
  151. package/template/modules/examples/minimal.yaml +0 -14
  152. package/template/modules/modules.yaml +0 -59
  153. package/template/projects/.gitkeep +0 -0
  154. package/template/projects/incorporate-workers-into-pure-ralph/prd.json +0 -88
  155. package/template/projects/pure-ralph-branch-isolation/README.md +0 -114
  156. package/template/projects/pure-ralph-branch-isolation/prd.json +0 -123
  157. package/template/projects/purist-ralph-loop/README.md +0 -148
  158. package/template/projects/purist-ralph-loop/prd.json +0 -135
  159. package/template/projects/ralph-test/prd.json +0 -50
  160. package/template/prompts/pure-ralph-base.md +0 -551
  161. package/template/settings/.gitkeep +0 -0
  162. package/template/settings/pure-ralph.json +0 -42
  163. package/template/social-content/drafts/INDEX.md +0 -21
  164. package/template/social-content/drafts/linkedin/.gitkeep +0 -1
  165. package/template/social-content/drafts/x/.gitkeep +0 -1
  166. package/template/social-content/images/.gitkeep +0 -1
  167. package/template/starter-projects/code-worker/README.md +0 -97
  168. package/template/starter-projects/code-worker/prd.json +0 -45
  169. package/template/starter-projects/personal-assistant/README.md +0 -42
  170. package/template/starter-projects/personal-assistant/prd.json +0 -43
  171. package/template/starter-projects/social-media/README.md +0 -60
  172. package/template/starter-projects/social-media/prd.json +0 -43
  173. package/template/workers/content-brand/README.md +0 -59
  174. package/template/workers/content-brand/skills/messaging-alignment.md +0 -91
  175. package/template/workers/content-brand/skills/tone-check.md +0 -76
  176. package/template/workers/content-brand/skills/voice-analysis.md +0 -68
  177. package/template/workers/content-brand/worker.yaml +0 -81
  178. package/template/workers/content-legal/README.md +0 -80
  179. package/template/workers/content-legal/skills/claim-substantiation.md +0 -150
  180. package/template/workers/content-legal/skills/compliance-scan.md +0 -123
  181. package/template/workers/content-legal/skills/disclaimer-check.md +0 -146
  182. package/template/workers/content-legal/worker.yaml +0 -118
  183. package/template/workers/content-product/README.md +0 -77
  184. package/template/workers/content-product/skills/claim-verification.md +0 -96
  185. package/template/workers/content-product/skills/feature-accuracy.md +0 -117
  186. package/template/workers/content-product/skills/stats-check.md +0 -128
  187. package/template/workers/content-product/worker.yaml +0 -97
  188. package/template/workers/content-sales/README.md +0 -70
  189. package/template/workers/content-sales/skills/conversion-analysis.md +0 -96
  190. package/template/workers/content-sales/skills/cta-audit.md +0 -107
  191. package/template/workers/content-sales/skills/value-prop-check.md +0 -114
  192. package/template/workers/content-sales/worker.yaml +0 -93
  193. package/template/workers/content-shared/cli.ts +0 -242
  194. package/template/workers/content-shared/index.ts +0 -234
  195. package/template/workers/content-shared/lib/accuracy-analyzer.ts +0 -661
  196. package/template/workers/content-shared/lib/analyze.ts +0 -370
  197. package/template/workers/content-shared/lib/brand-analyzer.ts +0 -526
  198. package/template/workers/content-shared/lib/cms-integration.ts +0 -446
  199. package/template/workers/content-shared/lib/compliance-analyzer.ts +0 -655
  200. package/template/workers/content-shared/lib/conversion-analyzer.ts +0 -555
  201. package/template/workers/content-shared/lib/github-integration.ts +0 -582
  202. package/template/workers/content-shared/lib/output.ts +0 -373
  203. package/template/workers/content-shared/lib/parser.ts +0 -771
  204. package/template/workers/content-shared/lib/priority.ts +0 -439
  205. package/template/workers/content-shared/lib/recommendations.ts +0 -512
  206. package/template/workers/content-shared/lib/reporter.ts +0 -749
  207. package/template/workers/content-shared/lib/restructure.ts +0 -664
  208. package/template/workers/content-shared/lib/scorer.ts +0 -140
  209. package/template/workers/content-shared/lib/types.ts +0 -227
  210. package/template/workers/content-shared/lib/variants.ts +0 -595
  211. package/template/workers/content-shared/package.json +0 -51
  212. package/template/workers/content-shared/pnpm-lock.yaml +0 -39
  213. package/template/workers/content-shared/test/sample-page.json +0 -115
  214. package/template/workers/content-shared/tsconfig.json +0 -20
  215. package/template/workers/dev-team/README.md +0 -166
  216. package/template/workers/dev-team/_template.yaml +0 -70
  217. package/template/workers/dev-team/architect/package.json +0 -27
  218. package/template/workers/dev-team/architect/skills/api-design.md +0 -89
  219. package/template/workers/dev-team/architect/skills/refactor-plan.md +0 -96
  220. package/template/workers/dev-team/architect/skills/system-design.md +0 -100
  221. package/template/workers/dev-team/architect/src/index.ts +0 -49
  222. package/template/workers/dev-team/architect/src/mcp-server.ts +0 -122
  223. package/template/workers/dev-team/architect/src/skills/api-design.ts +0 -316
  224. package/template/workers/dev-team/architect/src/skills/refactor-plan.ts +0 -264
  225. package/template/workers/dev-team/architect/src/skills/system-design.ts +0 -212
  226. package/template/workers/dev-team/architect/tsconfig.json +0 -19
  227. package/template/workers/dev-team/architect/worker.yaml +0 -128
  228. package/template/workers/dev-team/backend-dev/package-lock.json +0 -1252
  229. package/template/workers/dev-team/backend-dev/package.json +0 -27
  230. package/template/workers/dev-team/backend-dev/skills/implement-endpoint.md +0 -70
  231. package/template/workers/dev-team/backend-dev/skills/implement-service.md +0 -62
  232. package/template/workers/dev-team/backend-dev/src/index.ts +0 -51
  233. package/template/workers/dev-team/backend-dev/src/mcp-server.ts +0 -109
  234. package/template/workers/dev-team/backend-dev/src/skills/implement-endpoint.ts +0 -122
  235. package/template/workers/dev-team/backend-dev/src/skills/implement-service.ts +0 -126
  236. package/template/workers/dev-team/backend-dev/tsconfig.json +0 -19
  237. package/template/workers/dev-team/backend-dev/worker.yaml +0 -128
  238. package/template/workers/dev-team/code-reviewer/package-lock.json +0 -1080
  239. package/template/workers/dev-team/code-reviewer/package.json +0 -24
  240. package/template/workers/dev-team/code-reviewer/skills/merge-to-production.md +0 -61
  241. package/template/workers/dev-team/code-reviewer/skills/merge-to-staging.md +0 -54
  242. package/template/workers/dev-team/code-reviewer/skills/request-changes.md +0 -63
  243. package/template/workers/dev-team/code-reviewer/skills/review-pr.md +0 -77
  244. package/template/workers/dev-team/code-reviewer/src/index.ts +0 -56
  245. package/template/workers/dev-team/code-reviewer/src/mcp-server.ts +0 -101
  246. package/template/workers/dev-team/code-reviewer/tsconfig.json +0 -19
  247. package/template/workers/dev-team/code-reviewer/worker.yaml +0 -90
  248. package/template/workers/dev-team/database-dev/package.json +0 -22
  249. package/template/workers/dev-team/database-dev/skills/create-schema.md +0 -48
  250. package/template/workers/dev-team/database-dev/src/index.ts +0 -50
  251. package/template/workers/dev-team/database-dev/src/mcp-server.ts +0 -76
  252. package/template/workers/dev-team/database-dev/tsconfig.json +0 -18
  253. package/template/workers/dev-team/database-dev/worker.yaml +0 -90
  254. package/template/workers/dev-team/frontend-dev/package.json +0 -22
  255. package/template/workers/dev-team/frontend-dev/skills/create-component.md +0 -26
  256. package/template/workers/dev-team/frontend-dev/src/index.ts +0 -50
  257. package/template/workers/dev-team/frontend-dev/src/mcp-server.ts +0 -77
  258. package/template/workers/dev-team/frontend-dev/tsconfig.json +0 -18
  259. package/template/workers/dev-team/frontend-dev/worker.yaml +0 -132
  260. package/template/workers/dev-team/infra-dev/package.json +0 -24
  261. package/template/workers/dev-team/infra-dev/skills/add-monitoring.md +0 -73
  262. package/template/workers/dev-team/infra-dev/skills/configure-deployment.md +0 -80
  263. package/template/workers/dev-team/infra-dev/skills/create-dockerfile.md +0 -62
  264. package/template/workers/dev-team/infra-dev/skills/setup-cicd.md +0 -63
  265. package/template/workers/dev-team/infra-dev/src/index.ts +0 -55
  266. package/template/workers/dev-team/infra-dev/src/mcp-server.ts +0 -82
  267. package/template/workers/dev-team/infra-dev/tsconfig.json +0 -19
  268. package/template/workers/dev-team/infra-dev/worker.yaml +0 -92
  269. package/template/workers/dev-team/knowledge-curator/package.json +0 -24
  270. package/template/workers/dev-team/knowledge-curator/skills/curate-troubleshooting.md +0 -63
  271. package/template/workers/dev-team/knowledge-curator/skills/process-learnings.md +0 -61
  272. package/template/workers/dev-team/knowledge-curator/skills/sync-documentation.md +0 -76
  273. package/template/workers/dev-team/knowledge-curator/skills/update-patterns.md +0 -63
  274. package/template/workers/dev-team/knowledge-curator/src/index.ts +0 -53
  275. package/template/workers/dev-team/knowledge-curator/src/mcp-server.ts +0 -92
  276. package/template/workers/dev-team/knowledge-curator/tsconfig.json +0 -19
  277. package/template/workers/dev-team/knowledge-curator/worker.yaml +0 -80
  278. package/template/workers/dev-team/motion-designer/package.json +0 -22
  279. package/template/workers/dev-team/motion-designer/skills/add-animation.md +0 -25
  280. package/template/workers/dev-team/motion-designer/skills/generate-image.md +0 -36
  281. package/template/workers/dev-team/motion-designer/src/index.ts +0 -63
  282. package/template/workers/dev-team/motion-designer/src/mcp-server.ts +0 -79
  283. package/template/workers/dev-team/motion-designer/tsconfig.json +0 -18
  284. package/template/workers/dev-team/motion-designer/worker.yaml +0 -84
  285. package/template/workers/dev-team/product-planner/queue.json +0 -4
  286. package/template/workers/dev-team/product-planner/worker.yaml +0 -220
  287. package/template/workers/dev-team/project-manager/package-lock.json +0 -1252
  288. package/template/workers/dev-team/project-manager/package.json +0 -27
  289. package/template/workers/dev-team/project-manager/skills/create-prd.md +0 -66
  290. package/template/workers/dev-team/project-manager/skills/next-issue.md +0 -51
  291. package/template/workers/dev-team/project-manager/skills/project-status.md +0 -59
  292. package/template/workers/dev-team/project-manager/skills/update-learnings.md +0 -65
  293. package/template/workers/dev-team/project-manager/src/index.ts +0 -54
  294. package/template/workers/dev-team/project-manager/src/mcp-server.ts +0 -207
  295. package/template/workers/dev-team/project-manager/src/skills/create-prd.ts +0 -86
  296. package/template/workers/dev-team/project-manager/src/skills/next-issue.ts +0 -137
  297. package/template/workers/dev-team/project-manager/src/skills/project-status.ts +0 -131
  298. package/template/workers/dev-team/project-manager/src/skills/update-learnings.ts +0 -94
  299. package/template/workers/dev-team/project-manager/tsconfig.json +0 -19
  300. package/template/workers/dev-team/project-manager/worker.yaml +0 -96
  301. package/template/workers/dev-team/qa-tester/package.json +0 -24
  302. package/template/workers/dev-team/qa-tester/skills/create-demo-account.md +0 -36
  303. package/template/workers/dev-team/qa-tester/skills/run-tests.md +0 -36
  304. package/template/workers/dev-team/qa-tester/skills/write-test.md +0 -27
  305. package/template/workers/dev-team/qa-tester/src/index.ts +0 -61
  306. package/template/workers/dev-team/qa-tester/src/mcp-server.ts +0 -88
  307. package/template/workers/dev-team/qa-tester/tsconfig.json +0 -18
  308. package/template/workers/dev-team/qa-tester/worker.yaml +0 -116
  309. package/template/workers/dev-team/task-executor/package-lock.json +0 -1252
  310. package/template/workers/dev-team/task-executor/package.json +0 -27
  311. package/template/workers/dev-team/task-executor/skills/analyze-issue.md +0 -101
  312. package/template/workers/dev-team/task-executor/skills/execute.md +0 -133
  313. package/template/workers/dev-team/task-executor/skills/report-learnings.md +0 -106
  314. package/template/workers/dev-team/task-executor/skills/validate-completion.md +0 -121
  315. package/template/workers/dev-team/task-executor/src/index.ts +0 -54
  316. package/template/workers/dev-team/task-executor/src/mcp-server.ts +0 -139
  317. package/template/workers/dev-team/task-executor/src/skills/analyze-issue.ts +0 -219
  318. package/template/workers/dev-team/task-executor/src/skills/execute.ts +0 -132
  319. package/template/workers/dev-team/task-executor/src/skills/report-learnings.ts +0 -119
  320. package/template/workers/dev-team/task-executor/src/skills/validate-completion.ts +0 -142
  321. package/template/workers/dev-team/task-executor/tsconfig.json +0 -19
  322. package/template/workers/dev-team/task-executor/worker.yaml +0 -110
  323. package/template/workers/registry.yaml +0 -171
  324. package/template/workers/security-scanner/README.md +0 -73
  325. package/template/workers/security-scanner/skills/pre-deploy-check.md +0 -205
  326. package/template/workers/security-scanner/worker.yaml +0 -26
  327. package/template/workspace/checkpoints/.gitkeep +0 -0
  328. package/template/workspace/content-ideas/inbox.jsonl +0 -0
  329. package/template/workspace/drafts/.gitkeep +0 -0
  330. package/template/workspace/learnings/.gitkeep +0 -3
  331. package/template/workspace/orchestrator/.gitkeep +0 -0
  332. package/template/workspace/ralph-test/COMPLETE.md +0 -18
  333. package/template/workspace/ralph-test/hello.txt +0 -2
  334. package/template/workspace/reports/.gitkeep +0 -0
  335. package/template/workspace/scratch/.gitkeep +0 -0
  336. package/template/workspace/threads/.gitkeep +0 -3
@@ -1,526 +0,0 @@
1
- /**
2
- * Brand Voice Analyzer (US-007)
3
- * Analyzes content against brand guidelines for tone, messaging, and clarity
4
- */
5
-
6
- import type {
7
- AnalysisInput,
8
- BrandGuidelines,
9
- BrandAnalysis,
10
- Finding,
11
- Recommendation,
12
- } from './types.js';
13
-
14
- // ============================================
15
- // Default Brand Attributes
16
- // ============================================
17
-
18
- /**
19
- * Brand voice characteristics to check
20
- */
21
- export const BRAND_ATTRIBUTES = {
22
- professional: ['enterprise', 'secure', 'compliance', 'trusted', 'reliable', 'proven', 'robust'],
23
- confident: ['leading', 'proven', 'powerful', 'best-in-class', 'premier', 'industry-leading', 'world-class'],
24
- approachable: ['simple', 'easy', 'seamless', 'intuitive', 'straightforward', 'effortless', 'user-friendly'],
25
- avoid: ['cheap', 'basic', 'try', 'maybe', 'kind of', 'sort of', 'hopefully', 'might', 'possibly'],
26
- };
27
-
28
- /**
29
- * Default brand guidelines when none provided
30
- */
31
- export const DEFAULT_BRAND_GUIDELINES: BrandGuidelines = {
32
- voiceAttributes: ['professional', 'confident', 'approachable'],
33
- toneDescriptors: ['authoritative', 'helpful', 'clear'],
34
- approvedTerms: [
35
- ...BRAND_ATTRIBUTES.professional,
36
- ...BRAND_ATTRIBUTES.confident,
37
- ...BRAND_ATTRIBUTES.approachable,
38
- ],
39
- avoidTerms: BRAND_ATTRIBUTES.avoid,
40
- messagingPillars: ['security', 'efficiency', 'innovation', 'trust'],
41
- };
42
-
43
- // ============================================
44
- // Scoring Weights
45
- // ============================================
46
-
47
- const WEIGHTS = {
48
- tone: 0.30,
49
- messaging: 0.35,
50
- clarity: 0.35,
51
- };
52
-
53
- // ============================================
54
- // Main Analysis Function
55
- // ============================================
56
-
57
- /**
58
- * Analyze content for brand voice alignment
59
- */
60
- export function analyzeBrandVoice(
61
- content: AnalysisInput,
62
- guidelines: BrandGuidelines = DEFAULT_BRAND_GUIDELINES
63
- ): BrandAnalysis {
64
- const findings: Finding[] = [];
65
- const recommendations: Recommendation[] = [];
66
-
67
- // Analyze tone
68
- const toneResult = analyzeTone(content, guidelines, findings, recommendations);
69
-
70
- // Analyze messaging alignment
71
- const messagingResult = analyzeMessaging(content, guidelines, findings, recommendations);
72
-
73
- // Analyze clarity
74
- const clarityResult = analyzeClarity(content, findings, recommendations);
75
-
76
- // Calculate overall score
77
- const overallScore = Math.round(
78
- toneResult.score * WEIGHTS.tone +
79
- messagingResult.score * WEIGHTS.messaging +
80
- clarityResult.score * WEIGHTS.clarity
81
- );
82
-
83
- return {
84
- overallScore,
85
- toneScore: toneResult.score,
86
- messagingScore: messagingResult.score,
87
- clarityScore: clarityResult.score,
88
- findings,
89
- recommendations,
90
- };
91
- }
92
-
93
- // ============================================
94
- // Tone Analysis
95
- // ============================================
96
-
97
- interface AnalysisScoreResult {
98
- score: number;
99
- }
100
-
101
- function analyzeTone(
102
- content: AnalysisInput,
103
- guidelines: BrandGuidelines,
104
- findings: Finding[],
105
- recommendations: Recommendation[]
106
- ): AnalysisScoreResult {
107
- let score = 100;
108
- const allText = getAllText(content).toLowerCase();
109
-
110
- // Check for approved terms (positive)
111
- const approvedTermsFound = guidelines.approvedTerms.filter(term =>
112
- allText.includes(term.toLowerCase())
113
- );
114
-
115
- if (approvedTermsFound.length > 0) {
116
- findings.push({
117
- severity: 'pass',
118
- category: 'Brand Voice - Tone',
119
- message: `Found ${approvedTermsFound.length} approved brand terms`,
120
- evidence: approvedTermsFound.slice(0, 5).join(', '),
121
- });
122
- } else {
123
- findings.push({
124
- severity: 'warning',
125
- category: 'Brand Voice - Tone',
126
- message: 'No approved brand terms found in content',
127
- });
128
- score -= 15;
129
- }
130
-
131
- // Check for terms to avoid (negative)
132
- const avoidTermsFound = guidelines.avoidTerms.filter(term =>
133
- allText.includes(term.toLowerCase())
134
- );
135
-
136
- if (avoidTermsFound.length > 0) {
137
- findings.push({
138
- severity: 'warning',
139
- category: 'Brand Voice - Tone',
140
- message: `Found ${avoidTermsFound.length} terms that should be avoided`,
141
- evidence: avoidTermsFound.join(', '),
142
- });
143
- score -= avoidTermsFound.length * 10;
144
-
145
- for (const term of avoidTermsFound) {
146
- const suggestion = getSuggestionForAvoidTerm(term);
147
- recommendations.push({
148
- priority: 'medium',
149
- category: 'Tone',
150
- current: `Uses "${term}"`,
151
- suggested: suggestion,
152
- rationale: 'This term undermines confidence and authority in messaging',
153
- });
154
- }
155
- }
156
-
157
- // Check for passive voice (weakens tone)
158
- const passiveCount = countPassiveVoice(allText);
159
- if (passiveCount > 3) {
160
- findings.push({
161
- severity: 'info',
162
- category: 'Brand Voice - Tone',
163
- message: `Detected ${passiveCount} instances of passive voice`,
164
- });
165
- score -= Math.min(passiveCount * 2, 10);
166
- recommendations.push({
167
- priority: 'low',
168
- category: 'Tone',
169
- current: 'Multiple passive voice constructions',
170
- suggested: 'Convert to active voice for stronger messaging',
171
- rationale: 'Active voice is more direct and confident',
172
- });
173
- }
174
-
175
- // Check for hedging language
176
- const hedgingTerms = ['possibly', 'perhaps', 'might', 'could be', 'tends to', 'generally'];
177
- const hedgingFound = hedgingTerms.filter(term => allText.includes(term));
178
- if (hedgingFound.length > 0) {
179
- findings.push({
180
- severity: 'info',
181
- category: 'Brand Voice - Tone',
182
- message: 'Hedging language detected',
183
- evidence: hedgingFound.join(', '),
184
- });
185
- score -= hedgingFound.length * 3;
186
- }
187
-
188
- return { score: Math.max(0, Math.min(100, score)) };
189
- }
190
-
191
- // ============================================
192
- // Messaging Analysis
193
- // ============================================
194
-
195
- function analyzeMessaging(
196
- content: AnalysisInput,
197
- guidelines: BrandGuidelines,
198
- findings: Finding[],
199
- recommendations: Recommendation[]
200
- ): AnalysisScoreResult {
201
- let score = 100;
202
- const allText = getAllText(content).toLowerCase();
203
-
204
- // Check messaging pillar coverage
205
- const pillarsFound = guidelines.messagingPillars.filter(pillar =>
206
- allText.includes(pillar.toLowerCase())
207
- );
208
-
209
- const pillarCoverage = pillarsFound.length / guidelines.messagingPillars.length;
210
-
211
- if (pillarCoverage >= 0.75) {
212
- findings.push({
213
- severity: 'pass',
214
- category: 'Brand Voice - Messaging',
215
- message: `Strong messaging pillar coverage: ${Math.round(pillarCoverage * 100)}%`,
216
- evidence: pillarsFound.join(', '),
217
- });
218
- } else if (pillarCoverage >= 0.5) {
219
- findings.push({
220
- severity: 'info',
221
- category: 'Brand Voice - Messaging',
222
- message: `Moderate messaging pillar coverage: ${Math.round(pillarCoverage * 100)}%`,
223
- evidence: pillarsFound.join(', '),
224
- });
225
- score -= 10;
226
- } else {
227
- const missingPillars = guidelines.messagingPillars.filter(p =>
228
- !pillarsFound.includes(p)
229
- );
230
- findings.push({
231
- severity: 'warning',
232
- category: 'Brand Voice - Messaging',
233
- message: `Low messaging pillar coverage: ${Math.round(pillarCoverage * 100)}%`,
234
- evidence: `Missing: ${missingPillars.join(', ')}`,
235
- });
236
- score -= 25;
237
-
238
- recommendations.push({
239
- priority: 'high',
240
- category: 'Messaging',
241
- current: `Only covers ${pillarsFound.length} of ${guidelines.messagingPillars.length} messaging pillars`,
242
- suggested: `Incorporate messaging around: ${missingPillars.join(', ')}`,
243
- rationale: 'Core messaging pillars should be represented for brand consistency',
244
- });
245
- }
246
-
247
- // Check for value proposition clarity
248
- const valueIndicators = ['save', 'reduce', 'increase', 'improve', 'boost', 'grow', 'eliminate', 'streamline'];
249
- const valueTermsFound = valueIndicators.filter(term => allText.includes(term));
250
-
251
- if (valueTermsFound.length === 0) {
252
- findings.push({
253
- severity: 'warning',
254
- category: 'Brand Voice - Messaging',
255
- message: 'No clear value proposition language found',
256
- });
257
- score -= 15;
258
- recommendations.push({
259
- priority: 'high',
260
- category: 'Messaging',
261
- current: 'Value proposition unclear',
262
- suggested: 'Add specific benefits using action verbs (save, reduce, improve, etc.)',
263
- rationale: 'Clear value propositions drive engagement and conversion',
264
- });
265
- } else {
266
- findings.push({
267
- severity: 'pass',
268
- category: 'Brand Voice - Messaging',
269
- message: `Value proposition language present: ${valueTermsFound.length} indicators`,
270
- evidence: valueTermsFound.join(', '),
271
- });
272
- }
273
-
274
- // Check for consistent terminology
275
- const inconsistencies = checkTerminologyConsistency(content);
276
- if (inconsistencies.length > 0) {
277
- findings.push({
278
- severity: 'info',
279
- category: 'Brand Voice - Messaging',
280
- message: 'Potential terminology inconsistencies detected',
281
- evidence: inconsistencies.join('; '),
282
- });
283
- score -= inconsistencies.length * 3;
284
- }
285
-
286
- return { score: Math.max(0, Math.min(100, score)) };
287
- }
288
-
289
- // ============================================
290
- // Clarity Analysis
291
- // ============================================
292
-
293
- function analyzeClarity(
294
- content: AnalysisInput,
295
- findings: Finding[],
296
- recommendations: Recommendation[]
297
- ): AnalysisScoreResult {
298
- let score = 100;
299
-
300
- // Analyze readability
301
- const readabilityResult = analyzeReadability(content);
302
-
303
- if (readabilityResult.grade > 12) {
304
- findings.push({
305
- severity: 'warning',
306
- category: 'Brand Voice - Clarity',
307
- message: `Content reading level too high: Grade ${readabilityResult.grade}`,
308
- evidence: `Average sentence length: ${readabilityResult.avgSentenceLength} words`,
309
- });
310
- score -= 20;
311
- recommendations.push({
312
- priority: 'medium',
313
- category: 'Clarity',
314
- current: `Grade ${readabilityResult.grade} reading level`,
315
- suggested: 'Simplify sentences to Grade 8-10 level for broader accessibility',
316
- rationale: 'B2B content should be professional but accessible',
317
- });
318
- } else if (readabilityResult.grade >= 8) {
319
- findings.push({
320
- severity: 'pass',
321
- category: 'Brand Voice - Clarity',
322
- message: `Appropriate reading level: Grade ${readabilityResult.grade}`,
323
- });
324
- } else {
325
- findings.push({
326
- severity: 'info',
327
- category: 'Brand Voice - Clarity',
328
- message: `Reading level may be too simple: Grade ${readabilityResult.grade}`,
329
- });
330
- score -= 5;
331
- }
332
-
333
- // Check for jargon overuse
334
- const jargonTerms = [
335
- 'synergy', 'leverage', 'paradigm', 'bandwidth', 'circle back',
336
- 'low-hanging fruit', 'move the needle', 'drill down', 'holistic',
337
- ];
338
- const allText = getAllText(content).toLowerCase();
339
- const jargonFound = jargonTerms.filter(term => allText.includes(term));
340
-
341
- if (jargonFound.length > 2) {
342
- findings.push({
343
- severity: 'warning',
344
- category: 'Brand Voice - Clarity',
345
- message: 'Excessive business jargon detected',
346
- evidence: jargonFound.join(', '),
347
- });
348
- score -= jargonFound.length * 5;
349
- recommendations.push({
350
- priority: 'medium',
351
- category: 'Clarity',
352
- current: `Uses jargon: ${jargonFound.join(', ')}`,
353
- suggested: 'Replace with clearer, more specific language',
354
- rationale: 'Jargon reduces clarity and can alienate readers',
355
- });
356
- }
357
-
358
- // Check for long paragraphs
359
- const longParagraphs = content.paragraphs.filter(p => p.split(/\s+/).length > 100);
360
- if (longParagraphs.length > 0) {
361
- findings.push({
362
- severity: 'info',
363
- category: 'Brand Voice - Clarity',
364
- message: `${longParagraphs.length} paragraph(s) exceed 100 words`,
365
- });
366
- score -= longParagraphs.length * 3;
367
- recommendations.push({
368
- priority: 'low',
369
- category: 'Clarity',
370
- current: 'Long paragraphs reduce scanability',
371
- suggested: 'Break into shorter paragraphs (3-5 sentences max)',
372
- rationale: 'Shorter paragraphs improve readability on screens',
373
- });
374
- }
375
-
376
- // Check heading clarity
377
- const unclearHeadings = content.headings.filter(h => {
378
- const words = h.split(/\s+/);
379
- return words.length < 2 || words.length > 12;
380
- });
381
-
382
- if (unclearHeadings.length > 0) {
383
- findings.push({
384
- severity: 'info',
385
- category: 'Brand Voice - Clarity',
386
- message: `${unclearHeadings.length} heading(s) may need refinement`,
387
- evidence: unclearHeadings.slice(0, 3).join(', '),
388
- });
389
- score -= unclearHeadings.length * 2;
390
- }
391
-
392
- return { score: Math.max(0, Math.min(100, score)) };
393
- }
394
-
395
- // ============================================
396
- // Helper Functions
397
- // ============================================
398
-
399
- /**
400
- * Get all text from content as single string
401
- */
402
- function getAllText(content: AnalysisInput): string {
403
- return [
404
- content.title,
405
- ...content.headings,
406
- ...content.paragraphs,
407
- ...content.ctas.map(c => c.text),
408
- ].join(' ');
409
- }
410
-
411
- /**
412
- * Count passive voice instances
413
- */
414
- function countPassiveVoice(text: string): number {
415
- // Simplified passive voice detection
416
- const passivePatterns = [
417
- /\b(is|are|was|were|been|being)\s+\w+ed\b/gi,
418
- /\b(is|are|was|were|been|being)\s+\w+en\b/gi,
419
- ];
420
-
421
- let count = 0;
422
- for (const pattern of passivePatterns) {
423
- const matches = text.match(pattern);
424
- if (matches) count += matches.length;
425
- }
426
- return count;
427
- }
428
-
429
- /**
430
- * Get suggestion for avoided term
431
- */
432
- function getSuggestionForAvoidTerm(term: string): string {
433
- const suggestions: Record<string, string> = {
434
- 'cheap': 'Use "cost-effective" or "affordable"',
435
- 'basic': 'Use "essential" or "foundational"',
436
- 'try': 'Use "experience" or "discover"',
437
- 'maybe': 'Remove hedging or state confidently',
438
- 'kind of': 'Be specific or remove qualifier',
439
- 'sort of': 'Be specific or remove qualifier',
440
- 'hopefully': 'State with confidence or specify conditions',
441
- 'might': 'Use "will" or "can" when appropriate',
442
- 'possibly': 'Be specific about conditions or remove',
443
- };
444
- return suggestions[term.toLowerCase()] ?? 'Replace with more confident language';
445
- }
446
-
447
- /**
448
- * Check for terminology consistency
449
- */
450
- function checkTerminologyConsistency(content: AnalysisInput): string[] {
451
- const inconsistencies: string[] = [];
452
- const allText = getAllText(content).toLowerCase();
453
-
454
- // Check for inconsistent product/feature naming
455
- const termPairs = [
456
- ['customer', 'client'],
457
- ['user', 'member'],
458
- ['platform', 'solution'],
459
- ['dashboard', 'portal'],
460
- ];
461
-
462
- for (const [term1, term2] of termPairs) {
463
- const has1 = allText.includes(term1);
464
- const has2 = allText.includes(term2);
465
- if (has1 && has2) {
466
- inconsistencies.push(`Mixed usage: "${term1}" and "${term2}"`);
467
- }
468
- }
469
-
470
- return inconsistencies;
471
- }
472
-
473
- /**
474
- * Analyze readability metrics
475
- */
476
- function analyzeReadability(content: AnalysisInput): {
477
- grade: number;
478
- avgSentenceLength: number;
479
- avgWordLength: number;
480
- } {
481
- const allText = getAllText(content);
482
- const sentences = allText.split(/[.!?]+/).filter(s => s.trim().length > 0);
483
- const words = allText.split(/\s+/).filter(w => w.length > 0);
484
-
485
- const avgSentenceLength = sentences.length > 0 ? words.length / sentences.length : 0;
486
- const avgWordLength = words.length > 0
487
- ? words.reduce((sum, w) => sum + w.length, 0) / words.length
488
- : 0;
489
-
490
- // Simplified Flesch-Kincaid grade level approximation
491
- const syllables = words.reduce((sum, w) => sum + countSyllables(w), 0);
492
- const avgSyllablesPerWord = words.length > 0 ? syllables / words.length : 0;
493
-
494
- // Flesch-Kincaid Grade Level formula (simplified)
495
- const grade = Math.round(
496
- 0.39 * avgSentenceLength + 11.8 * avgSyllablesPerWord - 15.59
497
- );
498
-
499
- return {
500
- grade: Math.max(1, Math.min(20, grade)),
501
- avgSentenceLength: Math.round(avgSentenceLength * 10) / 10,
502
- avgWordLength: Math.round(avgWordLength * 10) / 10,
503
- };
504
- }
505
-
506
- /**
507
- * Count syllables in a word (approximation)
508
- */
509
- function countSyllables(word: string): number {
510
- word = word.toLowerCase().replace(/[^a-z]/g, '');
511
- if (word.length <= 3) return 1;
512
-
513
- // Count vowel groups
514
- const matches = word.match(/[aeiouy]+/g);
515
- let count = matches ? matches.length : 1;
516
-
517
- // Adjust for silent e
518
- if (word.endsWith('e')) count--;
519
-
520
- // Adjust for -le endings
521
- if (word.endsWith('le') && word.length > 2 && !/[aeiouy]/.test(word[word.length - 3])) {
522
- count++;
523
- }
524
-
525
- return Math.max(1, count);
526
- }