create-hq 6.0.0 → 7.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 (315) hide show
  1. package/dist/__tests__/scaffold.test.d.ts +2 -0
  2. package/dist/__tests__/scaffold.test.d.ts.map +1 -0
  3. package/dist/__tests__/scaffold.test.js +150 -0
  4. package/dist/__tests__/scaffold.test.js.map +1 -0
  5. package/dist/cloud-sync.d.ts +11 -0
  6. package/dist/cloud-sync.d.ts.map +1 -0
  7. package/dist/cloud-sync.js +25 -0
  8. package/dist/cloud-sync.js.map +1 -0
  9. package/dist/deps.d.ts.map +1 -1
  10. package/dist/deps.js +7 -1
  11. package/dist/deps.js.map +1 -1
  12. package/dist/fetch-template.d.ts +14 -0
  13. package/dist/fetch-template.d.ts.map +1 -0
  14. package/dist/fetch-template.js +136 -0
  15. package/dist/fetch-template.js.map +1 -0
  16. package/dist/index.js +8 -7
  17. package/dist/index.js.map +1 -1
  18. package/dist/scaffold.d.ts +2 -2
  19. package/dist/scaffold.d.ts.map +1 -1
  20. package/dist/scaffold.js +95 -286
  21. package/dist/scaffold.js.map +1 -1
  22. package/dist/ui.d.ts +2 -3
  23. package/dist/ui.d.ts.map +1 -1
  24. package/dist/ui.js +90 -44
  25. package/dist/ui.js.map +1 -1
  26. package/package.json +48 -40
  27. package/template/.claude/CLAUDE.md +0 -202
  28. package/template/.claude/commands/checkpoint.md +0 -127
  29. package/template/.claude/commands/cleanup.md +0 -307
  30. package/template/.claude/commands/execute-task.md +0 -440
  31. package/template/.claude/commands/exit-plan.md +0 -41
  32. package/template/.claude/commands/handoff.md +0 -97
  33. package/template/.claude/commands/learn.md +0 -218
  34. package/template/.claude/commands/metrics.md +0 -118
  35. package/template/.claude/commands/newworker.md +0 -162
  36. package/template/.claude/commands/nexttask.md +0 -67
  37. package/template/.claude/commands/prd.md +0 -238
  38. package/template/.claude/commands/reanchor.md +0 -51
  39. package/template/.claude/commands/remember.md +0 -126
  40. package/template/.claude/commands/run-project.md +0 -348
  41. package/template/.claude/commands/run.md +0 -110
  42. package/template/.claude/commands/search-reindex.md +0 -62
  43. package/template/.claude/commands/search.md +0 -100
  44. package/template/.claude/commands/setup.md +0 -381
  45. package/template/.claude/scripts/pure-ralph-loop.ps1 +0 -312
  46. package/template/.claude/scripts/pure-ralph-loop.sh +0 -859
  47. package/template/CHANGELOG.md +0 -220
  48. package/template/LICENSE +0 -21
  49. package/template/MIGRATION.md +0 -259
  50. package/template/README.md +0 -368
  51. package/template/data/journal/.gitkeep +0 -0
  52. package/template/docs/images/ascii-banner-options.md +0 -122
  53. package/template/docs/images/hq-banner.svg +0 -105
  54. package/template/knowledge/Ralph/01-overview.md +0 -71
  55. package/template/knowledge/Ralph/02-core-concepts.md +0 -114
  56. package/template/knowledge/Ralph/03-how-ralph-works.md +0 -184
  57. package/template/knowledge/Ralph/04-back-pressure.md +0 -222
  58. package/template/knowledge/Ralph/05-specifications.md +0 -210
  59. package/template/knowledge/Ralph/06-agents-md.md +0 -222
  60. package/template/knowledge/Ralph/07-implementation.md +0 -316
  61. package/template/knowledge/Ralph/08-economics.md +0 -182
  62. package/template/knowledge/Ralph/09-resources.md +0 -145
  63. package/template/knowledge/Ralph/10-claude-code-workflow.md +0 -212
  64. package/template/knowledge/Ralph/11-team-training-guide.md +0 -383
  65. package/template/knowledge/Ralph/README.md +0 -40
  66. package/template/knowledge/ai-security-framework/CONTRIBUTING.md +0 -139
  67. package/template/knowledge/ai-security-framework/GLOSSARY.md +0 -176
  68. package/template/knowledge/ai-security-framework/LICENSE +0 -21
  69. package/template/knowledge/ai-security-framework/QUICK-START.md +0 -172
  70. package/template/knowledge/ai-security-framework/README.md +0 -232
  71. package/template/knowledge/ai-security-framework/checklists/browser-security.md +0 -301
  72. package/template/knowledge/ai-security-framework/checklists/credential-isolation.md +0 -322
  73. package/template/knowledge/ai-security-framework/checklists/incident-response.md +0 -288
  74. package/template/knowledge/ai-security-framework/checklists/pre-flight.md +0 -249
  75. package/template/knowledge/ai-security-framework/checklists/weekly-audit.md +0 -159
  76. package/template/knowledge/ai-security-framework/configs/audit-logging.md +0 -372
  77. package/template/knowledge/ai-security-framework/configs/kill-switches.md +0 -354
  78. package/template/knowledge/ai-security-framework/docs/01-core-principles.md +0 -256
  79. package/template/knowledge/ai-security-framework/docs/02-threat-landscape.md +0 -326
  80. package/template/knowledge/ai-security-framework/docs/03-security-posture.md +0 -250
  81. package/template/knowledge/ai-security-framework/templates/agents-security.md +0 -233
  82. package/template/knowledge/design-styles/README.md +0 -42
  83. package/template/knowledge/design-styles/american-industrial.md +0 -136
  84. package/template/knowledge/design-styles/ethereal-abstract.md +0 -133
  85. package/template/knowledge/design-styles/liminal-portal.md +0 -111
  86. package/template/knowledge/design-styles/swipes/american-industrial/G-3m4YPW0AADdu2.jpeg +0 -0
  87. package/template/knowledge/design-styles/swipes/american-industrial/G-JJlt5WwAABK3K.png +0 -0
  88. package/template/knowledge/design-styles/swipes/american-industrial/G-JJmj5W0AEbJ-7.png +0 -0
  89. package/template/knowledge/design-styles/swipes/american-industrial/G59fgNuXkAAKLJQ (1).jpeg +0 -0
  90. package/template/knowledge/design-styles/swipes/american-industrial/G59fgNuXkAAKLJQ.jpeg +0 -0
  91. package/template/knowledge/design-styles/swipes/american-industrial/G7fVkn3WEAAM-ST.jpeg +0 -0
  92. package/template/knowledge/design-styles/swipes/american-industrial/G8ECO5JWEAIksyn.png +0 -0
  93. package/template/knowledge/design-styles/swipes/american-industrial/G9-3GQSWoAA8eqZ.png +0 -0
  94. package/template/knowledge/design-styles/swipes/american-industrial/G9xEOqrXkAEZRcs.png +0 -0
  95. package/template/knowledge/design-styles/swipes/american-industrial/G_MVeJrXQAA8sx4.jpeg +0 -0
  96. package/template/knowledge/design-styles/swipes/american-industrial/G_RSkmGXkAAgAVZ.png +0 -0
  97. package/template/knowledge/design-styles/swipes/american-industrial/README.md +0 -31
  98. package/template/knowledge/design-styles/swipes/american-industrial/qyqtg7Dq.png +0 -0
  99. package/template/knowledge/dev-team/README.md +0 -35
  100. package/template/knowledge/dev-team/patterns/README.md +0 -34
  101. package/template/knowledge/dev-team/patterns/frontend/react-best-practices.md +0 -178
  102. package/template/knowledge/dev-team/troubleshooting/README.md +0 -31
  103. package/template/knowledge/dev-team/workflows/README.md +0 -49
  104. package/template/knowledge/hq/checkpoint-schema.json +0 -51
  105. package/template/knowledge/hq/index-md-spec.md +0 -74
  106. package/template/knowledge/hq/thread-schema.md +0 -153
  107. package/template/knowledge/hq-core/checkpoint-schema.json +0 -51
  108. package/template/knowledge/hq-core/index-md-spec.md +0 -74
  109. package/template/knowledge/hq-core/thread-schema.md +0 -153
  110. package/template/knowledge/loom/README.md +0 -51
  111. package/template/knowledge/loom/architecture.md +0 -125
  112. package/template/knowledge/loom/code-style.md +0 -169
  113. package/template/knowledge/loom/llm-proxy.md +0 -132
  114. package/template/knowledge/loom/state-machine.md +0 -131
  115. package/template/knowledge/loom/thread-system.md +0 -117
  116. package/template/knowledge/loom/tools.md +0 -94
  117. package/template/knowledge/loom/weaver.md +0 -96
  118. package/template/knowledge/loom/web-frontend.md +0 -131
  119. package/template/knowledge/projects/README.md +0 -72
  120. package/template/knowledge/projects/templates/README.template.md +0 -28
  121. package/template/knowledge/workers/README.md +0 -195
  122. package/template/knowledge/workers/ralph-loop-pattern.md +0 -157
  123. package/template/knowledge/workers/skill-schema.md +0 -182
  124. package/template/knowledge/workers/state-machine.md +0 -102
  125. package/template/knowledge/workers/templates/base-worker.yaml +0 -73
  126. package/template/knowledge/workers/templates/code-worker.yaml +0 -85
  127. package/template/knowledge/workers/templates/skill.yaml +0 -49
  128. package/template/knowledge/workers/templates/social-worker.yaml +0 -70
  129. package/template/modules/examples/full-manifest.yaml +0 -92
  130. package/template/modules/examples/minimal.yaml +0 -14
  131. package/template/modules/modules.yaml +0 -59
  132. package/template/projects/.gitkeep +0 -0
  133. package/template/projects/incorporate-workers-into-pure-ralph/prd.json +0 -88
  134. package/template/projects/pure-ralph-branch-isolation/README.md +0 -114
  135. package/template/projects/pure-ralph-branch-isolation/prd.json +0 -123
  136. package/template/projects/purist-ralph-loop/README.md +0 -148
  137. package/template/projects/purist-ralph-loop/prd.json +0 -135
  138. package/template/projects/ralph-test/prd.json +0 -50
  139. package/template/prompts/pure-ralph-base.md +0 -551
  140. package/template/settings/.gitkeep +0 -0
  141. package/template/settings/pure-ralph.json +0 -42
  142. package/template/social-content/drafts/INDEX.md +0 -21
  143. package/template/social-content/drafts/linkedin/.gitkeep +0 -1
  144. package/template/social-content/drafts/x/.gitkeep +0 -1
  145. package/template/social-content/images/.gitkeep +0 -1
  146. package/template/starter-projects/code-worker/README.md +0 -97
  147. package/template/starter-projects/code-worker/prd.json +0 -45
  148. package/template/starter-projects/personal-assistant/README.md +0 -42
  149. package/template/starter-projects/personal-assistant/prd.json +0 -43
  150. package/template/starter-projects/social-media/README.md +0 -60
  151. package/template/starter-projects/social-media/prd.json +0 -43
  152. package/template/workers/content-brand/README.md +0 -59
  153. package/template/workers/content-brand/skills/messaging-alignment.md +0 -91
  154. package/template/workers/content-brand/skills/tone-check.md +0 -76
  155. package/template/workers/content-brand/skills/voice-analysis.md +0 -68
  156. package/template/workers/content-brand/worker.yaml +0 -81
  157. package/template/workers/content-legal/README.md +0 -80
  158. package/template/workers/content-legal/skills/claim-substantiation.md +0 -150
  159. package/template/workers/content-legal/skills/compliance-scan.md +0 -123
  160. package/template/workers/content-legal/skills/disclaimer-check.md +0 -146
  161. package/template/workers/content-legal/worker.yaml +0 -118
  162. package/template/workers/content-product/README.md +0 -77
  163. package/template/workers/content-product/skills/claim-verification.md +0 -96
  164. package/template/workers/content-product/skills/feature-accuracy.md +0 -117
  165. package/template/workers/content-product/skills/stats-check.md +0 -128
  166. package/template/workers/content-product/worker.yaml +0 -97
  167. package/template/workers/content-sales/README.md +0 -70
  168. package/template/workers/content-sales/skills/conversion-analysis.md +0 -96
  169. package/template/workers/content-sales/skills/cta-audit.md +0 -107
  170. package/template/workers/content-sales/skills/value-prop-check.md +0 -114
  171. package/template/workers/content-sales/worker.yaml +0 -93
  172. package/template/workers/content-shared/cli.ts +0 -242
  173. package/template/workers/content-shared/index.ts +0 -234
  174. package/template/workers/content-shared/lib/accuracy-analyzer.ts +0 -661
  175. package/template/workers/content-shared/lib/analyze.ts +0 -370
  176. package/template/workers/content-shared/lib/brand-analyzer.ts +0 -526
  177. package/template/workers/content-shared/lib/cms-integration.ts +0 -446
  178. package/template/workers/content-shared/lib/compliance-analyzer.ts +0 -655
  179. package/template/workers/content-shared/lib/conversion-analyzer.ts +0 -555
  180. package/template/workers/content-shared/lib/github-integration.ts +0 -582
  181. package/template/workers/content-shared/lib/output.ts +0 -373
  182. package/template/workers/content-shared/lib/parser.ts +0 -771
  183. package/template/workers/content-shared/lib/priority.ts +0 -439
  184. package/template/workers/content-shared/lib/recommendations.ts +0 -512
  185. package/template/workers/content-shared/lib/reporter.ts +0 -749
  186. package/template/workers/content-shared/lib/restructure.ts +0 -664
  187. package/template/workers/content-shared/lib/scorer.ts +0 -140
  188. package/template/workers/content-shared/lib/types.ts +0 -227
  189. package/template/workers/content-shared/lib/variants.ts +0 -595
  190. package/template/workers/content-shared/package.json +0 -51
  191. package/template/workers/content-shared/pnpm-lock.yaml +0 -39
  192. package/template/workers/content-shared/test/sample-page.json +0 -115
  193. package/template/workers/content-shared/tsconfig.json +0 -20
  194. package/template/workers/dev-team/README.md +0 -166
  195. package/template/workers/dev-team/_template.yaml +0 -70
  196. package/template/workers/dev-team/architect/package.json +0 -27
  197. package/template/workers/dev-team/architect/skills/api-design.md +0 -89
  198. package/template/workers/dev-team/architect/skills/refactor-plan.md +0 -96
  199. package/template/workers/dev-team/architect/skills/system-design.md +0 -100
  200. package/template/workers/dev-team/architect/src/index.ts +0 -49
  201. package/template/workers/dev-team/architect/src/mcp-server.ts +0 -122
  202. package/template/workers/dev-team/architect/src/skills/api-design.ts +0 -316
  203. package/template/workers/dev-team/architect/src/skills/refactor-plan.ts +0 -264
  204. package/template/workers/dev-team/architect/src/skills/system-design.ts +0 -212
  205. package/template/workers/dev-team/architect/tsconfig.json +0 -19
  206. package/template/workers/dev-team/architect/worker.yaml +0 -128
  207. package/template/workers/dev-team/backend-dev/package-lock.json +0 -1252
  208. package/template/workers/dev-team/backend-dev/package.json +0 -27
  209. package/template/workers/dev-team/backend-dev/skills/implement-endpoint.md +0 -70
  210. package/template/workers/dev-team/backend-dev/skills/implement-service.md +0 -62
  211. package/template/workers/dev-team/backend-dev/src/index.ts +0 -51
  212. package/template/workers/dev-team/backend-dev/src/mcp-server.ts +0 -109
  213. package/template/workers/dev-team/backend-dev/src/skills/implement-endpoint.ts +0 -122
  214. package/template/workers/dev-team/backend-dev/src/skills/implement-service.ts +0 -126
  215. package/template/workers/dev-team/backend-dev/tsconfig.json +0 -19
  216. package/template/workers/dev-team/backend-dev/worker.yaml +0 -128
  217. package/template/workers/dev-team/code-reviewer/package-lock.json +0 -1080
  218. package/template/workers/dev-team/code-reviewer/package.json +0 -24
  219. package/template/workers/dev-team/code-reviewer/skills/merge-to-production.md +0 -61
  220. package/template/workers/dev-team/code-reviewer/skills/merge-to-staging.md +0 -54
  221. package/template/workers/dev-team/code-reviewer/skills/request-changes.md +0 -63
  222. package/template/workers/dev-team/code-reviewer/skills/review-pr.md +0 -77
  223. package/template/workers/dev-team/code-reviewer/src/index.ts +0 -56
  224. package/template/workers/dev-team/code-reviewer/src/mcp-server.ts +0 -101
  225. package/template/workers/dev-team/code-reviewer/tsconfig.json +0 -19
  226. package/template/workers/dev-team/code-reviewer/worker.yaml +0 -90
  227. package/template/workers/dev-team/database-dev/package.json +0 -22
  228. package/template/workers/dev-team/database-dev/skills/create-schema.md +0 -48
  229. package/template/workers/dev-team/database-dev/src/index.ts +0 -50
  230. package/template/workers/dev-team/database-dev/src/mcp-server.ts +0 -76
  231. package/template/workers/dev-team/database-dev/tsconfig.json +0 -18
  232. package/template/workers/dev-team/database-dev/worker.yaml +0 -90
  233. package/template/workers/dev-team/frontend-dev/package.json +0 -22
  234. package/template/workers/dev-team/frontend-dev/skills/create-component.md +0 -26
  235. package/template/workers/dev-team/frontend-dev/src/index.ts +0 -50
  236. package/template/workers/dev-team/frontend-dev/src/mcp-server.ts +0 -77
  237. package/template/workers/dev-team/frontend-dev/tsconfig.json +0 -18
  238. package/template/workers/dev-team/frontend-dev/worker.yaml +0 -132
  239. package/template/workers/dev-team/infra-dev/package.json +0 -24
  240. package/template/workers/dev-team/infra-dev/skills/add-monitoring.md +0 -73
  241. package/template/workers/dev-team/infra-dev/skills/configure-deployment.md +0 -80
  242. package/template/workers/dev-team/infra-dev/skills/create-dockerfile.md +0 -62
  243. package/template/workers/dev-team/infra-dev/skills/setup-cicd.md +0 -63
  244. package/template/workers/dev-team/infra-dev/src/index.ts +0 -55
  245. package/template/workers/dev-team/infra-dev/src/mcp-server.ts +0 -82
  246. package/template/workers/dev-team/infra-dev/tsconfig.json +0 -19
  247. package/template/workers/dev-team/infra-dev/worker.yaml +0 -92
  248. package/template/workers/dev-team/knowledge-curator/package.json +0 -24
  249. package/template/workers/dev-team/knowledge-curator/skills/curate-troubleshooting.md +0 -63
  250. package/template/workers/dev-team/knowledge-curator/skills/process-learnings.md +0 -61
  251. package/template/workers/dev-team/knowledge-curator/skills/sync-documentation.md +0 -76
  252. package/template/workers/dev-team/knowledge-curator/skills/update-patterns.md +0 -63
  253. package/template/workers/dev-team/knowledge-curator/src/index.ts +0 -53
  254. package/template/workers/dev-team/knowledge-curator/src/mcp-server.ts +0 -92
  255. package/template/workers/dev-team/knowledge-curator/tsconfig.json +0 -19
  256. package/template/workers/dev-team/knowledge-curator/worker.yaml +0 -80
  257. package/template/workers/dev-team/motion-designer/package.json +0 -22
  258. package/template/workers/dev-team/motion-designer/skills/add-animation.md +0 -25
  259. package/template/workers/dev-team/motion-designer/skills/generate-image.md +0 -36
  260. package/template/workers/dev-team/motion-designer/src/index.ts +0 -63
  261. package/template/workers/dev-team/motion-designer/src/mcp-server.ts +0 -79
  262. package/template/workers/dev-team/motion-designer/tsconfig.json +0 -18
  263. package/template/workers/dev-team/motion-designer/worker.yaml +0 -84
  264. package/template/workers/dev-team/product-planner/queue.json +0 -4
  265. package/template/workers/dev-team/product-planner/worker.yaml +0 -220
  266. package/template/workers/dev-team/project-manager/package-lock.json +0 -1252
  267. package/template/workers/dev-team/project-manager/package.json +0 -27
  268. package/template/workers/dev-team/project-manager/skills/create-prd.md +0 -66
  269. package/template/workers/dev-team/project-manager/skills/next-issue.md +0 -51
  270. package/template/workers/dev-team/project-manager/skills/project-status.md +0 -59
  271. package/template/workers/dev-team/project-manager/skills/update-learnings.md +0 -65
  272. package/template/workers/dev-team/project-manager/src/index.ts +0 -54
  273. package/template/workers/dev-team/project-manager/src/mcp-server.ts +0 -207
  274. package/template/workers/dev-team/project-manager/src/skills/create-prd.ts +0 -86
  275. package/template/workers/dev-team/project-manager/src/skills/next-issue.ts +0 -137
  276. package/template/workers/dev-team/project-manager/src/skills/project-status.ts +0 -131
  277. package/template/workers/dev-team/project-manager/src/skills/update-learnings.ts +0 -94
  278. package/template/workers/dev-team/project-manager/tsconfig.json +0 -19
  279. package/template/workers/dev-team/project-manager/worker.yaml +0 -96
  280. package/template/workers/dev-team/qa-tester/package.json +0 -24
  281. package/template/workers/dev-team/qa-tester/skills/create-demo-account.md +0 -36
  282. package/template/workers/dev-team/qa-tester/skills/run-tests.md +0 -36
  283. package/template/workers/dev-team/qa-tester/skills/write-test.md +0 -27
  284. package/template/workers/dev-team/qa-tester/src/index.ts +0 -61
  285. package/template/workers/dev-team/qa-tester/src/mcp-server.ts +0 -88
  286. package/template/workers/dev-team/qa-tester/tsconfig.json +0 -18
  287. package/template/workers/dev-team/qa-tester/worker.yaml +0 -116
  288. package/template/workers/dev-team/task-executor/package-lock.json +0 -1252
  289. package/template/workers/dev-team/task-executor/package.json +0 -27
  290. package/template/workers/dev-team/task-executor/skills/analyze-issue.md +0 -101
  291. package/template/workers/dev-team/task-executor/skills/execute.md +0 -133
  292. package/template/workers/dev-team/task-executor/skills/report-learnings.md +0 -106
  293. package/template/workers/dev-team/task-executor/skills/validate-completion.md +0 -121
  294. package/template/workers/dev-team/task-executor/src/index.ts +0 -54
  295. package/template/workers/dev-team/task-executor/src/mcp-server.ts +0 -139
  296. package/template/workers/dev-team/task-executor/src/skills/analyze-issue.ts +0 -219
  297. package/template/workers/dev-team/task-executor/src/skills/execute.ts +0 -132
  298. package/template/workers/dev-team/task-executor/src/skills/report-learnings.ts +0 -119
  299. package/template/workers/dev-team/task-executor/src/skills/validate-completion.ts +0 -142
  300. package/template/workers/dev-team/task-executor/tsconfig.json +0 -19
  301. package/template/workers/dev-team/task-executor/worker.yaml +0 -110
  302. package/template/workers/registry.yaml +0 -171
  303. package/template/workers/security-scanner/README.md +0 -73
  304. package/template/workers/security-scanner/skills/pre-deploy-check.md +0 -205
  305. package/template/workers/security-scanner/worker.yaml +0 -26
  306. package/template/workspace/checkpoints/.gitkeep +0 -0
  307. package/template/workspace/content-ideas/inbox.jsonl +0 -0
  308. package/template/workspace/drafts/.gitkeep +0 -0
  309. package/template/workspace/learnings/.gitkeep +0 -3
  310. package/template/workspace/orchestrator/.gitkeep +0 -0
  311. package/template/workspace/ralph-test/COMPLETE.md +0 -18
  312. package/template/workspace/ralph-test/hello.txt +0 -2
  313. package/template/workspace/reports/.gitkeep +0 -0
  314. package/template/workspace/scratch/.gitkeep +0 -0
  315. package/template/workspace/threads/.gitkeep +0 -3
@@ -1,555 +0,0 @@
1
- /**
2
- * Conversion Analyzer (US-008)
3
- * Analyzes content for conversion optimization opportunities
4
- */
5
-
6
- import type {
7
- AnalysisInput,
8
- ConversionAnalysis,
9
- Finding,
10
- Recommendation,
11
- } from './types.js';
12
-
13
- // ============================================
14
- // Conversion Elements to Check
15
- // ============================================
16
-
17
- export const CONVERSION_ELEMENTS = {
18
- // Strong CTA verbs and phrases
19
- ctaStrength: {
20
- strong: ['get started', 'start free', 'request demo', 'schedule call', 'book demo', 'try free', 'sign up free'],
21
- moderate: ['learn more', 'see how', 'explore', 'discover', 'find out', 'contact us', 'talk to sales'],
22
- weak: ['click here', 'submit', 'continue', 'next', 'read more'],
23
- },
24
-
25
- // Value indicators
26
- valueIndicators: ['save', 'reduce', 'increase', 'improve', 'boost', 'grow', 'eliminate', 'cut', 'accelerate', 'streamline'],
27
-
28
- // Quantified value (percentages, dollars, time)
29
- quantifiedValue: [
30
- /save\s+(?:\$[\d,]+|\d+%)/gi,
31
- /reduce\s+(?:by\s+)?\d+%/gi,
32
- /increase\s+(?:by\s+)?\d+%/gi,
33
- /\d+x\s+(?:faster|more|better)/gi,
34
- /in\s+(?:just\s+)?\d+\s+(?:minutes?|hours?|days?)/gi,
35
- ],
36
-
37
- // Urgency words
38
- urgencyWords: ['now', 'today', 'limited', 'exclusive', 'while', 'before', 'last chance', 'ending soon', 'hurry'],
39
-
40
- // Social proof elements
41
- proofElements: ['customers', 'clients', 'companies', 'teams', 'trusted by', 'used by', 'join', 'chosen by', 'preferred by'],
42
-
43
- // Trust indicators
44
- trustIndicators: ['secure', 'guaranteed', 'certified', 'compliant', 'protected', 'verified', 'trusted', 'enterprise-grade'],
45
- };
46
-
47
- // ============================================
48
- // Scoring Weights
49
- // ============================================
50
-
51
- const WEIGHTS = {
52
- cta: 0.30,
53
- valueProp: 0.30,
54
- urgency: 0.15,
55
- socialProof: 0.25,
56
- };
57
-
58
- // ============================================
59
- // Main Analysis Function
60
- // ============================================
61
-
62
- /**
63
- * Analyze content for conversion optimization
64
- */
65
- export function analyzeConversion(content: AnalysisInput): ConversionAnalysis {
66
- const findings: Finding[] = [];
67
- const recommendations: Recommendation[] = [];
68
-
69
- // Analyze CTAs
70
- const ctaResult = analyzeCTAs(content, findings, recommendations);
71
-
72
- // Analyze value proposition
73
- const valueResult = analyzeValueProp(content, findings, recommendations);
74
-
75
- // Analyze urgency
76
- const urgencyResult = analyzeUrgency(content, findings, recommendations);
77
-
78
- // Analyze social proof
79
- const socialProofResult = analyzeSocialProof(content, findings, recommendations);
80
-
81
- // Calculate overall score
82
- const overallScore = Math.round(
83
- ctaResult.score * WEIGHTS.cta +
84
- valueResult.score * WEIGHTS.valueProp +
85
- urgencyResult.score * WEIGHTS.urgency +
86
- socialProofResult.score * WEIGHTS.socialProof
87
- );
88
-
89
- return {
90
- overallScore,
91
- ctaScore: ctaResult.score,
92
- valuePropScore: valueResult.score,
93
- urgencyScore: urgencyResult.score,
94
- socialProofScore: socialProofResult.score,
95
- findings,
96
- recommendations,
97
- };
98
- }
99
-
100
- // ============================================
101
- // CTA Analysis
102
- // ============================================
103
-
104
- interface ScoreResult {
105
- score: number;
106
- }
107
-
108
- function analyzeCTAs(
109
- content: AnalysisInput,
110
- findings: Finding[],
111
- recommendations: Recommendation[]
112
- ): ScoreResult {
113
- let score = 100;
114
- const { ctaStrength } = CONVERSION_ELEMENTS;
115
-
116
- // Check if CTAs exist
117
- if (content.ctas.length === 0) {
118
- findings.push({
119
- severity: 'critical',
120
- category: 'Conversion - CTA',
121
- message: 'No calls-to-action found on page',
122
- });
123
- recommendations.push({
124
- priority: 'high',
125
- category: 'CTA',
126
- current: 'No CTAs present',
127
- suggested: 'Add primary CTA (e.g., "Get Started Free", "Request Demo")',
128
- rationale: 'Every page should guide visitors toward conversion',
129
- });
130
- return { score: 0 };
131
- }
132
-
133
- // Analyze CTA strength
134
- let strongCTAs = 0;
135
- let moderateCTAs = 0;
136
- let weakCTAs = 0;
137
-
138
- for (const cta of content.ctas) {
139
- const ctaLower = cta.text.toLowerCase();
140
-
141
- if (ctaStrength.strong.some(phrase => ctaLower.includes(phrase))) {
142
- strongCTAs++;
143
- } else if (ctaStrength.moderate.some(phrase => ctaLower.includes(phrase))) {
144
- moderateCTAs++;
145
- } else if (ctaStrength.weak.some(phrase => ctaLower.includes(phrase))) {
146
- weakCTAs++;
147
- } else {
148
- moderateCTAs++; // Assume moderate if not categorized
149
- }
150
- }
151
-
152
- // Score based on CTA quality mix
153
- if (strongCTAs === 0) {
154
- findings.push({
155
- severity: 'warning',
156
- category: 'Conversion - CTA',
157
- message: 'No strong CTAs found',
158
- evidence: `Found ${moderateCTAs} moderate and ${weakCTAs} weak CTAs`,
159
- });
160
- score -= 20;
161
- recommendations.push({
162
- priority: 'high',
163
- category: 'CTA',
164
- current: content.ctas[0]?.text ?? 'No strong CTA',
165
- suggested: 'Use action-oriented CTAs: "Get Started Free", "Request Demo", "Start Trial"',
166
- rationale: 'Strong CTAs drive higher conversion rates',
167
- });
168
- } else {
169
- findings.push({
170
- severity: 'pass',
171
- category: 'Conversion - CTA',
172
- message: `Found ${strongCTAs} strong CTA(s)`,
173
- evidence: content.ctas.slice(0, 3).map(c => c.text).join(', '),
174
- });
175
- }
176
-
177
- if (weakCTAs > 0) {
178
- findings.push({
179
- severity: 'info',
180
- category: 'Conversion - CTA',
181
- message: `${weakCTAs} weak CTA(s) could be strengthened`,
182
- });
183
- score -= weakCTAs * 5;
184
- }
185
-
186
- // Check CTA variety (primary vs secondary)
187
- const hasPrimary = content.ctas.some(c => ctaStrength.strong.some(phrase =>
188
- c.text.toLowerCase().includes(phrase)
189
- ));
190
- const hasSecondary = content.ctas.some(c => ctaStrength.moderate.some(phrase =>
191
- c.text.toLowerCase().includes(phrase)
192
- ));
193
-
194
- if (hasPrimary && hasSecondary) {
195
- findings.push({
196
- severity: 'pass',
197
- category: 'Conversion - CTA',
198
- message: 'Good CTA hierarchy with primary and secondary options',
199
- });
200
- } else if (!hasSecondary && content.ctas.length < 2) {
201
- findings.push({
202
- severity: 'info',
203
- category: 'Conversion - CTA',
204
- message: 'Consider adding secondary CTA for visitors not ready to commit',
205
- });
206
- score -= 5;
207
- recommendations.push({
208
- priority: 'low',
209
- category: 'CTA',
210
- current: 'Only one type of CTA',
211
- suggested: 'Add secondary option like "Learn More" or "See How It Works"',
212
- rationale: 'Multiple CTAs accommodate different buyer stages',
213
- });
214
- }
215
-
216
- // Check for above-the-fold CTA
217
- const heroSection = content.sections.find(s => s.type === 'hero');
218
- if (heroSection) {
219
- const heroCTA = content.ctas.find(c => c.link && (c.link.includes('#') || c.link.startsWith('/')));
220
- if (!heroCTA) {
221
- findings.push({
222
- severity: 'info',
223
- category: 'Conversion - CTA',
224
- message: 'Ensure primary CTA is visible above the fold',
225
- });
226
- score -= 5;
227
- }
228
- }
229
-
230
- return { score: Math.max(0, Math.min(100, score)) };
231
- }
232
-
233
- // ============================================
234
- // Value Proposition Analysis
235
- // ============================================
236
-
237
- function analyzeValueProp(
238
- content: AnalysisInput,
239
- findings: Finding[],
240
- recommendations: Recommendation[]
241
- ): ScoreResult {
242
- let score = 100;
243
- const allText = getAllText(content).toLowerCase();
244
-
245
- // Check for value indicators
246
- const valueTermsFound = CONVERSION_ELEMENTS.valueIndicators.filter(term =>
247
- allText.includes(term)
248
- );
249
-
250
- if (valueTermsFound.length === 0) {
251
- findings.push({
252
- severity: 'warning',
253
- category: 'Conversion - Value Proposition',
254
- message: 'No clear value indicators found',
255
- });
256
- score -= 25;
257
- recommendations.push({
258
- priority: 'high',
259
- category: 'Value Proposition',
260
- current: 'Value proposition unclear',
261
- suggested: 'Explicitly state benefits: "Save 50% on...", "Reduce X by..."',
262
- rationale: 'Clear value propositions are essential for conversion',
263
- });
264
- } else {
265
- findings.push({
266
- severity: 'pass',
267
- category: 'Conversion - Value Proposition',
268
- message: `${valueTermsFound.length} value indicator(s) found`,
269
- evidence: valueTermsFound.join(', '),
270
- });
271
- }
272
-
273
- // Check for quantified value (numbers, percentages)
274
- let quantifiedCount = 0;
275
- for (const pattern of CONVERSION_ELEMENTS.quantifiedValue) {
276
- const matches = allText.match(pattern);
277
- if (matches) quantifiedCount += matches.length;
278
- }
279
-
280
- if (quantifiedCount === 0) {
281
- findings.push({
282
- severity: 'warning',
283
- category: 'Conversion - Value Proposition',
284
- message: 'No quantified benefits found',
285
- });
286
- score -= 20;
287
- recommendations.push({
288
- priority: 'high',
289
- category: 'Value Proposition',
290
- current: 'Benefits are not quantified',
291
- suggested: 'Add specific metrics: "Save 40%", "10x faster", "In just 5 minutes"',
292
- rationale: 'Specific numbers are more persuasive than vague claims',
293
- });
294
- } else {
295
- findings.push({
296
- severity: 'pass',
297
- category: 'Conversion - Value Proposition',
298
- message: `Found ${quantifiedCount} quantified benefit(s)`,
299
- });
300
- }
301
-
302
- // Check stats coverage
303
- if (content.stats.length > 0) {
304
- findings.push({
305
- severity: 'pass',
306
- category: 'Conversion - Value Proposition',
307
- message: `${content.stats.length} statistics/metrics displayed`,
308
- evidence: content.stats.slice(0, 3).map(s => s.value).join(', '),
309
- });
310
- } else {
311
- findings.push({
312
- severity: 'info',
313
- category: 'Conversion - Value Proposition',
314
- message: 'Consider adding key statistics or metrics',
315
- });
316
- score -= 10;
317
- }
318
-
319
- // Check hero section for value prop
320
- const heroSection = content.sections.find(s => s.type === 'hero');
321
- if (heroSection) {
322
- const heroText = heroSection.content.join(' ').toLowerCase();
323
- const hasValueInHero = CONVERSION_ELEMENTS.valueIndicators.some(term =>
324
- heroText.includes(term)
325
- );
326
-
327
- if (!hasValueInHero) {
328
- findings.push({
329
- severity: 'warning',
330
- category: 'Conversion - Value Proposition',
331
- message: 'Hero section lacks clear value proposition',
332
- location: 'Hero section',
333
- });
334
- score -= 15;
335
- recommendations.push({
336
- priority: 'high',
337
- category: 'Value Proposition',
338
- current: 'Hero section missing value prop',
339
- suggested: 'Lead with primary benefit in hero headline or subheadline',
340
- rationale: 'Visitors should understand value within seconds',
341
- });
342
- }
343
- }
344
-
345
- return { score: Math.max(0, Math.min(100, score)) };
346
- }
347
-
348
- // ============================================
349
- // Urgency Analysis
350
- // ============================================
351
-
352
- function analyzeUrgency(
353
- content: AnalysisInput,
354
- findings: Finding[],
355
- recommendations: Recommendation[]
356
- ): ScoreResult {
357
- let score = 70; // Start at 70 since urgency isn't always appropriate
358
- const allText = getAllText(content).toLowerCase();
359
-
360
- // Check for urgency words
361
- const urgencyFound = CONVERSION_ELEMENTS.urgencyWords.filter(term =>
362
- allText.includes(term)
363
- );
364
-
365
- if (urgencyFound.length > 0) {
366
- findings.push({
367
- severity: 'pass',
368
- category: 'Conversion - Urgency',
369
- message: `Urgency elements present: ${urgencyFound.length} indicator(s)`,
370
- evidence: urgencyFound.join(', '),
371
- });
372
- score += 20;
373
-
374
- // Check for authentic vs artificial urgency
375
- const artificialUrgency = ['limited time', 'act now', 'hurry', 'last chance'];
376
- const hasArtificial = artificialUrgency.some(phrase => allText.includes(phrase));
377
-
378
- if (hasArtificial && !allText.includes('offer') && !allText.includes('promo')) {
379
- findings.push({
380
- severity: 'info',
381
- category: 'Conversion - Urgency',
382
- message: 'Urgency language may feel artificial without context',
383
- });
384
- score -= 10;
385
- recommendations.push({
386
- priority: 'low',
387
- category: 'Urgency',
388
- current: 'Generic urgency language',
389
- suggested: 'Tie urgency to specific context (limited seats, trial ending, etc.)',
390
- rationale: 'Authentic urgency is more effective than manufactured scarcity',
391
- });
392
- }
393
- } else {
394
- findings.push({
395
- severity: 'info',
396
- category: 'Conversion - Urgency',
397
- message: 'No urgency elements found',
398
- });
399
- recommendations.push({
400
- priority: 'low',
401
- category: 'Urgency',
402
- current: 'No urgency drivers',
403
- suggested: 'Consider adding contextual urgency (limited beta spots, early pricing, etc.)',
404
- rationale: 'Appropriate urgency can accelerate decision-making',
405
- });
406
- }
407
-
408
- // Check CTAs for urgency
409
- const ctasWithUrgency = content.ctas.filter(cta => {
410
- const ctaLower = cta.text.toLowerCase();
411
- return CONVERSION_ELEMENTS.urgencyWords.some(word => ctaLower.includes(word));
412
- });
413
-
414
- if (ctasWithUrgency.length > 0) {
415
- findings.push({
416
- severity: 'pass',
417
- category: 'Conversion - Urgency',
418
- message: 'CTA includes urgency element',
419
- evidence: ctasWithUrgency[0].text,
420
- });
421
- score += 10;
422
- }
423
-
424
- return { score: Math.max(0, Math.min(100, score)) };
425
- }
426
-
427
- // ============================================
428
- // Social Proof Analysis
429
- // ============================================
430
-
431
- function analyzeSocialProof(
432
- content: AnalysisInput,
433
- findings: Finding[],
434
- recommendations: Recommendation[]
435
- ): ScoreResult {
436
- let score = 100;
437
- const allText = getAllText(content).toLowerCase();
438
-
439
- // Check for social proof elements
440
- const proofFound = CONVERSION_ELEMENTS.proofElements.filter(term =>
441
- allText.includes(term)
442
- );
443
-
444
- if (proofFound.length === 0) {
445
- findings.push({
446
- severity: 'warning',
447
- category: 'Conversion - Social Proof',
448
- message: 'No social proof elements found',
449
- });
450
- score -= 30;
451
- recommendations.push({
452
- priority: 'high',
453
- category: 'Social Proof',
454
- current: 'Missing social proof',
455
- suggested: 'Add customer count, logos, testimonials, or case study references',
456
- rationale: 'Social proof significantly increases conversion rates',
457
- });
458
- } else {
459
- findings.push({
460
- severity: 'pass',
461
- category: 'Conversion - Social Proof',
462
- message: `Social proof present: ${proofFound.length} indicator(s)`,
463
- evidence: proofFound.join(', '),
464
- });
465
- }
466
-
467
- // Check for testimonials section
468
- const hasTestimonials = content.sections.some(s => s.type === 'testimonials');
469
- if (hasTestimonials) {
470
- findings.push({
471
- severity: 'pass',
472
- category: 'Conversion - Social Proof',
473
- message: 'Testimonials section present',
474
- });
475
- } else {
476
- findings.push({
477
- severity: 'info',
478
- category: 'Conversion - Social Proof',
479
- message: 'No dedicated testimonials section found',
480
- });
481
- score -= 10;
482
- recommendations.push({
483
- priority: 'medium',
484
- category: 'Social Proof',
485
- current: 'No testimonials section',
486
- suggested: 'Add customer testimonials with names, titles, and companies',
487
- rationale: 'Named testimonials build credibility and trust',
488
- });
489
- }
490
-
491
- // Check for trust indicators
492
- const trustFound = CONVERSION_ELEMENTS.trustIndicators.filter(term =>
493
- allText.includes(term)
494
- );
495
-
496
- if (trustFound.length > 0) {
497
- findings.push({
498
- severity: 'pass',
499
- category: 'Conversion - Social Proof',
500
- message: `Trust indicators present: ${trustFound.length}`,
501
- evidence: trustFound.join(', '),
502
- });
503
- } else {
504
- findings.push({
505
- severity: 'info',
506
- category: 'Conversion - Social Proof',
507
- message: 'No explicit trust indicators found',
508
- });
509
- score -= 10;
510
- }
511
-
512
- // Check for specific numbers (more credible)
513
- const specificNumbers = allText.match(/(?:over\s+)?\d{1,3}(?:,\d{3})*\+?\s+(?:customers?|clients?|companies?|teams?)/gi);
514
- if (specificNumbers && specificNumbers.length > 0) {
515
- findings.push({
516
- severity: 'pass',
517
- category: 'Conversion - Social Proof',
518
- message: 'Specific customer count mentioned',
519
- evidence: specificNumbers[0],
520
- });
521
- } else {
522
- findings.push({
523
- severity: 'info',
524
- category: 'Conversion - Social Proof',
525
- message: 'Consider adding specific customer count',
526
- });
527
- score -= 5;
528
- recommendations.push({
529
- priority: 'low',
530
- category: 'Social Proof',
531
- current: 'Generic social proof',
532
- suggested: 'Add specific number: "Trusted by 10,000+ companies"',
533
- rationale: 'Specific numbers are more credible than vague claims',
534
- });
535
- }
536
-
537
- return { score: Math.max(0, Math.min(100, score)) };
538
- }
539
-
540
- // ============================================
541
- // Helper Functions
542
- // ============================================
543
-
544
- /**
545
- * Get all text from content
546
- */
547
- function getAllText(content: AnalysisInput): string {
548
- return [
549
- content.title,
550
- ...content.headings,
551
- ...content.paragraphs,
552
- ...content.ctas.map(c => c.text),
553
- ...content.claims,
554
- ].join(' ');
555
- }