qualia-framework 2.6.0 → 3.2.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 (321) hide show
  1. package/CLAUDE.md +64 -0
  2. package/README.md +103 -30
  3. package/agents/builder.md +110 -0
  4. package/agents/planner.md +134 -0
  5. package/agents/qa-browser.md +186 -0
  6. package/agents/verifier.md +221 -0
  7. package/bin/cli.js +336 -531
  8. package/bin/install.js +570 -0
  9. package/bin/qualia-ui.js +299 -0
  10. package/bin/state.js +630 -0
  11. package/bin/statusline.js +252 -0
  12. package/guide.md +63 -0
  13. package/hooks/auto-update.js +139 -0
  14. package/hooks/branch-guard.js +47 -0
  15. package/hooks/migration-guard.js +60 -0
  16. package/hooks/pre-compact.js +32 -0
  17. package/hooks/pre-deploy-gate.js +110 -0
  18. package/hooks/pre-push.js +33 -0
  19. package/hooks/session-start.js +170 -0
  20. package/package.json +29 -20
  21. package/rules/design-reference.md +179 -0
  22. package/rules/frontend.md +126 -0
  23. package/skills/qualia/SKILL.md +87 -0
  24. package/skills/qualia-build/SKILL.md +97 -0
  25. package/skills/qualia-debug/SKILL.md +87 -0
  26. package/skills/qualia-design/SKILL.md +93 -0
  27. package/skills/qualia-handoff/SKILL.md +66 -0
  28. package/skills/qualia-idk/SKILL.md +8 -0
  29. package/skills/qualia-learn/SKILL.md +88 -0
  30. package/skills/qualia-new/SKILL.md +323 -0
  31. package/{framework/skills → skills}/qualia-optimize/SKILL.md +1 -1
  32. package/skills/qualia-pause/SKILL.md +63 -0
  33. package/skills/qualia-plan/SKILL.md +101 -0
  34. package/skills/qualia-polish/SKILL.md +157 -0
  35. package/skills/qualia-quick/SKILL.md +37 -0
  36. package/skills/qualia-report/SKILL.md +105 -0
  37. package/skills/qualia-resume/SKILL.md +49 -0
  38. package/skills/qualia-review/SKILL.md +76 -0
  39. package/skills/qualia-ship/SKILL.md +90 -0
  40. package/skills/qualia-skill-new/SKILL.md +167 -0
  41. package/skills/qualia-task/SKILL.md +91 -0
  42. package/skills/qualia-verify/SKILL.md +113 -0
  43. package/templates/DESIGN.md +137 -0
  44. package/templates/plan.md +28 -0
  45. package/templates/project.md +22 -0
  46. package/templates/state.md +27 -0
  47. package/templates/tracking.json +20 -0
  48. package/tests/bin.test.sh +673 -0
  49. package/tests/hooks.test.sh +315 -0
  50. package/tests/state.test.sh +535 -0
  51. package/tests/statusline.test.sh +243 -0
  52. package/bin/collect-metrics.sh +0 -62
  53. package/framework/.claudeignore +0 -51
  54. package/framework/CLAUDE.md +0 -51
  55. package/framework/MCP_SETUP.md +0 -229
  56. package/framework/agents/architecture-strategist.md +0 -53
  57. package/framework/agents/backend-agent.md +0 -150
  58. package/framework/agents/code-simplicity-reviewer.md +0 -86
  59. package/framework/agents/frontend-agent.md +0 -111
  60. package/framework/agents/kieran-typescript-reviewer.md +0 -96
  61. package/framework/agents/performance-oracle.md +0 -111
  62. package/framework/agents/qualia-codebase-mapper.md +0 -761
  63. package/framework/agents/qualia-debugger.md +0 -1204
  64. package/framework/agents/qualia-executor.md +0 -882
  65. package/framework/agents/qualia-integration-checker.md +0 -424
  66. package/framework/agents/qualia-phase-researcher.md +0 -457
  67. package/framework/agents/qualia-plan-checker.md +0 -700
  68. package/framework/agents/qualia-planner.md +0 -1245
  69. package/framework/agents/qualia-project-researcher.md +0 -603
  70. package/framework/agents/qualia-research-synthesizer.md +0 -200
  71. package/framework/agents/qualia-roadmapper.md +0 -606
  72. package/framework/agents/qualia-verifier.md +0 -686
  73. package/framework/agents/red-team-qa.md +0 -130
  74. package/framework/agents/security-auditor.md +0 -72
  75. package/framework/agents/team-orchestrator.md +0 -229
  76. package/framework/agents/teams/framework-audit-team.md +0 -66
  77. package/framework/agents/teams/full-stack-team.md +0 -48
  78. package/framework/agents/teams/optimize-team.md +0 -53
  79. package/framework/agents/teams/review-team.md +0 -70
  80. package/framework/agents/teams/ship-team.md +0 -86
  81. package/framework/agents/test-agent.md +0 -182
  82. package/framework/hooks/auto-format.sh +0 -54
  83. package/framework/hooks/block-env-edit.sh +0 -42
  84. package/framework/hooks/branch-guard.sh +0 -43
  85. package/framework/hooks/confirm-delete.sh +0 -59
  86. package/framework/hooks/migration-validate.sh +0 -77
  87. package/framework/hooks/notification-speak.sh +0 -16
  88. package/framework/hooks/pre-commit.sh +0 -100
  89. package/framework/hooks/pre-compact.sh +0 -56
  90. package/framework/hooks/pre-deploy-gate.sh +0 -160
  91. package/framework/hooks/qualia-colors.sh +0 -32
  92. package/framework/hooks/retention-cleanup.sh +0 -62
  93. package/framework/hooks/save-session-state.sh +0 -185
  94. package/framework/hooks/session-context-loader.sh +0 -96
  95. package/framework/hooks/session-learn.sh +0 -32
  96. package/framework/hooks/skill-announce.sh +0 -123
  97. package/framework/hooks/tool-error-announce.sh +0 -27
  98. package/framework/install.ps1 +0 -323
  99. package/framework/install.sh +0 -313
  100. package/framework/qualia-framework/VERSION +0 -1
  101. package/framework/qualia-framework/assets/qualia-logo.png +0 -0
  102. package/framework/qualia-framework/bin/collect-metrics.sh +0 -67
  103. package/framework/qualia-framework/bin/generate-report-docx.py +0 -429
  104. package/framework/qualia-framework/bin/qualia-tools.js +0 -2201
  105. package/framework/qualia-framework/bin/qualia-tools.test.js +0 -1054
  106. package/framework/qualia-framework/references/checkpoints.md +0 -775
  107. package/framework/qualia-framework/references/completion-checklists.md +0 -359
  108. package/framework/qualia-framework/references/continuation-format.md +0 -249
  109. package/framework/qualia-framework/references/continuation-prompt.md +0 -97
  110. package/framework/qualia-framework/references/decimal-phase-calculation.md +0 -65
  111. package/framework/qualia-framework/references/design-quality.md +0 -56
  112. package/framework/qualia-framework/references/employee-guide.md +0 -167
  113. package/framework/qualia-framework/references/git-integration.md +0 -254
  114. package/framework/qualia-framework/references/git-planning-commit.md +0 -50
  115. package/framework/qualia-framework/references/model-profile-resolution.md +0 -32
  116. package/framework/qualia-framework/references/model-profiles.md +0 -73
  117. package/framework/qualia-framework/references/phase-argument-parsing.md +0 -61
  118. package/framework/qualia-framework/references/planning-config.md +0 -195
  119. package/framework/qualia-framework/references/questioning.md +0 -141
  120. package/framework/qualia-framework/references/tdd.md +0 -263
  121. package/framework/qualia-framework/references/ui-brand.md +0 -160
  122. package/framework/qualia-framework/references/verification-patterns.md +0 -612
  123. package/framework/qualia-framework/templates/DEBUG.md +0 -159
  124. package/framework/qualia-framework/templates/DESIGN.md +0 -81
  125. package/framework/qualia-framework/templates/UAT.md +0 -247
  126. package/framework/qualia-framework/templates/codebase/architecture.md +0 -255
  127. package/framework/qualia-framework/templates/codebase/concerns.md +0 -310
  128. package/framework/qualia-framework/templates/codebase/conventions.md +0 -307
  129. package/framework/qualia-framework/templates/codebase/integrations.md +0 -280
  130. package/framework/qualia-framework/templates/codebase/stack.md +0 -186
  131. package/framework/qualia-framework/templates/codebase/structure.md +0 -285
  132. package/framework/qualia-framework/templates/codebase/testing.md +0 -480
  133. package/framework/qualia-framework/templates/config.json +0 -35
  134. package/framework/qualia-framework/templates/context.md +0 -283
  135. package/framework/qualia-framework/templates/continue-here.md +0 -78
  136. package/framework/qualia-framework/templates/debug-subagent-prompt.md +0 -91
  137. package/framework/qualia-framework/templates/discovery.md +0 -146
  138. package/framework/qualia-framework/templates/lab-notes.md +0 -16
  139. package/framework/qualia-framework/templates/milestone-archive.md +0 -123
  140. package/framework/qualia-framework/templates/milestone.md +0 -115
  141. package/framework/qualia-framework/templates/phase-prompt.md +0 -567
  142. package/framework/qualia-framework/templates/planner-subagent-prompt.md +0 -117
  143. package/framework/qualia-framework/templates/project.md +0 -184
  144. package/framework/qualia-framework/templates/projects/ai-agent.md +0 -156
  145. package/framework/qualia-framework/templates/projects/mobile-app.md +0 -181
  146. package/framework/qualia-framework/templates/projects/voice-agent.md +0 -134
  147. package/framework/qualia-framework/templates/projects/website.md +0 -137
  148. package/framework/qualia-framework/templates/requirements.md +0 -231
  149. package/framework/qualia-framework/templates/research-project/ARCHITECTURE.md +0 -204
  150. package/framework/qualia-framework/templates/research-project/FEATURES.md +0 -147
  151. package/framework/qualia-framework/templates/research-project/PITFALLS.md +0 -200
  152. package/framework/qualia-framework/templates/research-project/STACK.md +0 -120
  153. package/framework/qualia-framework/templates/research-project/SUMMARY.md +0 -170
  154. package/framework/qualia-framework/templates/research.md +0 -552
  155. package/framework/qualia-framework/templates/roadmap.md +0 -206
  156. package/framework/qualia-framework/templates/state.md +0 -179
  157. package/framework/qualia-framework/templates/summary-complex.md +0 -59
  158. package/framework/qualia-framework/templates/summary-minimal.md +0 -41
  159. package/framework/qualia-framework/templates/summary-standard.md +0 -48
  160. package/framework/qualia-framework/templates/summary.md +0 -246
  161. package/framework/qualia-framework/templates/user-setup.md +0 -311
  162. package/framework/qualia-framework/templates/verification-report.md +0 -322
  163. package/framework/qualia-framework/workflows/add-phase.md +0 -179
  164. package/framework/qualia-framework/workflows/add-todo.md +0 -157
  165. package/framework/qualia-framework/workflows/audit-milestone.md +0 -241
  166. package/framework/qualia-framework/workflows/check-todos.md +0 -176
  167. package/framework/qualia-framework/workflows/complete-milestone.md +0 -858
  168. package/framework/qualia-framework/workflows/diagnose-issues.md +0 -219
  169. package/framework/qualia-framework/workflows/discovery-phase.md +0 -289
  170. package/framework/qualia-framework/workflows/discuss-phase.md +0 -534
  171. package/framework/qualia-framework/workflows/execute-phase.md +0 -559
  172. package/framework/qualia-framework/workflows/execute-plan.md +0 -438
  173. package/framework/qualia-framework/workflows/help.md +0 -470
  174. package/framework/qualia-framework/workflows/insert-phase.md +0 -220
  175. package/framework/qualia-framework/workflows/list-phase-assumptions.md +0 -178
  176. package/framework/qualia-framework/workflows/map-codebase.md +0 -327
  177. package/framework/qualia-framework/workflows/new-milestone.md +0 -363
  178. package/framework/qualia-framework/workflows/new-project.md +0 -982
  179. package/framework/qualia-framework/workflows/pause-work.md +0 -122
  180. package/framework/qualia-framework/workflows/plan-milestone-gaps.md +0 -256
  181. package/framework/qualia-framework/workflows/plan-phase.md +0 -422
  182. package/framework/qualia-framework/workflows/progress.md +0 -389
  183. package/framework/qualia-framework/workflows/quick.md +0 -252
  184. package/framework/qualia-framework/workflows/remove-phase.md +0 -326
  185. package/framework/qualia-framework/workflows/research-phase.md +0 -74
  186. package/framework/qualia-framework/workflows/resume-project.md +0 -306
  187. package/framework/qualia-framework/workflows/set-profile.md +0 -80
  188. package/framework/qualia-framework/workflows/settings.md +0 -145
  189. package/framework/qualia-framework/workflows/transition.md +0 -556
  190. package/framework/qualia-framework/workflows/update.md +0 -197
  191. package/framework/qualia-framework/workflows/verify-phase.md +0 -195
  192. package/framework/qualia-framework/workflows/verify-work.md +0 -625
  193. package/framework/rules/context7.md +0 -14
  194. package/framework/rules/frontend.md +0 -33
  195. package/framework/rules/speed.md +0 -23
  196. package/framework/scripts/__pycache__/say.cpython-314.pyc +0 -0
  197. package/framework/scripts/apply-retention.sh +0 -120
  198. package/framework/scripts/bootstrap-pop-os.sh +0 -354
  199. package/framework/scripts/claude-voice +0 -13
  200. package/framework/scripts/cleanup.sh +0 -131
  201. package/framework/scripts/cowork-mode.sh +0 -141
  202. package/framework/scripts/generate-project-claude-md.sh +0 -153
  203. package/framework/scripts/load-test-webhook.js +0 -172
  204. package/framework/scripts/say.py +0 -236
  205. package/framework/scripts/showcase-video-recorder/ffmpeg-builder.js +0 -167
  206. package/framework/scripts/showcase-video-recorder/playwright-helpers.js +0 -216
  207. package/framework/scripts/speak.py +0 -55
  208. package/framework/scripts/speak.sh +0 -18
  209. package/framework/scripts/status.sh +0 -138
  210. package/framework/scripts/sync-to-framework.sh +0 -65
  211. package/framework/scripts/voice-hotkey.py +0 -227
  212. package/framework/scripts/voice-input.sh +0 -51
  213. package/framework/skills/animate/SKILL.md +0 -202
  214. package/framework/skills/bolder/SKILL.md +0 -144
  215. package/framework/skills/browser-qa/SKILL.md +0 -536
  216. package/framework/skills/clarify/SKILL.md +0 -179
  217. package/framework/skills/client-handoff/SKILL.md +0 -135
  218. package/framework/skills/collab-onboard/SKILL.md +0 -111
  219. package/framework/skills/colorize/SKILL.md +0 -170
  220. package/framework/skills/critique/SKILL.md +0 -126
  221. package/framework/skills/deep-research/SKILL.md +0 -240
  222. package/framework/skills/delight/SKILL.md +0 -329
  223. package/framework/skills/deploy/SKILL.md +0 -261
  224. package/framework/skills/deploy-verify/SKILL.md +0 -377
  225. package/framework/skills/deploy-verify/scripts/canary-check.sh +0 -206
  226. package/framework/skills/deploy-verify/scripts/check-console-errors.js +0 -147
  227. package/framework/skills/deploy-verify/scripts/check-cwv.js +0 -139
  228. package/framework/skills/deploy-verify/scripts/project-detect.sh +0 -84
  229. package/framework/skills/deploy-verify/scripts/verify.sh +0 -548
  230. package/framework/skills/design-quieter/SKILL.md +0 -130
  231. package/framework/skills/distill/SKILL.md +0 -149
  232. package/framework/skills/docs-lookup/SKILL.md +0 -79
  233. package/framework/skills/fcm-notifications/SKILL.md +0 -125
  234. package/framework/skills/financial-ledger/SKILL.md +0 -1039
  235. package/framework/skills/frontend-master/NOTICE.md +0 -4
  236. package/framework/skills/frontend-master/SKILL.md +0 -127
  237. package/framework/skills/frontend-master/reference/color-and-contrast.md +0 -132
  238. package/framework/skills/frontend-master/reference/interaction-design.md +0 -123
  239. package/framework/skills/frontend-master/reference/motion-design.md +0 -99
  240. package/framework/skills/frontend-master/reference/responsive-design.md +0 -114
  241. package/framework/skills/frontend-master/reference/spatial-design.md +0 -100
  242. package/framework/skills/frontend-master/reference/typography.md +0 -131
  243. package/framework/skills/frontend-master/reference/ux-writing.md +0 -107
  244. package/framework/skills/harden/SKILL.md +0 -357
  245. package/framework/skills/i18n-rtl/SKILL.md +0 -752
  246. package/framework/skills/learn/SKILL.md +0 -95
  247. package/framework/skills/memory/SKILL.md +0 -50
  248. package/framework/skills/mobile-expo/SKILL.md +0 -977
  249. package/framework/skills/mobile-expo/references/store-checklist.md +0 -550
  250. package/framework/skills/nestjs-backend/README.md +0 -73
  251. package/framework/skills/nestjs-backend/SKILL.md +0 -446
  252. package/framework/skills/nestjs-backend/references/templates.md +0 -1173
  253. package/framework/skills/normalize/SKILL.md +0 -79
  254. package/framework/skills/onboard/SKILL.md +0 -242
  255. package/framework/skills/openrouter-agent/SKILL.md +0 -922
  256. package/framework/skills/polish/SKILL.md +0 -209
  257. package/framework/skills/pr/SKILL.md +0 -66
  258. package/framework/skills/qualia/SKILL.md +0 -199
  259. package/framework/skills/qualia-add-todo/SKILL.md +0 -68
  260. package/framework/skills/qualia-audit-milestone/SKILL.md +0 -95
  261. package/framework/skills/qualia-check-todos/SKILL.md +0 -55
  262. package/framework/skills/qualia-complete-milestone/SKILL.md +0 -134
  263. package/framework/skills/qualia-debug/SKILL.md +0 -149
  264. package/framework/skills/qualia-design/SKILL.md +0 -203
  265. package/framework/skills/qualia-discuss-phase/SKILL.md +0 -72
  266. package/framework/skills/qualia-evolve/SKILL.md +0 -200
  267. package/framework/skills/qualia-execute-phase/SKILL.md +0 -89
  268. package/framework/skills/qualia-framework-audit/SKILL.md +0 -604
  269. package/framework/skills/qualia-guide/SKILL.md +0 -32
  270. package/framework/skills/qualia-help/SKILL.md +0 -114
  271. package/framework/skills/qualia-idk/SKILL.md +0 -352
  272. package/framework/skills/qualia-list-phase-assumptions/SKILL.md +0 -67
  273. package/framework/skills/qualia-new-milestone/SKILL.md +0 -72
  274. package/framework/skills/qualia-new-project/SKILL.md +0 -232
  275. package/framework/skills/qualia-pause-work/SKILL.md +0 -96
  276. package/framework/skills/qualia-plan-milestone-gaps/SKILL.md +0 -57
  277. package/framework/skills/qualia-plan-phase/SKILL.md +0 -104
  278. package/framework/skills/qualia-production-check/SKILL.md +0 -0
  279. package/framework/skills/qualia-progress/SKILL.md +0 -53
  280. package/framework/skills/qualia-quick/SKILL.md +0 -89
  281. package/framework/skills/qualia-report/SKILL.md +0 -166
  282. package/framework/skills/qualia-research-phase/SKILL.md +0 -88
  283. package/framework/skills/qualia-resume-work/SKILL.md +0 -62
  284. package/framework/skills/qualia-review/SKILL.md +0 -263
  285. package/framework/skills/qualia-start/SKILL.md +0 -161
  286. package/framework/skills/qualia-verify-work/SKILL.md +0 -132
  287. package/framework/skills/rag/SKILL.md +0 -750
  288. package/framework/skills/responsive/SKILL.md +0 -231
  289. package/framework/skills/retro/SKILL.md +0 -284
  290. package/framework/skills/sakani-conventions/SKILL.md +0 -136
  291. package/framework/skills/sakani-conventions/evals/evals.json +0 -23
  292. package/framework/skills/sakani-conventions/references/entities.md +0 -365
  293. package/framework/skills/sakani-conventions/references/error-codes.md +0 -95
  294. package/framework/skills/seo-master/SKILL.md +0 -490
  295. package/framework/skills/seo-master/references/checklist.md +0 -199
  296. package/framework/skills/seo-master/references/structured-data.md +0 -609
  297. package/framework/skills/ship/SKILL.md +0 -239
  298. package/framework/skills/stack-researcher/SKILL.md +0 -215
  299. package/framework/skills/status/SKILL.md +0 -154
  300. package/framework/skills/status/scripts/health-check.sh +0 -562
  301. package/framework/skills/subscription-payments/SKILL.md +0 -250
  302. package/framework/skills/supabase/SKILL.md +0 -973
  303. package/framework/skills/supabase/references/templates.md +0 -159
  304. package/framework/skills/team/SKILL.md +0 -67
  305. package/framework/skills/test-runner/SKILL.md +0 -202
  306. package/framework/skills/voice-agent/SKILL.md +0 -1312
  307. package/framework/skills/zoho-workflow/SKILL.md +0 -51
  308. package/framework/statusline-command.sh +0 -117
  309. package/framework/teams/default/inboxes/plan-04.json +0 -9
  310. package/framework/teams/review-team.md +0 -75
  311. package/framework/teams/ship-team.md +0 -86
  312. package/profiles/fawzi.json +0 -16
  313. package/profiles/hasan.json +0 -16
  314. package/profiles/moayad.json +0 -16
  315. package/templates/CLAUDE-owner.md +0 -52
  316. package/templates/CLAUDE.md.hbs +0 -58
  317. package/templates/env.claude.template +0 -12
  318. package/templates/settings.json +0 -172
  319. package/uninstall.sh +0 -90
  320. /package/{framework/rules → rules}/deployment.md +0 -0
  321. /package/{framework/rules → rules}/security.md +0 -0
@@ -1,307 +0,0 @@
1
- # Coding Conventions Template
2
-
3
- Template for `.planning/codebase/CONVENTIONS.md` - captures coding style and patterns.
4
-
5
- **Purpose:** Document how code is written in this codebase. Prescriptive guide for Claude to match existing style.
6
-
7
- ---
8
-
9
- ## File Template
10
-
11
- ```markdown
12
- # Coding Conventions
13
-
14
- **Analysis Date:** [YYYY-MM-DD]
15
-
16
- ## Naming Patterns
17
-
18
- **Files:**
19
- - [Pattern: e.g., "kebab-case for all files"]
20
- - [Test files: e.g., "*.test.ts alongside source"]
21
- - [Components: e.g., "PascalCase.tsx for React components"]
22
-
23
- **Functions:**
24
- - [Pattern: e.g., "camelCase for all functions"]
25
- - [Async: e.g., "no special prefix for async functions"]
26
- - [Handlers: e.g., "handleEventName for event handlers"]
27
-
28
- **Variables:**
29
- - [Pattern: e.g., "camelCase for variables"]
30
- - [Constants: e.g., "UPPER_SNAKE_CASE for constants"]
31
- - [Private: e.g., "_prefix for private members" or "no prefix"]
32
-
33
- **Types:**
34
- - [Interfaces: e.g., "PascalCase, no I prefix"]
35
- - [Types: e.g., "PascalCase for type aliases"]
36
- - [Enums: e.g., "PascalCase for enum name, UPPER_CASE for values"]
37
-
38
- ## Code Style
39
-
40
- **Formatting:**
41
- - [Tool: e.g., "Prettier with config in .prettierrc"]
42
- - [Line length: e.g., "100 characters max"]
43
- - [Quotes: e.g., "single quotes for strings"]
44
- - [Semicolons: e.g., "required" or "omitted"]
45
-
46
- **Linting:**
47
- - [Tool: e.g., "ESLint with eslint.config.js"]
48
- - [Rules: e.g., "extends airbnb-base, no console in production"]
49
- - [Run: e.g., "npm run lint"]
50
-
51
- ## Import Organization
52
-
53
- **Order:**
54
- 1. [e.g., "External packages (react, express, etc.)"]
55
- 2. [e.g., "Internal modules (@/lib, @/components)"]
56
- 3. [e.g., "Relative imports (., ..)"]
57
- 4. [e.g., "Type imports (import type {})"]
58
-
59
- **Grouping:**
60
- - [Blank lines: e.g., "blank line between groups"]
61
- - [Sorting: e.g., "alphabetical within each group"]
62
-
63
- **Path Aliases:**
64
- - [Aliases used: e.g., "@/ for src/, @components/ for src/components/"]
65
-
66
- ## Error Handling
67
-
68
- **Patterns:**
69
- - [Strategy: e.g., "throw errors, catch at boundaries"]
70
- - [Custom errors: e.g., "extend Error class, named *Error"]
71
- - [Async: e.g., "use try/catch, no .catch() chains"]
72
-
73
- **Error Types:**
74
- - [When to throw: e.g., "invalid input, missing dependencies"]
75
- - [When to return: e.g., "expected failures return Result<T, E>"]
76
- - [Logging: e.g., "log error with context before throwing"]
77
-
78
- ## Logging
79
-
80
- **Framework:**
81
- - [Tool: e.g., "console.log, pino, winston"]
82
- - [Levels: e.g., "debug, info, warn, error"]
83
-
84
- **Patterns:**
85
- - [Format: e.g., "structured logging with context object"]
86
- - [When: e.g., "log state transitions, external calls"]
87
- - [Where: e.g., "log at service boundaries, not in utils"]
88
-
89
- ## Comments
90
-
91
- **When to Comment:**
92
- - [e.g., "explain why, not what"]
93
- - [e.g., "document business logic, algorithms, edge cases"]
94
- - [e.g., "avoid obvious comments like // increment counter"]
95
-
96
- **JSDoc/TSDoc:**
97
- - [Usage: e.g., "required for public APIs, optional for internal"]
98
- - [Format: e.g., "use @param, @returns, @throws tags"]
99
-
100
- **TODO Comments:**
101
- - [Pattern: e.g., "// TODO(username): description"]
102
- - [Tracking: e.g., "link to issue number if available"]
103
-
104
- ## Function Design
105
-
106
- **Size:**
107
- - [e.g., "keep under 50 lines, extract helpers"]
108
-
109
- **Parameters:**
110
- - [e.g., "max 3 parameters, use object for more"]
111
- - [e.g., "destructure objects in parameter list"]
112
-
113
- **Return Values:**
114
- - [e.g., "explicit returns, no implicit undefined"]
115
- - [e.g., "return early for guard clauses"]
116
-
117
- ## Module Design
118
-
119
- **Exports:**
120
- - [e.g., "named exports preferred, default exports for React components"]
121
- - [e.g., "export from index.ts for public API"]
122
-
123
- **Barrel Files:**
124
- - [e.g., "use index.ts to re-export public API"]
125
- - [e.g., "avoid circular dependencies"]
126
-
127
- ---
128
-
129
- *Convention analysis: [date]*
130
- *Update when patterns change*
131
- ```
132
-
133
- <good_examples>
134
- ```markdown
135
- # Coding Conventions
136
-
137
- **Analysis Date:** 2025-01-20
138
-
139
- ## Naming Patterns
140
-
141
- **Files:**
142
- - kebab-case for all files (command-handler.ts, user-service.ts)
143
- - *.test.ts alongside source files
144
- - index.ts for barrel exports
145
-
146
- **Functions:**
147
- - camelCase for all functions
148
- - No special prefix for async functions
149
- - handleEventName for event handlers (handleClick, handleSubmit)
150
-
151
- **Variables:**
152
- - camelCase for variables
153
- - UPPER_SNAKE_CASE for constants (MAX_RETRIES, API_BASE_URL)
154
- - No underscore prefix (no private marker in TS)
155
-
156
- **Types:**
157
- - PascalCase for interfaces, no I prefix (User, not IUser)
158
- - PascalCase for type aliases (UserConfig, ResponseData)
159
- - PascalCase for enum names, UPPER_CASE for values (Status.PENDING)
160
-
161
- ## Code Style
162
-
163
- **Formatting:**
164
- - Prettier with .prettierrc
165
- - 100 character line length
166
- - Single quotes for strings
167
- - Semicolons required
168
- - 2 space indentation
169
-
170
- **Linting:**
171
- - ESLint with eslint.config.js
172
- - Extends @typescript-eslint/recommended
173
- - No console.log in production code (use logger)
174
- - Run: npm run lint
175
-
176
- ## Import Organization
177
-
178
- **Order:**
179
- 1. External packages (react, express, commander)
180
- 2. Internal modules (@/lib, @/services)
181
- 3. Relative imports (./utils, ../types)
182
- 4. Type imports (import type { User })
183
-
184
- **Grouping:**
185
- - Blank line between groups
186
- - Alphabetical within each group
187
- - Type imports last within each group
188
-
189
- **Path Aliases:**
190
- - @/ maps to src/
191
- - No other aliases defined
192
-
193
- ## Error Handling
194
-
195
- **Patterns:**
196
- - Throw errors, catch at boundaries (route handlers, main functions)
197
- - Extend Error class for custom errors (ValidationError, NotFoundError)
198
- - Async functions use try/catch, no .catch() chains
199
-
200
- **Error Types:**
201
- - Throw on invalid input, missing dependencies, invariant violations
202
- - Log error with context before throwing: logger.error({ err, userId }, 'Failed to process')
203
- - Include cause in error message: new Error('Failed to X', { cause: originalError })
204
-
205
- ## Logging
206
-
207
- **Framework:**
208
- - pino logger instance exported from lib/logger.ts
209
- - Levels: debug, info, warn, error (no trace)
210
-
211
- **Patterns:**
212
- - Structured logging with context: logger.info({ userId, action }, 'User action')
213
- - Log at service boundaries, not in utility functions
214
- - Log state transitions, external API calls, errors
215
- - No console.log in committed code
216
-
217
- ## Comments
218
-
219
- **When to Comment:**
220
- - Explain why, not what: // Retry 3 times because API has transient failures
221
- - Document business rules: // Users must verify email within 24 hours
222
- - Explain non-obvious algorithms or workarounds
223
- - Avoid obvious comments: // set count to 0
224
-
225
- **JSDoc/TSDoc:**
226
- - Required for public API functions
227
- - Optional for internal functions if signature is self-explanatory
228
- - Use @param, @returns, @throws tags
229
-
230
- **TODO Comments:**
231
- - Format: // TODO: description (no username, using git blame)
232
- - Link to issue if exists: // TODO: Fix race condition (issue #123)
233
-
234
- ## Function Design
235
-
236
- **Size:**
237
- - Keep under 50 lines
238
- - Extract helpers for complex logic
239
- - One level of abstraction per function
240
-
241
- **Parameters:**
242
- - Max 3 parameters
243
- - Use options object for 4+ parameters: function create(options: CreateOptions)
244
- - Destructure in parameter list: function process({ id, name }: ProcessParams)
245
-
246
- **Return Values:**
247
- - Explicit return statements
248
- - Return early for guard clauses
249
- - Use Result<T, E> type for expected failures
250
-
251
- ## Module Design
252
-
253
- **Exports:**
254
- - Named exports preferred
255
- - Default exports only for React components
256
- - Export public API from index.ts barrel files
257
-
258
- **Barrel Files:**
259
- - index.ts re-exports public API
260
- - Keep internal helpers private (don't export from index)
261
- - Avoid circular dependencies (import from specific files if needed)
262
-
263
- ---
264
-
265
- *Convention analysis: 2025-01-20*
266
- *Update when patterns change*
267
- ```
268
- </good_examples>
269
-
270
- <guidelines>
271
- **What belongs in CONVENTIONS.md:**
272
- - Naming patterns observed in the codebase
273
- - Formatting rules (Prettier config, linting rules)
274
- - Import organization patterns
275
- - Error handling strategy
276
- - Logging approach
277
- - Comment conventions
278
- - Function and module design patterns
279
-
280
- **What does NOT belong here:**
281
- - Architecture decisions (that's ARCHITECTURE.md)
282
- - Technology choices (that's STACK.md)
283
- - Test patterns (that's TESTING.md)
284
- - File organization (that's STRUCTURE.md)
285
-
286
- **When filling this template:**
287
- - Check .prettierrc, .eslintrc, or similar config files
288
- - Examine 5-10 representative source files for patterns
289
- - Look for consistency: if 80%+ follows a pattern, document it
290
- - Be prescriptive: "Use X" not "Sometimes Y is used"
291
- - Note deviations: "Legacy code uses Y, new code should use X"
292
- - Keep under ~150 lines total
293
-
294
- **Useful for phase planning when:**
295
- - Writing new code (match existing style)
296
- - Adding features (follow naming patterns)
297
- - Refactoring (apply consistent conventions)
298
- - Code review (check against documented patterns)
299
- - Onboarding (understand style expectations)
300
-
301
- **Analysis approach:**
302
- - Scan src/ directory for file naming patterns
303
- - Check package.json scripts for lint/format commands
304
- - Read 5-10 files to identify function naming, error handling
305
- - Look for config files (.prettierrc, eslint.config.js)
306
- - Note patterns in imports, comments, function signatures
307
- </guidelines>
@@ -1,280 +0,0 @@
1
- # External Integrations Template
2
-
3
- Template for `.planning/codebase/INTEGRATIONS.md` - captures external service dependencies.
4
-
5
- **Purpose:** Document what external systems this codebase communicates with. Focused on "what lives outside our code that we depend on."
6
-
7
- ---
8
-
9
- ## File Template
10
-
11
- ```markdown
12
- # External Integrations
13
-
14
- **Analysis Date:** [YYYY-MM-DD]
15
-
16
- ## APIs & External Services
17
-
18
- **Payment Processing:**
19
- - [Service] - [What it's used for: e.g., "subscription billing, one-time payments"]
20
- - SDK/Client: [e.g., "stripe npm package v14.x"]
21
- - Auth: [e.g., "API key in STRIPE_SECRET_KEY env var"]
22
- - Endpoints used: [e.g., "checkout sessions, webhooks"]
23
-
24
- **Email/SMS:**
25
- - [Service] - [What it's used for: e.g., "transactional emails"]
26
- - SDK/Client: [e.g., "sendgrid/mail v8.x"]
27
- - Auth: [e.g., "API key in SENDGRID_API_KEY env var"]
28
- - Templates: [e.g., "managed in SendGrid dashboard"]
29
-
30
- **External APIs:**
31
- - [Service] - [What it's used for]
32
- - Integration method: [e.g., "REST API via fetch", "GraphQL client"]
33
- - Auth: [e.g., "OAuth2 token in AUTH_TOKEN env var"]
34
- - Rate limits: [if applicable]
35
-
36
- ## Data Storage
37
-
38
- **Databases:**
39
- - [Type/Provider] - [e.g., "PostgreSQL on Supabase"]
40
- - Connection: [e.g., "via DATABASE_URL env var"]
41
- - Client: [e.g., "Prisma ORM v5.x"]
42
- - Migrations: [e.g., "prisma migrate in migrations/"]
43
-
44
- **File Storage:**
45
- - [Service] - [e.g., "AWS S3 for user uploads"]
46
- - SDK/Client: [e.g., "@aws-sdk/client-s3"]
47
- - Auth: [e.g., "IAM credentials in AWS_* env vars"]
48
- - Buckets: [e.g., "prod-uploads, dev-uploads"]
49
-
50
- **Caching:**
51
- - [Service] - [e.g., "Redis for session storage"]
52
- - Connection: [e.g., "REDIS_URL env var"]
53
- - Client: [e.g., "ioredis v5.x"]
54
-
55
- ## Authentication & Identity
56
-
57
- **Auth Provider:**
58
- - [Service] - [e.g., "Supabase Auth", "Auth0", "custom JWT"]
59
- - Implementation: [e.g., "Supabase client SDK"]
60
- - Token storage: [e.g., "httpOnly cookies", "localStorage"]
61
- - Session management: [e.g., "JWT refresh tokens"]
62
-
63
- **OAuth Integrations:**
64
- - [Provider] - [e.g., "Google OAuth for sign-in"]
65
- - Credentials: [e.g., "GOOGLE_CLIENT_ID, GOOGLE_CLIENT_SECRET"]
66
- - Scopes: [e.g., "email, profile"]
67
-
68
- ## Monitoring & Observability
69
-
70
- **Error Tracking:**
71
- - [Service] - [e.g., "Sentry"]
72
- - DSN: [e.g., "SENTRY_DSN env var"]
73
- - Release tracking: [e.g., "via SENTRY_RELEASE"]
74
-
75
- **Analytics:**
76
- - [Service] - [e.g., "Mixpanel for product analytics"]
77
- - Token: [e.g., "MIXPANEL_TOKEN env var"]
78
- - Events tracked: [e.g., "user actions, page views"]
79
-
80
- **Logs:**
81
- - [Service] - [e.g., "CloudWatch", "Datadog", "none (stdout only)"]
82
- - Integration: [e.g., "AWS Lambda built-in"]
83
-
84
- ## CI/CD & Deployment
85
-
86
- **Hosting:**
87
- - [Platform] - [e.g., "Vercel", "AWS Lambda", "Docker on ECS"]
88
- - Deployment: [e.g., "automatic on main branch push"]
89
- - Environment vars: [e.g., "configured in Vercel dashboard"]
90
-
91
- **CI Pipeline:**
92
- - [Service] - [e.g., "GitHub Actions"]
93
- - Workflows: [e.g., "test.yml, deploy.yml"]
94
- - Secrets: [e.g., "stored in GitHub repo secrets"]
95
-
96
- ## Environment Configuration
97
-
98
- **Development:**
99
- - Required env vars: [List critical vars]
100
- - Secrets location: [e.g., ".env.local (gitignored)", "1Password vault"]
101
- - Mock/stub services: [e.g., "Stripe test mode", "local PostgreSQL"]
102
-
103
- **Staging:**
104
- - Environment-specific differences: [e.g., "uses staging Stripe account"]
105
- - Data: [e.g., "separate staging database"]
106
-
107
- **Production:**
108
- - Secrets management: [e.g., "Vercel environment variables"]
109
- - Failover/redundancy: [e.g., "multi-region DB replication"]
110
-
111
- ## Webhooks & Callbacks
112
-
113
- **Incoming:**
114
- - [Service] - [Endpoint: e.g., "/api/webhooks/stripe"]
115
- - Verification: [e.g., "signature validation via stripe.webhooks.constructEvent"]
116
- - Events: [e.g., "payment_intent.succeeded, customer.subscription.updated"]
117
-
118
- **Outgoing:**
119
- - [Service] - [What triggers it]
120
- - Endpoint: [e.g., "external CRM webhook on user signup"]
121
- - Retry logic: [if applicable]
122
-
123
- ---
124
-
125
- *Integration audit: [date]*
126
- *Update when adding/removing external services*
127
- ```
128
-
129
- <good_examples>
130
- ```markdown
131
- # External Integrations
132
-
133
- **Analysis Date:** 2025-01-20
134
-
135
- ## APIs & External Services
136
-
137
- **Payment Processing:**
138
- - Stripe - Subscription billing and one-time course payments
139
- - SDK/Client: stripe npm package v14.8
140
- - Auth: API key in STRIPE_SECRET_KEY env var
141
- - Endpoints used: checkout sessions, customer portal, webhooks
142
-
143
- **Email/SMS:**
144
- - SendGrid - Transactional emails (receipts, password resets)
145
- - SDK/Client: @sendgrid/mail v8.1
146
- - Auth: API key in SENDGRID_API_KEY env var
147
- - Templates: Managed in SendGrid dashboard (template IDs in code)
148
-
149
- **External APIs:**
150
- - OpenAI API - Course content generation
151
- - Integration method: REST API via openai npm package v4.x
152
- - Auth: Bearer token in OPENAI_API_KEY env var
153
- - Rate limits: 3500 requests/min (tier 3)
154
-
155
- ## Data Storage
156
-
157
- **Databases:**
158
- - PostgreSQL on Supabase - Primary data store
159
- - Connection: via DATABASE_URL env var
160
- - Client: Prisma ORM v5.8
161
- - Migrations: prisma migrate in prisma/migrations/
162
-
163
- **File Storage:**
164
- - Supabase Storage - User uploads (profile images, course materials)
165
- - SDK/Client: @supabase/supabase-js v2.x
166
- - Auth: Service role key in SUPABASE_SERVICE_ROLE_KEY
167
- - Buckets: avatars (public), course-materials (private)
168
-
169
- **Caching:**
170
- - None currently (all database queries, no Redis)
171
-
172
- ## Authentication & Identity
173
-
174
- **Auth Provider:**
175
- - Supabase Auth - Email/password + OAuth
176
- - Implementation: Supabase client SDK with server-side session management
177
- - Token storage: httpOnly cookies via @supabase/ssr
178
- - Session management: JWT refresh tokens handled by Supabase
179
-
180
- **OAuth Integrations:**
181
- - Google OAuth - Social sign-in
182
- - Credentials: GOOGLE_CLIENT_ID, GOOGLE_CLIENT_SECRET (Supabase dashboard)
183
- - Scopes: email, profile
184
-
185
- ## Monitoring & Observability
186
-
187
- **Error Tracking:**
188
- - Sentry - Server and client errors
189
- - DSN: SENTRY_DSN env var
190
- - Release tracking: Git commit SHA via SENTRY_RELEASE
191
-
192
- **Analytics:**
193
- - None (planned: Mixpanel)
194
-
195
- **Logs:**
196
- - Vercel logs - stdout/stderr only
197
- - Retention: 7 days on Pro plan
198
-
199
- ## CI/CD & Deployment
200
-
201
- **Hosting:**
202
- - Vercel - Next.js app hosting
203
- - Deployment: Automatic on main branch push
204
- - Environment vars: Configured in Vercel dashboard (synced to .env.example)
205
-
206
- **CI Pipeline:**
207
- - GitHub Actions - Tests and type checking
208
- - Workflows: .github/workflows/ci.yml
209
- - Secrets: None needed (public repo tests only)
210
-
211
- ## Environment Configuration
212
-
213
- **Development:**
214
- - Required env vars: DATABASE_URL, NEXT_PUBLIC_SUPABASE_URL, NEXT_PUBLIC_SUPABASE_ANON_KEY
215
- - Secrets location: .env.local (gitignored), team shared via 1Password vault
216
- - Mock/stub services: Stripe test mode, Supabase local dev project
217
-
218
- **Staging:**
219
- - Uses separate Supabase staging project
220
- - Stripe test mode
221
- - Same Vercel account, different environment
222
-
223
- **Production:**
224
- - Secrets management: Vercel environment variables
225
- - Database: Supabase production project with daily backups
226
-
227
- ## Webhooks & Callbacks
228
-
229
- **Incoming:**
230
- - Stripe - /api/webhooks/stripe
231
- - Verification: Signature validation via stripe.webhooks.constructEvent
232
- - Events: payment_intent.succeeded, customer.subscription.updated, customer.subscription.deleted
233
-
234
- **Outgoing:**
235
- - None
236
-
237
- ---
238
-
239
- *Integration audit: 2025-01-20*
240
- *Update when adding/removing external services*
241
- ```
242
- </good_examples>
243
-
244
- <guidelines>
245
- **What belongs in INTEGRATIONS.md:**
246
- - External services the code communicates with
247
- - Authentication patterns (where secrets live, not the secrets themselves)
248
- - SDKs and client libraries used
249
- - Environment variable names (not values)
250
- - Webhook endpoints and verification methods
251
- - Database connection patterns
252
- - File storage locations
253
- - Monitoring and logging services
254
-
255
- **What does NOT belong here:**
256
- - Actual API keys or secrets (NEVER write these)
257
- - Internal architecture (that's ARCHITECTURE.md)
258
- - Code patterns (that's PATTERNS.md)
259
- - Technology choices (that's STACK.md)
260
- - Performance issues (that's CONCERNS.md)
261
-
262
- **When filling this template:**
263
- - Check .env.example or .env.template for required env vars
264
- - Look for SDK imports (stripe, @sendgrid/mail, etc.)
265
- - Check for webhook handlers in routes/endpoints
266
- - Note where secrets are managed (not the secrets)
267
- - Document environment-specific differences (dev/staging/prod)
268
- - Include auth patterns for each service
269
-
270
- **Useful for phase planning when:**
271
- - Adding new external service integrations
272
- - Debugging authentication issues
273
- - Understanding data flow outside the application
274
- - Setting up new environments
275
- - Auditing third-party dependencies
276
- - Planning for service outages or migrations
277
-
278
- **Security note:**
279
- Document WHERE secrets live (env vars, Vercel dashboard, 1Password), never WHAT the secrets are.
280
- </guidelines>