qualia-framework 2.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.
- package/README.md +50 -0
- package/bin/cli.js +519 -0
- package/framework/agents/architecture-strategist.md +53 -0
- package/framework/agents/backend-agent.md +150 -0
- package/framework/agents/code-simplicity-reviewer.md +86 -0
- package/framework/agents/frontend-agent.md +111 -0
- package/framework/agents/kieran-typescript-reviewer.md +96 -0
- package/framework/agents/performance-oracle.md +111 -0
- package/framework/agents/qualia-codebase-mapper.md +760 -0
- package/framework/agents/qualia-debugger.md +1203 -0
- package/framework/agents/qualia-executor.md +881 -0
- package/framework/agents/qualia-integration-checker.md +423 -0
- package/framework/agents/qualia-phase-researcher.md +453 -0
- package/framework/agents/qualia-plan-checker.md +699 -0
- package/framework/agents/qualia-planner.md +1241 -0
- package/framework/agents/qualia-project-researcher.md +602 -0
- package/framework/agents/qualia-research-synthesizer.md +236 -0
- package/framework/agents/qualia-roadmapper.md +605 -0
- package/framework/agents/qualia-verifier.md +685 -0
- package/framework/agents/team-orchestrator.md +228 -0
- package/framework/agents/teams/full-stack-team.md +48 -0
- package/framework/agents/teams/optimize-team.md +53 -0
- package/framework/agents/teams/review-team.md +62 -0
- package/framework/agents/teams/ship-team.md +86 -0
- package/framework/agents/test-agent.md +182 -0
- package/framework/askpass.sh +2 -0
- package/framework/commands/design.md +53 -0
- package/framework/commands/quick-db.md +22 -0
- package/framework/config/retention.json +35 -0
- package/framework/core/PRINCIPLES.md +77 -0
- package/framework/hooks/auto-format.sh +45 -0
- package/framework/hooks/block-env-edit.sh +42 -0
- package/framework/hooks/branch-guard.sh +46 -0
- package/framework/hooks/confirm-delete.sh +56 -0
- package/framework/hooks/migration-validate.sh +68 -0
- package/framework/hooks/notification-speak.sh +15 -0
- package/framework/hooks/pre-commit.sh +80 -0
- package/framework/hooks/pre-compact.sh +55 -0
- package/framework/hooks/pre-deploy-gate.sh +151 -0
- package/framework/hooks/qualia-colors.sh +32 -0
- package/framework/hooks/retention-cleanup.sh +43 -0
- package/framework/hooks/save-session-state.sh +153 -0
- package/framework/hooks/session-context-loader.sh +28 -0
- package/framework/hooks/session-learn.sh +30 -0
- package/framework/knowledge/claudecode-bible.md +1384 -0
- package/framework/knowledge/client-prefs.md +22 -0
- package/framework/knowledge/common-fixes.md +25 -0
- package/framework/knowledge/deployment-map.md +35 -0
- package/framework/knowledge/email-signature.html +1 -0
- package/framework/knowledge/employees.md +8 -0
- package/framework/knowledge/learned-patterns.md +51 -0
- package/framework/knowledge/optimization-research-2026.md +137 -0
- package/framework/knowledge/qualia-context.md +67 -0
- package/framework/knowledge/supabase-patterns.md +50 -0
- package/framework/knowledge/voice-agent-patterns.md +46 -0
- package/framework/qualia-engine/VERSION +1 -0
- package/framework/qualia-engine/bin/qualia-tools.js +2160 -0
- package/framework/qualia-engine/bin/qualia-tools.test.js +1054 -0
- package/framework/qualia-engine/references/checkpoints.md +775 -0
- package/framework/qualia-engine/references/continuation-format.md +249 -0
- package/framework/qualia-engine/references/decimal-phase-calculation.md +65 -0
- package/framework/qualia-engine/references/design-quality.md +56 -0
- package/framework/qualia-engine/references/git-integration.md +254 -0
- package/framework/qualia-engine/references/git-planning-commit.md +50 -0
- package/framework/qualia-engine/references/model-profile-resolution.md +32 -0
- package/framework/qualia-engine/references/model-profiles.md +73 -0
- package/framework/qualia-engine/references/phase-argument-parsing.md +61 -0
- package/framework/qualia-engine/references/planning-config.md +195 -0
- package/framework/qualia-engine/references/questioning.md +141 -0
- package/framework/qualia-engine/references/tdd.md +263 -0
- package/framework/qualia-engine/references/ui-brand.md +160 -0
- package/framework/qualia-engine/references/verification-patterns.md +612 -0
- package/framework/qualia-engine/templates/DEBUG.md +159 -0
- package/framework/qualia-engine/templates/DESIGN.md +81 -0
- package/framework/qualia-engine/templates/UAT.md +247 -0
- package/framework/qualia-engine/templates/codebase/architecture.md +255 -0
- package/framework/qualia-engine/templates/codebase/concerns.md +310 -0
- package/framework/qualia-engine/templates/codebase/conventions.md +307 -0
- package/framework/qualia-engine/templates/codebase/integrations.md +280 -0
- package/framework/qualia-engine/templates/codebase/stack.md +186 -0
- package/framework/qualia-engine/templates/codebase/structure.md +285 -0
- package/framework/qualia-engine/templates/codebase/testing.md +480 -0
- package/framework/qualia-engine/templates/config.json +35 -0
- package/framework/qualia-engine/templates/context.md +283 -0
- package/framework/qualia-engine/templates/continue-here.md +78 -0
- package/framework/qualia-engine/templates/debug-subagent-prompt.md +91 -0
- package/framework/qualia-engine/templates/discovery.md +146 -0
- package/framework/qualia-engine/templates/milestone-archive.md +123 -0
- package/framework/qualia-engine/templates/milestone.md +115 -0
- package/framework/qualia-engine/templates/phase-prompt.md +567 -0
- package/framework/qualia-engine/templates/planner-subagent-prompt.md +117 -0
- package/framework/qualia-engine/templates/project.md +184 -0
- package/framework/qualia-engine/templates/projects/ai-agent.md +156 -0
- package/framework/qualia-engine/templates/projects/mobile-app.md +181 -0
- package/framework/qualia-engine/templates/projects/voice-agent.md +134 -0
- package/framework/qualia-engine/templates/projects/website.md +137 -0
- package/framework/qualia-engine/templates/requirements.md +231 -0
- package/framework/qualia-engine/templates/research-project/ARCHITECTURE.md +204 -0
- package/framework/qualia-engine/templates/research-project/FEATURES.md +147 -0
- package/framework/qualia-engine/templates/research-project/PITFALLS.md +200 -0
- package/framework/qualia-engine/templates/research-project/STACK.md +120 -0
- package/framework/qualia-engine/templates/research-project/SUMMARY.md +170 -0
- package/framework/qualia-engine/templates/research.md +552 -0
- package/framework/qualia-engine/templates/roadmap.md +202 -0
- package/framework/qualia-engine/templates/state.md +176 -0
- package/framework/qualia-engine/templates/summary-complex.md +59 -0
- package/framework/qualia-engine/templates/summary-minimal.md +41 -0
- package/framework/qualia-engine/templates/summary-standard.md +48 -0
- package/framework/qualia-engine/templates/summary.md +246 -0
- package/framework/qualia-engine/templates/user-setup.md +311 -0
- package/framework/qualia-engine/templates/verification-report.md +322 -0
- package/framework/qualia-engine/workflows/add-phase.md +179 -0
- package/framework/qualia-engine/workflows/add-todo.md +157 -0
- package/framework/qualia-engine/workflows/audit-milestone.md +241 -0
- package/framework/qualia-engine/workflows/check-todos.md +176 -0
- package/framework/qualia-engine/workflows/complete-milestone.md +858 -0
- package/framework/qualia-engine/workflows/diagnose-issues.md +219 -0
- package/framework/qualia-engine/workflows/discovery-phase.md +289 -0
- package/framework/qualia-engine/workflows/discuss-phase.md +534 -0
- package/framework/qualia-engine/workflows/execute-phase.md +559 -0
- package/framework/qualia-engine/workflows/execute-plan.md +438 -0
- package/framework/qualia-engine/workflows/help.md +470 -0
- package/framework/qualia-engine/workflows/insert-phase.md +220 -0
- package/framework/qualia-engine/workflows/list-phase-assumptions.md +178 -0
- package/framework/qualia-engine/workflows/map-codebase.md +327 -0
- package/framework/qualia-engine/workflows/new-milestone.md +363 -0
- package/framework/qualia-engine/workflows/new-project.md +1037 -0
- package/framework/qualia-engine/workflows/pause-work.md +122 -0
- package/framework/qualia-engine/workflows/plan-milestone-gaps.md +256 -0
- package/framework/qualia-engine/workflows/plan-phase.md +422 -0
- package/framework/qualia-engine/workflows/progress.md +354 -0
- package/framework/qualia-engine/workflows/quick.md +252 -0
- package/framework/qualia-engine/workflows/remove-phase.md +326 -0
- package/framework/qualia-engine/workflows/research-phase.md +74 -0
- package/framework/qualia-engine/workflows/resume-project.md +306 -0
- package/framework/qualia-engine/workflows/set-profile.md +80 -0
- package/framework/qualia-engine/workflows/settings.md +145 -0
- package/framework/qualia-engine/workflows/transition.md +556 -0
- package/framework/qualia-engine/workflows/update.md +197 -0
- package/framework/qualia-engine/workflows/verify-phase.md +195 -0
- package/framework/qualia-engine/workflows/verify-work.md +625 -0
- package/framework/rules/context7.md +11 -0
- package/framework/rules/deployment.md +29 -0
- package/framework/rules/frontend.md +33 -0
- package/framework/rules/security.md +12 -0
- package/framework/rules/speed.md +20 -0
- package/framework/scripts/__pycache__/say.cpython-314.pyc +0 -0
- package/framework/scripts/apply-retention.sh +120 -0
- package/framework/scripts/bootstrap-pop-os.sh +354 -0
- package/framework/scripts/claude-voice +13 -0
- package/framework/scripts/cleanup.sh +131 -0
- package/framework/scripts/cowork-mode.sh +141 -0
- package/framework/scripts/generate-project-claude-md.sh +153 -0
- package/framework/scripts/load-test-webhook.js +172 -0
- package/framework/scripts/say.py +236 -0
- package/framework/scripts/showcase-video-recorder/ffmpeg-builder.js +167 -0
- package/framework/scripts/showcase-video-recorder/playwright-helpers.js +216 -0
- package/framework/scripts/speak.py +55 -0
- package/framework/scripts/speak.sh +18 -0
- package/framework/scripts/status.sh +138 -0
- package/framework/scripts/sync-to-framework.sh +65 -0
- package/framework/scripts/voice-hotkey.py +227 -0
- package/framework/scripts/voice-input.sh +51 -0
- package/framework/skills/animate/SKILL.md +202 -0
- package/framework/skills/bolder/SKILL.md +144 -0
- package/framework/skills/browser-qa/SKILL.md +536 -0
- package/framework/skills/clarify/SKILL.md +179 -0
- package/framework/skills/colorize/SKILL.md +170 -0
- package/framework/skills/critique/SKILL.md +126 -0
- package/framework/skills/deep-research/SKILL.md +271 -0
- package/framework/skills/delight/SKILL.md +329 -0
- package/framework/skills/deploy/SKILL.md +261 -0
- package/framework/skills/deploy-verify/SKILL.md +377 -0
- package/framework/skills/deploy-verify/scripts/canary-check.sh +206 -0
- package/framework/skills/deploy-verify/scripts/check-console-errors.js +147 -0
- package/framework/skills/deploy-verify/scripts/check-cwv.js +139 -0
- package/framework/skills/deploy-verify/scripts/project-detect.sh +84 -0
- package/framework/skills/deploy-verify/scripts/verify.sh +548 -0
- package/framework/skills/design-quieter/SKILL.md +130 -0
- package/framework/skills/distill/SKILL.md +149 -0
- package/framework/skills/docs-lookup/SKILL.md +78 -0
- package/framework/skills/fcm-notifications/SKILL.md +125 -0
- package/framework/skills/financial-ledger/SKILL.md +1039 -0
- package/framework/skills/frontend-master/NOTICE.md +4 -0
- package/framework/skills/frontend-master/SKILL.md +127 -0
- package/framework/skills/frontend-master/reference/color-and-contrast.md +132 -0
- package/framework/skills/frontend-master/reference/interaction-design.md +123 -0
- package/framework/skills/frontend-master/reference/motion-design.md +99 -0
- package/framework/skills/frontend-master/reference/responsive-design.md +114 -0
- package/framework/skills/frontend-master/reference/spatial-design.md +100 -0
- package/framework/skills/frontend-master/reference/typography.md +131 -0
- package/framework/skills/frontend-master/reference/ux-writing.md +107 -0
- package/framework/skills/harden/SKILL.md +357 -0
- package/framework/skills/i18n-rtl/SKILL.md +752 -0
- package/framework/skills/learn/SKILL.md +71 -0
- package/framework/skills/memory/SKILL.md +50 -0
- package/framework/skills/mobile-expo/SKILL.md +864 -0
- package/framework/skills/mobile-expo/references/store-checklist.md +550 -0
- package/framework/skills/nestjs-backend/README.md +73 -0
- package/framework/skills/nestjs-backend/SKILL.md +446 -0
- package/framework/skills/nestjs-backend/references/templates.md +1173 -0
- package/framework/skills/normalize/SKILL.md +79 -0
- package/framework/skills/onboard/SKILL.md +242 -0
- package/framework/skills/polish/SKILL.md +209 -0
- package/framework/skills/pr/SKILL.md +66 -0
- package/framework/skills/qualia/SKILL.md +153 -0
- package/framework/skills/qualia-add-todo/SKILL.md +68 -0
- package/framework/skills/qualia-audit-milestone/SKILL.md +92 -0
- package/framework/skills/qualia-check-todos/SKILL.md +55 -0
- package/framework/skills/qualia-complete-milestone/SKILL.md +108 -0
- package/framework/skills/qualia-debug/SKILL.md +149 -0
- package/framework/skills/qualia-design/SKILL.md +203 -0
- package/framework/skills/qualia-discuss-phase/SKILL.md +72 -0
- package/framework/skills/qualia-execute-phase/SKILL.md +86 -0
- package/framework/skills/qualia-help/SKILL.md +67 -0
- package/framework/skills/qualia-idk/SKILL.md +352 -0
- package/framework/skills/qualia-list-phase-assumptions/SKILL.md +67 -0
- package/framework/skills/qualia-new-milestone/SKILL.md +72 -0
- package/framework/skills/qualia-new-project/SKILL.md +92 -0
- package/framework/skills/qualia-optimize/SKILL.md +417 -0
- package/framework/skills/qualia-pause-work/SKILL.md +96 -0
- package/framework/skills/qualia-plan-milestone-gaps/SKILL.md +57 -0
- package/framework/skills/qualia-plan-phase/SKILL.md +101 -0
- package/framework/skills/qualia-progress/SKILL.md +53 -0
- package/framework/skills/qualia-quick/SKILL.md +89 -0
- package/framework/skills/qualia-research-phase/SKILL.md +88 -0
- package/framework/skills/qualia-resume-work/SKILL.md +62 -0
- package/framework/skills/qualia-review/SKILL.md +263 -0
- package/framework/skills/qualia-start/SKILL.md +182 -0
- package/framework/skills/qualia-verify-work/SKILL.md +105 -0
- package/framework/skills/qualia-workflow/SKILL.md +130 -0
- package/framework/skills/rag/SKILL.md +750 -0
- package/framework/skills/responsive/SKILL.md +231 -0
- package/framework/skills/retro/SKILL.md +284 -0
- package/framework/skills/sakani-conventions/SKILL.md +136 -0
- package/framework/skills/sakani-conventions/evals/evals.json +23 -0
- package/framework/skills/sakani-conventions/references/entities.md +365 -0
- package/framework/skills/sakani-conventions/references/error-codes.md +95 -0
- package/framework/skills/seo-master/SKILL.md +490 -0
- package/framework/skills/seo-master/references/checklist.md +199 -0
- package/framework/skills/seo-master/references/structured-data.md +609 -0
- package/framework/skills/ship/SKILL.md +202 -0
- package/framework/skills/stack-researcher/SKILL.md +215 -0
- package/framework/skills/status/SKILL.md +154 -0
- package/framework/skills/status/scripts/health-check.sh +562 -0
- package/framework/skills/subscription-payments/SKILL.md +250 -0
- package/framework/skills/supabase/SKILL.md +973 -0
- package/framework/skills/supabase/references/templates.md +159 -0
- package/framework/skills/team/SKILL.md +67 -0
- package/framework/skills/test-runner/SKILL.md +202 -0
- package/framework/skills/voice-agent/SKILL.md +407 -0
- package/framework/skills/zoho-workflow/SKILL.md +51 -0
- package/framework/statusline-command.sh +117 -0
- package/package.json +24 -0
- package/profiles/fawzi.json +16 -0
- package/profiles/hasan.json +16 -0
- package/profiles/moayad.json +16 -0
- package/templates/CLAUDE-owner.md +52 -0
- package/templates/CLAUDE.md.hbs +58 -0
- package/templates/env.claude.template +12 -0
- package/templates/settings.json +141 -0
|
@@ -0,0 +1,625 @@
|
|
|
1
|
+
<purpose>
|
|
2
|
+
Validate built features through conversational testing with persistent state. Creates UAT.md that tracks test progress, survives /clear, and feeds gaps into /qualia:plan-phase --gaps.
|
|
3
|
+
|
|
4
|
+
User tests, Claude records. One test at a time. Plain text responses.
|
|
5
|
+
</purpose>
|
|
6
|
+
|
|
7
|
+
<philosophy>
|
|
8
|
+
**Show expected, ask if reality matches.**
|
|
9
|
+
|
|
10
|
+
Claude presents what SHOULD happen. User confirms or describes what's different.
|
|
11
|
+
- "yes" / "y" / "next" / empty → pass
|
|
12
|
+
- Anything else → logged as issue, severity inferred
|
|
13
|
+
|
|
14
|
+
No Pass/Fail buttons. No severity questions. Just: "Here's what should happen. Does it?"
|
|
15
|
+
</philosophy>
|
|
16
|
+
|
|
17
|
+
<template>
|
|
18
|
+
@/home/qualia/.claude/qualia-engine/templates/UAT.md
|
|
19
|
+
</template>
|
|
20
|
+
|
|
21
|
+
<process>
|
|
22
|
+
|
|
23
|
+
<step name="initialize" priority="first">
|
|
24
|
+
If $ARGUMENTS contains a phase number, load context:
|
|
25
|
+
|
|
26
|
+
```bash
|
|
27
|
+
INIT=$(node /home/qualia/.claude/qualia-engine/bin/qualia-tools.js init verify-work "${PHASE_ARG}")
|
|
28
|
+
```
|
|
29
|
+
|
|
30
|
+
Parse JSON for: `planner_model`, `checker_model`, `commit_docs`, `phase_found`, `phase_dir`, `phase_number`, `phase_name`, `has_verification`.
|
|
31
|
+
</step>
|
|
32
|
+
|
|
33
|
+
<step name="check_active_session">
|
|
34
|
+
**First: Check for active UAT sessions**
|
|
35
|
+
|
|
36
|
+
```bash
|
|
37
|
+
find .planning/phases -name "*-UAT.md" -type f 2>/dev/null | head -5
|
|
38
|
+
```
|
|
39
|
+
|
|
40
|
+
**If active sessions exist AND no $ARGUMENTS provided:**
|
|
41
|
+
|
|
42
|
+
Read each file's frontmatter (status, phase) and Current Test section.
|
|
43
|
+
|
|
44
|
+
Display inline:
|
|
45
|
+
|
|
46
|
+
```
|
|
47
|
+
## Active UAT Sessions
|
|
48
|
+
|
|
49
|
+
| # | Phase | Status | Current Test | Progress |
|
|
50
|
+
|---|-------|--------|--------------|----------|
|
|
51
|
+
| 1 | 04-comments | testing | 3. Reply to Comment | 2/6 |
|
|
52
|
+
| 2 | 05-auth | testing | 1. Login Form | 0/4 |
|
|
53
|
+
|
|
54
|
+
Reply with a number to resume, or provide a phase number to start new.
|
|
55
|
+
```
|
|
56
|
+
|
|
57
|
+
Wait for user response.
|
|
58
|
+
|
|
59
|
+
- If user replies with number (1, 2) → Load that file, go to `resume_from_file`
|
|
60
|
+
- If user replies with phase number → Treat as new session, go to `create_uat_file`
|
|
61
|
+
|
|
62
|
+
**If active sessions exist AND $ARGUMENTS provided:**
|
|
63
|
+
|
|
64
|
+
Check if session exists for that phase. If yes, offer to resume or restart.
|
|
65
|
+
If no, continue to `create_uat_file`.
|
|
66
|
+
|
|
67
|
+
**If no active sessions AND no $ARGUMENTS:**
|
|
68
|
+
|
|
69
|
+
```
|
|
70
|
+
No active UAT sessions.
|
|
71
|
+
|
|
72
|
+
Provide a phase number to start testing (e.g., /qualia:verify-work 4)
|
|
73
|
+
```
|
|
74
|
+
|
|
75
|
+
**If no active sessions AND $ARGUMENTS provided:**
|
|
76
|
+
|
|
77
|
+
Continue to `create_uat_file`.
|
|
78
|
+
</step>
|
|
79
|
+
|
|
80
|
+
<step name="run_automated_tests">
|
|
81
|
+
**Run automated tests before manual UAT:**
|
|
82
|
+
|
|
83
|
+
Follow the canonical test detection and execution from `~/.claude/skills/test-runner/SKILL.md` (Run Tests section).
|
|
84
|
+
|
|
85
|
+
**If tests fail:**
|
|
86
|
+
|
|
87
|
+
Present to user:
|
|
88
|
+
```
|
|
89
|
+
⚠ {N} automated test(s) failed. These should be fixed before manual UAT.
|
|
90
|
+
|
|
91
|
+
Failed tests:
|
|
92
|
+
{list}
|
|
93
|
+
|
|
94
|
+
Options:
|
|
95
|
+
1. Fix tests first (recommended) — exit and fix, then re-run /qualia:verify-work
|
|
96
|
+
2. Continue to manual UAT anyway — test failures will be noted in UAT.md
|
|
97
|
+
```
|
|
98
|
+
|
|
99
|
+
Use AskUserQuestion with those 2 options.
|
|
100
|
+
|
|
101
|
+
If "Fix tests first": Exit with guidance.
|
|
102
|
+
If "Continue": Note failures in UAT.md header and proceed to find_summaries.
|
|
103
|
+
|
|
104
|
+
**If no test infrastructure detected:**
|
|
105
|
+
|
|
106
|
+
Skip silently — proceed to find_summaries.
|
|
107
|
+
</step>
|
|
108
|
+
|
|
109
|
+
<step name="find_summaries">
|
|
110
|
+
**Find what to test:**
|
|
111
|
+
|
|
112
|
+
Use `phase_dir` from init (or run init if not already done).
|
|
113
|
+
|
|
114
|
+
```bash
|
|
115
|
+
ls "$phase_dir"/*-SUMMARY.md 2>/dev/null
|
|
116
|
+
```
|
|
117
|
+
|
|
118
|
+
Read each SUMMARY.md to extract testable deliverables.
|
|
119
|
+
</step>
|
|
120
|
+
|
|
121
|
+
<step name="extract_tests">
|
|
122
|
+
**Extract testable deliverables from SUMMARY.md:**
|
|
123
|
+
|
|
124
|
+
Parse for:
|
|
125
|
+
1. **Accomplishments** - Features/functionality added
|
|
126
|
+
2. **User-facing changes** - UI, workflows, interactions
|
|
127
|
+
|
|
128
|
+
Focus on USER-OBSERVABLE outcomes, not implementation details.
|
|
129
|
+
|
|
130
|
+
For each deliverable, create a test:
|
|
131
|
+
- name: Brief test name
|
|
132
|
+
- expected: What the user should see/experience (specific, observable)
|
|
133
|
+
|
|
134
|
+
Examples:
|
|
135
|
+
- Accomplishment: "Added comment threading with infinite nesting"
|
|
136
|
+
→ Test: "Reply to a Comment"
|
|
137
|
+
→ Expected: "Clicking Reply opens inline composer below comment. Submitting shows reply nested under parent with visual indentation."
|
|
138
|
+
|
|
139
|
+
Skip internal/non-observable items (refactors, type changes, etc.).
|
|
140
|
+
</step>
|
|
141
|
+
|
|
142
|
+
<step name="create_uat_file">
|
|
143
|
+
**Create UAT file with all tests:**
|
|
144
|
+
|
|
145
|
+
```bash
|
|
146
|
+
mkdir -p "$PHASE_DIR"
|
|
147
|
+
```
|
|
148
|
+
|
|
149
|
+
Build test list from extracted deliverables.
|
|
150
|
+
|
|
151
|
+
Create file:
|
|
152
|
+
|
|
153
|
+
```markdown
|
|
154
|
+
---
|
|
155
|
+
status: testing
|
|
156
|
+
phase: XX-name
|
|
157
|
+
source: [list of SUMMARY.md files]
|
|
158
|
+
started: [ISO timestamp]
|
|
159
|
+
updated: [ISO timestamp]
|
|
160
|
+
---
|
|
161
|
+
|
|
162
|
+
## Current Test
|
|
163
|
+
<!-- OVERWRITE each test - shows where we are -->
|
|
164
|
+
|
|
165
|
+
number: 1
|
|
166
|
+
name: [first test name]
|
|
167
|
+
expected: |
|
|
168
|
+
[what user should observe]
|
|
169
|
+
awaiting: user response
|
|
170
|
+
|
|
171
|
+
## Tests
|
|
172
|
+
|
|
173
|
+
### 1. [Test Name]
|
|
174
|
+
expected: [observable behavior]
|
|
175
|
+
result: [pending]
|
|
176
|
+
|
|
177
|
+
### 2. [Test Name]
|
|
178
|
+
expected: [observable behavior]
|
|
179
|
+
result: [pending]
|
|
180
|
+
|
|
181
|
+
...
|
|
182
|
+
|
|
183
|
+
## Summary
|
|
184
|
+
|
|
185
|
+
total: [N]
|
|
186
|
+
passed: 0
|
|
187
|
+
issues: 0
|
|
188
|
+
pending: [N]
|
|
189
|
+
skipped: 0
|
|
190
|
+
|
|
191
|
+
## Gaps
|
|
192
|
+
|
|
193
|
+
[none yet]
|
|
194
|
+
```
|
|
195
|
+
|
|
196
|
+
Write to `.planning/phases/XX-name/{phase}-UAT.md`
|
|
197
|
+
|
|
198
|
+
Proceed to `present_test`.
|
|
199
|
+
</step>
|
|
200
|
+
|
|
201
|
+
<step name="present_test">
|
|
202
|
+
**Present current test to user:**
|
|
203
|
+
|
|
204
|
+
Read Current Test section from UAT file.
|
|
205
|
+
|
|
206
|
+
Display using checkpoint box format:
|
|
207
|
+
|
|
208
|
+
```
|
|
209
|
+
╔══════════════════════════════════════════════════════════════╗
|
|
210
|
+
║ CHECKPOINT: Verification Required ║
|
|
211
|
+
╚══════════════════════════════════════════════════════════════╝
|
|
212
|
+
|
|
213
|
+
**Test {number}: {name}**
|
|
214
|
+
|
|
215
|
+
{expected}
|
|
216
|
+
|
|
217
|
+
──────────────────────────────────────────────────────────────
|
|
218
|
+
→ Type "pass" or describe what's wrong
|
|
219
|
+
──────────────────────────────────────────────────────────────
|
|
220
|
+
```
|
|
221
|
+
|
|
222
|
+
Wait for user response (plain text, no AskUserQuestion).
|
|
223
|
+
</step>
|
|
224
|
+
|
|
225
|
+
<step name="process_response">
|
|
226
|
+
**Process user response and update file:**
|
|
227
|
+
|
|
228
|
+
**If response indicates pass:**
|
|
229
|
+
- Empty response, "yes", "y", "ok", "pass", "next", "approved", "✓"
|
|
230
|
+
|
|
231
|
+
Update Tests section:
|
|
232
|
+
```
|
|
233
|
+
### {N}. {name}
|
|
234
|
+
expected: {expected}
|
|
235
|
+
result: pass
|
|
236
|
+
```
|
|
237
|
+
|
|
238
|
+
**If response indicates skip:**
|
|
239
|
+
- "skip", "can't test", "n/a"
|
|
240
|
+
|
|
241
|
+
Update Tests section:
|
|
242
|
+
```
|
|
243
|
+
### {N}. {name}
|
|
244
|
+
expected: {expected}
|
|
245
|
+
result: skipped
|
|
246
|
+
reason: [user's reason if provided]
|
|
247
|
+
```
|
|
248
|
+
|
|
249
|
+
**If response is anything else:**
|
|
250
|
+
- Treat as issue description
|
|
251
|
+
|
|
252
|
+
Infer severity from description:
|
|
253
|
+
- Contains: crash, error, exception, fails, broken, unusable → blocker
|
|
254
|
+
- Contains: doesn't work, wrong, missing, can't → major
|
|
255
|
+
- Contains: slow, weird, off, minor, small → minor
|
|
256
|
+
- Contains: color, font, spacing, alignment, visual → cosmetic
|
|
257
|
+
- Default if unclear: major
|
|
258
|
+
|
|
259
|
+
Update Tests section:
|
|
260
|
+
```
|
|
261
|
+
### {N}. {name}
|
|
262
|
+
expected: {expected}
|
|
263
|
+
result: issue
|
|
264
|
+
reported: "{verbatim user response}"
|
|
265
|
+
severity: {inferred}
|
|
266
|
+
```
|
|
267
|
+
|
|
268
|
+
Append to Gaps section (structured YAML for plan-phase --gaps):
|
|
269
|
+
```yaml
|
|
270
|
+
- truth: "{expected behavior from test}"
|
|
271
|
+
status: failed
|
|
272
|
+
reason: "User reported: {verbatim user response}"
|
|
273
|
+
severity: {inferred}
|
|
274
|
+
test: {N}
|
|
275
|
+
artifacts: [] # Filled by diagnosis
|
|
276
|
+
missing: [] # Filled by diagnosis
|
|
277
|
+
```
|
|
278
|
+
|
|
279
|
+
**After any response:**
|
|
280
|
+
|
|
281
|
+
Update Summary counts.
|
|
282
|
+
Update frontmatter.updated timestamp.
|
|
283
|
+
|
|
284
|
+
If more tests remain → Update Current Test, go to `present_test`
|
|
285
|
+
If no more tests → Go to `complete_session`
|
|
286
|
+
</step>
|
|
287
|
+
|
|
288
|
+
<step name="resume_from_file">
|
|
289
|
+
**Resume testing from UAT file:**
|
|
290
|
+
|
|
291
|
+
Read the full UAT file.
|
|
292
|
+
|
|
293
|
+
Find first test with `result: [pending]`.
|
|
294
|
+
|
|
295
|
+
Announce:
|
|
296
|
+
```
|
|
297
|
+
Resuming: Phase {phase} UAT
|
|
298
|
+
Progress: {passed + issues + skipped}/{total}
|
|
299
|
+
Issues found so far: {issues count}
|
|
300
|
+
|
|
301
|
+
Continuing from Test {N}...
|
|
302
|
+
```
|
|
303
|
+
|
|
304
|
+
Update Current Test section with the pending test.
|
|
305
|
+
Proceed to `present_test`.
|
|
306
|
+
</step>
|
|
307
|
+
|
|
308
|
+
<step name="complete_session">
|
|
309
|
+
**Complete testing and commit:**
|
|
310
|
+
|
|
311
|
+
Update frontmatter:
|
|
312
|
+
- status: complete
|
|
313
|
+
- updated: [now]
|
|
314
|
+
|
|
315
|
+
Clear Current Test section:
|
|
316
|
+
```
|
|
317
|
+
## Current Test
|
|
318
|
+
|
|
319
|
+
[testing complete]
|
|
320
|
+
```
|
|
321
|
+
|
|
322
|
+
Commit the UAT file:
|
|
323
|
+
```bash
|
|
324
|
+
node /home/qualia/.claude/qualia-engine/bin/qualia-tools.js commit "test({phase}): complete UAT - {passed} passed, {issues} issues" --files ".planning/phases/XX-name/{phase}-UAT.md"
|
|
325
|
+
```
|
|
326
|
+
|
|
327
|
+
Present summary:
|
|
328
|
+
```
|
|
329
|
+
## UAT Complete: Phase {phase}
|
|
330
|
+
|
|
331
|
+
| Result | Count |
|
|
332
|
+
|--------|-------|
|
|
333
|
+
| Passed | {N} |
|
|
334
|
+
| Issues | {N} |
|
|
335
|
+
| Skipped| {N} |
|
|
336
|
+
|
|
337
|
+
[If issues > 0:]
|
|
338
|
+
### Issues Found
|
|
339
|
+
|
|
340
|
+
[List from Issues section]
|
|
341
|
+
```
|
|
342
|
+
|
|
343
|
+
**If issues > 0:** Proceed to `diagnose_issues`
|
|
344
|
+
|
|
345
|
+
**If issues == 0:**
|
|
346
|
+
|
|
347
|
+
**Frontend design quality check:**
|
|
348
|
+
|
|
349
|
+
Detect if this phase includes frontend work:
|
|
350
|
+
```bash
|
|
351
|
+
# Check phase PLAN.md files for frontend signals
|
|
352
|
+
grep -rlE '\.(tsx|css|scss)|components/|app/page|app/layout|Tailwind|className' "$PHASE_DIR"/*-PLAN.md 2>/dev/null && echo "HAS_FRONTEND=true" || echo "HAS_FRONTEND=false"
|
|
353
|
+
```
|
|
354
|
+
|
|
355
|
+
Also check if phase name/objective contains: UI, frontend, design, component, page, layout, dashboard, form, landing, hero.
|
|
356
|
+
|
|
357
|
+
**If HAS_FRONTEND=true AND issues == 0:**
|
|
358
|
+
|
|
359
|
+
```
|
|
360
|
+
All tests passed. This phase includes frontend work.
|
|
361
|
+
|
|
362
|
+
### Design Quality (recommended before moving on)
|
|
363
|
+
|
|
364
|
+
1. `/critique` — Design director review (catches AI slop, visual hierarchy issues)
|
|
365
|
+
2. `/polish` — Detail pass (spacing, alignment, consistency)
|
|
366
|
+
3. `/harden` — Edge cases, overflow, i18n robustness
|
|
367
|
+
|
|
368
|
+
Skip? Just run the next command directly. Otherwise run `/critique` now.
|
|
369
|
+
```
|
|
370
|
+
|
|
371
|
+
**If HAS_FRONTEND=false:**
|
|
372
|
+
```
|
|
373
|
+
All tests passed. Ready to continue.
|
|
374
|
+
|
|
375
|
+
- `/clear` then `/qualia:plan-phase {next}` — Plan next phase
|
|
376
|
+
- `/clear` then `/qualia:execute-phase {next}` — Execute next phase
|
|
377
|
+
```
|
|
378
|
+
</step>
|
|
379
|
+
|
|
380
|
+
<step name="diagnose_issues">
|
|
381
|
+
**Diagnose root causes before planning fixes:**
|
|
382
|
+
|
|
383
|
+
```
|
|
384
|
+
---
|
|
385
|
+
|
|
386
|
+
{N} issues found. Diagnosing root causes...
|
|
387
|
+
|
|
388
|
+
Spawning parallel debug agents to investigate each issue.
|
|
389
|
+
```
|
|
390
|
+
|
|
391
|
+
- Load diagnose-issues workflow
|
|
392
|
+
- Follow @/home/qualia/.claude/qualia-engine/workflows/diagnose-issues.md
|
|
393
|
+
- Spawn parallel debug agents for each issue
|
|
394
|
+
- Collect root causes
|
|
395
|
+
- Update UAT.md with root causes
|
|
396
|
+
- Proceed to `plan_gap_closure`
|
|
397
|
+
|
|
398
|
+
Diagnosis runs automatically - no user prompt. Parallel agents investigate simultaneously, so overhead is minimal and fixes are more accurate.
|
|
399
|
+
</step>
|
|
400
|
+
|
|
401
|
+
<step name="plan_gap_closure">
|
|
402
|
+
**Auto-plan fixes from diagnosed gaps:**
|
|
403
|
+
|
|
404
|
+
Display:
|
|
405
|
+
```
|
|
406
|
+
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
|
|
407
|
+
Qualia ► PLANNING FIXES
|
|
408
|
+
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
|
|
409
|
+
|
|
410
|
+
◆ Spawning planner for gap closure...
|
|
411
|
+
```
|
|
412
|
+
|
|
413
|
+
Spawn qualia-planner in --gaps mode:
|
|
414
|
+
|
|
415
|
+
```
|
|
416
|
+
Task(
|
|
417
|
+
prompt="""
|
|
418
|
+
<planning_context>
|
|
419
|
+
|
|
420
|
+
**Phase:** {phase_number}
|
|
421
|
+
**Mode:** gap_closure
|
|
422
|
+
|
|
423
|
+
**UAT with diagnoses:**
|
|
424
|
+
@.planning/phases/{phase_dir}/{phase}-UAT.md
|
|
425
|
+
|
|
426
|
+
**Project State:**
|
|
427
|
+
@.planning/STATE.md
|
|
428
|
+
|
|
429
|
+
**Roadmap:**
|
|
430
|
+
@.planning/ROADMAP.md
|
|
431
|
+
|
|
432
|
+
</planning_context>
|
|
433
|
+
|
|
434
|
+
<downstream_consumer>
|
|
435
|
+
Output consumed by /qualia:execute-phase
|
|
436
|
+
Plans must be executable prompts.
|
|
437
|
+
</downstream_consumer>
|
|
438
|
+
""",
|
|
439
|
+
subagent_type="qualia-planner",
|
|
440
|
+
model="{planner_model}",
|
|
441
|
+
description="Plan gap fixes for Phase {phase}"
|
|
442
|
+
)
|
|
443
|
+
```
|
|
444
|
+
|
|
445
|
+
On return:
|
|
446
|
+
- **PLANNING COMPLETE:** Proceed to `verify_gap_plans`
|
|
447
|
+
- **PLANNING INCONCLUSIVE:** Report and offer manual intervention
|
|
448
|
+
</step>
|
|
449
|
+
|
|
450
|
+
<step name="verify_gap_plans">
|
|
451
|
+
**Verify fix plans with checker:**
|
|
452
|
+
|
|
453
|
+
Display:
|
|
454
|
+
```
|
|
455
|
+
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
|
|
456
|
+
Qualia ► VERIFYING FIX PLANS
|
|
457
|
+
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
|
|
458
|
+
|
|
459
|
+
◆ Spawning plan checker...
|
|
460
|
+
```
|
|
461
|
+
|
|
462
|
+
Initialize: `iteration_count = 1`
|
|
463
|
+
|
|
464
|
+
Spawn qualia-plan-checker:
|
|
465
|
+
|
|
466
|
+
```
|
|
467
|
+
Task(
|
|
468
|
+
prompt="""
|
|
469
|
+
<verification_context>
|
|
470
|
+
|
|
471
|
+
**Phase:** {phase_number}
|
|
472
|
+
**Phase Goal:** Close diagnosed gaps from UAT
|
|
473
|
+
|
|
474
|
+
**Plans to verify:**
|
|
475
|
+
@.planning/phases/{phase_dir}/*-PLAN.md
|
|
476
|
+
|
|
477
|
+
</verification_context>
|
|
478
|
+
|
|
479
|
+
<expected_output>
|
|
480
|
+
Return one of:
|
|
481
|
+
- ## VERIFICATION PASSED — all checks pass
|
|
482
|
+
- ## ISSUES FOUND — structured issue list
|
|
483
|
+
</expected_output>
|
|
484
|
+
""",
|
|
485
|
+
subagent_type="qualia-plan-checker",
|
|
486
|
+
model="{checker_model}",
|
|
487
|
+
description="Verify Phase {phase} fix plans"
|
|
488
|
+
)
|
|
489
|
+
```
|
|
490
|
+
|
|
491
|
+
On return:
|
|
492
|
+
- **VERIFICATION PASSED:** Proceed to `present_ready`
|
|
493
|
+
- **ISSUES FOUND:** Proceed to `revision_loop`
|
|
494
|
+
</step>
|
|
495
|
+
|
|
496
|
+
<step name="revision_loop">
|
|
497
|
+
**Iterate planner ↔ checker until plans pass (max 3):**
|
|
498
|
+
|
|
499
|
+
**If iteration_count < 3:**
|
|
500
|
+
|
|
501
|
+
Display: `Sending back to planner for revision... (iteration {N}/3)`
|
|
502
|
+
|
|
503
|
+
Spawn qualia-planner with revision context:
|
|
504
|
+
|
|
505
|
+
```
|
|
506
|
+
Task(
|
|
507
|
+
prompt="""
|
|
508
|
+
<revision_context>
|
|
509
|
+
|
|
510
|
+
**Phase:** {phase_number}
|
|
511
|
+
**Mode:** revision
|
|
512
|
+
|
|
513
|
+
**Existing plans:**
|
|
514
|
+
@.planning/phases/{phase_dir}/*-PLAN.md
|
|
515
|
+
|
|
516
|
+
**Checker issues:**
|
|
517
|
+
{structured_issues_from_checker}
|
|
518
|
+
|
|
519
|
+
</revision_context>
|
|
520
|
+
|
|
521
|
+
<instructions>
|
|
522
|
+
Read existing PLAN.md files. Make targeted updates to address checker issues.
|
|
523
|
+
Do NOT replan from scratch unless issues are fundamental.
|
|
524
|
+
</instructions>
|
|
525
|
+
""",
|
|
526
|
+
subagent_type="qualia-planner",
|
|
527
|
+
model="{planner_model}",
|
|
528
|
+
description="Revise Phase {phase} plans"
|
|
529
|
+
)
|
|
530
|
+
```
|
|
531
|
+
|
|
532
|
+
After planner returns → spawn checker again (verify_gap_plans logic)
|
|
533
|
+
Increment iteration_count
|
|
534
|
+
|
|
535
|
+
**If iteration_count >= 3:**
|
|
536
|
+
|
|
537
|
+
Display: `Max iterations reached. {N} issues remain.`
|
|
538
|
+
|
|
539
|
+
Offer options:
|
|
540
|
+
1. Force proceed (execute despite issues)
|
|
541
|
+
2. Provide guidance (user gives direction, retry)
|
|
542
|
+
3. Abandon (exit, user runs /qualia:plan-phase manually)
|
|
543
|
+
|
|
544
|
+
Wait for user response.
|
|
545
|
+
</step>
|
|
546
|
+
|
|
547
|
+
<step name="present_ready">
|
|
548
|
+
**Present completion and next steps:**
|
|
549
|
+
|
|
550
|
+
```
|
|
551
|
+
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
|
|
552
|
+
Qualia ► FIXES READY ✓
|
|
553
|
+
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
|
|
554
|
+
|
|
555
|
+
**Phase {X}: {Name}** — {N} gap(s) diagnosed, {M} fix plan(s) created
|
|
556
|
+
|
|
557
|
+
| Gap | Root Cause | Fix Plan |
|
|
558
|
+
|-----|------------|----------|
|
|
559
|
+
| {truth 1} | {root_cause} | {phase}-04 |
|
|
560
|
+
| {truth 2} | {root_cause} | {phase}-04 |
|
|
561
|
+
|
|
562
|
+
Plans verified and ready for execution.
|
|
563
|
+
|
|
564
|
+
───────────────────────────────────────────────────────────────
|
|
565
|
+
|
|
566
|
+
## ▶ Next Up
|
|
567
|
+
|
|
568
|
+
**Execute fixes** — run fix plans
|
|
569
|
+
|
|
570
|
+
`/clear` then `/qualia:execute-phase {phase} --gaps-only`
|
|
571
|
+
|
|
572
|
+
───────────────────────────────────────────────────────────────
|
|
573
|
+
```
|
|
574
|
+
</step>
|
|
575
|
+
|
|
576
|
+
</process>
|
|
577
|
+
|
|
578
|
+
<update_rules>
|
|
579
|
+
**Batched writes for efficiency:**
|
|
580
|
+
|
|
581
|
+
Keep results in memory. Write to file only when:
|
|
582
|
+
1. **Issue found** — Preserve the problem immediately
|
|
583
|
+
2. **Session complete** — Final write before commit
|
|
584
|
+
3. **Checkpoint** — Every 5 passed tests (safety net)
|
|
585
|
+
|
|
586
|
+
| Section | Rule | When Written |
|
|
587
|
+
|---------|------|--------------|
|
|
588
|
+
| Frontmatter.status | OVERWRITE | Start, complete |
|
|
589
|
+
| Frontmatter.updated | OVERWRITE | On any file write |
|
|
590
|
+
| Current Test | OVERWRITE | On any file write |
|
|
591
|
+
| Tests.{N}.result | OVERWRITE | On any file write |
|
|
592
|
+
| Summary | OVERWRITE | On any file write |
|
|
593
|
+
| Gaps | APPEND | When issue found |
|
|
594
|
+
|
|
595
|
+
On context reset: File shows last checkpoint. Resume from there.
|
|
596
|
+
</update_rules>
|
|
597
|
+
|
|
598
|
+
<severity_inference>
|
|
599
|
+
**Infer severity from user's natural language:**
|
|
600
|
+
|
|
601
|
+
| User says | Infer |
|
|
602
|
+
|-----------|-------|
|
|
603
|
+
| "crashes", "error", "exception", "fails completely" | blocker |
|
|
604
|
+
| "doesn't work", "nothing happens", "wrong behavior" | major |
|
|
605
|
+
| "works but...", "slow", "weird", "minor issue" | minor |
|
|
606
|
+
| "color", "spacing", "alignment", "looks off" | cosmetic |
|
|
607
|
+
|
|
608
|
+
Default to **major** if unclear. User can correct if needed.
|
|
609
|
+
|
|
610
|
+
**Never ask "how severe is this?"** - just infer and move on.
|
|
611
|
+
</severity_inference>
|
|
612
|
+
|
|
613
|
+
<success_criteria>
|
|
614
|
+
- [ ] UAT file created with all tests from SUMMARY.md
|
|
615
|
+
- [ ] Tests presented one at a time with expected behavior
|
|
616
|
+
- [ ] User responses processed as pass/issue/skip
|
|
617
|
+
- [ ] Severity inferred from description (never asked)
|
|
618
|
+
- [ ] Batched writes: on issue, every 5 passes, or completion
|
|
619
|
+
- [ ] Committed on completion
|
|
620
|
+
- [ ] If issues: parallel debug agents diagnose root causes
|
|
621
|
+
- [ ] If issues: qualia-planner creates fix plans (gap_closure mode)
|
|
622
|
+
- [ ] If issues: qualia-plan-checker verifies fix plans
|
|
623
|
+
- [ ] If issues: revision loop until plans pass (max 3 iterations)
|
|
624
|
+
- [ ] Ready for `/qualia:execute-phase --gaps-only` when complete
|
|
625
|
+
</success_criteria>
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
---
|
|
2
|
+
alwaysApply: true
|
|
3
|
+
---
|
|
4
|
+
|
|
5
|
+
When working with libraries, frameworks, or APIs — fetch current documentation instead of relying on training data. This includes setup questions, code generation, API references, and anything involving specific packages.
|
|
6
|
+
|
|
7
|
+
## Steps
|
|
8
|
+
|
|
9
|
+
1. If Context7 MCP is available, use `resolve-library-id` + `query-docs`
|
|
10
|
+
2. Otherwise, use WebFetch or WebSearch to find current docs
|
|
11
|
+
3. Answer using the fetched docs — include code examples and cite the version
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
---
|
|
2
|
+
globs: ["vercel.json", "next.config.*", "wrangler.*", "Dockerfile"]
|
|
3
|
+
---
|
|
4
|
+
|
|
5
|
+
# Deployment (MANDATORY - Every Project)
|
|
6
|
+
|
|
7
|
+
When work on a project is **done**, ALWAYS execute these steps in order:
|
|
8
|
+
|
|
9
|
+
## 1. Push to GitHub
|
|
10
|
+
Commit and push all changes to the remote repository.
|
|
11
|
+
|
|
12
|
+
## 2. Redeploy to Vercel
|
|
13
|
+
Deploy through the Vercel CLI (`vercel --prod` or appropriate command).
|
|
14
|
+
|
|
15
|
+
## 3. Verify Supabase
|
|
16
|
+
Confirm Supabase is configured correctly via MCP (check tables, RLS, migrations are applied).
|
|
17
|
+
|
|
18
|
+
## 4. Post-Deploy Verification Checklist
|
|
19
|
+
|
|
20
|
+
After deployment, verify all 4 checks pass:
|
|
21
|
+
|
|
22
|
+
- [ ] **HTTP 200** — Homepage loads successfully (`curl -s -o /dev/null -w "%{http_code}" <url>` returns 200)
|
|
23
|
+
- [ ] **Auth flow** — Login/signup endpoint responds correctly (test auth callback URL)
|
|
24
|
+
- [ ] **Console errors** — No critical JS errors in browser console on homepage load
|
|
25
|
+
- [ ] **API latency** — Key API endpoints respond under 500ms (`curl -w "%{time_total}" <api-url>`)
|
|
26
|
+
|
|
27
|
+
If any check fails, investigate and fix before considering deployment complete.
|
|
28
|
+
|
|
29
|
+
This applies to **every project, every time**. No exceptions. Don't ask — just do it.
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
---
|
|
2
|
+
globs: ["*.tsx", "*.jsx", "*.css", "*.scss", "tailwind.config.*"]
|
|
3
|
+
---
|
|
4
|
+
|
|
5
|
+
# Frontend Aesthetics
|
|
6
|
+
|
|
7
|
+
- Distinctive fonts (not Inter/Arial)
|
|
8
|
+
- Cohesive color palette with sharp accents
|
|
9
|
+
- CSS transitions, staggered animations
|
|
10
|
+
- Layered backgrounds, subtle gradients
|
|
11
|
+
- Avoid: card grids, generic heroes, blue-purple gradients
|
|
12
|
+
- Full-width layouts — no hardcoded 1200px/1280px caps. Use fluid widths that fill the viewport with sensible padding.
|
|
13
|
+
|
|
14
|
+
Note: Qualia agents MUST follow these rules when building any frontend component. These are Fawzi's brand standards, not suggestions.
|
|
15
|
+
|
|
16
|
+
## Impeccable Design Skills (global)
|
|
17
|
+
Use these `/commands` for design refinement on any frontend work:
|
|
18
|
+
- `/polish` — Final detail pass before shipping (spacing, alignment, consistency)
|
|
19
|
+
- `/bolder` — Amplify safe/boring designs to be more striking
|
|
20
|
+
- `/design-quieter` — Tone down overly aggressive designs
|
|
21
|
+
- `/animate` — Add purposeful micro-interactions and motion
|
|
22
|
+
- `/colorize` — Inject strategic color into monochrome UIs
|
|
23
|
+
- `/clarify` — Fix unclear UX copy, labels, error messages
|
|
24
|
+
- `/critique` — Design director-level review (run before shipping)
|
|
25
|
+
- `/distill` — Strip unnecessary complexity
|
|
26
|
+
- `/delight` — Add memorable touches and personality
|
|
27
|
+
- `/harden` — Edge cases, overflow, i18n robustness
|
|
28
|
+
- `/onboard` — First-time user experience flows
|
|
29
|
+
- `/normalize` — Align with project design system
|
|
30
|
+
- `/responsive` — Cross-device responsive adaptation
|
|
31
|
+
|
|
32
|
+
### Recommended workflow
|
|
33
|
+
1. Build feature → 2. `/critique` → 3. `/polish` → 4. `/harden` → ship
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
---
|
|
2
|
+
globs: ["**/api/**", "**/actions/**", "**/lib/supabase/**", "**/*.sql", "**/middleware.*"]
|
|
3
|
+
---
|
|
4
|
+
|
|
5
|
+
# Security Rules
|
|
6
|
+
|
|
7
|
+
- Always check auth server-side. Never trust client IDs. Derive user from `auth.uid()`.
|
|
8
|
+
- Enable RLS on every table. Write policies checking `auth.uid()`. Never expose `service_role` key client-side.
|
|
9
|
+
- Validate with Zod. Never use `dangerouslySetInnerHTML`. Never use `eval()`.
|
|
10
|
+
- Never hardcode keys. Never commit `.env`.
|
|
11
|
+
- Audit that service role key is never imported in any client component.
|
|
12
|
+
- Use `lib/supabase/server.ts` for mutations, never `lib/supabase/client.ts`.
|