cc-devflow 4.2.0 → 4.4.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.
- package/.claude/skills/cc-act/CHANGELOG.md +64 -0
- package/.claude/skills/cc-act/PLAYBOOK.md +212 -0
- package/.claude/skills/cc-act/SKILL.md +322 -0
- package/.claude/skills/cc-act/assets/PR_BRIEF_TEMPLATE.md +64 -0
- package/.claude/skills/cc-act/assets/RELEASE_NOTE_TEMPLATE.md +25 -0
- package/.claude/skills/cc-act/references/closure-contract.md +49 -0
- package/.claude/skills/cc-act/references/git-commit-guidelines.md +83 -0
- package/.claude/skills/cc-act/scripts/archive-requirement.sh +49 -0
- package/.claude/skills/cc-act/scripts/cc-act-common.sh +240 -0
- package/.claude/skills/cc-act/scripts/detect-ship-target.sh +82 -0
- package/.claude/skills/cc-act/scripts/generate-status-report.sh +83 -0
- package/.claude/skills/cc-act/scripts/render-pr-brief.sh +195 -0
- package/.claude/skills/cc-act/scripts/sync-act-docs.sh +315 -0
- package/.claude/skills/cc-act/scripts/verify-act-gate.sh +63 -0
- package/.claude/skills/cc-check/CHANGELOG.md +73 -0
- package/.claude/skills/cc-check/PLAYBOOK.md +153 -0
- package/.claude/skills/cc-check/SKILL.md +345 -0
- package/.claude/skills/cc-check/assets/REPORT_CARD_TEMPLATE.json +50 -0
- package/.claude/skills/cc-check/references/gate-contract.md +29 -0
- package/.claude/skills/cc-check/references/review-contract.md +45 -0
- package/.claude/skills/cc-check/scripts/render-report-card.js +229 -0
- package/.claude/skills/cc-check/scripts/run-quality-gates.sh +86 -0
- package/.claude/skills/cc-check/scripts/verify-gate.sh +57 -0
- package/.claude/skills/cc-do/CHANGELOG.md +49 -0
- package/.claude/skills/cc-do/PLAYBOOK.md +119 -0
- package/.claude/skills/cc-do/SKILL.md +216 -0
- package/.claude/skills/cc-do/references/execution-recovery.md +86 -0
- package/.claude/skills/cc-do/references/parallel-dispatch.md +80 -0
- package/.claude/skills/cc-do/scripts/build-task-context.sh +184 -0
- package/.claude/skills/cc-do/scripts/cc-do-common.sh +79 -0
- package/.claude/skills/cc-do/scripts/check-task-status.sh +92 -0
- package/.claude/skills/cc-do/scripts/detect-file-conflicts.sh +87 -0
- package/.claude/skills/cc-do/scripts/mark-task-complete.sh +119 -0
- package/.claude/skills/cc-do/scripts/record-review-decision.sh +89 -0
- package/.claude/skills/cc-do/scripts/recover-workflow.sh +84 -0
- package/.claude/skills/cc-do/scripts/run-problem-analysis.sh +70 -0
- package/.claude/skills/cc-do/scripts/select-ready-tasks.sh +135 -0
- package/.claude/skills/cc-do/scripts/verify-task-gates.sh +94 -0
- package/.claude/skills/cc-do/scripts/write-task-checkpoint.sh +102 -0
- package/.claude/skills/cc-investigate/CHANGELOG.md +26 -0
- package/.claude/skills/cc-investigate/PLAYBOOK.md +49 -0
- package/.claude/skills/cc-investigate/SKILL.md +221 -0
- package/.claude/skills/cc-investigate/assets/ANALYSIS_TEMPLATE.md +55 -0
- package/.claude/skills/cc-investigate/assets/TASKS_TEMPLATE.md +52 -0
- package/.claude/skills/cc-investigate/assets/TASK_MANIFEST_TEMPLATE.json +103 -0
- package/.claude/skills/cc-investigate/references/investigation-contract.md +28 -0
- package/.claude/skills/cc-investigate/scripts/bootstrap-analysis.sh +38 -0
- package/.claude/skills/cc-plan/CHANGELOG.md +99 -0
- package/.claude/skills/cc-plan/PLAYBOOK.md +106 -0
- package/.claude/skills/cc-plan/SKILL.md +325 -0
- package/.claude/skills/cc-plan/assets/DESIGN_TEMPLATE.md +155 -0
- package/.claude/skills/cc-plan/assets/TASKS_TEMPLATE.md +98 -0
- package/.claude/skills/cc-plan/assets/TASK_MANIFEST_TEMPLATE.json +108 -0
- package/.claude/skills/cc-plan/assets/TINY_DESIGN_TEMPLATE.md +79 -0
- package/.claude/skills/cc-plan/references/planning-contract.md +82 -0
- package/.claude/skills/cc-plan/scripts/bump-skill-version.sh +103 -0
- package/.claude/skills/cc-plan/scripts/parse-task-dependencies.js +75 -0
- package/.claude/skills/cc-plan/scripts/validate-scope.sh +78 -0
- package/.claude/skills/cc-roadmap/CHANGELOG.md +114 -0
- package/.claude/skills/cc-roadmap/PLAYBOOK.md +136 -0
- package/.claude/skills/cc-roadmap/SKILL.md +259 -0
- package/.claude/skills/cc-roadmap/assets/BACKLOG_TEMPLATE.md +45 -0
- package/.claude/skills/cc-roadmap/assets/ROADMAP_TEMPLATE.md +153 -0
- package/.claude/skills/cc-roadmap/assets/TRACKING_TEMPLATE.json +48 -0
- package/.claude/skills/cc-roadmap/references/roadmap-dialogue.md +37 -0
- package/.claude/skills/cc-roadmap/scripts/bump-skill-version.sh +103 -0
- package/.claude/skills/cc-roadmap/scripts/lib/roadmap-tracking/markdown.js +604 -0
- package/.claude/skills/cc-roadmap/scripts/lib/roadmap-tracking/query.js +63 -0
- package/.claude/skills/cc-roadmap/scripts/lib/roadmap-tracking/schema.js +245 -0
- package/.claude/skills/cc-roadmap/scripts/lib/roadmap-tracking/store.js +139 -0
- package/.claude/skills/cc-roadmap/scripts/locate-roadmap-item.sh +109 -0
- package/.claude/skills/cc-roadmap/scripts/roadmap-tracking.js +153 -0
- package/.claude/skills/cc-roadmap/scripts/sync-roadmap-progress.sh +100 -0
- package/.claude/skills/cc-simplify/CHANGELOG.md +10 -0
- package/.claude/skills/cc-simplify/SKILL.md +55 -0
- package/.claude/skills/cc-spec-init/CHANGELOG.md +7 -0
- package/.claude/skills/cc-spec-init/PLAYBOOK.md +55 -0
- package/.claude/skills/cc-spec-init/SKILL.md +127 -0
- package/.claude/skills/cc-spec-init/assets/CAPABILITY_TEMPLATE.md +63 -0
- package/.claude/skills/cc-spec-init/assets/CHANGE_META_TEMPLATE.json +25 -0
- package/.claude/skills/cc-spec-init/assets/INDEX_TEMPLATE.md +34 -0
- package/.claude/skills/cc-spec-init/references/spec-contract.md +22 -0
- package/.claude/skills/cc-spec-init/scripts/bootstrap-specs.sh +31 -0
- package/.claude/skills/cc-spec-init/scripts/validate-spec-links.sh +45 -0
- package/CHANGELOG.md +101 -4
- package/README.md +120 -755
- package/README.zh-CN.md +119 -755
- package/bin/adapt.js +2 -6
- package/bin/cc-devflow-cli.js +72 -177
- package/config/distributable-skills.json +24 -0
- package/docs/CLAUDE.md +10 -6
- package/docs/commands/README.md +19 -46
- package/docs/commands/README.zh-CN.md +25 -48
- package/docs/examples/BY-ARTIFACT.md +7 -0
- package/docs/examples/README.md +38 -0
- package/docs/examples/START-HERE.md +149 -0
- package/docs/examples/example-bindings.json +38 -0
- package/docs/examples/full-design-blocked/BACKLOG.md +45 -0
- package/docs/examples/full-design-blocked/README.md +55 -0
- package/docs/examples/full-design-blocked/ROADMAP.md +53 -0
- package/docs/examples/full-design-blocked/changes/REQ-002-bulk-invite-import/planning/design.md +154 -0
- package/docs/examples/full-design-blocked/changes/REQ-002-bulk-invite-import/planning/task-manifest.json +146 -0
- package/docs/examples/full-design-blocked/changes/REQ-002-bulk-invite-import/planning/tasks.md +78 -0
- package/docs/examples/full-design-blocked/changes/REQ-002-bulk-invite-import/review/report-card.json +52 -0
- package/docs/examples/full-design-blocked/roadmap-tracking.json +50 -0
- package/docs/examples/local-handoff/BACKLOG.md +45 -0
- package/docs/examples/local-handoff/README.md +56 -0
- package/docs/examples/local-handoff/ROADMAP.md +45 -0
- package/docs/examples/local-handoff/changes/REQ-003-audit-log-export/handoff/resume-index.md +39 -0
- package/docs/examples/local-handoff/changes/REQ-003-audit-log-export/handoff/status.md +29 -0
- package/docs/examples/local-handoff/changes/REQ-003-audit-log-export/planning/design.md +71 -0
- package/docs/examples/local-handoff/changes/REQ-003-audit-log-export/planning/task-manifest.json +98 -0
- package/docs/examples/local-handoff/changes/REQ-003-audit-log-export/planning/tasks.md +59 -0
- package/docs/examples/local-handoff/changes/REQ-003-audit-log-export/review/report-card.json +44 -0
- package/docs/examples/local-handoff/roadmap-tracking.json +48 -0
- package/docs/examples/pdca-loop/BACKLOG.md +46 -0
- package/docs/examples/pdca-loop/README.md +58 -0
- package/docs/examples/pdca-loop/ROADMAP.md +133 -0
- package/docs/examples/pdca-loop/changes/REQ-001-copy-invite-link/handoff/pr-brief.md +72 -0
- package/docs/examples/pdca-loop/changes/REQ-001-copy-invite-link/handoff/status.md +29 -0
- package/docs/examples/pdca-loop/changes/REQ-001-copy-invite-link/planning/design.md +72 -0
- package/docs/examples/pdca-loop/changes/REQ-001-copy-invite-link/planning/task-manifest.json +201 -0
- package/docs/examples/pdca-loop/changes/REQ-001-copy-invite-link/planning/tasks.md +73 -0
- package/docs/examples/pdca-loop/changes/REQ-001-copy-invite-link/review/report-card.json +44 -0
- package/docs/examples/pdca-loop/roadmap-tracking.json +114 -0
- package/docs/examples/scripts/check-example-bindings.sh +116 -0
- package/docs/guides/getting-started.md +94 -129
- package/docs/guides/getting-started.zh-CN.md +103 -84
- package/docs/skill-runtime-migration.md +46 -0
- package/docs/v4.3.0-migration-guide.md +111 -0
- package/lib/compiler/CLAUDE.md +55 -84
- package/lib/compiler/__tests__/drift.test.js +1 -1
- package/lib/compiler/__tests__/errors.test.js +0 -1
- package/lib/compiler/__tests__/integration.test.js +49 -3
- package/lib/compiler/__tests__/manifest.test.js +0 -156
- package/lib/compiler/__tests__/parser.test.js +33 -104
- package/lib/compiler/__tests__/schemas.test.js +30 -34
- package/lib/compiler/__tests__/skills-registry.test.js +114 -0
- package/lib/compiler/__tests__/transformer.test.js +5 -9
- package/lib/compiler/emitters/antigravity-emitter.js +5 -213
- package/lib/compiler/emitters/base-emitter.js +3 -298
- package/lib/compiler/emitters/codex-emitter.js +4 -202
- package/lib/compiler/emitters/cursor-emitter.js +3 -287
- package/lib/compiler/emitters/qwen-emitter.js +4 -176
- package/lib/compiler/index.js +65 -345
- package/lib/compiler/manifest.js +6 -68
- package/lib/compiler/parser.js +31 -63
- package/lib/compiler/platforms.js +32 -277
- package/lib/compiler/resource-copier.js +176 -6
- package/lib/compiler/rules-emitters/__tests__/antigravity-rules-emitter.test.js +3 -3
- package/lib/compiler/rules-emitters/__tests__/cursor-rules-emitter.test.js +14 -4
- package/lib/compiler/rules-emitters/__tests__/qwen-rules-emitter.test.js +16 -7
- package/lib/compiler/rules-emitters/antigravity-rules-emitter.js +10 -15
- package/lib/compiler/rules-emitters/base-rules-emitter.js +5 -5
- package/lib/compiler/rules-emitters/cursor-rules-emitter.js +7 -12
- package/lib/compiler/rules-emitters/index.js +6 -3
- package/lib/compiler/rules-emitters/qwen-rules-emitter.js +7 -7
- package/lib/compiler/schemas.js +8 -4
- package/lib/compiler/skills-registry.js +213 -15
- package/lib/compiler/transformer.js +1 -1
- package/lib/skill-runtime/CLAUDE.md +19 -0
- package/lib/skill-runtime/__tests__/autopilot.test.js +210 -0
- package/lib/skill-runtime/__tests__/cli-bootstrap.integration.test.js +181 -0
- package/lib/skill-runtime/__tests__/delegation.test.js +97 -0
- package/lib/skill-runtime/__tests__/dispatch.test.js +267 -0
- package/lib/skill-runtime/__tests__/intent.test.js +219 -0
- package/lib/skill-runtime/__tests__/lifecycle.test.js +169 -0
- package/lib/skill-runtime/__tests__/paths.test.js +42 -0
- package/lib/skill-runtime/__tests__/planner.tdd.test.js +250 -0
- package/lib/skill-runtime/__tests__/prepare-pr.test.js +139 -0
- package/lib/skill-runtime/__tests__/query.test.js +284 -0
- package/lib/skill-runtime/__tests__/runtime.integration.test.js +279 -0
- package/lib/skill-runtime/__tests__/schemas.test.js +207 -0
- package/lib/skill-runtime/__tests__/team-state.test.js +51 -0
- package/lib/skill-runtime/__tests__/worker-run.test.js +253 -0
- package/lib/skill-runtime/__tests__/worker.test.js +56 -0
- package/lib/skill-runtime/artifacts.js +93 -0
- package/lib/skill-runtime/delegation.js +533 -0
- package/lib/skill-runtime/index.js +34 -0
- package/lib/skill-runtime/intent.js +333 -0
- package/lib/skill-runtime/lifecycle.js +294 -0
- package/lib/skill-runtime/operations/CLAUDE.md +19 -0
- package/lib/skill-runtime/operations/approve.js +66 -0
- package/lib/skill-runtime/operations/autopilot-core.js +337 -0
- package/lib/skill-runtime/operations/autopilot-execution.js +307 -0
- package/lib/skill-runtime/operations/autopilot-shared.js +48 -0
- package/lib/skill-runtime/operations/autopilot.js +163 -0
- package/lib/skill-runtime/operations/dispatch.js +454 -0
- package/lib/skill-runtime/operations/init.js +64 -0
- package/lib/{harness → skill-runtime}/operations/janitor.js +9 -6
- package/lib/skill-runtime/operations/plan.js +59 -0
- package/lib/skill-runtime/operations/prepare-pr.js +25 -0
- package/lib/{harness → skill-runtime}/operations/release.js +18 -5
- package/lib/skill-runtime/operations/resume.js +143 -0
- package/lib/skill-runtime/operations/snapshot.js +45 -0
- package/lib/skill-runtime/operations/verify.js +170 -0
- package/lib/skill-runtime/operations/worker-run.js +529 -0
- package/lib/skill-runtime/operations/worker.js +33 -0
- package/lib/skill-runtime/paths.js +213 -0
- package/lib/skill-runtime/planner.js +519 -0
- package/lib/skill-runtime/query.js +157 -0
- package/lib/skill-runtime/review.js +557 -0
- package/lib/skill-runtime/schemas.js +400 -0
- package/lib/{harness → skill-runtime}/store.js +45 -30
- package/lib/skill-runtime/team-state.js +122 -0
- package/package.json +13 -11
- package/.claude/CLAUDE.md +0 -125
- package/.claude/agents/architecture-designer.md +0 -443
- package/.claude/agents/bug-analyzer.md +0 -381
- package/.claude/agents/checklist-agent.md +0 -175
- package/.claude/agents/clarify-analyst.md +0 -50
- package/.claude/agents/code-quality-reviewer.md +0 -205
- package/.claude/agents/code-reviewer.md +0 -71
- package/.claude/agents/codex-analyzer.md +0 -39
- package/.claude/agents/compatibility-checker.md +0 -579
- package/.claude/agents/consistency-checker.md +0 -532
- package/.claude/agents/dev-implementer.md +0 -195
- package/.claude/agents/flow-researcher.md +0 -132
- package/.claude/agents/impact-analyzer.md +0 -440
- package/.claude/agents/planner.md +0 -230
- package/.claude/agents/prd-writer.md +0 -320
- package/.claude/agents/project-guidelines-generator.md +0 -1329
- package/.claude/agents/qa-tester.md +0 -313
- package/.claude/agents/release-manager.md +0 -295
- package/.claude/agents/security-reviewer.md +0 -314
- package/.claude/agents/spec-reviewer.md +0 -221
- package/.claude/agents/style-guide-generator.md +0 -458
- package/.claude/agents/tech-architect.md +0 -516
- package/.claude/agents/ui-designer.md +0 -485
- package/.claude/commands/core/architecture.md +0 -459
- package/.claude/commands/core/guidelines.md +0 -511
- package/.claude/commands/core/roadmap.md +0 -468
- package/.claude/commands/core/style.md +0 -83
- package/.claude/commands/flow/CLAUDE.md +0 -28
- package/.claude/commands/flow/archive.md +0 -280
- package/.claude/commands/flow/checklist.md +0 -18
- package/.claude/commands/flow/clarify.md +0 -18
- package/.claude/commands/flow/constitution.md +0 -82
- package/.claude/commands/flow/context.md +0 -150
- package/.claude/commands/flow/delta.md +0 -245
- package/.claude/commands/flow/dev.md +0 -40
- package/.claude/commands/flow/fix.md +0 -217
- package/.claude/commands/flow/ideate.md +0 -214
- package/.claude/commands/flow/init.md +0 -38
- package/.claude/commands/flow/new.md +0 -23
- package/.claude/commands/flow/quality.md +0 -21
- package/.claude/commands/flow/release.md +0 -36
- package/.claude/commands/flow/restart.md +0 -97
- package/.claude/commands/flow/spec.md +0 -36
- package/.claude/commands/flow/status.md +0 -64
- package/.claude/commands/flow/update.md +0 -111
- package/.claude/commands/flow/upgrade.md +0 -115
- package/.claude/commands/flow/verify.md +0 -37
- package/.claude/commands/flow/workspace.md +0 -155
- package/.claude/commands/util/cancel-ralph.md +0 -60
- package/.claude/commands/util/code-review.md +0 -58
- package/.claude/commands/util/git-commit.md +0 -422
- package/.claude/commands/util/problem-analyzer.md +0 -60
- package/.claude/config/quality-gates.yml +0 -305
- package/.claude/config/quality-rules.yml +0 -161
- package/.claude/docs/SPEC_KIT_CONSTITUTION_ANALYSIS.md +0 -426
- package/.claude/docs/design/consistency-conflict-detection-algorithms.md +0 -658
- package/.claude/docs/design/intent-driven-input-design.md +0 -380
- package/.claude/docs/design/prd-version-management-design.md +0 -437
- package/.claude/docs/guides/INIT_TROUBLESHOOTING.md +0 -117
- package/.claude/docs/guides/NEW_TROUBLESHOOTING.md +0 -99
- package/.claude/docs/guides/ROADMAP_TROUBLESHOOTING.md +0 -188
- package/.claude/docs/guides/TASK_COMPLETION_MARKING.md +0 -338
- package/.claude/docs/guides/TEAM_MODE_GUIDE.md +0 -312
- package/.claude/docs/templates/ARCHITECTURE_TEMPLATE.md +0 -633
- package/.claude/docs/templates/ATTEMPT_TEMPLATE.md +0 -156
- package/.claude/docs/templates/BACKLOG_TEMPLATE.md +0 -261
- package/.claude/docs/templates/BRAINSTORM_TEMPLATE.md +0 -148
- package/.claude/docs/templates/CHECKLIST_TEMPLATE.md +0 -52
- package/.claude/docs/templates/CLARIFICATION_REPORT_TEMPLATE.md +0 -206
- package/.claude/docs/templates/CODE_REVIEW_TEMPLATE.md +0 -71
- package/.claude/docs/templates/DELTA_SPEC_TEMPLATE.md +0 -91
- package/.claude/docs/templates/DESIGN_DECISIONS_TEMPLATE.md +0 -151
- package/.claude/docs/templates/EPIC_TEMPLATE.md +0 -805
- package/.claude/docs/templates/ERROR_LOG_TEMPLATE.md +0 -80
- package/.claude/docs/templates/INIT_FLOW_TEMPLATE.md +0 -198
- package/.claude/docs/templates/INTENT_CLARIFICATION_TEMPLATE.md +0 -57
- package/.claude/docs/templates/JOURNAL_TEMPLATE.md +0 -75
- package/.claude/docs/templates/NEW_ORCHESTRATION_TEMPLATE.md +0 -76
- package/.claude/docs/templates/PRD_TEMPLATE.md +0 -562
- package/.claude/docs/templates/RESEARCH_TEMPLATE.md +0 -276
- package/.claude/docs/templates/REVIEW-HIGH.md +0 -57
- package/.claude/docs/templates/ROADMAP_DIALOGUE_TEMPLATE.md +0 -198
- package/.claude/docs/templates/ROADMAP_TEMPLATE.md +0 -310
- package/.claude/docs/templates/STYLE_TEMPLATE.md +0 -1266
- package/.claude/docs/templates/TASKS_TEMPLATE.md +0 -523
- package/.claude/docs/templates/TECH_DESIGN_TEMPLATE.md +0 -1019
- package/.claude/docs/templates/UI_PROTOTYPE_TEMPLATE.md +0 -1435
- package/.claude/docs/templates/_shared/CLAUDE.md +0 -36
- package/.claude/docs/templates/_shared/CONSTITUTION_CHECK.md +0 -125
- package/.claude/docs/templates/_shared/VALIDATION_CHECKLIST.md +0 -187
- package/.claude/docs/templates/_shared/YAML_FRONTMATTER.md +0 -164
- package/.claude/docs/templates/context/dev.jsonl.template +0 -6
- package/.claude/docs/templates/context/epic.jsonl.template +0 -5
- package/.claude/docs/templates/context/prd.jsonl.template +0 -4
- package/.claude/docs/templates/context/research.jsonl.template +0 -4
- package/.claude/docs/templates/context/review.jsonl.template +0 -5
- package/.claude/docs/templates/context/tech.jsonl.template +0 -5
- package/.claude/guides/agent-guides/agent-coordination-guide.md +0 -459
- package/.claude/guides/project-guidelines-system.md +0 -463
- package/.claude/guides/technical-guides/datetime-handling-guide.md +0 -563
- package/.claude/guides/technical-guides/git-github-guide.md +0 -642
- package/.claude/guides/technical-guides/test-execution-guide.md +0 -618
- package/.claude/guides/workflow-guides/bug-fix-orchestrator.md +0 -217
- package/.claude/guides/workflow-guides/flow-orchestrator.md +0 -48
- package/.claude/hooks/CLAUDE.md +0 -342
- package/.claude/hooks/checklist-gate.js +0 -397
- package/.claude/hooks/error-handling-reminder.sh +0 -12
- package/.claude/hooks/error-handling-reminder.ts +0 -459
- package/.claude/hooks/hooks.json +0 -15
- package/.claude/hooks/inject-agent-context.ts +0 -480
- package/.claude/hooks/inject-skill-context.ts +0 -359
- package/.claude/hooks/post-tool-use-tracker.sh +0 -280
- package/.claude/hooks/pre-tool-use-guardrail.sh +0 -36
- package/.claude/hooks/pre-tool-use-guardrail.ts +0 -342
- package/.claude/hooks/ralph-loop.ts +0 -931
- package/.claude/hooks/ralph-stop-hook.sh +0 -190
- package/.claude/hooks/skill-activation-prompt.sh +0 -36
- package/.claude/hooks/skill-activation-prompt.ts +0 -214
- package/.claude/hooks/state/skills-used-test-guard.json +0 -3
- package/.claude/hooks/task-completed-hook.ts +0 -593
- package/.claude/hooks/teammate-idle-hook.ts +0 -690
- package/.claude/hooks/types/team-types.d.ts +0 -238
- package/.claude/rules/devflow-conventions.md +0 -286
- package/.claude/rules/project-constitution.md +0 -1002
- package/.claude/rules/rationalization-library.md +0 -282
- package/.claude/schemas/constitution.schema.json +0 -43
- package/.claude/scripts/CLAUDE.md +0 -76
- package/.claude/scripts/analyze-upgrade-impact.sh +0 -200
- package/.claude/scripts/archive-requirement.sh +0 -394
- package/.claude/scripts/calculate-checklist-completion.sh +0 -243
- package/.claude/scripts/calculate-quarter.sh +0 -206
- package/.claude/scripts/check-dependencies.sh +0 -409
- package/.claude/scripts/check-prerequisites.sh +0 -232
- package/.claude/scripts/check-task-status.sh +0 -288
- package/.claude/scripts/checklist-errors.sh +0 -131
- package/.claude/scripts/common.sh +0 -1102
- package/.claude/scripts/consolidate-research.sh +0 -182
- package/.claude/scripts/create-requirement.sh +0 -451
- package/.claude/scripts/delta-parser.ts +0 -527
- package/.claude/scripts/detect-file-conflicts.sh +0 -151
- package/.claude/scripts/export-contracts.sh +0 -117
- package/.claude/scripts/extract-data-model.sh +0 -78
- package/.claude/scripts/flow-context-add.sh +0 -134
- package/.claude/scripts/flow-context-init.sh +0 -133
- package/.claude/scripts/flow-context-validate.sh +0 -144
- package/.claude/scripts/flow-delta-apply.sh +0 -297
- package/.claude/scripts/flow-delta-archive.sh +0 -71
- package/.claude/scripts/flow-delta-create.sh +0 -202
- package/.claude/scripts/flow-delta-list.sh +0 -142
- package/.claude/scripts/flow-delta-status.sh +0 -235
- package/.claude/scripts/flow-quality-full.sh +0 -215
- package/.claude/scripts/flow-quality-quick.sh +0 -119
- package/.claude/scripts/flow-workspace-init.sh +0 -117
- package/.claude/scripts/flow-workspace-record.sh +0 -164
- package/.claude/scripts/generate-clarification-questions.sh +0 -377
- package/.claude/scripts/generate-clarification-report.sh +0 -463
- package/.claude/scripts/generate-quickstart.sh +0 -146
- package/.claude/scripts/generate-research-tasks.sh +0 -157
- package/.claude/scripts/generate-status-report.sh +0 -523
- package/.claude/scripts/generate-tech-analysis.sh +0 -46
- package/.claude/scripts/get-workflow-status.sh +0 -415
- package/.claude/scripts/locate-requirement-in-roadmap.sh +0 -233
- package/.claude/scripts/manage-constitution.sh +0 -602
- package/.claude/scripts/mark-task-complete.sh +0 -198
- package/.claude/scripts/parse-task-dependencies.js +0 -334
- package/.claude/scripts/populate-research-tasks.sh +0 -284
- package/.claude/scripts/record-quality-error.sh +0 -165
- package/.claude/scripts/recover-workflow.sh +0 -463
- package/.claude/scripts/run-clarify-scan.sh +0 -601
- package/.claude/scripts/run-high-review.sh +0 -62
- package/.claude/scripts/run-problem-analysis.sh +0 -68
- package/.claude/scripts/run-quality-gates.sh +0 -242
- package/.claude/scripts/setup-epic.sh +0 -173
- package/.claude/scripts/setup-ralph-loop.sh +0 -155
- package/.claude/scripts/sync-roadmap-progress.sh +0 -300
- package/.claude/scripts/sync-task-marks.sh +0 -199
- package/.claude/scripts/team-dev-init.sh +0 -319
- package/.claude/scripts/team-state-recovery.sh +0 -229
- package/.claude/scripts/test-clarify-scan.sh +0 -515
- package/.claude/scripts/update-agent-context.sh +0 -806
- package/.claude/scripts/validate-constitution.sh +0 -567
- package/.claude/scripts/validate-hooks.sh +0 -487
- package/.claude/scripts/validate-research.sh +0 -332
- package/.claude/scripts/validate-scope-boundary.sh +0 -493
- package/.claude/scripts/verify-gate.sh +0 -269
- package/.claude/scripts/verify-setup.sh +0 -37
- package/.claude/scripts/workflow-status.ts +0 -433
- package/.claude/settings.json +0 -95
- package/.claude/skills/_reference-implementations/README.md +0 -96
- package/.claude/skills/_reference-implementations/backend-express-prisma/SKILL.md +0 -302
- package/.claude/skills/_reference-implementations/backend-express-prisma/resources/architecture-overview.md +0 -451
- package/.claude/skills/_reference-implementations/backend-express-prisma/resources/async-and-errors.md +0 -307
- package/.claude/skills/_reference-implementations/backend-express-prisma/resources/complete-examples.md +0 -638
- package/.claude/skills/_reference-implementations/backend-express-prisma/resources/configuration.md +0 -275
- package/.claude/skills/_reference-implementations/backend-express-prisma/resources/database-patterns.md +0 -224
- package/.claude/skills/_reference-implementations/backend-express-prisma/resources/middleware-guide.md +0 -213
- package/.claude/skills/_reference-implementations/backend-express-prisma/resources/routing-and-controllers.md +0 -756
- package/.claude/skills/_reference-implementations/backend-express-prisma/resources/sentry-and-monitoring.md +0 -336
- package/.claude/skills/_reference-implementations/backend-express-prisma/resources/services-and-repositories.md +0 -789
- package/.claude/skills/_reference-implementations/backend-express-prisma/resources/testing-guide.md +0 -235
- package/.claude/skills/_reference-implementations/backend-express-prisma/resources/validation-patterns.md +0 -754
- package/.claude/skills/_reference-implementations/frontend-react-mui/SKILL.md +0 -399
- package/.claude/skills/_reference-implementations/frontend-react-mui/resources/common-patterns.md +0 -331
- package/.claude/skills/_reference-implementations/frontend-react-mui/resources/complete-examples.md +0 -872
- package/.claude/skills/_reference-implementations/frontend-react-mui/resources/component-patterns.md +0 -502
- package/.claude/skills/_reference-implementations/frontend-react-mui/resources/data-fetching.md +0 -767
- package/.claude/skills/_reference-implementations/frontend-react-mui/resources/file-organization.md +0 -502
- package/.claude/skills/_reference-implementations/frontend-react-mui/resources/loading-and-error-states.md +0 -501
- package/.claude/skills/_reference-implementations/frontend-react-mui/resources/performance.md +0 -406
- package/.claude/skills/_reference-implementations/frontend-react-mui/resources/routing-guide.md +0 -364
- package/.claude/skills/_reference-implementations/frontend-react-mui/resources/styling-guide.md +0 -428
- package/.claude/skills/_reference-implementations/frontend-react-mui/resources/typescript-standards.md +0 -418
- package/.claude/skills/cc-devflow-orchestrator/SKILL.md +0 -169
- package/.claude/skills/domain/attention-refresh/SKILL.md +0 -170
- package/.claude/skills/domain/brainstorming/SKILL.md +0 -161
- package/.claude/skills/domain/debugging/SKILL.md +0 -221
- package/.claude/skills/domain/finishing-branch/SKILL.md +0 -189
- package/.claude/skills/domain/receiving-review/SKILL.md +0 -153
- package/.claude/skills/domain/tdd/SKILL.md +0 -218
- package/.claude/skills/domain/verification/SKILL.md +0 -158
- package/.claude/skills/guardrail/constitution-guardian/SKILL.md +0 -306
- package/.claude/skills/guardrail/tdd-enforcer/SKILL.md +0 -192
- package/.claude/skills/skill-rules.json +0 -359
- package/.claude/skills/utility/constitution-quick-ref/SKILL.md +0 -374
- package/.claude/skills/utility/file-standards/SKILL.md +0 -353
- package/.claude/skills/utility/fractal-docs/SKILL.md +0 -45
- package/.claude/skills/utility/journey-checker/SKILL.md +0 -199
- package/.claude/skills/utility/journey-checker/pressure-scenarios.md +0 -164
- package/.claude/skills/utility/npm-release/SKILL.md +0 -314
- package/.claude/skills/utility/skill-creator/LICENSE.txt +0 -202
- package/.claude/skills/utility/skill-creator/SKILL.md +0 -356
- package/.claude/skills/utility/skill-creator/references/output-patterns.md +0 -82
- package/.claude/skills/utility/skill-creator/references/workflows.md +0 -28
- package/.claude/skills/utility/skill-creator/scripts/init_skill.py +0 -303
- package/.claude/skills/utility/skill-creator/scripts/package_skill.py +0 -110
- package/.claude/skills/utility/skill-creator/scripts/quick_validate.py +0 -95
- package/.claude/skills/workflow/CLAUDE.md +0 -24
- package/.claude/skills/workflow/flow-dev/CLAUDE.md +0 -16
- package/.claude/skills/workflow/flow-dev/SKILL.md +0 -94
- package/.claude/skills/workflow/flow-dev/assets/IMPLEMENTATION_PLAN_TEMPLATE.md +0 -71
- package/.claude/skills/workflow/flow-dev/context.jsonl +0 -4
- package/.claude/skills/workflow/flow-dev/dev-implementer.jsonl +0 -8
- package/.claude/skills/workflow/flow-dev/scripts/entry-gate.sh +0 -116
- package/.claude/skills/workflow/flow-dev/scripts/exit-gate.sh +0 -101
- package/.claude/skills/workflow/flow-dev/scripts/task-orchestrator.sh +0 -106
- package/.claude/skills/workflow/flow-fix/SKILL.md +0 -105
- package/.claude/skills/workflow/flow-fix/context.jsonl +0 -6
- package/.claude/skills/workflow/flow-fix/references/bug-analyzer.md +0 -381
- package/.claude/skills/workflow/flow-init/SKILL.md +0 -84
- package/.claude/skills/workflow/flow-init/assets/BRAINSTORM_TEMPLATE.md +0 -148
- package/.claude/skills/workflow/flow-init/assets/INIT_FLOW_TEMPLATE.md +0 -198
- package/.claude/skills/workflow/flow-init/assets/RESEARCH_TEMPLATE.md +0 -276
- package/.claude/skills/workflow/flow-init/context.jsonl +0 -5
- package/.claude/skills/workflow/flow-init/references/flow-researcher.md +0 -132
- package/.claude/skills/workflow/flow-init/scripts/check-prerequisites.sh +0 -240
- package/.claude/skills/workflow/flow-init/scripts/consolidate-research.sh +0 -182
- package/.claude/skills/workflow/flow-init/scripts/create-requirement.sh +0 -404
- package/.claude/skills/workflow/flow-init/scripts/generate-research-tasks.sh +0 -157
- package/.claude/skills/workflow/flow-init/scripts/populate-research-tasks.sh +0 -284
- package/.claude/skills/workflow/flow-init/scripts/validate-research.sh +0 -340
- package/.claude/skills/workflow/flow-quality/SKILL.md +0 -98
- package/.claude/skills/workflow/flow-quality/context.jsonl +0 -6
- package/.claude/skills/workflow/flow-quality/references/code-quality-reviewer.md +0 -205
- package/.claude/skills/workflow/flow-quality/references/qa-tester.md +0 -313
- package/.claude/skills/workflow/flow-quality/references/security-reviewer.md +0 -314
- package/.claude/skills/workflow/flow-quality/references/spec-reviewer.md +0 -221
- package/.claude/skills/workflow/flow-release/SKILL.md +0 -49
- package/.claude/skills/workflow/flow-release/context.jsonl +0 -5
- package/.claude/skills/workflow/flow-release/references/release-manager.md +0 -295
- package/.claude/skills/workflow/flow-spec/CLAUDE.md +0 -17
- package/.claude/skills/workflow/flow-spec/SKILL.md +0 -74
- package/.claude/skills/workflow/flow-spec/context.jsonl +0 -5
- package/.claude/skills/workflow/flow-spec/scripts/entry-gate.sh +0 -194
- package/.claude/skills/workflow/flow-spec/scripts/exit-gate.sh +0 -244
- package/.claude/skills/workflow/flow-spec/scripts/parallel-orchestrator.sh +0 -205
- package/.claude/skills/workflow/flow-spec/scripts/team-communication.sh +0 -353
- package/.claude/skills/workflow/flow-spec/scripts/team-init.sh +0 -195
- package/.claude/skills/workflow/flow-spec/scripts/test-team-mode.sh +0 -496
- package/.claude/skills/workflow/flow-spec/team-config.json +0 -165
- package/.claude/skills/workflow/flow-verify/CLAUDE.md +0 -10
- package/.claude/skills/workflow/flow-verify/SKILL.md +0 -53
- package/.claude/skills/workflow/flow-verify/context.jsonl +0 -5
- package/.claude/skills/workflow.yaml +0 -219
- package/.claude/tests/README.md +0 -300
- package/.claude/tests/TODO.md +0 -69
- package/.claude/tests/__pycache__/test_analyze_upgrade_impact.cpython-311-pytest-7.2.2.pyc +0 -0
- package/.claude/tests/__pycache__/test_consolidate_research.cpython-311-pytest-7.2.2.pyc +0 -0
- package/.claude/tests/__pycache__/test_export_contracts.cpython-311-pytest-7.2.2.pyc +0 -0
- package/.claude/tests/__pycache__/test_extract_data_model.cpython-311-pytest-7.2.2.pyc +0 -0
- package/.claude/tests/__pycache__/test_generate_quickstart.cpython-311-pytest-7.2.2.pyc +0 -0
- package/.claude/tests/__pycache__/test_generate_research_tasks.cpython-311-pytest-7.2.2.pyc +0 -0
- package/.claude/tests/constitution/run_all_constitution_tests.sh +0 -111
- package/.claude/tests/constitution/test_agent_assignment.sh +0 -207
- package/.claude/tests/constitution/test_article_coverage.sh +0 -201
- package/.claude/tests/constitution/test_template_completeness.sh +0 -150
- package/.claude/tests/constitution/test_version_consistency.sh +0 -120
- package/.claude/tests/fixtures/spec_delta_full.md +0 -16
- package/.claude/tests/fixtures/tasks_progress_sample.md +0 -5
- package/.claude/tests/run-all-tests.sh +0 -229
- package/.claude/tests/scripts/run.sh +0 -30
- package/.claude/tests/scripts/test-framework.sh +0 -128
- package/.claude/tests/scripts/test_check_prerequisites.sh +0 -511
- package/.claude/tests/scripts/test_check_prerequisites.sh.bak +0 -504
- package/.claude/tests/scripts/test_check_prerequisites.sh.bak2 +0 -505
- package/.claude/tests/scripts/test_check_prerequisites.sh.bak3 +0 -506
- package/.claude/tests/scripts/test_check_prerequisites.sh.bak4 +0 -507
- package/.claude/tests/scripts/test_check_prerequisites.sh.bak5 +0 -508
- package/.claude/tests/scripts/test_check_task_status.sh +0 -499
- package/.claude/tests/scripts/test_common.sh +0 -244
- package/.claude/tests/scripts/test_generate_status_report.sh +0 -71
- package/.claude/tests/scripts/test_mark_task_complete.sh +0 -441
- package/.claude/tests/scripts/test_mark_task_complete.sh.backup +0 -410
- package/.claude/tests/scripts/test_recover_workflow.sh +0 -304
- package/.claude/tests/scripts/test_setup_epic.sh +0 -437
- package/.claude/tests/scripts/test_sync_task_marks.sh +0 -196
- package/.claude/tests/scripts/test_validate_constitution.sh +0 -74
- package/.claude/tests/scripts/test_validate_research.sh +0 -462
- package/.claude/tests/slugify.bats +0 -82
- package/.claude/tests/test-framework.sh +0 -732
- package/.claude/tests/test_analyze_upgrade_impact.py +0 -34
- package/.claude/tests/test_consolidate_research.py +0 -48
- package/.claude/tests/test_export_contracts.py +0 -43
- package/.claude/tests/test_extract_data_model.py +0 -33
- package/.claude/tests/test_generate_quickstart.py +0 -50
- package/.claude/tests/test_generate_research_tasks.py +0 -52
- package/bin/harness.js +0 -22
- package/docs/commands/core-roadmap.md +0 -106
- package/docs/commands/core-roadmap.zh-CN.md +0 -102
- package/docs/commands/core-style.md +0 -53
- package/docs/commands/core-style.zh-CN.md +0 -53
- package/docs/commands/flow-init.md +0 -140
- package/docs/commands/flow-init.zh-CN.md +0 -169
- package/docs/commands/flow-new.md +0 -39
- package/docs/commands/flow-new.zh-CN.md +0 -39
- package/lib/compiler/__tests__/compile-regression.test.js +0 -103
- package/lib/compiler/__tests__/multi-module-emitters.test.js +0 -534
- package/lib/compiler/__tests__/resource-copier.test.js +0 -26
- package/lib/compiler/__tests__/skill-discovery.test.js +0 -72
- package/lib/compiler/context-expander.js +0 -179
- package/lib/compiler/rules-emitters/__tests__/codex-rules-emitter.test.js +0 -109
- package/lib/compiler/rules-emitters/codex-rules-emitter.js +0 -116
- package/lib/compiler/skill-discovery.js +0 -68
- package/lib/harness/CLAUDE.md +0 -21
- package/lib/harness/cli.js +0 -208
- package/lib/harness/index.js +0 -16
- package/lib/harness/operations/dispatch.js +0 -285
- package/lib/harness/operations/init.js +0 -48
- package/lib/harness/operations/pack.js +0 -100
- package/lib/harness/operations/plan.js +0 -29
- package/lib/harness/operations/resume.js +0 -44
- package/lib/harness/operations/verify.js +0 -163
- package/lib/harness/planner.js +0 -141
- package/lib/harness/schemas.js +0 -108
|
@@ -1,418 +0,0 @@
|
|
|
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
|
|
@@ -1,169 +0,0 @@
|
|
|
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 command/skill without duplicating detailed implementation standards.
|
|
10
|
-
|
|
11
|
-
## Workflow Map
|
|
12
|
-
|
|
13
|
-
### Project-Level (run once per project)
|
|
14
|
-
|
|
15
|
-
```text
|
|
16
|
-
/core:roadmap → ROADMAP.md + BACKLOG.md
|
|
17
|
-
/core:architecture → ARCHITECTURE.md
|
|
18
|
-
/core:guidelines → frontend/backend guidelines
|
|
19
|
-
/core:style → STYLE.md
|
|
20
|
-
```
|
|
21
|
-
|
|
22
|
-
## Project-Level Harness Protocol (Long-running)
|
|
23
|
-
|
|
24
|
-
For `/core:*` commands, enforce a two-session model before declaring completion:
|
|
25
|
-
|
|
26
|
-
1. Initializer session
|
|
27
|
-
- establish/update `devflow/.core-harness/<command>/checklist.json`, `progress.md`, `session-handoff.md`
|
|
28
|
-
- convert high-level goal into structured acceptance checks (default all failing)
|
|
29
|
-
2. Worker session(s)
|
|
30
|
-
- resume from `session-handoff.md` + `progress.md`
|
|
31
|
-
- execute one smallest deliverable per session
|
|
32
|
-
- update checklist status only after command-specific validation
|
|
33
|
-
3. Completion gate
|
|
34
|
-
- completion is allowed only when checklist is fully passing and command validation gates pass
|
|
35
|
-
- never declare success from “looks complete”; require artifact evidence
|
|
36
|
-
|
|
37
|
-
### Core Route Defaults
|
|
38
|
-
|
|
39
|
-
- no `devflow/ROADMAP.md` → route to `/core:roadmap` (initializer first)
|
|
40
|
-
- roadmap exists but architecture missing/stale → route to `/core:architecture`
|
|
41
|
-
- architecture exists but guidelines missing/stale → route to `/core:guidelines`
|
|
42
|
-
- style missing/stale → route to `/core:style`
|
|
43
|
-
- interrupted core command → rerun same command from handoff (`/core:roadmap --resume` if supported; otherwise run command again and continue from `session-handoff.md`)
|
|
44
|
-
|
|
45
|
-
### Requirement-Level Canonical Mainline (v6)
|
|
46
|
-
|
|
47
|
-
```text
|
|
48
|
-
/flow:init → harness:init + harness:pack
|
|
49
|
-
→ context-package.md + harness-state.json
|
|
50
|
-
↓
|
|
51
|
-
/flow:spec → harness:plan
|
|
52
|
-
→ task-manifest.json
|
|
53
|
-
↓
|
|
54
|
-
/flow:dev → harness:dispatch / harness:resume
|
|
55
|
-
→ runtime events + checkpoints + manifest status
|
|
56
|
-
↓
|
|
57
|
-
/flow:verify → harness:verify
|
|
58
|
-
→ report-card.json (quick/strict gates)
|
|
59
|
-
↓
|
|
60
|
-
/flow:release → harness:release + harness:janitor
|
|
61
|
-
→ RELEASE_NOTE.md + released state
|
|
62
|
-
```
|
|
63
|
-
|
|
64
|
-
### Bug Workflow
|
|
65
|
-
|
|
66
|
-
```text
|
|
67
|
-
/flow:fix "BUG-123|描述" → 系统化调试与修复
|
|
68
|
-
```
|
|
69
|
-
|
|
70
|
-
### Deprecated Migrations (keep for compatibility)
|
|
71
|
-
|
|
72
|
-
```text
|
|
73
|
-
/flow:new → /flow:init → /flow:spec → /flow:dev → /flow:verify → /flow:release
|
|
74
|
-
/flow:clarify → merged into /flow:spec
|
|
75
|
-
/flow:checklist → merged into /flow:verify --strict
|
|
76
|
-
/flow:quality → merged into /flow:verify
|
|
77
|
-
```
|
|
78
|
-
|
|
79
|
-
## Routing Guide
|
|
80
|
-
|
|
81
|
-
### Requirement kickoff
|
|
82
|
-
- Recommend: `/flow:init "REQ-123|Title|URLs?"`
|
|
83
|
-
- Then: `/flow:spec "REQ-123"`
|
|
84
|
-
|
|
85
|
-
### Planning/specification questions
|
|
86
|
-
- Recommend: `/flow:spec`
|
|
87
|
-
- Notes: this is the unified planning stage for executable task-manifest generation.
|
|
88
|
-
|
|
89
|
-
### Development execution / interrupted execution
|
|
90
|
-
- Recommend: `/flow:dev "REQ-123"`
|
|
91
|
-
- If interrupted/failed: `/flow:dev "REQ-123" --resume`
|
|
92
|
-
|
|
93
|
-
### QA/security/release readiness
|
|
94
|
-
- Recommend: `/flow:verify "REQ-123"`
|
|
95
|
-
- Strict gate: `/flow:verify "REQ-123" --strict`
|
|
96
|
-
|
|
97
|
-
### Release
|
|
98
|
-
- Recommend: `/flow:release "REQ-123"`
|
|
99
|
-
- Release is blocked when report-card overall is fail.
|
|
100
|
-
|
|
101
|
-
### Code review requests
|
|
102
|
-
- Recommend: `/flow:verify "REQ-123" --strict`
|
|
103
|
-
- Optional deep review: `/util:code-review "<diff>"`
|
|
104
|
-
|
|
105
|
-
## Phase Gates (Quick Reference)
|
|
106
|
-
|
|
107
|
-
### Entry Gates
|
|
108
|
-
- `flow:init`: repository and requirement id are valid.
|
|
109
|
-
- `flow:spec`: `context-package.md` and `harness-state.json` exist.
|
|
110
|
-
- `flow:dev`: `task-manifest.json` exists and is schema-valid.
|
|
111
|
-
- `flow:verify`: task dispatch completed or at least one dispatch/resume run exists.
|
|
112
|
-
- `flow:release`: `report-card.json.overall == pass`.
|
|
113
|
-
|
|
114
|
-
### Exit Gates
|
|
115
|
-
- `flow:init`: requirement context packaged.
|
|
116
|
-
- `flow:spec`: task-manifest generated.
|
|
117
|
-
- `flow:dev`: task statuses updated with runtime checkpoints/events.
|
|
118
|
-
- `flow:verify`: report-card emitted (quick/strict/review sections).
|
|
119
|
-
- `flow:release`: release note generated and harness state marked released.
|
|
120
|
-
|
|
121
|
-
## State → Recommended Command
|
|
122
|
-
|
|
123
|
-
```yaml
|
|
124
|
-
no_requirement_context:
|
|
125
|
-
recommend: /flow:init
|
|
126
|
-
|
|
127
|
-
initialized_or_context_packed:
|
|
128
|
-
recommend: /flow:spec
|
|
129
|
-
|
|
130
|
-
manifest_exists_with_pending_or_failed:
|
|
131
|
-
recommend: /flow:dev
|
|
132
|
-
alternative: /flow:dev --resume
|
|
133
|
-
|
|
134
|
-
manifest_all_passed_without_report_card:
|
|
135
|
-
recommend: /flow:verify --strict
|
|
136
|
-
|
|
137
|
-
report_card_fail:
|
|
138
|
-
recommend: /flow:dev --resume
|
|
139
|
-
then: /flow:verify --strict
|
|
140
|
-
|
|
141
|
-
report_card_pass:
|
|
142
|
-
recommend: /flow:release
|
|
143
|
-
|
|
144
|
-
released:
|
|
145
|
-
recommend: /flow:archive (optional)
|
|
146
|
-
```
|
|
147
|
-
|
|
148
|
-
## Auxiliary Commands
|
|
149
|
-
|
|
150
|
-
### Progress and recovery
|
|
151
|
-
- `/flow:status` - query requirement progress
|
|
152
|
-
- `/flow:update "REQ-123" "T012"` - update task progress
|
|
153
|
-
- `/flow:restart "REQ-123" --from=dev` - recover interrupted workflow state
|
|
154
|
-
|
|
155
|
-
### Upgrade and governance
|
|
156
|
-
- `/flow:upgrade "REQ-123" --analyze` - PRD version impact analysis
|
|
157
|
-
- `/flow:constitution` - constitution governance
|
|
158
|
-
- `/flow:verify "REQ-123"` - consistency and quality verification
|
|
159
|
-
|
|
160
|
-
## Design Principle
|
|
161
|
-
|
|
162
|
-
This skill only does routing:
|
|
163
|
-
- Which command to run next
|
|
164
|
-
- Which gate blocks progress
|
|
165
|
-
- Which migration path applies for deprecated commands
|
|
166
|
-
- Prefer incremental convergence over one-shot generation
|
|
167
|
-
- Require artifact-backed completion for long-running sessions
|
|
168
|
-
|
|
169
|
-
Detailed quality standards stay in command files and workflow skills.
|