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,439 @@
1
+ /**
2
+ * Priority Scoring System (US-012)
3
+ * Ranks suggestions by impact and effort for optimal prioritization
4
+ */
5
+
6
+ import type { Suggestion } from './recommendations.js';
7
+
8
+ // ============================================
9
+ // Types
10
+ // ============================================
11
+
12
+ export interface PriorityConfig {
13
+ impactWeights: { high: number; medium: number; low: number };
14
+ effortWeights: { quick: number; moderate: number; significant: number };
15
+ }
16
+
17
+ export interface PrioritizedSuggestion extends Suggestion {
18
+ priorityLabel: string;
19
+ priorityRank: number;
20
+ }
21
+
22
+ export interface PriorityBreakdown {
23
+ quickWins: Suggestion[];
24
+ highValue: Suggestion[];
25
+ strategic: Suggestion[];
26
+ backlog: Suggestion[];
27
+ }
28
+
29
+ // ============================================
30
+ // Configuration
31
+ // ============================================
32
+
33
+ export const DEFAULT_PRIORITY_CONFIG: PriorityConfig = {
34
+ impactWeights: { high: 3, medium: 2, low: 1 },
35
+ effortWeights: { quick: 3, moderate: 2, significant: 1 },
36
+ };
37
+
38
+ // Alternative configs for different strategies
39
+ export const URGENCY_FOCUSED_CONFIG: PriorityConfig = {
40
+ impactWeights: { high: 4, medium: 2, low: 1 },
41
+ effortWeights: { quick: 2, moderate: 2, significant: 2 },
42
+ };
43
+
44
+ export const EFFICIENCY_FOCUSED_CONFIG: PriorityConfig = {
45
+ impactWeights: { high: 2, medium: 2, low: 2 },
46
+ effortWeights: { quick: 4, moderate: 2, significant: 1 },
47
+ };
48
+
49
+ // ============================================
50
+ // Priority Calculation
51
+ // ============================================
52
+
53
+ /**
54
+ * Calculate priority score (higher = do first)
55
+ * Score = impact weight * effort weight
56
+ */
57
+ export function calculatePriority(
58
+ impact: Suggestion['impact'],
59
+ effort: Suggestion['effort'],
60
+ config: PriorityConfig = DEFAULT_PRIORITY_CONFIG
61
+ ): number {
62
+ const impactScore = config.impactWeights[impact];
63
+ const effortScore = config.effortWeights[effort];
64
+ return impactScore * effortScore;
65
+ }
66
+
67
+ /**
68
+ * Get the maximum possible priority score for a config
69
+ */
70
+ export function getMaxPriority(config: PriorityConfig = DEFAULT_PRIORITY_CONFIG): number {
71
+ return Math.max(...Object.values(config.impactWeights)) *
72
+ Math.max(...Object.values(config.effortWeights));
73
+ }
74
+
75
+ /**
76
+ * Normalize priority to 0-100 scale
77
+ */
78
+ export function normalizePriority(
79
+ priority: number,
80
+ config: PriorityConfig = DEFAULT_PRIORITY_CONFIG
81
+ ): number {
82
+ const max = getMaxPriority(config);
83
+ return Math.round((priority / max) * 100);
84
+ }
85
+
86
+ /**
87
+ * Get priority label based on score
88
+ */
89
+ export function getPriorityLabel(priority: number, config: PriorityConfig = DEFAULT_PRIORITY_CONFIG): string {
90
+ const normalized = normalizePriority(priority, config);
91
+
92
+ if (normalized >= 75) return 'Critical';
93
+ if (normalized >= 50) return 'High';
94
+ if (normalized >= 25) return 'Medium';
95
+ return 'Low';
96
+ }
97
+
98
+ // ============================================
99
+ // Sorting and Ranking
100
+ // ============================================
101
+
102
+ /**
103
+ * Sort suggestions by priority (highest first)
104
+ */
105
+ export function sortByPriority(
106
+ suggestions: Suggestion[],
107
+ config: PriorityConfig = DEFAULT_PRIORITY_CONFIG
108
+ ): Suggestion[] {
109
+ return [...suggestions].sort((a, b) => {
110
+ const priorityA = calculatePriority(a.impact, a.effort, config);
111
+ const priorityB = calculatePriority(b.impact, b.effort, config);
112
+ return priorityB - priorityA;
113
+ });
114
+ }
115
+
116
+ /**
117
+ * Sort and add rank/label to suggestions
118
+ */
119
+ export function rankSuggestions(
120
+ suggestions: Suggestion[],
121
+ config: PriorityConfig = DEFAULT_PRIORITY_CONFIG
122
+ ): PrioritizedSuggestion[] {
123
+ const sorted = sortByPriority(suggestions, config);
124
+
125
+ return sorted.map((suggestion, index) => ({
126
+ ...suggestion,
127
+ priorityLabel: getPriorityLabel(suggestion.priority, config),
128
+ priorityRank: index + 1,
129
+ }));
130
+ }
131
+
132
+ // ============================================
133
+ // Grouping Functions
134
+ // ============================================
135
+
136
+ /**
137
+ * Group suggestions by effort level
138
+ */
139
+ export function groupByEffort(suggestions: Suggestion[]): Record<string, Suggestion[]> {
140
+ return {
141
+ quick: suggestions.filter(s => s.effort === 'quick'),
142
+ moderate: suggestions.filter(s => s.effort === 'moderate'),
143
+ significant: suggestions.filter(s => s.effort === 'significant'),
144
+ };
145
+ }
146
+
147
+ /**
148
+ * Group suggestions by impact level
149
+ */
150
+ export function groupByImpact(suggestions: Suggestion[]): Record<string, Suggestion[]> {
151
+ return {
152
+ high: suggestions.filter(s => s.impact === 'high'),
153
+ medium: suggestions.filter(s => s.impact === 'medium'),
154
+ low: suggestions.filter(s => s.impact === 'low'),
155
+ };
156
+ }
157
+
158
+ /**
159
+ * Group suggestions by source
160
+ */
161
+ export function groupBySource(suggestions: Suggestion[]): Record<string, Suggestion[]> {
162
+ return {
163
+ brand: suggestions.filter(s => s.source === 'brand'),
164
+ sales: suggestions.filter(s => s.source === 'sales'),
165
+ product: suggestions.filter(s => s.source === 'product'),
166
+ legal: suggestions.filter(s => s.source === 'legal'),
167
+ };
168
+ }
169
+
170
+ /**
171
+ * Group suggestions by type
172
+ */
173
+ export function groupByType(suggestions: Suggestion[]): Record<string, Suggestion[]> {
174
+ return {
175
+ text: suggestions.filter(s => s.type === 'text'),
176
+ structure: suggestions.filter(s => s.type === 'structure'),
177
+ cta: suggestions.filter(s => s.type === 'cta'),
178
+ stat: suggestions.filter(s => s.type === 'stat'),
179
+ claim: suggestions.filter(s => s.type === 'claim'),
180
+ };
181
+ }
182
+
183
+ /**
184
+ * Group suggestions by page
185
+ */
186
+ export function groupByPage(suggestions: Suggestion[]): Record<string, Suggestion[]> {
187
+ const byPage: Record<string, Suggestion[]> = {};
188
+
189
+ for (const suggestion of suggestions) {
190
+ if (!byPage[suggestion.pageSlug]) {
191
+ byPage[suggestion.pageSlug] = [];
192
+ }
193
+ byPage[suggestion.pageSlug].push(suggestion);
194
+ }
195
+
196
+ return byPage;
197
+ }
198
+
199
+ // ============================================
200
+ // Quick Wins and Strategic Breakdown
201
+ // ============================================
202
+
203
+ /**
204
+ * Get quick wins (high impact, quick effort)
205
+ */
206
+ export function getQuickWins(suggestions: Suggestion[]): Suggestion[] {
207
+ return suggestions
208
+ .filter(s => s.impact === 'high' && s.effort === 'quick')
209
+ .sort((a, b) => b.priority - a.priority);
210
+ }
211
+
212
+ /**
213
+ * Get high-value items (high impact, any effort)
214
+ */
215
+ export function getHighValue(suggestions: Suggestion[]): Suggestion[] {
216
+ return suggestions
217
+ .filter(s => s.impact === 'high')
218
+ .sort((a, b) => b.priority - a.priority);
219
+ }
220
+
221
+ /**
222
+ * Get easy fixes (any impact, quick effort)
223
+ */
224
+ export function getEasyFixes(suggestions: Suggestion[]): Suggestion[] {
225
+ return suggestions
226
+ .filter(s => s.effort === 'quick')
227
+ .sort((a, b) => b.priority - a.priority);
228
+ }
229
+
230
+ /**
231
+ * Get strategic items (high impact, significant effort)
232
+ * These require planning but deliver big results
233
+ */
234
+ export function getStrategicItems(suggestions: Suggestion[]): Suggestion[] {
235
+ return suggestions
236
+ .filter(s => s.impact === 'high' && s.effort === 'significant')
237
+ .sort((a, b) => b.priority - a.priority);
238
+ }
239
+
240
+ /**
241
+ * Get backlog items (low impact, significant effort)
242
+ * These should be deprioritized
243
+ */
244
+ export function getBacklogItems(suggestions: Suggestion[]): Suggestion[] {
245
+ return suggestions
246
+ .filter(s => s.impact === 'low' && s.effort === 'significant')
247
+ .sort((a, b) => b.priority - a.priority);
248
+ }
249
+
250
+ /**
251
+ * Get full priority breakdown
252
+ */
253
+ export function getPriorityBreakdown(suggestions: Suggestion[]): PriorityBreakdown {
254
+ return {
255
+ quickWins: getQuickWins(suggestions),
256
+ highValue: getHighValue(suggestions).filter(s => s.effort !== 'quick'), // Exclude already in quick wins
257
+ strategic: getStrategicItems(suggestions),
258
+ backlog: getBacklogItems(suggestions),
259
+ };
260
+ }
261
+
262
+ // ============================================
263
+ // Filtering
264
+ // ============================================
265
+
266
+ /**
267
+ * Filter suggestions by minimum priority
268
+ */
269
+ export function filterByMinPriority(
270
+ suggestions: Suggestion[],
271
+ minPriority: number
272
+ ): Suggestion[] {
273
+ return suggestions.filter(s => s.priority >= minPriority);
274
+ }
275
+
276
+ /**
277
+ * Filter suggestions by source
278
+ */
279
+ export function filterBySource(
280
+ suggestions: Suggestion[],
281
+ sources: Suggestion['source'][]
282
+ ): Suggestion[] {
283
+ return suggestions.filter(s => sources.includes(s.source));
284
+ }
285
+
286
+ /**
287
+ * Filter suggestions by page
288
+ */
289
+ export function filterByPage(
290
+ suggestions: Suggestion[],
291
+ pageSlugs: string[]
292
+ ): Suggestion[] {
293
+ return suggestions.filter(s => pageSlugs.includes(s.pageSlug));
294
+ }
295
+
296
+ /**
297
+ * Get top N suggestions
298
+ */
299
+ export function getTopSuggestions(
300
+ suggestions: Suggestion[],
301
+ n: number,
302
+ config: PriorityConfig = DEFAULT_PRIORITY_CONFIG
303
+ ): Suggestion[] {
304
+ return sortByPriority(suggestions, config).slice(0, n);
305
+ }
306
+
307
+ // ============================================
308
+ // Statistics
309
+ // ============================================
310
+
311
+ /**
312
+ * Calculate priority statistics for a set of suggestions
313
+ */
314
+ export function calculatePriorityStats(suggestions: Suggestion[]): {
315
+ total: number;
316
+ avgPriority: number;
317
+ byImpact: Record<string, number>;
318
+ byEffort: Record<string, number>;
319
+ quickWinCount: number;
320
+ estimatedHours: number;
321
+ } {
322
+ if (suggestions.length === 0) {
323
+ return {
324
+ total: 0,
325
+ avgPriority: 0,
326
+ byImpact: { high: 0, medium: 0, low: 0 },
327
+ byEffort: { quick: 0, moderate: 0, significant: 0 },
328
+ quickWinCount: 0,
329
+ estimatedHours: 0,
330
+ };
331
+ }
332
+
333
+ const byImpact = { high: 0, medium: 0, low: 0 };
334
+ const byEffort = { quick: 0, moderate: 0, significant: 0 };
335
+ let totalPriority = 0;
336
+ let quickWinCount = 0;
337
+
338
+ for (const s of suggestions) {
339
+ totalPriority += s.priority;
340
+ byImpact[s.impact]++;
341
+ byEffort[s.effort]++;
342
+ if (s.impact === 'high' && s.effort === 'quick') quickWinCount++;
343
+ }
344
+
345
+ // Rough hour estimates
346
+ const effortHours = {
347
+ quick: 0.5,
348
+ moderate: 2,
349
+ significant: 8,
350
+ };
351
+
352
+ const estimatedHours = suggestions.reduce((sum, s) => sum + effortHours[s.effort], 0);
353
+
354
+ return {
355
+ total: suggestions.length,
356
+ avgPriority: Math.round(totalPriority / suggestions.length),
357
+ byImpact,
358
+ byEffort,
359
+ quickWinCount,
360
+ estimatedHours,
361
+ };
362
+ }
363
+
364
+ // ============================================
365
+ // Formatting
366
+ // ============================================
367
+
368
+ /**
369
+ * Format priority breakdown as markdown
370
+ */
371
+ export function formatPriorityBreakdownMarkdown(breakdown: PriorityBreakdown): string {
372
+ const lines: string[] = ['# Priority Breakdown\n'];
373
+
374
+ if (breakdown.quickWins.length > 0) {
375
+ lines.push(`## Quick Wins (${breakdown.quickWins.length})`);
376
+ lines.push('High impact, low effort - do these first!\n');
377
+ for (const s of breakdown.quickWins) {
378
+ lines.push(`- **${s.pageSlug}**: ${truncate(s.original, 60)} -> ${truncate(s.suggested, 60)}`);
379
+ }
380
+ lines.push('');
381
+ }
382
+
383
+ if (breakdown.highValue.length > 0) {
384
+ lines.push(`## High Value (${breakdown.highValue.length})`);
385
+ lines.push('High impact, moderate effort - schedule these\n');
386
+ for (const s of breakdown.highValue) {
387
+ lines.push(`- **${s.pageSlug}**: ${truncate(s.original, 60)}`);
388
+ }
389
+ lines.push('');
390
+ }
391
+
392
+ if (breakdown.strategic.length > 0) {
393
+ lines.push(`## Strategic (${breakdown.strategic.length})`);
394
+ lines.push('High impact, significant effort - plan these carefully\n');
395
+ for (const s of breakdown.strategic) {
396
+ lines.push(`- **${s.pageSlug}**: ${truncate(s.original, 60)}`);
397
+ }
398
+ lines.push('');
399
+ }
400
+
401
+ if (breakdown.backlog.length > 0) {
402
+ lines.push(`## Backlog (${breakdown.backlog.length})`);
403
+ lines.push('Low priority - consider deprioritizing\n');
404
+ for (const s of breakdown.backlog) {
405
+ lines.push(`- **${s.pageSlug}**: ${truncate(s.original, 60)}`);
406
+ }
407
+ }
408
+
409
+ return lines.join('\n');
410
+ }
411
+
412
+ function truncate(text: string, maxLength: number): string {
413
+ if (text.length <= maxLength) return text;
414
+ return text.slice(0, maxLength - 3) + '...';
415
+ }
416
+
417
+ /**
418
+ * Format priority stats as text
419
+ */
420
+ export function formatPriorityStats(stats: ReturnType<typeof calculatePriorityStats>): string {
421
+ return `
422
+ Priority Statistics
423
+ -------------------
424
+ Total Suggestions: ${stats.total}
425
+ Average Priority: ${stats.avgPriority}
426
+ Quick Wins: ${stats.quickWinCount}
427
+ Estimated Hours: ${stats.estimatedHours}
428
+
429
+ By Impact:
430
+ High: ${stats.byImpact.high}
431
+ Medium: ${stats.byImpact.medium}
432
+ Low: ${stats.byImpact.low}
433
+
434
+ By Effort:
435
+ Quick: ${stats.byEffort.quick}
436
+ Moderate: ${stats.byEffort.moderate}
437
+ Significant: ${stats.byEffort.significant}
438
+ `.trim();
439
+ }