cc-devflow 1.0.1

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 (277) hide show
  1. package/.claude/CLAUDE.md +83 -0
  2. package/.claude/agents/architecture-designer.md +443 -0
  3. package/.claude/agents/bug-analyzer.md +382 -0
  4. package/.claude/agents/checklist-agent.md +175 -0
  5. package/.claude/agents/clarify-analyst.md +50 -0
  6. package/.claude/agents/code-reviewer.md +71 -0
  7. package/.claude/agents/codex-analyzer.md +39 -0
  8. package/.claude/agents/compatibility-checker.md +580 -0
  9. package/.claude/agents/consistency-checker.md +532 -0
  10. package/.claude/agents/impact-analyzer.md +441 -0
  11. package/.claude/agents/planner.md +230 -0
  12. package/.claude/agents/prd-writer.md +320 -0
  13. package/.claude/agents/project-guidelines-generator.md +1329 -0
  14. package/.claude/agents/qa-tester.md +313 -0
  15. package/.claude/agents/release-manager.md +295 -0
  16. package/.claude/agents/security-reviewer.md +314 -0
  17. package/.claude/agents/style-guide-generator.md +458 -0
  18. package/.claude/agents/tech-architect.md +516 -0
  19. package/.claude/agents/ui-designer.md +485 -0
  20. package/.claude/commands/code-review-high.md +58 -0
  21. package/.claude/commands/core-architecture.md +429 -0
  22. package/.claude/commands/core-guidelines.md +486 -0
  23. package/.claude/commands/core-roadmap.md +439 -0
  24. package/.claude/commands/core-style.md +293 -0
  25. package/.claude/commands/flow-archive.md +245 -0
  26. package/.claude/commands/flow-checklist.md +260 -0
  27. package/.claude/commands/flow-clarify.md +136 -0
  28. package/.claude/commands/flow-constitution.md +82 -0
  29. package/.claude/commands/flow-dev.md +134 -0
  30. package/.claude/commands/flow-epic.md +150 -0
  31. package/.claude/commands/flow-fix.md +104 -0
  32. package/.claude/commands/flow-ideate.md +214 -0
  33. package/.claude/commands/flow-init.md +313 -0
  34. package/.claude/commands/flow-new.md +394 -0
  35. package/.claude/commands/flow-prd.md +131 -0
  36. package/.claude/commands/flow-qa.md +93 -0
  37. package/.claude/commands/flow-release.md +92 -0
  38. package/.claude/commands/flow-restart.md +98 -0
  39. package/.claude/commands/flow-status.md +64 -0
  40. package/.claude/commands/flow-tech.md +142 -0
  41. package/.claude/commands/flow-ui.md +189 -0
  42. package/.claude/commands/flow-update.md +111 -0
  43. package/.claude/commands/flow-upgrade.md +115 -0
  44. package/.claude/commands/flow-verify.md +96 -0
  45. package/.claude/commands/problem-analyzer.md +60 -0
  46. package/.claude/config/quality-rules.yml +161 -0
  47. package/.claude/docs/SPEC_KIT_CONSTITUTION_ANALYSIS.md +426 -0
  48. package/.claude/docs/design/consistency-conflict-detection-algorithms.md +658 -0
  49. package/.claude/docs/design/intent-driven-input-design.md +380 -0
  50. package/.claude/docs/design/prd-version-management-design.md +437 -0
  51. package/.claude/docs/guides/INIT_TROUBLESHOOTING.md +117 -0
  52. package/.claude/docs/guides/NEW_TROUBLESHOOTING.md +151 -0
  53. package/.claude/docs/guides/ROADMAP_TROUBLESHOOTING.md +188 -0
  54. package/.claude/docs/guides/TASK_COMPLETION_MARKING.md +338 -0
  55. package/.claude/docs/templates/ARCHITECTURE_TEMPLATE.md +633 -0
  56. package/.claude/docs/templates/BACKLOG_TEMPLATE.md +261 -0
  57. package/.claude/docs/templates/CHECKLIST_TEMPLATE.md +52 -0
  58. package/.claude/docs/templates/CLARIFICATION_REPORT_TEMPLATE.md +206 -0
  59. package/.claude/docs/templates/CODE_REVIEW_TEMPLATE.md +71 -0
  60. package/.claude/docs/templates/EPIC_TEMPLATE.md +805 -0
  61. package/.claude/docs/templates/INIT_FLOW_TEMPLATE.md +213 -0
  62. package/.claude/docs/templates/INTENT_CLARIFICATION_TEMPLATE.md +57 -0
  63. package/.claude/docs/templates/NEW_ORCHESTRATION_TEMPLATE.md +148 -0
  64. package/.claude/docs/templates/PRD_TEMPLATE.md +562 -0
  65. package/.claude/docs/templates/RESEARCH_TEMPLATE.md +276 -0
  66. package/.claude/docs/templates/REVIEW-HIGH.md +57 -0
  67. package/.claude/docs/templates/ROADMAP_DIALOGUE_TEMPLATE.md +198 -0
  68. package/.claude/docs/templates/ROADMAP_TEMPLATE.md +310 -0
  69. package/.claude/docs/templates/STYLE_TEMPLATE.md +1266 -0
  70. package/.claude/docs/templates/TASKS_TEMPLATE.md +523 -0
  71. package/.claude/docs/templates/TECH_DESIGN_TEMPLATE.md +1019 -0
  72. package/.claude/docs/templates/UI_PROTOTYPE_TEMPLATE.md +1436 -0
  73. package/.claude/guides/agent-guides/agent-coordination-guide.md +459 -0
  74. package/.claude/guides/project-guidelines-system.md +463 -0
  75. package/.claude/guides/technical-guides/datetime-handling-guide.md +563 -0
  76. package/.claude/guides/technical-guides/git-github-guide.md +642 -0
  77. package/.claude/guides/technical-guides/test-execution-guide.md +618 -0
  78. package/.claude/guides/workflow-guides/bug-fix-orchestrator.md +217 -0
  79. package/.claude/guides/workflow-guides/flow-orchestrator.md +282 -0
  80. package/.claude/hooks/checklist-gate.js +397 -0
  81. package/.claude/hooks/error-handling-reminder.sh +12 -0
  82. package/.claude/hooks/error-handling-reminder.ts +459 -0
  83. package/.claude/hooks/post-tool-use-tracker.sh +280 -0
  84. package/.claude/hooks/pre-tool-use-guardrail.sh +36 -0
  85. package/.claude/hooks/pre-tool-use-guardrail.ts +342 -0
  86. package/.claude/hooks/skill-activation-prompt.sh +36 -0
  87. package/.claude/hooks/skill-activation-prompt.ts +214 -0
  88. package/.claude/hooks/state/skills-used-test-guard.json +3 -0
  89. package/.claude/rules/devflow-conventions.md +305 -0
  90. package/.claude/rules/project-constitution.md +748 -0
  91. package/.claude/schemas/constitution.schema.json +43 -0
  92. package/.claude/scripts/analyze-upgrade-impact.sh +200 -0
  93. package/.claude/scripts/archive-requirement.sh +351 -0
  94. package/.claude/scripts/calculate-checklist-completion.sh +243 -0
  95. package/.claude/scripts/calculate-quarter.sh +206 -0
  96. package/.claude/scripts/check-dependencies.sh +409 -0
  97. package/.claude/scripts/check-prerequisites.sh +232 -0
  98. package/.claude/scripts/check-task-status.sh +264 -0
  99. package/.claude/scripts/checklist-errors.sh +131 -0
  100. package/.claude/scripts/common.sh +570 -0
  101. package/.claude/scripts/consolidate-research.sh +182 -0
  102. package/.claude/scripts/create-requirement.sh +426 -0
  103. package/.claude/scripts/export-contracts.sh +117 -0
  104. package/.claude/scripts/extract-data-model.sh +78 -0
  105. package/.claude/scripts/generate-clarification-questions.sh +377 -0
  106. package/.claude/scripts/generate-clarification-report.sh +463 -0
  107. package/.claude/scripts/generate-quickstart.sh +146 -0
  108. package/.claude/scripts/generate-research-tasks.sh +157 -0
  109. package/.claude/scripts/generate-status-report.sh +523 -0
  110. package/.claude/scripts/generate-tech-analysis.sh +46 -0
  111. package/.claude/scripts/locate-requirement-in-roadmap.sh +233 -0
  112. package/.claude/scripts/manage-constitution.sh +602 -0
  113. package/.claude/scripts/mark-task-complete.sh +198 -0
  114. package/.claude/scripts/populate-research-tasks.sh +259 -0
  115. package/.claude/scripts/recover-workflow.sh +460 -0
  116. package/.claude/scripts/run-clarify-scan.sh +601 -0
  117. package/.claude/scripts/run-high-review.sh +62 -0
  118. package/.claude/scripts/run-problem-analysis.sh +68 -0
  119. package/.claude/scripts/setup-epic.sh +173 -0
  120. package/.claude/scripts/sync-roadmap-progress.sh +300 -0
  121. package/.claude/scripts/sync-task-marks.sh +199 -0
  122. package/.claude/scripts/test-clarify-scan.sh +515 -0
  123. package/.claude/scripts/update-agent-context.sh +806 -0
  124. package/.claude/scripts/validate-constitution.sh +567 -0
  125. package/.claude/scripts/validate-hooks.sh +487 -0
  126. package/.claude/scripts/validate-research.sh +332 -0
  127. package/.claude/scripts/validate-scope-boundary.sh +493 -0
  128. package/.claude/scripts/verify-setup.sh +37 -0
  129. package/.claude/settings.json +76 -0
  130. package/.claude/skills/_reference-implementations/README.md +96 -0
  131. package/.claude/skills/_reference-implementations/backend-express-prisma/SKILL.md +302 -0
  132. package/.claude/skills/_reference-implementations/backend-express-prisma/resources/architecture-overview.md +451 -0
  133. package/.claude/skills/_reference-implementations/backend-express-prisma/resources/async-and-errors.md +307 -0
  134. package/.claude/skills/_reference-implementations/backend-express-prisma/resources/complete-examples.md +638 -0
  135. package/.claude/skills/_reference-implementations/backend-express-prisma/resources/configuration.md +275 -0
  136. package/.claude/skills/_reference-implementations/backend-express-prisma/resources/database-patterns.md +224 -0
  137. package/.claude/skills/_reference-implementations/backend-express-prisma/resources/middleware-guide.md +213 -0
  138. package/.claude/skills/_reference-implementations/backend-express-prisma/resources/routing-and-controllers.md +756 -0
  139. package/.claude/skills/_reference-implementations/backend-express-prisma/resources/sentry-and-monitoring.md +336 -0
  140. package/.claude/skills/_reference-implementations/backend-express-prisma/resources/services-and-repositories.md +789 -0
  141. package/.claude/skills/_reference-implementations/backend-express-prisma/resources/testing-guide.md +235 -0
  142. package/.claude/skills/_reference-implementations/backend-express-prisma/resources/validation-patterns.md +754 -0
  143. package/.claude/skills/_reference-implementations/frontend-react-mui/SKILL.md +399 -0
  144. package/.claude/skills/_reference-implementations/frontend-react-mui/resources/common-patterns.md +331 -0
  145. package/.claude/skills/_reference-implementations/frontend-react-mui/resources/complete-examples.md +872 -0
  146. package/.claude/skills/_reference-implementations/frontend-react-mui/resources/component-patterns.md +502 -0
  147. package/.claude/skills/_reference-implementations/frontend-react-mui/resources/data-fetching.md +767 -0
  148. package/.claude/skills/_reference-implementations/frontend-react-mui/resources/file-organization.md +502 -0
  149. package/.claude/skills/_reference-implementations/frontend-react-mui/resources/loading-and-error-states.md +501 -0
  150. package/.claude/skills/_reference-implementations/frontend-react-mui/resources/performance.md +406 -0
  151. package/.claude/skills/_reference-implementations/frontend-react-mui/resources/routing-guide.md +364 -0
  152. package/.claude/skills/_reference-implementations/frontend-react-mui/resources/styling-guide.md +428 -0
  153. package/.claude/skills/_reference-implementations/frontend-react-mui/resources/typescript-standards.md +418 -0
  154. package/.claude/skills/cc-devflow-orchestrator/SKILL.md +229 -0
  155. package/.claude/skills/constitution-guardian/SKILL.md +306 -0
  156. package/.claude/skills/devflow-constitution-quick-ref/SKILL.md +374 -0
  157. package/.claude/skills/devflow-file-standards/SKILL.md +353 -0
  158. package/.claude/skills/devflow-tdd-enforcer/SKILL.md +192 -0
  159. package/.claude/skills/skill-developer/ADVANCED.md +197 -0
  160. package/.claude/skills/skill-developer/HOOK_MECHANISMS.md +306 -0
  161. package/.claude/skills/skill-developer/PATTERNS_LIBRARY.md +152 -0
  162. package/.claude/skills/skill-developer/SKILL.md +426 -0
  163. package/.claude/skills/skill-developer/SKILL_RULES_REFERENCE.md +315 -0
  164. package/.claude/skills/skill-developer/TRIGGER_TYPES.md +305 -0
  165. package/.claude/skills/skill-developer/TROUBLESHOOTING.md +514 -0
  166. package/.claude/skills/skill-rules.json +213 -0
  167. package/.claude/tests/README.md +300 -0
  168. package/.claude/tests/TODO.md +69 -0
  169. package/.claude/tests/__pycache__/test_analyze_upgrade_impact.cpython-311-pytest-7.2.2.pyc +0 -0
  170. package/.claude/tests/__pycache__/test_consolidate_research.cpython-311-pytest-7.2.2.pyc +0 -0
  171. package/.claude/tests/__pycache__/test_export_contracts.cpython-311-pytest-7.2.2.pyc +0 -0
  172. package/.claude/tests/__pycache__/test_extract_data_model.cpython-311-pytest-7.2.2.pyc +0 -0
  173. package/.claude/tests/__pycache__/test_generate_quickstart.cpython-311-pytest-7.2.2.pyc +0 -0
  174. package/.claude/tests/__pycache__/test_generate_research_tasks.cpython-311-pytest-7.2.2.pyc +0 -0
  175. package/.claude/tests/constitution/run_all_constitution_tests.sh +111 -0
  176. package/.claude/tests/constitution/test_agent_assignment.sh +207 -0
  177. package/.claude/tests/constitution/test_article_coverage.sh +201 -0
  178. package/.claude/tests/constitution/test_template_completeness.sh +150 -0
  179. package/.claude/tests/constitution/test_version_consistency.sh +120 -0
  180. package/.claude/tests/fixtures/spec_delta_full.md +16 -0
  181. package/.claude/tests/fixtures/tasks_progress_sample.md +5 -0
  182. package/.claude/tests/run-all-tests.sh +229 -0
  183. package/.claude/tests/scripts/run.sh +30 -0
  184. package/.claude/tests/scripts/test-framework.sh +128 -0
  185. package/.claude/tests/scripts/test_check_prerequisites.sh +511 -0
  186. package/.claude/tests/scripts/test_check_prerequisites.sh.bak +504 -0
  187. package/.claude/tests/scripts/test_check_prerequisites.sh.bak2 +505 -0
  188. package/.claude/tests/scripts/test_check_prerequisites.sh.bak3 +506 -0
  189. package/.claude/tests/scripts/test_check_prerequisites.sh.bak4 +507 -0
  190. package/.claude/tests/scripts/test_check_prerequisites.sh.bak5 +508 -0
  191. package/.claude/tests/scripts/test_check_task_status.sh +499 -0
  192. package/.claude/tests/scripts/test_common.sh +244 -0
  193. package/.claude/tests/scripts/test_generate_status_report.sh +71 -0
  194. package/.claude/tests/scripts/test_mark_task_complete.sh +441 -0
  195. package/.claude/tests/scripts/test_mark_task_complete.sh.backup +410 -0
  196. package/.claude/tests/scripts/test_recover_workflow.sh +304 -0
  197. package/.claude/tests/scripts/test_setup_epic.sh +437 -0
  198. package/.claude/tests/scripts/test_sync_task_marks.sh +196 -0
  199. package/.claude/tests/scripts/test_validate_constitution.sh +74 -0
  200. package/.claude/tests/scripts/test_validate_research.sh +462 -0
  201. package/.claude/tests/slugify.bats +82 -0
  202. package/.claude/tests/test-framework.sh +732 -0
  203. package/.claude/tests/test_analyze_upgrade_impact.py +34 -0
  204. package/.claude/tests/test_consolidate_research.py +48 -0
  205. package/.claude/tests/test_export_contracts.py +43 -0
  206. package/.claude/tests/test_extract_data_model.py +33 -0
  207. package/.claude/tests/test_generate_quickstart.py +50 -0
  208. package/.claude/tests/test_generate_research_tasks.py +52 -0
  209. package/.claude/tsc-cache/6e64f818-6398-49ca-8623-581a9af85c44/edited-files.log +1 -0
  210. package/.claude/tsc-cache/795ba6e3-b98a-423b-bab2-51aa62812569/affected-repos.txt +1 -0
  211. package/.claude/tsc-cache/795ba6e3-b98a-423b-bab2-51aa62812569/edited-files.log +1 -0
  212. package/.claude/tsc-cache/ae335694-be5a-4ba4-a1a0-b676c09a7906/affected-repos.txt +1 -0
  213. package/.claude/tsc-cache/ae335694-be5a-4ba4-a1a0-b676c09a7906/edited-files.log +1 -0
  214. package/CHANGELOG.md +507 -0
  215. package/LICENSE +21 -0
  216. package/README.md +534 -0
  217. package/README.zh-CN.md +530 -0
  218. package/bin/adapt.js +240 -0
  219. package/bin/cc-devflow-cli.js +185 -0
  220. package/bin/cc-devflow.js +78 -0
  221. package/config/adapters.yml +5 -0
  222. package/config/schema/adapters.schema.json +44 -0
  223. package/docs/CLAUDE.md +26 -0
  224. package/docs/commands/README.md +61 -0
  225. package/docs/commands/README.zh-CN.md +55 -0
  226. package/docs/commands/core-roadmap.md +106 -0
  227. package/docs/commands/core-roadmap.zh-CN.md +102 -0
  228. package/docs/commands/core-style.md +405 -0
  229. package/docs/commands/core-style.zh-CN.md +405 -0
  230. package/docs/commands/flow-init.md +134 -0
  231. package/docs/commands/flow-init.zh-CN.md +163 -0
  232. package/docs/commands/flow-new.md +274 -0
  233. package/docs/commands/flow-new.zh-CN.md +270 -0
  234. package/docs/guides/getting-started.md +204 -0
  235. package/docs/guides/getting-started.zh-CN.md +152 -0
  236. package/lib/adapters/adapter-interface.js +57 -0
  237. package/lib/adapters/claude-adapter.js +74 -0
  238. package/lib/adapters/codex-adapter.js +40 -0
  239. package/lib/adapters/config-validator.js +68 -0
  240. package/lib/adapters/logger.js +42 -0
  241. package/lib/adapters/registry.js +153 -0
  242. package/lib/compiler/CLAUDE.md +92 -0
  243. package/lib/compiler/__tests__/drift.test.js +215 -0
  244. package/lib/compiler/__tests__/errors.test.js +184 -0
  245. package/lib/compiler/__tests__/incremental.test.js +174 -0
  246. package/lib/compiler/__tests__/integration.test.js +174 -0
  247. package/lib/compiler/__tests__/manifest.test.js +233 -0
  248. package/lib/compiler/__tests__/parser.test.js +456 -0
  249. package/lib/compiler/__tests__/schemas.test.js +301 -0
  250. package/lib/compiler/__tests__/skills-registry.test.js +125 -0
  251. package/lib/compiler/__tests__/transformer.test.js +286 -0
  252. package/lib/compiler/emitters/antigravity-emitter.js +171 -0
  253. package/lib/compiler/emitters/base-emitter.js +73 -0
  254. package/lib/compiler/emitters/codex-emitter.js +52 -0
  255. package/lib/compiler/emitters/cursor-emitter.js +31 -0
  256. package/lib/compiler/emitters/index.js +50 -0
  257. package/lib/compiler/emitters/qwen-emitter.js +39 -0
  258. package/lib/compiler/errors.js +119 -0
  259. package/lib/compiler/index.js +256 -0
  260. package/lib/compiler/manifest.js +242 -0
  261. package/lib/compiler/parser.js +258 -0
  262. package/lib/compiler/platforms.js +113 -0
  263. package/lib/compiler/resource-copier.js +320 -0
  264. package/lib/compiler/rules-emitters/__tests__/antigravity-rules-emitter.test.js +191 -0
  265. package/lib/compiler/rules-emitters/__tests__/codex-rules-emitter.test.js +109 -0
  266. package/lib/compiler/rules-emitters/__tests__/cursor-rules-emitter.test.js +123 -0
  267. package/lib/compiler/rules-emitters/__tests__/qwen-rules-emitter.test.js +123 -0
  268. package/lib/compiler/rules-emitters/antigravity-rules-emitter.js +253 -0
  269. package/lib/compiler/rules-emitters/base-rules-emitter.js +83 -0
  270. package/lib/compiler/rules-emitters/codex-rules-emitter.js +116 -0
  271. package/lib/compiler/rules-emitters/cursor-rules-emitter.js +98 -0
  272. package/lib/compiler/rules-emitters/index.js +71 -0
  273. package/lib/compiler/rules-emitters/qwen-rules-emitter.js +70 -0
  274. package/lib/compiler/schemas.js +144 -0
  275. package/lib/compiler/skills-registry.js +225 -0
  276. package/lib/compiler/transformer.js +236 -0
  277. package/package.json +50 -0
@@ -0,0 +1,418 @@
1
+ # TypeScript Standards
2
+
3
+ TypeScript best practices for type safety and maintainability in React frontend code.
4
+
5
+ ---
6
+
7
+ ## Strict Mode
8
+
9
+ ### Configuration
10
+
11
+ TypeScript strict mode is **enabled** in the project:
12
+
13
+ ```json
14
+ // tsconfig.json
15
+ {
16
+ "compilerOptions": {
17
+ "strict": true,
18
+ "noImplicitAny": true,
19
+ "strictNullChecks": true
20
+ }
21
+ }
22
+ ```
23
+
24
+ **This means:**
25
+ - No implicit `any` types
26
+ - Null/undefined must be handled explicitly
27
+ - Type safety enforced
28
+
29
+ ---
30
+
31
+ ## No `any` Type
32
+
33
+ ### The Rule
34
+
35
+ ```typescript
36
+ // ❌ NEVER use any
37
+ function handleData(data: any) {
38
+ return data.something;
39
+ }
40
+
41
+ // ✅ Use specific types
42
+ interface MyData {
43
+ something: string;
44
+ }
45
+
46
+ function handleData(data: MyData) {
47
+ return data.something;
48
+ }
49
+
50
+ // ✅ Or use unknown for truly unknown data
51
+ function handleUnknown(data: unknown) {
52
+ if (typeof data === 'object' && data !== null && 'something' in data) {
53
+ return (data as MyData).something;
54
+ }
55
+ }
56
+ ```
57
+
58
+ **If you truly don't know the type:**
59
+ - Use `unknown` (forces type checking)
60
+ - Use type guards to narrow
61
+ - Document why type is unknown
62
+
63
+ ---
64
+
65
+ ## Explicit Return Types
66
+
67
+ ### Function Return Types
68
+
69
+ ```typescript
70
+ // ✅ CORRECT - Explicit return type
71
+ function getUser(id: number): Promise<User> {
72
+ return apiClient.get(`/users/${id}`);
73
+ }
74
+
75
+ function calculateTotal(items: Item[]): number {
76
+ return items.reduce((sum, item) => sum + item.price, 0);
77
+ }
78
+
79
+ // ❌ AVOID - Implicit return type (less clear)
80
+ function getUser(id: number) {
81
+ return apiClient.get(`/users/${id}`);
82
+ }
83
+ ```
84
+
85
+ ### Component Return Types
86
+
87
+ ```typescript
88
+ // React.FC already provides return type (ReactElement)
89
+ export const MyComponent: React.FC<Props> = ({ prop }) => {
90
+ return <div>{prop}</div>;
91
+ };
92
+
93
+ // For custom hooks
94
+ function useMyData(id: number): { data: Data; isLoading: boolean } {
95
+ const [data, setData] = useState<Data | null>(null);
96
+ const [isLoading, setIsLoading] = useState(true);
97
+
98
+ return { data: data!, isLoading };
99
+ }
100
+ ```
101
+
102
+ ---
103
+
104
+ ## Type Imports
105
+
106
+ ### Use 'type' Keyword
107
+
108
+ ```typescript
109
+ // ✅ CORRECT - Explicitly mark as type import
110
+ import type { User } from '~types/user';
111
+ import type { Post } from '~types/post';
112
+ import type { SxProps, Theme } from '@mui/material';
113
+
114
+ // ❌ AVOID - Mixed value and type imports
115
+ import { User } from '~types/user'; // Unclear if type or value
116
+ ```
117
+
118
+ **Benefits:**
119
+ - Clearly separates types from values
120
+ - Better tree-shaking
121
+ - Prevents circular dependencies
122
+ - TypeScript compiler optimization
123
+
124
+ ---
125
+
126
+ ## Component Prop Interfaces
127
+
128
+ ### Interface Pattern
129
+
130
+ ```typescript
131
+ /**
132
+ * Props for MyComponent
133
+ */
134
+ interface MyComponentProps {
135
+ /** The user ID to display */
136
+ userId: number;
137
+
138
+ /** Optional callback when action completes */
139
+ onComplete?: () => void;
140
+
141
+ /** Display mode for the component */
142
+ mode?: 'view' | 'edit';
143
+
144
+ /** Additional CSS classes */
145
+ className?: string;
146
+ }
147
+
148
+ export const MyComponent: React.FC<MyComponentProps> = ({
149
+ userId,
150
+ onComplete,
151
+ mode = 'view', // Default value
152
+ className,
153
+ }) => {
154
+ return <div>...</div>;
155
+ };
156
+ ```
157
+
158
+ **Key Points:**
159
+ - Separate interface for props
160
+ - JSDoc comments for each prop
161
+ - Optional props use `?`
162
+ - Provide defaults in destructuring
163
+
164
+ ### Props with Children
165
+
166
+ ```typescript
167
+ interface ContainerProps {
168
+ children: React.ReactNode;
169
+ title: string;
170
+ }
171
+
172
+ // React.FC automatically includes children type, but be explicit
173
+ export const Container: React.FC<ContainerProps> = ({ children, title }) => {
174
+ return (
175
+ <div>
176
+ <h2>{title}</h2>
177
+ {children}
178
+ </div>
179
+ );
180
+ };
181
+ ```
182
+
183
+ ---
184
+
185
+ ## Utility Types
186
+
187
+ ### Partial<T>
188
+
189
+ ```typescript
190
+ // Make all properties optional
191
+ type UserUpdate = Partial<User>;
192
+
193
+ function updateUser(id: number, updates: Partial<User>) {
194
+ // updates can have any subset of User properties
195
+ }
196
+ ```
197
+
198
+ ### Pick<T, K>
199
+
200
+ ```typescript
201
+ // Select specific properties
202
+ type UserPreview = Pick<User, 'id' | 'name' | 'email'>;
203
+
204
+ const preview: UserPreview = {
205
+ id: 1,
206
+ name: 'John',
207
+ email: 'john@example.com',
208
+ // Other User properties not allowed
209
+ };
210
+ ```
211
+
212
+ ### Omit<T, K>
213
+
214
+ ```typescript
215
+ // Exclude specific properties
216
+ type UserWithoutPassword = Omit<User, 'password' | 'passwordHash'>;
217
+
218
+ const publicUser: UserWithoutPassword = {
219
+ id: 1,
220
+ name: 'John',
221
+ email: 'john@example.com',
222
+ // password and passwordHash not allowed
223
+ };
224
+ ```
225
+
226
+ ### Required<T>
227
+
228
+ ```typescript
229
+ // Make all properties required
230
+ type RequiredConfig = Required<Config>; // All optional props become required
231
+ ```
232
+
233
+ ### Record<K, V>
234
+
235
+ ```typescript
236
+ // Type-safe object/map
237
+ const userMap: Record<string, User> = {
238
+ 'user1': { id: 1, name: 'John' },
239
+ 'user2': { id: 2, name: 'Jane' },
240
+ };
241
+
242
+ // For styles
243
+ import type { SxProps, Theme } from '@mui/material';
244
+
245
+ const styles: Record<string, SxProps<Theme>> = {
246
+ container: { p: 2 },
247
+ header: { mb: 1 },
248
+ };
249
+ ```
250
+
251
+ ---
252
+
253
+ ## Type Guards
254
+
255
+ ### Basic Type Guards
256
+
257
+ ```typescript
258
+ function isUser(data: unknown): data is User {
259
+ return (
260
+ typeof data === 'object' &&
261
+ data !== null &&
262
+ 'id' in data &&
263
+ 'name' in data
264
+ );
265
+ }
266
+
267
+ // Usage
268
+ if (isUser(response)) {
269
+ console.log(response.name); // TypeScript knows it's User
270
+ }
271
+ ```
272
+
273
+ ### Discriminated Unions
274
+
275
+ ```typescript
276
+ type LoadingState =
277
+ | { status: 'idle' }
278
+ | { status: 'loading' }
279
+ | { status: 'success'; data: Data }
280
+ | { status: 'error'; error: Error };
281
+
282
+ function Component({ state }: { state: LoadingState }) {
283
+ // TypeScript narrows type based on status
284
+ if (state.status === 'success') {
285
+ return <Display data={state.data} />; // data available here
286
+ }
287
+
288
+ if (state.status === 'error') {
289
+ return <Error error={state.error} />; // error available here
290
+ }
291
+
292
+ return <Loading />;
293
+ }
294
+ ```
295
+
296
+ ---
297
+
298
+ ## Generic Types
299
+
300
+ ### Generic Functions
301
+
302
+ ```typescript
303
+ function getById<T>(items: T[], id: number): T | undefined {
304
+ return items.find(item => (item as any).id === id);
305
+ }
306
+
307
+ // Usage with type inference
308
+ const users: User[] = [...];
309
+ const user = getById(users, 123); // Type: User | undefined
310
+ ```
311
+
312
+ ### Generic Components
313
+
314
+ ```typescript
315
+ interface ListProps<T> {
316
+ items: T[];
317
+ renderItem: (item: T) => React.ReactNode;
318
+ }
319
+
320
+ export function List<T>({ items, renderItem }: ListProps<T>): React.ReactElement {
321
+ return (
322
+ <div>
323
+ {items.map((item, index) => (
324
+ <div key={index}>{renderItem(item)}</div>
325
+ ))}
326
+ </div>
327
+ );
328
+ }
329
+
330
+ // Usage
331
+ <List<User>
332
+ items={users}
333
+ renderItem={(user) => <UserCard user={user} />}
334
+ />
335
+ ```
336
+
337
+ ---
338
+
339
+ ## Type Assertions (Use Sparingly)
340
+
341
+ ### When to Use
342
+
343
+ ```typescript
344
+ // ✅ OK - When you know more than TypeScript
345
+ const element = document.getElementById('my-element') as HTMLInputElement;
346
+ const value = element.value;
347
+
348
+ // ✅ OK - API response that you've validated
349
+ const response = await api.getData();
350
+ const user = response.data as User; // You know the shape
351
+ ```
352
+
353
+ ### When NOT to Use
354
+
355
+ ```typescript
356
+ // ❌ AVOID - Circumventing type safety
357
+ const data = getData() as any; // WRONG - defeats TypeScript
358
+
359
+ // ❌ AVOID - Unsafe assertion
360
+ const value = unknownValue as string; // Might not actually be string
361
+ ```
362
+
363
+ ---
364
+
365
+ ## Null/Undefined Handling
366
+
367
+ ### Optional Chaining
368
+
369
+ ```typescript
370
+ // ✅ CORRECT
371
+ const name = user?.profile?.name;
372
+
373
+ // Equivalent to:
374
+ const name = user && user.profile && user.profile.name;
375
+ ```
376
+
377
+ ### Nullish Coalescing
378
+
379
+ ```typescript
380
+ // ✅ CORRECT
381
+ const displayName = user?.name ?? 'Anonymous';
382
+
383
+ // Only uses default if null or undefined
384
+ // (Different from || which triggers on '', 0, false)
385
+ ```
386
+
387
+ ### Non-Null Assertion (Use Carefully)
388
+
389
+ ```typescript
390
+ // ✅ OK - When you're certain value exists
391
+ const data = queryClient.getQueryData<Data>(['data'])!;
392
+
393
+ // ⚠️ CAREFUL - Only use when you KNOW it's not null
394
+ // Better to check explicitly:
395
+ const data = queryClient.getQueryData<Data>(['data']);
396
+ if (data) {
397
+ // Use data
398
+ }
399
+ ```
400
+
401
+ ---
402
+
403
+ ## Summary
404
+
405
+ **TypeScript Checklist:**
406
+ - ✅ Strict mode enabled
407
+ - ✅ No `any` type (use `unknown` if needed)
408
+ - ✅ Explicit return types on functions
409
+ - ✅ Use `import type` for type imports
410
+ - ✅ JSDoc comments on prop interfaces
411
+ - ✅ Utility types (Partial, Pick, Omit, Required, Record)
412
+ - ✅ Type guards for narrowing
413
+ - ✅ Optional chaining and nullish coalescing
414
+ - ❌ Avoid type assertions unless necessary
415
+
416
+ **See Also:**
417
+ - [component-patterns.md](component-patterns.md) - Component typing
418
+ - [data-fetching.md](data-fetching.md) - API typing
@@ -0,0 +1,229 @@
1
+ ---
2
+ name: cc-devflow-orchestrator
3
+ description: CC-DevFlow workflow router and agent recommender. Use when starting requirements, running flow commands, or asking about devflow processes.
4
+ ---
5
+
6
+ # CC-DevFlow Orchestrator
7
+
8
+ ## Purpose
9
+ Guide users to the correct agent/command WITHOUT duplicating their detailed standards.
10
+
11
+ ## Workflow Map
12
+
13
+ ### 🏢 项目级工作流(Project-Level, 项目初期执行一次)
14
+
15
+ ```
16
+ /core-roadmap → ROADMAP.md + BACKLOG.md (产品路线图)
17
+ /core-architecture → ARCHITECTURE.md (系统架构设计)
18
+ /core-guidelines → frontend-guidelines.md / backend-guidelines.md (项目规范)
19
+ /core-style → STYLE.md (设计风格指南) ⭐ 新增
20
+ ```
21
+
22
+ ### 📦 需求级工作流(Requirement-Level, 每个需求执行一次)
23
+
24
+ ```
25
+ /flow-init → research.md + tasks.json (研究初始化)
26
+
27
+ /flow-clarify → clarifications/*.md (11 维度歧义扫描, 可选) ⭐ 新增
28
+
29
+ /flow-prd → PRD.md (invoke prd-writer agent)
30
+
31
+ /flow-checklist → checklists/*.md (需求质量检查, 可选) ⭐ 新增
32
+
33
+ /flow-tech → TECH_DESIGN.md + data-model + contracts (invoke tech-architect agent)
34
+
35
+ /flow-ui → UI_PROTOTYPE.html (invoke ui-designer agent, 可选, 引用 STYLE.md) ⭐ 变更
36
+
37
+ /flow-epic → EPIC.md + TASKS.md (invoke planner agent with PRD+TECH+UI)
38
+
39
+ /flow-dev → TASKS.md execution (TDD order enforced, 引用 STYLE.md) ⭐ 变更
40
+
41
+ /flow-qa → QA reports (invoke qa-tester + security-reviewer agents)
42
+
43
+ /flow-release → PR creation + deployment
44
+
45
+ /flow-verify → consistency check (invoke consistency-checker agent, 任意阶段可调用)
46
+ ```
47
+
48
+ **说明**:
49
+ - 项目级命令建立全局标准(SSOT),需求级命令引用这些标准
50
+ - `/flow-clarify` 在 PRD 前可选执行,消除 research.md 中的歧义
51
+ - `/flow-ui` 和 `/flow-dev` 自动加载 `devflow/STYLE.md`(如存在)
52
+ - 项目级命令可按需执行,无严格顺序要求
53
+
54
+ ## Agent Delegation Guide
55
+
56
+ ### When User Asks About Requirements Clarification
57
+ - **DO**: Recommend `/flow-clarify` command → invokes clarify-analyst agent
58
+ - **DON'T**: Duplicate clarification logic (flow-clarify.md has ~128 lines)
59
+ - **Link**: See [.claude/commands/flow-clarify.md](.claude/commands/flow-clarify.md) for details
60
+ - **Outputs**: clarifications/[timestamp]-flow-clarify.md (澄清报告)
61
+ - **Features**: 11-dimension scan, ≤5 prioritized questions, session recovery
62
+
63
+ ### When User Asks About PRD
64
+ - **DO**: Recommend `/flow-prd` command → invokes prd-writer agent
65
+ - **DON'T**: Duplicate PRD standards (prd-writer agent has ~300 lines)
66
+ - **Link**: See [.claude/agents/prd-writer.md](.claude/agents/prd-writer.md) for PRD details
67
+ - **Standards**: INVEST principles, Anti-Expansion mandate, Given-When-Then criteria
68
+
69
+ ### When User Asks About Requirement Quality Checklist
70
+ - **DO**: Recommend `/flow-checklist` command → invokes checklist-agent
71
+ - **DON'T**: Duplicate checklist standards (checklist-agent has ~180 lines)
72
+ - **Link**: See [.claude/commands/flow-checklist.md](.claude/commands/flow-checklist.md) for details
73
+ - **Outputs**: checklists/*.md (ux, api, security, performance, data, general)
74
+ - **Features**: 5 quality dimensions, Anti-Example rules, 80% gate threshold
75
+ - **Level**: Requirement-level (optional, before /flow-epic)
76
+
77
+ ### When User Asks About Tech Design
78
+ - **DO**: Recommend `/flow-tech` command → invokes tech-architect agent
79
+ - **DON'T**: Duplicate tech standards (tech-architect agent has ~516 lines)
80
+ - **Link**: See [.claude/agents/tech-architect.md](.claude/agents/tech-architect.md) for design details
81
+ - **Outputs**: TECH_DESIGN.md, data-model.md, contracts/, quickstart.md
82
+
83
+ ### When User Asks About Design Style Guide
84
+ - **DO**: Recommend `/core-style` command → invokes style-guide-generator agent
85
+ - **DON'T**: Duplicate style guide standards (style-guide-generator agent has ~400 lines)
86
+ - **Link**: See [.claude/agents/style-guide-generator.md](.claude/agents/style-guide-generator.md) for details
87
+ - **Outputs**: STYLE.md (project-level SSOT for visual consistency)
88
+ - **Level**: Project-level (execute once per project)
89
+
90
+ ### When User Asks About UI Prototype
91
+ - **DO**: Recommend `/flow-ui` command → invokes ui-designer agent
92
+ - **DON'T**: Duplicate UI standards (ui-designer agent has ~485 lines)
93
+ - **Link**: See [.claude/agents/ui-designer.md](.claude/agents/ui-designer.md) for UI details
94
+ - **Features**: 80+ design masters sampling, responsive design, NO PLACEHOLDER, references STYLE.md
95
+
96
+ ### When User Asks About Task Planning
97
+ - **DO**: Recommend `/flow-epic` command → invokes planner agent
98
+ - **DON'T**: Duplicate planning logic (planner agent has ~400 lines)
99
+ - **Link**: See [.claude/agents/planner.md](.claude/agents/planner.md) for task breakdown rules
100
+ - **Enforces**: Phase -1 Gates (Articles VII, VIII, IX), TDD sequence
101
+
102
+ ### When User Asks About QA/Security
103
+ - **DO**: Recommend `/flow-qa` command → invokes qa-tester + security-reviewer agents
104
+ - **DON'T**: Duplicate QA standards (qa-tester agent has ~300 lines)
105
+ - **Link**: See [.claude/agents/qa-tester.md](.claude/agents/qa-tester.md) for QA details
106
+
107
+ ## Phase Gates (Quick Reference Only)
108
+
109
+ ### Entry Gates
110
+ - **flow-clarify Entry**: research.md 存在, phase0_complete == true
111
+ - **flow-prd Entry**: research.md 无 TODO placeholder, phase0_complete == true (clarify 可选)
112
+ - **flow-checklist Entry**: PRD.md 必须完成 (prd_complete == true)
113
+ - **flow-tech Entry**: PRD.md 必须完成
114
+ - **flow-ui Entry**: PRD.md 必须完成(可与 tech 并行)
115
+ - **flow-epic Entry**: PRD 完成,tech/ui 推荐但可选,Checklist Gate (如存在 checklists/)
116
+ - **flow-dev Entry**: EPIC.md + TASKS.md 存在
117
+ - **flow-qa Entry**: development_complete == true
118
+
119
+ ### Exit Gates
120
+ - **flow-init Exit**: research.md 5-level quality check
121
+ - **flow-clarify Exit**: clarification report 完整, orchestration_status.clarify_complete == true
122
+ - **flow-prd Exit**: PRD.md 无 placeholder, Constitution 合规
123
+ - **flow-tech Exit**: TECH_DESIGN.md + data-model + contracts 完整
124
+ - **flow-epic Exit**: TASKS.md TDD 顺序正确, Phase -1 Gates 通过
125
+ - **flow-dev Exit**: 所有 TASKS 完成, 测试通过
126
+ - **flow-qa Exit**: 无 high-severity 漏洞
127
+
128
+ **For Details**: See [orchestration_status.json](devflow/requirements/REQ-XXX/orchestration_status.json) and [EXECUTION_LOG.md](devflow/requirements/REQ-XXX/EXECUTION_LOG.md)
129
+
130
+ ## State Machine: Status → Recommended Command
131
+
132
+ Read `orchestration_status.json` to determine current phase:
133
+
134
+ ```yaml
135
+ status: "initialized"
136
+ → Recommend: /flow-clarify (optional, clarify ambiguities)
137
+ → Alternative: /flow-prd (skip clarification, generate PRD directly)
138
+
139
+ status: "clarify_complete" OR "clarify_skipped"
140
+ → Recommend: /flow-prd (generate PRD)
141
+
142
+ status: "prd_complete"
143
+ → Recommend: /flow-tech (generate technical design)
144
+ → Alternative: /flow-ui (generate UI prototype, optional)
145
+
146
+ status: "tech_design_complete"
147
+ → If UI not done: /flow-ui (optional)
148
+ → Else: /flow-epic (generate EPIC and TASKS)
149
+
150
+ status: "epic_complete"
151
+ → Recommend: /flow-dev (start TDD development)
152
+
153
+ status: "development_complete"
154
+ → Recommend: /flow-qa (quality assurance and security review)
155
+
156
+ status: "qa_complete"
157
+ → Recommend: /flow-release (create PR and release)
158
+
159
+ status: "released"
160
+ → Recommend: /flow-verify (final consistency check)
161
+ ```
162
+
163
+ ## Troubleshooting Quick Routing
164
+
165
+ ### Phase gate blocked?
166
+ - **Action**: Check `orchestration_status.json` for current status
167
+ - **Script**: Run `.claude/scripts/check-prerequisites.sh --json`
168
+
169
+ ### Document missing?
170
+ - **Action**: Check which phase is incomplete
171
+ - **Script**: Run `.claude/scripts/generate-status-report.sh`
172
+
173
+ ### Need detailed standards?
174
+ - **Clarify**: See flow-clarify.md command + clarify-analyst agent
175
+ - **PRD**: Consult prd-writer agent
176
+ - **Tech**: Consult tech-architect agent
177
+ - **UI**: Consult ui-designer agent
178
+ - **Tasks**: Consult planner agent
179
+ - **QA**: Consult qa-tester agent
180
+
181
+ ### Constitution violation?
182
+ - **Real-time check**: constitution-guardian guardrail (PreToolUse hook)
183
+ - **Batch validation**: Run `.claude/scripts/validate-constitution.sh`
184
+ - **Reference**: See [.claude/constitution/project-constitution.md](.claude/constitution/project-constitution.md) v2.0.0
185
+
186
+ ### TDD order violated?
187
+ - **Real-time check**: devflow-tdd-enforcer guardrail (PreToolUse hook)
188
+ - **Manual check**: See TASKS.md, tests MUST be marked [x] before implementation
189
+
190
+ ## Auxiliary Commands
191
+
192
+ ### Status and Progress
193
+ - `/flow-status` - Query requirement progress
194
+ - `/flow-update "REQ-123" "T012"` - Update task completion
195
+ - `/flow-restart "REQ-123" --from=epic` - Resume interrupted workflow
196
+
197
+ ### Upgrade and Analysis
198
+ - `/flow-upgrade "REQ-123" --analyze` - PRD version upgrade impact analysis
199
+ - `/flow-constitution` - Constitution management
200
+ - `/flow-verify "REQ-123"` - Comprehensive consistency verification
201
+
202
+ ### Bug Fix
203
+ - `/flow-fix "BUG-123|登录超时"` - One-shot BUG fix workflow
204
+ - `/problem-analyzer "<issue>"` - Problem diagnosis
205
+
206
+ ### Code Review
207
+ - `/code-review-high "<diff>"` - High-rigor code review
208
+
209
+ ## Integration with Other Skills
210
+
211
+ - **devflow-tdd-enforcer**: Enforces TDD order in TASKS.md (Guardrail, blocks)
212
+ - **constitution-guardian**: Enforces Constitution compliance (Guardrail, blocks)
213
+ - **devflow-file-standards**: File naming and directory structure reference
214
+ - **devflow-constitution-quick-ref**: Constitution quick reference
215
+
216
+ ## Design Principle
217
+
218
+ **This skill does NOT contain**:
219
+ - ❌ Detailed agent execution standards (those are in agent files)
220
+ - ❌ Full Phase Gate validation logic (those are in flow command files)
221
+ - ❌ Complete Constitution articles (those are in project-constitution.md)
222
+
223
+ **This skill ONLY contains**:
224
+ - ✅ Workflow routing (which command to run next)
225
+ - ✅ Agent delegation (which agent handles what)
226
+ - ✅ Quick reference (Phase Gates summary, not full details)
227
+ - ✅ Links to detailed documentation
228
+
229
+ **Rationale**: Avoid duplication ("不重不漏" principle). Agents and Commands own detailed standards.