qualia-framework 2.5.1 → 3.1.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 (327) hide show
  1. package/CLAUDE.md +63 -0
  2. package/README.md +108 -30
  3. package/agents/builder.md +110 -0
  4. package/agents/planner.md +186 -0
  5. package/agents/qa-browser.md +186 -0
  6. package/agents/verifier.md +369 -0
  7. package/bin/cli.js +706 -417
  8. package/bin/install.js +622 -0
  9. package/bin/qualia-ui.js +284 -0
  10. package/bin/state.js +824 -0
  11. package/bin/statusline.js +252 -0
  12. package/docs/erp-contract.md +161 -0
  13. package/guide.md +63 -0
  14. package/hooks/auto-update.js +117 -0
  15. package/hooks/block-env-edit.js +52 -0
  16. package/hooks/branch-guard.js +68 -0
  17. package/hooks/migration-guard.js +83 -0
  18. package/hooks/pre-compact.js +52 -0
  19. package/hooks/pre-deploy-gate.js +149 -0
  20. package/hooks/pre-push.js +53 -0
  21. package/hooks/session-start.js +126 -0
  22. package/package.json +31 -17
  23. package/rules/design-reference.md +179 -0
  24. package/rules/frontend.md +126 -0
  25. package/rules/infrastructure.md +87 -0
  26. package/skills/qualia/SKILL.md +88 -0
  27. package/skills/qualia-build/SKILL.md +115 -0
  28. package/skills/qualia-debug/SKILL.md +87 -0
  29. package/skills/qualia-design/SKILL.md +99 -0
  30. package/skills/qualia-handoff/SKILL.md +66 -0
  31. package/skills/qualia-help/SKILL.md +60 -0
  32. package/skills/qualia-idk/SKILL.md +8 -0
  33. package/skills/qualia-learn/SKILL.md +111 -0
  34. package/skills/qualia-new/SKILL.md +323 -0
  35. package/skills/qualia-pause/SKILL.md +63 -0
  36. package/skills/qualia-plan/SKILL.md +101 -0
  37. package/skills/qualia-polish/SKILL.md +207 -0
  38. package/skills/qualia-quick/SKILL.md +37 -0
  39. package/skills/qualia-report/SKILL.md +114 -0
  40. package/skills/qualia-resume/SKILL.md +49 -0
  41. package/skills/qualia-review/SKILL.md +161 -0
  42. package/skills/qualia-ship/SKILL.md +90 -0
  43. package/skills/qualia-skill-new/SKILL.md +167 -0
  44. package/skills/qualia-task/SKILL.md +91 -0
  45. package/skills/qualia-test/SKILL.md +134 -0
  46. package/skills/qualia-verify/SKILL.md +113 -0
  47. package/templates/DESIGN.md +475 -0
  48. package/templates/help.html +476 -0
  49. package/templates/plan.md +42 -0
  50. package/templates/project.md +22 -0
  51. package/templates/state.md +27 -0
  52. package/templates/tracking.json +20 -0
  53. package/tests/bin.test.sh +687 -0
  54. package/tests/hooks.test.sh +384 -0
  55. package/tests/runner.js +1956 -0
  56. package/tests/state.test.sh +713 -0
  57. package/tests/statusline.test.sh +243 -0
  58. package/bin/collect-metrics.sh +0 -62
  59. package/framework/.claudeignore +0 -51
  60. package/framework/CLAUDE.md +0 -51
  61. package/framework/MCP_SETUP.md +0 -229
  62. package/framework/agents/architecture-strategist.md +0 -53
  63. package/framework/agents/backend-agent.md +0 -150
  64. package/framework/agents/code-simplicity-reviewer.md +0 -86
  65. package/framework/agents/frontend-agent.md +0 -111
  66. package/framework/agents/kieran-typescript-reviewer.md +0 -96
  67. package/framework/agents/performance-oracle.md +0 -111
  68. package/framework/agents/qualia-codebase-mapper.md +0 -761
  69. package/framework/agents/qualia-debugger.md +0 -1204
  70. package/framework/agents/qualia-executor.md +0 -882
  71. package/framework/agents/qualia-integration-checker.md +0 -424
  72. package/framework/agents/qualia-phase-researcher.md +0 -457
  73. package/framework/agents/qualia-plan-checker.md +0 -700
  74. package/framework/agents/qualia-planner.md +0 -1245
  75. package/framework/agents/qualia-project-researcher.md +0 -603
  76. package/framework/agents/qualia-research-synthesizer.md +0 -200
  77. package/framework/agents/qualia-roadmapper.md +0 -606
  78. package/framework/agents/qualia-verifier.md +0 -686
  79. package/framework/agents/red-team-qa.md +0 -130
  80. package/framework/agents/security-auditor.md +0 -72
  81. package/framework/agents/team-orchestrator.md +0 -229
  82. package/framework/agents/teams/framework-audit-team.md +0 -66
  83. package/framework/agents/teams/full-stack-team.md +0 -48
  84. package/framework/agents/teams/optimize-team.md +0 -53
  85. package/framework/agents/teams/review-team.md +0 -70
  86. package/framework/agents/teams/ship-team.md +0 -86
  87. package/framework/agents/test-agent.md +0 -182
  88. package/framework/hooks/auto-format.sh +0 -54
  89. package/framework/hooks/block-env-edit.sh +0 -42
  90. package/framework/hooks/branch-guard.sh +0 -43
  91. package/framework/hooks/confirm-delete.sh +0 -59
  92. package/framework/hooks/migration-validate.sh +0 -77
  93. package/framework/hooks/notification-speak.sh +0 -16
  94. package/framework/hooks/pre-commit.sh +0 -100
  95. package/framework/hooks/pre-compact.sh +0 -56
  96. package/framework/hooks/pre-deploy-gate.sh +0 -160
  97. package/framework/hooks/qualia-colors.sh +0 -32
  98. package/framework/hooks/retention-cleanup.sh +0 -62
  99. package/framework/hooks/save-session-state.sh +0 -185
  100. package/framework/hooks/session-context-loader.sh +0 -96
  101. package/framework/hooks/session-learn.sh +0 -32
  102. package/framework/hooks/skill-announce.sh +0 -123
  103. package/framework/hooks/tool-error-announce.sh +0 -27
  104. package/framework/install.ps1 +0 -323
  105. package/framework/install.sh +0 -313
  106. package/framework/qualia-framework/VERSION +0 -1
  107. package/framework/qualia-framework/assets/qualia-logo.png +0 -0
  108. package/framework/qualia-framework/bin/collect-metrics.sh +0 -67
  109. package/framework/qualia-framework/bin/generate-report-docx.py +0 -429
  110. package/framework/qualia-framework/bin/qualia-tools.js +0 -2201
  111. package/framework/qualia-framework/bin/qualia-tools.test.js +0 -1054
  112. package/framework/qualia-framework/references/checkpoints.md +0 -775
  113. package/framework/qualia-framework/references/completion-checklists.md +0 -359
  114. package/framework/qualia-framework/references/continuation-format.md +0 -249
  115. package/framework/qualia-framework/references/continuation-prompt.md +0 -97
  116. package/framework/qualia-framework/references/decimal-phase-calculation.md +0 -65
  117. package/framework/qualia-framework/references/design-quality.md +0 -56
  118. package/framework/qualia-framework/references/employee-guide.md +0 -167
  119. package/framework/qualia-framework/references/git-integration.md +0 -254
  120. package/framework/qualia-framework/references/git-planning-commit.md +0 -50
  121. package/framework/qualia-framework/references/model-profile-resolution.md +0 -32
  122. package/framework/qualia-framework/references/model-profiles.md +0 -73
  123. package/framework/qualia-framework/references/phase-argument-parsing.md +0 -61
  124. package/framework/qualia-framework/references/planning-config.md +0 -195
  125. package/framework/qualia-framework/references/questioning.md +0 -141
  126. package/framework/qualia-framework/references/tdd.md +0 -263
  127. package/framework/qualia-framework/references/ui-brand.md +0 -160
  128. package/framework/qualia-framework/references/verification-patterns.md +0 -612
  129. package/framework/qualia-framework/templates/DEBUG.md +0 -159
  130. package/framework/qualia-framework/templates/DESIGN.md +0 -81
  131. package/framework/qualia-framework/templates/UAT.md +0 -247
  132. package/framework/qualia-framework/templates/codebase/architecture.md +0 -255
  133. package/framework/qualia-framework/templates/codebase/concerns.md +0 -310
  134. package/framework/qualia-framework/templates/codebase/conventions.md +0 -307
  135. package/framework/qualia-framework/templates/codebase/integrations.md +0 -280
  136. package/framework/qualia-framework/templates/codebase/stack.md +0 -186
  137. package/framework/qualia-framework/templates/codebase/structure.md +0 -285
  138. package/framework/qualia-framework/templates/codebase/testing.md +0 -480
  139. package/framework/qualia-framework/templates/config.json +0 -35
  140. package/framework/qualia-framework/templates/context.md +0 -283
  141. package/framework/qualia-framework/templates/continue-here.md +0 -78
  142. package/framework/qualia-framework/templates/debug-subagent-prompt.md +0 -91
  143. package/framework/qualia-framework/templates/discovery.md +0 -146
  144. package/framework/qualia-framework/templates/lab-notes.md +0 -16
  145. package/framework/qualia-framework/templates/milestone-archive.md +0 -123
  146. package/framework/qualia-framework/templates/milestone.md +0 -115
  147. package/framework/qualia-framework/templates/phase-prompt.md +0 -567
  148. package/framework/qualia-framework/templates/planner-subagent-prompt.md +0 -117
  149. package/framework/qualia-framework/templates/project.md +0 -184
  150. package/framework/qualia-framework/templates/projects/ai-agent.md +0 -156
  151. package/framework/qualia-framework/templates/projects/mobile-app.md +0 -181
  152. package/framework/qualia-framework/templates/projects/voice-agent.md +0 -134
  153. package/framework/qualia-framework/templates/projects/website.md +0 -137
  154. package/framework/qualia-framework/templates/requirements.md +0 -231
  155. package/framework/qualia-framework/templates/research-project/ARCHITECTURE.md +0 -204
  156. package/framework/qualia-framework/templates/research-project/FEATURES.md +0 -147
  157. package/framework/qualia-framework/templates/research-project/PITFALLS.md +0 -200
  158. package/framework/qualia-framework/templates/research-project/STACK.md +0 -120
  159. package/framework/qualia-framework/templates/research-project/SUMMARY.md +0 -170
  160. package/framework/qualia-framework/templates/research.md +0 -552
  161. package/framework/qualia-framework/templates/roadmap.md +0 -206
  162. package/framework/qualia-framework/templates/state.md +0 -179
  163. package/framework/qualia-framework/templates/summary-complex.md +0 -59
  164. package/framework/qualia-framework/templates/summary-minimal.md +0 -41
  165. package/framework/qualia-framework/templates/summary-standard.md +0 -48
  166. package/framework/qualia-framework/templates/summary.md +0 -246
  167. package/framework/qualia-framework/templates/user-setup.md +0 -311
  168. package/framework/qualia-framework/templates/verification-report.md +0 -322
  169. package/framework/qualia-framework/workflows/add-phase.md +0 -179
  170. package/framework/qualia-framework/workflows/add-todo.md +0 -157
  171. package/framework/qualia-framework/workflows/audit-milestone.md +0 -241
  172. package/framework/qualia-framework/workflows/check-todos.md +0 -176
  173. package/framework/qualia-framework/workflows/complete-milestone.md +0 -858
  174. package/framework/qualia-framework/workflows/diagnose-issues.md +0 -219
  175. package/framework/qualia-framework/workflows/discovery-phase.md +0 -289
  176. package/framework/qualia-framework/workflows/discuss-phase.md +0 -534
  177. package/framework/qualia-framework/workflows/execute-phase.md +0 -559
  178. package/framework/qualia-framework/workflows/execute-plan.md +0 -438
  179. package/framework/qualia-framework/workflows/help.md +0 -470
  180. package/framework/qualia-framework/workflows/insert-phase.md +0 -220
  181. package/framework/qualia-framework/workflows/list-phase-assumptions.md +0 -178
  182. package/framework/qualia-framework/workflows/map-codebase.md +0 -327
  183. package/framework/qualia-framework/workflows/new-milestone.md +0 -363
  184. package/framework/qualia-framework/workflows/new-project.md +0 -982
  185. package/framework/qualia-framework/workflows/pause-work.md +0 -122
  186. package/framework/qualia-framework/workflows/plan-milestone-gaps.md +0 -256
  187. package/framework/qualia-framework/workflows/plan-phase.md +0 -422
  188. package/framework/qualia-framework/workflows/progress.md +0 -389
  189. package/framework/qualia-framework/workflows/quick.md +0 -252
  190. package/framework/qualia-framework/workflows/remove-phase.md +0 -326
  191. package/framework/qualia-framework/workflows/research-phase.md +0 -74
  192. package/framework/qualia-framework/workflows/resume-project.md +0 -306
  193. package/framework/qualia-framework/workflows/set-profile.md +0 -80
  194. package/framework/qualia-framework/workflows/settings.md +0 -145
  195. package/framework/qualia-framework/workflows/transition.md +0 -556
  196. package/framework/qualia-framework/workflows/update.md +0 -197
  197. package/framework/qualia-framework/workflows/verify-phase.md +0 -195
  198. package/framework/qualia-framework/workflows/verify-work.md +0 -625
  199. package/framework/rules/context7.md +0 -14
  200. package/framework/rules/frontend.md +0 -33
  201. package/framework/rules/speed.md +0 -23
  202. package/framework/scripts/__pycache__/say.cpython-314.pyc +0 -0
  203. package/framework/scripts/apply-retention.sh +0 -120
  204. package/framework/scripts/bootstrap-pop-os.sh +0 -354
  205. package/framework/scripts/claude-voice +0 -13
  206. package/framework/scripts/cleanup.sh +0 -131
  207. package/framework/scripts/cowork-mode.sh +0 -141
  208. package/framework/scripts/generate-project-claude-md.sh +0 -153
  209. package/framework/scripts/load-test-webhook.js +0 -172
  210. package/framework/scripts/say.py +0 -236
  211. package/framework/scripts/showcase-video-recorder/ffmpeg-builder.js +0 -167
  212. package/framework/scripts/showcase-video-recorder/playwright-helpers.js +0 -216
  213. package/framework/scripts/speak.py +0 -55
  214. package/framework/scripts/speak.sh +0 -18
  215. package/framework/scripts/status.sh +0 -138
  216. package/framework/scripts/sync-to-framework.sh +0 -65
  217. package/framework/scripts/voice-hotkey.py +0 -227
  218. package/framework/scripts/voice-input.sh +0 -51
  219. package/framework/skills/animate/SKILL.md +0 -202
  220. package/framework/skills/bolder/SKILL.md +0 -144
  221. package/framework/skills/browser-qa/SKILL.md +0 -536
  222. package/framework/skills/clarify/SKILL.md +0 -179
  223. package/framework/skills/client-handoff/SKILL.md +0 -135
  224. package/framework/skills/collab-onboard/SKILL.md +0 -111
  225. package/framework/skills/colorize/SKILL.md +0 -170
  226. package/framework/skills/critique/SKILL.md +0 -126
  227. package/framework/skills/deep-research/SKILL.md +0 -240
  228. package/framework/skills/delight/SKILL.md +0 -329
  229. package/framework/skills/deploy/SKILL.md +0 -261
  230. package/framework/skills/deploy-verify/SKILL.md +0 -377
  231. package/framework/skills/deploy-verify/scripts/canary-check.sh +0 -206
  232. package/framework/skills/deploy-verify/scripts/check-console-errors.js +0 -147
  233. package/framework/skills/deploy-verify/scripts/check-cwv.js +0 -139
  234. package/framework/skills/deploy-verify/scripts/project-detect.sh +0 -84
  235. package/framework/skills/deploy-verify/scripts/verify.sh +0 -548
  236. package/framework/skills/design-quieter/SKILL.md +0 -130
  237. package/framework/skills/distill/SKILL.md +0 -149
  238. package/framework/skills/docs-lookup/SKILL.md +0 -79
  239. package/framework/skills/fcm-notifications/SKILL.md +0 -125
  240. package/framework/skills/financial-ledger/SKILL.md +0 -1039
  241. package/framework/skills/frontend-master/NOTICE.md +0 -4
  242. package/framework/skills/frontend-master/SKILL.md +0 -127
  243. package/framework/skills/frontend-master/reference/color-and-contrast.md +0 -132
  244. package/framework/skills/frontend-master/reference/interaction-design.md +0 -123
  245. package/framework/skills/frontend-master/reference/motion-design.md +0 -99
  246. package/framework/skills/frontend-master/reference/responsive-design.md +0 -114
  247. package/framework/skills/frontend-master/reference/spatial-design.md +0 -100
  248. package/framework/skills/frontend-master/reference/typography.md +0 -131
  249. package/framework/skills/frontend-master/reference/ux-writing.md +0 -107
  250. package/framework/skills/harden/SKILL.md +0 -357
  251. package/framework/skills/i18n-rtl/SKILL.md +0 -752
  252. package/framework/skills/learn/SKILL.md +0 -95
  253. package/framework/skills/memory/SKILL.md +0 -50
  254. package/framework/skills/mobile-expo/SKILL.md +0 -977
  255. package/framework/skills/mobile-expo/references/store-checklist.md +0 -550
  256. package/framework/skills/nestjs-backend/README.md +0 -73
  257. package/framework/skills/nestjs-backend/SKILL.md +0 -446
  258. package/framework/skills/nestjs-backend/references/templates.md +0 -1173
  259. package/framework/skills/normalize/SKILL.md +0 -79
  260. package/framework/skills/onboard/SKILL.md +0 -242
  261. package/framework/skills/openrouter-agent/SKILL.md +0 -922
  262. package/framework/skills/polish/SKILL.md +0 -209
  263. package/framework/skills/pr/SKILL.md +0 -66
  264. package/framework/skills/qualia/SKILL.md +0 -199
  265. package/framework/skills/qualia-add-todo/SKILL.md +0 -68
  266. package/framework/skills/qualia-audit-milestone/SKILL.md +0 -95
  267. package/framework/skills/qualia-check-todos/SKILL.md +0 -55
  268. package/framework/skills/qualia-complete-milestone/SKILL.md +0 -134
  269. package/framework/skills/qualia-debug/SKILL.md +0 -149
  270. package/framework/skills/qualia-design/SKILL.md +0 -203
  271. package/framework/skills/qualia-discuss-phase/SKILL.md +0 -72
  272. package/framework/skills/qualia-evolve/SKILL.md +0 -200
  273. package/framework/skills/qualia-execute-phase/SKILL.md +0 -89
  274. package/framework/skills/qualia-framework-audit/SKILL.md +0 -604
  275. package/framework/skills/qualia-guide/SKILL.md +0 -32
  276. package/framework/skills/qualia-help/SKILL.md +0 -114
  277. package/framework/skills/qualia-idk/SKILL.md +0 -352
  278. package/framework/skills/qualia-list-phase-assumptions/SKILL.md +0 -67
  279. package/framework/skills/qualia-new-milestone/SKILL.md +0 -72
  280. package/framework/skills/qualia-new-project/SKILL.md +0 -232
  281. package/framework/skills/qualia-optimize/SKILL.md +0 -417
  282. package/framework/skills/qualia-pause-work/SKILL.md +0 -96
  283. package/framework/skills/qualia-plan-milestone-gaps/SKILL.md +0 -57
  284. package/framework/skills/qualia-plan-phase/SKILL.md +0 -104
  285. package/framework/skills/qualia-production-check/SKILL.md +0 -0
  286. package/framework/skills/qualia-progress/SKILL.md +0 -53
  287. package/framework/skills/qualia-quick/SKILL.md +0 -89
  288. package/framework/skills/qualia-report/SKILL.md +0 -166
  289. package/framework/skills/qualia-research-phase/SKILL.md +0 -88
  290. package/framework/skills/qualia-resume-work/SKILL.md +0 -62
  291. package/framework/skills/qualia-review/SKILL.md +0 -263
  292. package/framework/skills/qualia-start/SKILL.md +0 -161
  293. package/framework/skills/qualia-verify-work/SKILL.md +0 -132
  294. package/framework/skills/rag/SKILL.md +0 -750
  295. package/framework/skills/responsive/SKILL.md +0 -231
  296. package/framework/skills/retro/SKILL.md +0 -284
  297. package/framework/skills/sakani-conventions/SKILL.md +0 -136
  298. package/framework/skills/sakani-conventions/evals/evals.json +0 -23
  299. package/framework/skills/sakani-conventions/references/entities.md +0 -365
  300. package/framework/skills/sakani-conventions/references/error-codes.md +0 -95
  301. package/framework/skills/seo-master/SKILL.md +0 -490
  302. package/framework/skills/seo-master/references/checklist.md +0 -199
  303. package/framework/skills/seo-master/references/structured-data.md +0 -609
  304. package/framework/skills/ship/SKILL.md +0 -239
  305. package/framework/skills/stack-researcher/SKILL.md +0 -215
  306. package/framework/skills/status/SKILL.md +0 -154
  307. package/framework/skills/status/scripts/health-check.sh +0 -562
  308. package/framework/skills/subscription-payments/SKILL.md +0 -250
  309. package/framework/skills/supabase/SKILL.md +0 -973
  310. package/framework/skills/supabase/references/templates.md +0 -159
  311. package/framework/skills/team/SKILL.md +0 -67
  312. package/framework/skills/test-runner/SKILL.md +0 -202
  313. package/framework/skills/voice-agent/SKILL.md +0 -1312
  314. package/framework/skills/zoho-workflow/SKILL.md +0 -51
  315. package/framework/statusline-command.sh +0 -117
  316. package/framework/teams/default/inboxes/plan-04.json +0 -9
  317. package/framework/teams/review-team.md +0 -75
  318. package/framework/teams/ship-team.md +0 -86
  319. package/profiles/fawzi.json +0 -16
  320. package/profiles/hasan.json +0 -16
  321. package/profiles/moayad.json +0 -16
  322. package/templates/CLAUDE-owner.md +0 -52
  323. package/templates/CLAUDE.md.hbs +0 -58
  324. package/templates/env.claude.template +0 -12
  325. package/templates/settings.json +0 -172
  326. /package/{framework/rules → rules}/deployment.md +0 -0
  327. /package/{framework/rules → rules}/security.md +0 -0
@@ -1,559 +0,0 @@
1
- <purpose>
2
- Execute all plans in a phase using wave-based parallel execution. Orchestrator stays lean — delegates plan execution to subagents.
3
- </purpose>
4
-
5
- <core_principle>
6
- Orchestrator coordinates, not executes. Each subagent loads the full execute-plan context. Orchestrator: discover plans → analyze deps → group waves → spawn agents → handle checkpoints → collect results.
7
- </core_principle>
8
-
9
- <required_reading>
10
- Read STATE.md before any operation to load project context.
11
- </required_reading>
12
-
13
- <process>
14
-
15
- <step name="initialize" priority="first">
16
- Load all context in one call:
17
-
18
- ```bash
19
- INIT=$(node /home/qualia/.claude/qualia-framework/bin/qualia-tools.js init execute-phase "${PHASE_ARG}")
20
- ```
21
-
22
- Parse JSON for: `executor_model`, `verifier_model`, `commit_docs`, `parallelization`, `branching_strategy`, `branch_name`, `phase_found`, `phase_dir`, `phase_number`, `phase_name`, `phase_slug`, `plans`, `incomplete_plans`, `plan_count`, `incomplete_count`, `state_exists`, `roadmap_exists`.
23
-
24
- **If `phase_found` is false:** Error — phase directory not found.
25
- **If `plan_count` is 0:** Error — no plans found in phase.
26
- **If `state_exists` is false but `.planning/` exists:** Offer reconstruct or continue.
27
-
28
- When `parallelization` is false, plans within a wave execute sequentially.
29
- </step>
30
-
31
- <step name="handle_branching">
32
- Check `branching_strategy` from init:
33
-
34
- **"none":** Skip, continue on current branch.
35
-
36
- **"phase" or "milestone":** Use pre-computed `branch_name` from init:
37
- ```bash
38
- git checkout -b "$BRANCH_NAME" 2>/dev/null || git checkout "$BRANCH_NAME"
39
- ```
40
-
41
- All subsequent commits go to this branch. User handles merging.
42
- </step>
43
-
44
- <step name="validate_phase">
45
- From init JSON: `phase_dir`, `plan_count`, `incomplete_count`.
46
-
47
- Report: "Found {plan_count} plans in {phase_dir} ({incomplete_count} incomplete)"
48
-
49
- **Team suggestion (optional):** Check if the phase in ROADMAP.md has a `team:` field (e.g., `team: full-stack-team`). If present, suggest:
50
-
51
- ```
52
- Note: This phase has a team template configured (full-stack-team).
53
- Consider using `/team full-stack "<phase goal>"` for coordinated multi-agent execution.
54
- Continuing with standard execution...
55
- ```
56
-
57
- This is a suggestion only — execution continues normally regardless. The user can cancel and run `/team` instead, or let standard execution proceed.
58
- </step>
59
-
60
- <step name="discover_and_group_plans">
61
- Load plan inventory with wave grouping in one call:
62
-
63
- ```bash
64
- PLAN_INDEX=$(node /home/qualia/.claude/qualia-framework/bin/qualia-tools.js phase-plan-index "${PHASE_NUMBER}")
65
- ```
66
-
67
- Parse JSON for: `phase`, `plans[]` (each with `id`, `wave`, `autonomous`, `objective`, `files_modified`, `task_count`, `has_summary`), `waves` (map of wave number → plan IDs), `incomplete`, `has_checkpoints`.
68
-
69
- **Filtering:** Skip plans where `has_summary: true`. If `--gaps-only`: also skip non-gap_closure plans. If all filtered: "No matching incomplete plans" → exit.
70
-
71
- Report:
72
- ```
73
- ## Execution Plan
74
-
75
- **Phase {X}: {Name}** — {total_plans} plans across {wave_count} waves
76
-
77
- | Wave | Plans | What it builds |
78
- |------|-------|----------------|
79
- | 1 | 01-01, 01-02 | {from plan objectives, 3-8 words} |
80
- | 2 | 01-03 | ... |
81
- ```
82
- </step>
83
-
84
- <step name="execute_waves">
85
- Execute each wave in sequence. Within a wave: parallel if `PARALLELIZATION=true`, sequential if `false`.
86
-
87
- **For each wave:**
88
-
89
- 1. **Describe what's being built (BEFORE spawning):**
90
-
91
- Read each plan's `<objective>`. Extract what's being built and why.
92
-
93
- ```
94
- ---
95
- ## Wave {N}
96
-
97
- **{Plan ID}: {Plan Name}**
98
- {2-3 sentences: what this builds, technical approach, why it matters}
99
-
100
- Spawning {count} agent(s)...
101
- ---
102
- ```
103
-
104
- - Bad: "Executing terrain generation plan"
105
- - Good: "Procedural terrain generator using Perlin noise — creates height maps, biome zones, and collision meshes. Required before vehicle physics can interact with ground."
106
-
107
- 2. **Read files and spawn agents:**
108
-
109
- Content must be inlined — `@` syntax doesn't work across Task() boundaries.
110
-
111
- ```bash
112
- PLAN_CONTENT=$(cat "{plan_path}")
113
- STATE_CONTENT=$(cat .planning/STATE.md)
114
- CONFIG_CONTENT=$(cat .planning/config.json 2>/dev/null)
115
- # Content must be inlined — @ syntax doesn't work across Task() boundaries
116
- EXECUTE_PLAN_WF=$(cat /home/qualia/.claude/qualia-framework/workflows/execute-plan.md)
117
- SUMMARY_TMPL=$(cat /home/qualia/.claude/qualia-framework/templates/summary.md)
118
- CHECKPOINTS_REF=$(cat /home/qualia/.claude/qualia-framework/references/checkpoints.md)
119
- TDD_REF=$(cat /home/qualia/.claude/qualia-framework/references/tdd.md)
120
- # Detect if plan involves frontend work
121
- IS_FRONTEND=$(echo "$PLAN_CONTENT" | grep -qiE '\.(tsx|jsx|css|scss)|frontend|ui|component|page|layout|dashboard|form|modal' && echo "true" || echo "false")
122
- if [ "$IS_FRONTEND" = "true" ]; then
123
- DESIGN_CONTEXT=$(cat /home/qualia/.claude/qualia-framework/references/design-quality.md 2>/dev/null)
124
- FRONTEND_SKILL=$(cat /home/qualia/.claude/skills/frontend-master/SKILL.md 2>/dev/null)
125
- fi
126
- ```
127
-
128
- **Resolve domain skill references from plan:**
129
-
130
- ```bash
131
- # Extract @skill references from plan
132
- SKILL_REFS=$(echo "$PLAN_CONTENT" | grep -oP '@/home/qualia/.claude/skills/[^\s]+/SKILL\.md' | sort -u)
133
-
134
- # Inline each skill's content into domain context
135
- DOMAIN_CONTEXT=""
136
- for ref in $SKILL_REFS; do
137
- SKILL_PATH="${ref#@}"
138
- if [ -f "$SKILL_PATH" ]; then
139
- SKILL_NAME=$(basename "$(dirname "$SKILL_PATH")")
140
- DOMAIN_CONTEXT="${DOMAIN_CONTEXT}
141
-
142
- --- Skill: ${SKILL_NAME} ---
143
- $(cat "$SKILL_PATH")
144
- "
145
- fi
146
- done
147
- ```
148
-
149
- Each agent prompt:
150
-
151
- ```
152
- <objective>
153
- Execute plan {plan_number} of phase {phase_number}-{phase_name}.
154
- Commit each task atomically. Create SUMMARY.md. Update STATE.md.
155
- </objective>
156
-
157
- <execution_context>
158
- {execute_plan_wf}
159
- {summary_tmpl}
160
- {checkpoints_ref}
161
- {tdd_ref}
162
- </execution_context>
163
-
164
- <context>
165
- Plan:
166
- {plan_content}
167
-
168
- Project state:
169
- {state_content}
170
-
171
- Config (if exists):
172
- {config_content}
173
- </context>
174
-
175
- {If DOMAIN_CONTEXT is non-empty:}
176
- <domain_skills>
177
- These skill guidelines apply to this plan. Follow these patterns.
178
- {DOMAIN_CONTEXT}
179
- </domain_skills>
180
-
181
- <success_criteria>
182
- - [ ] All tasks executed
183
- - [ ] Each task committed individually
184
- - [ ] SUMMARY.md created in plan directory
185
- - [ ] STATE.md updated with position and decisions
186
- </success_criteria>
187
- ```
188
-
189
- **If `IS_FRONTEND` is true**, append this block to the agent prompt before `</success_criteria>`:
190
-
191
- ```
192
- <design_quality>
193
- This plan involves frontend work. Use the frontend-master skill as your primary design guide.
194
-
195
- {frontend_skill}
196
-
197
- Build-time standards summary:
198
- {design_context}
199
- </design_quality>
200
- ```
201
-
202
- And add to success_criteria:
203
- ```
204
- - [ ] Frontend components meet design quality standards (no generic look, states handled, copy is clear, transitions present)
205
- ```
206
-
207
- 3. **Wait for all agents in wave to complete.**
208
-
209
- 4. **Report completion — spot-check claims first:**
210
-
211
- For each SUMMARY.md:
212
- - Verify first 2 files from `key-files.created` exist on disk
213
- - Check `git log --oneline --all --grep="{phase}-{plan}"` returns ≥1 commit
214
- - Check for `## Self-Check: FAILED` marker
215
-
216
- If ANY spot-check fails: report which plan failed, route to failure handler — ask "Retry plan?" or "Continue with remaining waves?"
217
-
218
- If pass:
219
- ```
220
- ---
221
- ## Wave {N} Complete
222
-
223
- **{Plan ID}: {Plan Name}**
224
- {What was built — from SUMMARY.md}
225
- {Notable deviations, if any}
226
-
227
- {If more waves: what this enables for next wave}
228
- ---
229
- ```
230
-
231
- - Bad: "Wave 2 complete. Proceeding to Wave 3."
232
- - Good: "Terrain system complete — 3 biome types, height-based texturing, physics collision meshes. Vehicle physics (Wave 3) can now reference ground surfaces."
233
-
234
- 5. **Handle failures:** Report which plan failed → ask "Continue?" or "Stop?" → if continue, dependent plans may also fail. If stop, partial completion report.
235
-
236
- 6. **Execute checkpoint plans between waves** — see `<checkpoint_handling>`.
237
-
238
- 7. **Proceed to next wave.**
239
- </step>
240
-
241
- <step name="checkpoint_handling">
242
- Plans with `autonomous: false` require user interaction.
243
-
244
- **Flow:**
245
-
246
- 1. Spawn agent for checkpoint plan
247
- 2. Agent runs until checkpoint task or auth gate → returns structured state
248
- 3. Agent return includes: completed tasks table, current task + blocker, checkpoint type/details, what's awaited
249
- 4. **Present to user:**
250
- ```
251
- ## Checkpoint: [Type]
252
-
253
- **Plan:** 03-03 Dashboard Layout
254
- **Progress:** 2/3 tasks complete
255
-
256
- [Checkpoint Details from agent return]
257
- [Awaiting section from agent return]
258
- ```
259
- 5. User responds: "approved"/"done" | issue description | decision selection
260
- 6. **Spawn continuation agent (NOT resume)** using `/home/qualia/.claude/qualia-framework/references/continuation-prompt.md` template:
261
- - `{completed_tasks_table}`: From checkpoint return
262
- - `{resume_task_number}` + `{resume_task_name}`: Current task
263
- - `{user_response}`: What user provided
264
- - `{resume_instructions}`: Based on checkpoint type
265
- 7. Continuation agent verifies previous commits, continues from resume point
266
- 8. Repeat until plan completes or user stops
267
-
268
- **Why fresh agent, not resume:** Resume relies on internal serialization that breaks with parallel tool calls. Fresh agents with explicit state are more reliable.
269
-
270
- **Checkpoints in parallel waves:** Agent pauses and returns while other parallel agents may complete. Present checkpoint, spawn continuation, wait for all before next wave.
271
- </step>
272
-
273
- <step name="aggregate_results">
274
- After all waves:
275
-
276
- ```markdown
277
- ## Phase {X}: {Name} Execution Complete
278
-
279
- **Waves:** {N} | **Plans:** {M}/{total} complete
280
-
281
- | Wave | Plans | Status |
282
- |------|-------|--------|
283
- | 1 | plan-01, plan-02 | ✓ Complete |
284
- | CP | plan-03 | ✓ Verified |
285
- | 2 | plan-04 | ✓ Complete |
286
-
287
- ### Plan Details
288
- 1. **03-01**: [one-liner from SUMMARY.md]
289
- 2. **03-02**: [one-liner from SUMMARY.md]
290
-
291
- ### Test Summary
292
- If any plan SUMMARY.md mentions test results, aggregate:
293
- ```
294
- Tests: X passed, Y failed across {N} plans
295
- ```
296
- If Y > 0, note in Issues Encountered.
297
-
298
- ### Issues Encountered
299
- [Aggregate from SUMMARYs, or "None"]
300
- ```
301
- </step>
302
-
303
- <step name="design_polish_pass">
304
- After all waves complete, check if this phase produced frontend work.
305
-
306
- ```bash
307
- # Find the earliest commit from this phase across all plan numbering formats
308
- PHASE_BASE=$(git log --oneline --all --grep="(${PHASE_NUMBER}-" --reverse 2>/dev/null | head -1 | cut -d' ' -f1)
309
- if [ -z "$PHASE_BASE" ]; then
310
- # Fallback: try zero-padded format
311
- PADDED=$(printf "%02d" "${PHASE_NUMBER}")
312
- PHASE_BASE=$(git log --oneline --all --grep="(${PADDED}-" --reverse 2>/dev/null | head -1 | cut -d' ' -f1)
313
- fi
314
-
315
- if [ -n "$PHASE_BASE" ]; then
316
- FRONTEND_FILES=$(git diff --name-only ${PHASE_BASE}^..HEAD 2>/dev/null | grep -E '\.(tsx|jsx|css|scss)$' | head -30)
317
- else
318
- # Last resort: check all uncommitted + recent commits
319
- FRONTEND_FILES=$(git diff --name-only HEAD~20..HEAD 2>/dev/null | grep -E '\.(tsx|jsx|css|scss)$' | head -30)
320
- fi
321
- ```
322
-
323
- **If no frontend files:** Skip to verify_phase_goal.
324
-
325
- **If frontend files exist:** Run the impeccable diagnostic-then-fix flow.
326
-
327
- ### Step 1: Run /critique diagnostic
328
-
329
- ```bash
330
- # Content must be inlined — @ syntax doesn't work across Task() boundaries
331
- CRITIQUE_SKILL=$(cat /home/qualia/.claude/skills/critique/SKILL.md 2>/dev/null)
332
- FRONTEND_SKILL=$(cat /home/qualia/.claude/skills/frontend-master/SKILL.md 2>/dev/null)
333
- ```
334
-
335
- ```
336
- Task(
337
- prompt="You are a design director reviewing frontend work. Run a /critique diagnostic on all changed files.
338
-
339
- <skill>
340
- {critique_skill}
341
- </skill>
342
-
343
- <frontend_master>
344
- {frontend_skill}
345
- </frontend_master>
346
-
347
- <files_to_review>
348
- ${FRONTEND_FILES}
349
- </files_to_review>
350
-
351
- <rules>
352
- - Read each file before reviewing
353
- - Follow the critique skill exactly: AI slop detection, visual hierarchy, information architecture, emotional resonance, states, typography, color, microcopy
354
- - For each issue, specify which command to run (from the Priority Issues > Command field)
355
- - Do NOT fix anything — only diagnose and recommend
356
- - Output a structured report with:
357
- 1. Anti-Patterns Verdict (pass/fail)
358
- 2. Priority Issues (each with: what, why, fix, command)
359
- 3. Minor Observations
360
- - If everything looks good, report 'Design quality meets standards — no fixes needed'
361
- </rules>",
362
- subagent_type="qualia-executor",
363
- description="Design critique for Phase ${PHASE_NUMBER}"
364
- )
365
- ```
366
-
367
- ### Step 2: Parse critique and run recommended commands
368
-
369
- Read the critique report. If it says "no fixes needed" — skip to verify_phase_goal.
370
-
371
- If issues were found, collect the unique recommended commands from the report (e.g., `/polish`, `/harden`, `/animate`, `/normalize`, `/clarify`, `/bolder`, `/distill`, etc.).
372
-
373
- For each recommended command, load the corresponding skill and spawn a fix agent:
374
-
375
- ```bash
376
- # Load only the skills the critique recommended
377
- # Example: if critique recommended /polish and /harden
378
- for SKILL_NAME in ${RECOMMENDED_COMMANDS}; do
379
- SKILL_CONTENT=$(cat /home/qualia/.claude/skills/${SKILL_NAME}/SKILL.md 2>/dev/null)
380
- # Only proceed if skill file exists
381
- if [ -n "$SKILL_CONTENT" ]; then
382
- echo "Loading skill: ${SKILL_NAME}"
383
- fi
384
- done
385
- ```
386
-
387
- Spawn a single fix agent with all recommended skills loaded:
388
-
389
- ```
390
- Task(
391
- prompt="You are a design quality fixer. Apply the recommended fixes from the critique report.
392
-
393
- <critique_report>
394
- {critique_output}
395
- </critique_report>
396
-
397
- <skills>
398
- {For each recommended command, inline its SKILL.md content here}
399
- </skills>
400
-
401
- <frontend_master>
402
- {frontend_skill}
403
- </frontend_master>
404
-
405
- <files_to_fix>
406
- ${FRONTEND_FILES}
407
- </files_to_fix>
408
-
409
- <rules>
410
- - Read each file before modifying — understand context first
411
- - Only modify files in the list above
412
- - Only fix what the critique identified — do not refactor or restructure logic
413
- - Apply each recommended skill to address its specific issues
414
- - Commit changes as: style(${PHASE_NUMBER}): design quality — [summary of what was fixed]
415
- - If a recommended fix would require architectural changes, skip it and note why
416
- </rules>",
417
- subagent_type="qualia-executor",
418
- description="Design fixes for Phase ${PHASE_NUMBER}"
419
- )
420
- ```
421
-
422
- ### Step 3: Report
423
-
424
- ```
425
- ---
426
- ## Design Quality Pass
427
-
428
- **Critique:** {pass/fail verdict}
429
- **Issues found:** {N}
430
- **Commands applied:** {list of skills that ran}
431
- **Fixed:** {summary of changes}
432
-
433
- {If issues were skipped: list why}
434
- ---
435
- ```
436
-
437
- Report before proceeding to verify_phase_goal.
438
- </step>
439
-
440
- <step name="verify_phase_goal">
441
- Verify phase achieved its GOAL, not just completed tasks.
442
-
443
- ```
444
- Task(
445
- prompt="Verify phase {phase_number} goal achievement.
446
- Phase directory: {phase_dir}
447
- Phase goal: {goal from ROADMAP.md}
448
- Check must_haves against actual codebase. Create VERIFICATION.md.",
449
- subagent_type="qualia-verifier",
450
- model="{verifier_model}"
451
- )
452
- ```
453
-
454
- Read status:
455
- ```bash
456
- grep "^status:" "$PHASE_DIR"/*-VERIFICATION.md | cut -d: -f2 | tr -d ' '
457
- ```
458
-
459
- | Status | Action |
460
- |--------|--------|
461
- | `passed` | → update_roadmap |
462
- | `human_needed` | Present items for human testing, get approval or feedback |
463
- | `gaps_found` | Present gap summary, offer `/qualia-plan-phase {phase} --gaps` |
464
-
465
- **If human_needed:**
466
- ```
467
- ## ✓ Phase {X}: {Name} — Human Verification Required
468
-
469
- All automated checks passed. {N} items need human testing:
470
-
471
- {From VERIFICATION.md human_verification section}
472
-
473
- "approved" → continue | Report issues → gap closure
474
- ```
475
-
476
- **If gaps_found:**
477
- ```
478
- ## ⚠ Phase {X}: {Name} — Gaps Found
479
-
480
- **Score:** {N}/{M} must-haves verified
481
- **Report:** {phase_dir}/{phase}-VERIFICATION.md
482
-
483
- ### What's Missing
484
- {Gap summaries from VERIFICATION.md}
485
-
486
- ---
487
- ## ▶ Next Up
488
-
489
- `/qualia-plan-phase {X} --gaps`
490
-
491
- <sub>`/clear` first → fresh context window</sub>
492
-
493
- Also: `cat {phase_dir}/{phase}-VERIFICATION.md` — full report
494
- Also: `/qualia-verify-work {X}` — manual testing first
495
- ```
496
-
497
- Gap closure cycle: `/qualia-plan-phase {X} --gaps` reads VERIFICATION.md → creates gap plans with `gap_closure: true` → user runs `/qualia-execute-phase {X} --gaps-only` → verifier re-runs automatically (see below).
498
-
499
- **Mandatory re-verification after gap closure:**
500
-
501
- When executing with `--gaps-only`, after all gap plans complete (aggregate_results), automatically re-run verification — do NOT skip to update_roadmap. The flow is:
502
-
503
- 1. Gap plans execute via execute_waves
504
- 2. aggregate_results reports completion
505
- 3. verify_phase_goal re-runs (spawn qualia-verifier again)
506
- 4. **If `passed`:** → update_roadmap (phase complete)
507
- 5. **If `gaps_found` again:** Present new gaps, offer another `/qualia-plan-phase {X} --gaps` cycle. **Never mark phase complete with gaps.**
508
- 6. **If `human_needed`:** Present for manual testing as usual
509
-
510
- A phase MUST NOT be marked complete in ROADMAP.md until verification returns `passed` or the user explicitly approves after `human_needed`. There is no bypass.
511
- </step>
512
-
513
- <step name="update_roadmap">
514
- Mark phase complete in ROADMAP.md (date, status). **Only reachable when verification status is `passed` or user approved `human_needed` items.**
515
-
516
- ```bash
517
- node /home/qualia/.claude/qualia-framework/bin/qualia-tools.js commit "docs(phase-{X}): complete phase execution" --files .planning/ROADMAP.md .planning/STATE.md .planning/phases/{phase_dir}/*-VERIFICATION.md .planning/REQUIREMENTS.md
518
- ```
519
- </step>
520
-
521
- <step name="offer_next">
522
-
523
- **If more phases:**
524
- ```
525
- ## Next Up
526
-
527
- **Phase {X+1}: {Name}** — {Goal}
528
-
529
- `/clear` then `/qualia-plan-phase {X+1}`
530
- ```
531
-
532
- **If milestone complete:**
533
- ```
534
- MILESTONE COMPLETE!
535
-
536
- All {N} phases executed.
537
-
538
- `/clear` then `/qualia-complete-milestone`
539
- ```
540
- </step>
541
-
542
- </process>
543
-
544
- <context_efficiency>
545
- Orchestrator: ~10-15% context. Subagents: fresh 200k each. No polling (Task blocks). No context bleed.
546
- </context_efficiency>
547
-
548
- <failure_handling>
549
- - **Agent fails mid-plan:** Missing SUMMARY.md → report, ask user how to proceed
550
- - **Dependency chain breaks:** Wave 1 fails → Wave 2 dependents likely fail → user chooses attempt or skip
551
- - **All agents in wave fail:** Systemic issue → stop, report for investigation
552
- - **Checkpoint unresolvable:** "Skip this plan?" or "Abort phase execution?" → record partial progress in STATE.md
553
- </failure_handling>
554
-
555
- <resumption>
556
- Re-run `/qualia-execute-phase {phase}` → discover_plans finds completed SUMMARYs → skips them → resumes from first incomplete plan → continues wave execution.
557
-
558
- STATE.md tracks: last completed plan, current wave, pending checkpoints.
559
- </resumption>