maestro-flow 0.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.claude/CLAUDE.md +19 -0
- package/.claude/agents/cli-explore-agent.md +187 -0
- package/.claude/agents/conceptual-planning-agent.md +244 -0
- package/.claude/agents/team-supervisor.md +133 -0
- package/.claude/agents/team-worker.md +155 -0
- package/.claude/agents/ui-design-agent.md +286 -0
- package/.claude/agents/workflow-analyzer.md +114 -0
- package/.claude/agents/workflow-codebase-mapper.md +77 -0
- package/.claude/agents/workflow-collab-planner.md +144 -0
- package/.claude/agents/workflow-debugger.md +103 -0
- package/.claude/agents/workflow-executor.md +128 -0
- package/.claude/agents/workflow-external-researcher.md +86 -0
- package/.claude/agents/workflow-integration-checker.md +82 -0
- package/.claude/agents/workflow-nyquist-auditor.md +84 -0
- package/.claude/agents/workflow-phase-researcher.md +85 -0
- package/.claude/agents/workflow-plan-checker.md +90 -0
- package/.claude/agents/workflow-planner.md +178 -0
- package/.claude/agents/workflow-project-researcher.md +74 -0
- package/.claude/agents/workflow-research-synthesizer.md +70 -0
- package/.claude/agents/workflow-reviewer.md +80 -0
- package/.claude/agents/workflow-roadmapper.md +83 -0
- package/.claude/agents/workflow-verifier.md +119 -0
- package/.claude/commands/maestro-analyze.md +99 -0
- package/.claude/commands/maestro-brainstorm.md +90 -0
- package/.claude/commands/maestro-coordinate.md +65 -0
- package/.claude/commands/maestro-execute.md +86 -0
- package/.claude/commands/maestro-init.md +78 -0
- package/.claude/commands/maestro-link-coordinate.md +63 -0
- package/.claude/commands/maestro-milestone-audit.md +60 -0
- package/.claude/commands/maestro-milestone-complete.md +58 -0
- package/.claude/commands/maestro-phase-add.md +55 -0
- package/.claude/commands/maestro-phase-transition.md +65 -0
- package/.claude/commands/maestro-plan.md +87 -0
- package/.claude/commands/maestro-quick.md +56 -0
- package/.claude/commands/maestro-roadmap.md +95 -0
- package/.claude/commands/maestro-spec-generate.md +102 -0
- package/.claude/commands/maestro-ui-design.md +152 -0
- package/.claude/commands/maestro-verify.md +84 -0
- package/.claude/commands/maestro.md +116 -0
- package/.claude/commands/manage-codebase-rebuild.md +50 -0
- package/.claude/commands/manage-codebase-refresh.md +49 -0
- package/.claude/commands/manage-issue-analyze.md +62 -0
- package/.claude/commands/manage-issue-discover.md +77 -0
- package/.claude/commands/manage-issue-execute.md +73 -0
- package/.claude/commands/manage-issue-plan.md +62 -0
- package/.claude/commands/manage-issue.md +73 -0
- package/.claude/commands/manage-memory-capture.md +61 -0
- package/.claude/commands/manage-memory.md +88 -0
- package/.claude/commands/manage-status.md +69 -0
- package/.claude/commands/quality-debug.md +83 -0
- package/.claude/commands/quality-integration-test.md +87 -0
- package/.claude/commands/quality-refactor.md +55 -0
- package/.claude/commands/quality-review.md +125 -0
- package/.claude/commands/quality-sync.md +43 -0
- package/.claude/commands/quality-test-gen.md +76 -0
- package/.claude/commands/quality-test.md +86 -0
- package/.claude/commands/spec-add.md +56 -0
- package/.claude/commands/spec-load.md +59 -0
- package/.claude/commands/spec-map.md +82 -0
- package/.claude/commands/spec-setup.md +57 -0
- package/.codex/skills/maestro/SKILL.md +529 -0
- package/.codex/skills/maestro-analyze/SKILL.md +530 -0
- package/.codex/skills/maestro-brainstorm/SKILL.md +463 -0
- package/.codex/skills/maestro-execute/SKILL.md +437 -0
- package/.codex/skills/maestro-init/SKILL.md +167 -0
- package/.codex/skills/maestro-milestone-audit/SKILL.md +209 -0
- package/.codex/skills/maestro-milestone-complete/SKILL.md +158 -0
- package/.codex/skills/maestro-phase-add/SKILL.md +154 -0
- package/.codex/skills/maestro-phase-transition/SKILL.md +173 -0
- package/.codex/skills/maestro-plan/SKILL.md +458 -0
- package/.codex/skills/maestro-quick/SKILL.md +164 -0
- package/.codex/skills/maestro-roadmap/SKILL.md +385 -0
- package/.codex/skills/maestro-spec-generate/SKILL.md +399 -0
- package/.codex/skills/maestro-ui-design/SKILL.md +179 -0
- package/.codex/skills/maestro-verify/SKILL.md +566 -0
- package/.codex/skills/manage-codebase-rebuild/SKILL.md +405 -0
- package/.codex/skills/manage-codebase-refresh/SKILL.md +82 -0
- package/.codex/skills/manage-issue/SKILL.md +65 -0
- package/.codex/skills/manage-issue-discover/SKILL.md +503 -0
- package/.codex/skills/manage-memory/SKILL.md +72 -0
- package/.codex/skills/manage-memory-capture/SKILL.md +86 -0
- package/.codex/skills/manage-status/SKILL.md +89 -0
- package/.codex/skills/quality-debug/SKILL.md +413 -0
- package/.codex/skills/quality-integration-test/SKILL.md +544 -0
- package/.codex/skills/quality-refactor/SKILL.md +191 -0
- package/.codex/skills/quality-review/SKILL.md +408 -0
- package/.codex/skills/quality-sync/SKILL.md +89 -0
- package/.codex/skills/quality-test/SKILL.md +198 -0
- package/.codex/skills/quality-test-gen/SKILL.md +447 -0
- package/.codex/skills/spec-add/SKILL.md +79 -0
- package/.codex/skills/spec-load/SKILL.md +75 -0
- package/.codex/skills/spec-map/SKILL.md +182 -0
- package/.codex/skills/spec-setup/SKILL.md +76 -0
- package/.codex/skills/team-coordinate/SKILL.md +359 -0
- package/.codex/skills/team-coordinate/roles/coordinator/commands/analyze-task.md +247 -0
- package/.codex/skills/team-coordinate/roles/coordinator/commands/dispatch.md +126 -0
- package/.codex/skills/team-coordinate/roles/coordinator/commands/monitor.md +367 -0
- package/.codex/skills/team-coordinate/roles/coordinator/role.md +402 -0
- package/.codex/skills/team-coordinate/specs/knowledge-transfer.md +111 -0
- package/.codex/skills/team-coordinate/specs/pipelines.md +97 -0
- package/.codex/skills/team-coordinate/specs/quality-gates.md +112 -0
- package/.codex/skills/team-coordinate/specs/role-spec-template.md +192 -0
- package/.codex/skills/team-executor/SKILL.md +218 -0
- package/.codex/skills/team-executor/roles/executor/commands/monitor.md +288 -0
- package/.codex/skills/team-executor/roles/executor/role.md +170 -0
- package/.codex/skills/team-executor/specs/session-schema.md +264 -0
- package/.codex/skills/team-lifecycle-v4/MIGRATION-PLAN.md +512 -0
- package/.codex/skills/team-lifecycle-v4/SKILL.md +305 -0
- package/.codex/skills/team-lifecycle-v4/instructions/agent-instruction.md +725 -0
- package/.codex/skills/team-lifecycle-v4/roles/analyst/role.md +104 -0
- package/.codex/skills/team-lifecycle-v4/roles/coordinator/commands/analyze.md +56 -0
- package/.codex/skills/team-lifecycle-v4/roles/coordinator/commands/dispatch.md +61 -0
- package/.codex/skills/team-lifecycle-v4/roles/coordinator/commands/monitor.md +219 -0
- package/.codex/skills/team-lifecycle-v4/roles/coordinator/role.md +190 -0
- package/.codex/skills/team-lifecycle-v4/roles/executor/commands/fix.md +35 -0
- package/.codex/skills/team-lifecycle-v4/roles/executor/commands/implement.md +63 -0
- package/.codex/skills/team-lifecycle-v4/roles/executor/role.md +89 -0
- package/.codex/skills/team-lifecycle-v4/roles/planner/role.md +108 -0
- package/.codex/skills/team-lifecycle-v4/roles/reviewer/commands/review-code.md +57 -0
- package/.codex/skills/team-lifecycle-v4/roles/reviewer/commands/review-spec.md +44 -0
- package/.codex/skills/team-lifecycle-v4/roles/reviewer/role.md +98 -0
- package/.codex/skills/team-lifecycle-v4/roles/supervisor/role.md +210 -0
- package/.codex/skills/team-lifecycle-v4/roles/tester/role.md +126 -0
- package/.codex/skills/team-lifecycle-v4/roles/writer/role.md +125 -0
- package/.codex/skills/team-lifecycle-v4/schemas/tasks-schema.md +100 -0
- package/.codex/skills/team-lifecycle-v4/specs/knowledge-transfer.md +136 -0
- package/.codex/skills/team-lifecycle-v4/specs/pipelines.md +125 -0
- package/.codex/skills/team-lifecycle-v4/specs/quality-gates.md +130 -0
- package/.codex/skills/team-lifecycle-v4/templates/architecture.md +254 -0
- package/.codex/skills/team-lifecycle-v4/templates/epics.md +196 -0
- package/.codex/skills/team-lifecycle-v4/templates/product-brief.md +133 -0
- package/.codex/skills/team-lifecycle-v4/templates/requirements.md +224 -0
- package/.codex/skills/team-quality-assurance/SKILL.md +229 -0
- package/.codex/skills/team-quality-assurance/roles/analyst/role.md +80 -0
- package/.codex/skills/team-quality-assurance/roles/coordinator/commands/analyze.md +72 -0
- package/.codex/skills/team-quality-assurance/roles/coordinator/commands/dispatch.md +108 -0
- package/.codex/skills/team-quality-assurance/roles/coordinator/commands/monitor.md +243 -0
- package/.codex/skills/team-quality-assurance/roles/coordinator/role.md +176 -0
- package/.codex/skills/team-quality-assurance/roles/executor/role.md +66 -0
- package/.codex/skills/team-quality-assurance/roles/generator/role.md +68 -0
- package/.codex/skills/team-quality-assurance/roles/scout/role.md +67 -0
- package/.codex/skills/team-quality-assurance/roles/strategist/role.md +71 -0
- package/.codex/skills/team-quality-assurance/specs/pipelines.md +115 -0
- package/.codex/skills/team-quality-assurance/specs/team-config.json +131 -0
- package/.codex/skills/team-review/SKILL.md +227 -0
- package/.codex/skills/team-review/roles/coordinator/commands/analyze.md +71 -0
- package/.codex/skills/team-review/roles/coordinator/commands/dispatch.md +90 -0
- package/.codex/skills/team-review/roles/coordinator/commands/monitor.md +225 -0
- package/.codex/skills/team-review/roles/coordinator/role.md +175 -0
- package/.codex/skills/team-review/roles/fixer/role.md +76 -0
- package/.codex/skills/team-review/roles/reviewer/role.md +68 -0
- package/.codex/skills/team-review/roles/scanner/role.md +71 -0
- package/.codex/skills/team-review/specs/dimensions.md +82 -0
- package/.codex/skills/team-review/specs/finding-schema.json +82 -0
- package/.codex/skills/team-review/specs/pipelines.md +102 -0
- package/.codex/skills/team-review/specs/team-config.json +27 -0
- package/.codex/skills/team-tech-debt/SKILL.md +206 -0
- package/.codex/skills/team-tech-debt/roles/assessor/role.md +69 -0
- package/.codex/skills/team-tech-debt/roles/coordinator/commands/analyze.md +47 -0
- package/.codex/skills/team-tech-debt/roles/coordinator/commands/dispatch.md +163 -0
- package/.codex/skills/team-tech-debt/roles/coordinator/commands/monitor.md +272 -0
- package/.codex/skills/team-tech-debt/roles/coordinator/role.md +172 -0
- package/.codex/skills/team-tech-debt/roles/executor/role.md +76 -0
- package/.codex/skills/team-tech-debt/roles/planner/role.md +69 -0
- package/.codex/skills/team-tech-debt/roles/scanner/role.md +82 -0
- package/.codex/skills/team-tech-debt/roles/validator/role.md +75 -0
- package/.codex/skills/team-tech-debt/specs/pipelines.md +47 -0
- package/.codex/skills/team-tech-debt/specs/team-config.json +129 -0
- package/.codex/skills/team-testing/SKILL.md +237 -0
- package/.codex/skills/team-testing/roles/analyst/role.md +95 -0
- package/.codex/skills/team-testing/roles/coordinator/commands/analyze.md +70 -0
- package/.codex/skills/team-testing/roles/coordinator/commands/dispatch.md +106 -0
- package/.codex/skills/team-testing/roles/coordinator/commands/monitor.md +283 -0
- package/.codex/skills/team-testing/roles/coordinator/role.md +184 -0
- package/.codex/skills/team-testing/roles/executor/role.md +96 -0
- package/.codex/skills/team-testing/roles/generator/role.md +95 -0
- package/.codex/skills/team-testing/roles/strategist/role.md +83 -0
- package/.codex/skills/team-testing/specs/pipelines.md +101 -0
- package/.codex/skills/team-testing/specs/team-config.json +93 -0
- package/README.md +323 -0
- package/README.zh-CN.md +323 -0
- package/bin/maestro-context-monitor.js +3 -0
- package/bin/maestro-mcp.js +2 -0
- package/bin/maestro-statusline.js +4 -0
- package/bin/maestro.js +2 -0
- package/chains/_intent-map.json +259 -0
- package/chains/_router.json +201 -0
- package/chains/analyze-plan-execute.json +50 -0
- package/chains/brainstorm-driven.json +79 -0
- package/chains/execute-verify.json +59 -0
- package/chains/full-lifecycle.json +112 -0
- package/chains/issue-lifecycle.json +74 -0
- package/chains/milestone-close.json +29 -0
- package/chains/next-milestone.json +49 -0
- package/chains/quality-loop.json +94 -0
- package/chains/roadmap-driven.json +70 -0
- package/chains/singles/analyze.json +23 -0
- package/chains/singles/brainstorm.json +31 -0
- package/chains/singles/codebase-rebuild.json +26 -0
- package/chains/singles/codebase-refresh.json +26 -0
- package/chains/singles/debug.json +26 -0
- package/chains/singles/execute.json +26 -0
- package/chains/singles/init.json +23 -0
- package/chains/singles/integration-test.json +32 -0
- package/chains/singles/issue-analyze.json +31 -0
- package/chains/singles/issue-discover.json +31 -0
- package/chains/singles/issue-execute.json +31 -0
- package/chains/singles/issue-plan.json +31 -0
- package/chains/singles/issue.json +31 -0
- package/chains/singles/memory-capture.json +31 -0
- package/chains/singles/memory.json +31 -0
- package/chains/singles/milestone-audit.json +26 -0
- package/chains/singles/milestone-complete.json +26 -0
- package/chains/singles/phase-add.json +31 -0
- package/chains/singles/phase-transition.json +23 -0
- package/chains/singles/plan.json +27 -0
- package/chains/singles/quick.json +23 -0
- package/chains/singles/refactor.json +31 -0
- package/chains/singles/review.json +26 -0
- package/chains/singles/roadmap.json +31 -0
- package/chains/singles/spec-add.json +30 -0
- package/chains/singles/spec-generate.json +31 -0
- package/chains/singles/spec-load.json +30 -0
- package/chains/singles/spec-map.json +25 -0
- package/chains/singles/spec-setup.json +25 -0
- package/chains/singles/status.json +23 -0
- package/chains/singles/sync.json +32 -0
- package/chains/singles/team-coordinate.json +30 -0
- package/chains/singles/team-lifecycle.json +30 -0
- package/chains/singles/team-qa.json +31 -0
- package/chains/singles/team-review.json +31 -0
- package/chains/singles/team-tech-debt.json +31 -0
- package/chains/singles/team-testing.json +31 -0
- package/chains/singles/test-gen.json +32 -0
- package/chains/singles/test.json +26 -0
- package/chains/singles/ui-design.json +32 -0
- package/chains/singles/verify.json +26 -0
- package/chains/spec-driven.json +71 -0
- package/chains/ui-design-driven.json +64 -0
- package/dashboard/dist/assets/ArtifactsPage-D4xlwipN.js +3 -0
- package/dashboard/dist/assets/ChatInput-BQOmqgT5.js +67 -0
- package/dashboard/dist/assets/ChatPage-ekwfjZ-o.js +13 -0
- package/dashboard/dist/assets/KanbanPage-DunfYPZJ.js +16 -0
- package/dashboard/dist/assets/MarkdownRenderer-Dzj8FtoS.js +29 -0
- package/dashboard/dist/assets/McpPage-CkBQZQKI.js +16 -0
- package/dashboard/dist/assets/RequirementBoardPage-BHQik0cq.js +16 -0
- package/dashboard/dist/assets/RequirementPage-Bpx8qxeM.js +21 -0
- package/dashboard/dist/assets/SpecsPage-BU8JN8fw.js +36 -0
- package/dashboard/dist/assets/SupervisorPage-DRBTi1AP.js +6 -0
- package/dashboard/dist/assets/TeamsPage-CQsOc_Y8.js +1 -0
- package/dashboard/dist/assets/TreeBrowser-qW732QzJ.js +6 -0
- package/dashboard/dist/assets/WorkflowPage-D_WsulGC.js +6 -0
- package/dashboard/dist/assets/arrow-left-CCpsKWvn.js +6 -0
- package/dashboard/dist/assets/check-BR4mIlFD.js +6 -0
- package/dashboard/dist/assets/chevron-down-Db25lGmH.js +6 -0
- package/dashboard/dist/assets/chevron-right-DecIDoxI.js +6 -0
- package/dashboard/dist/assets/circle-BKy_Br8I.js +6 -0
- package/dashboard/dist/assets/circle-alert-CgxlhUAB.js +6 -0
- package/dashboard/dist/assets/circle-check-BvHAis-E.js +6 -0
- package/dashboard/dist/assets/circle-check-big-sQZH_YFo.js +6 -0
- package/dashboard/dist/assets/code-CO9Rrog6.js +6 -0
- package/dashboard/dist/assets/columns-3-DjIJTp-x.js +6 -0
- package/dashboard/dist/assets/download-B5rSR4pZ.js +6 -0
- package/dashboard/dist/assets/en-C8KOT1y5.js +1 -0
- package/dashboard/dist/assets/folder-Ifcb352Q.js +16 -0
- package/dashboard/dist/assets/git-branch-DZ1y6CY2.js +6 -0
- package/dashboard/dist/assets/index-CCfPkIHn.js +216 -0
- package/dashboard/dist/assets/index-CdDNRt77.js +9 -0
- package/dashboard/dist/assets/index-mS23S2sK.css +1 -0
- package/dashboard/dist/assets/list-BPzXxr9I.js +6 -0
- package/dashboard/dist/assets/pen-line-C9NUqMyn.js +6 -0
- package/dashboard/dist/assets/proxy-IZ0Btp7q.js +1 -0
- package/dashboard/dist/assets/search-DGaQh9xt.js +6 -0
- package/dashboard/dist/assets/shallow-B1CDhozp.js +1 -0
- package/dashboard/dist/assets/table-9byuvFFR.js +6 -0
- package/dashboard/dist/assets/trash-2-BXzvgl88.js +6 -0
- package/dashboard/dist/assets/wrench-PwKK7ns0.js +11 -0
- package/dashboard/dist/assets/x-C8XWclL8.js +6 -0
- package/dashboard/dist/assets/zap-mmGtwzz8.js +6 -0
- package/dashboard/dist/assets/zh-CN-Bss6VKAV.js +1 -0
- package/dashboard/dist/index.html +19 -0
- package/dashboard/dist-server/server/agents/agent-manager.d.ts +47 -0
- package/dashboard/dist-server/server/agents/agent-manager.js +253 -0
- package/dashboard/dist-server/server/agents/agent-manager.js.map +1 -0
- package/dashboard/dist-server/server/agents/agent-manager.test.d.ts +1 -0
- package/dashboard/dist-server/server/agents/agent-manager.test.js +162 -0
- package/dashboard/dist-server/server/agents/agent-manager.test.js.map +1 -0
- package/dashboard/dist-server/server/agents/agent-sdk-adapter.d.ts +18 -0
- package/dashboard/dist-server/server/agents/agent-sdk-adapter.js +219 -0
- package/dashboard/dist-server/server/agents/agent-sdk-adapter.js.map +1 -0
- package/dashboard/dist-server/server/agents/base-adapter.d.ts +43 -0
- package/dashboard/dist-server/server/agents/base-adapter.js +107 -0
- package/dashboard/dist-server/server/agents/base-adapter.js.map +1 -0
- package/dashboard/dist-server/server/agents/claude-code-adapter.d.ts +18 -0
- package/dashboard/dist-server/server/agents/claude-code-adapter.js +305 -0
- package/dashboard/dist-server/server/agents/claude-code-adapter.js.map +1 -0
- package/dashboard/dist-server/server/agents/codex-app-server-adapter.d.ts +31 -0
- package/dashboard/dist-server/server/agents/codex-app-server-adapter.js +433 -0
- package/dashboard/dist-server/server/agents/codex-app-server-adapter.js.map +1 -0
- package/dashboard/dist-server/server/agents/codex-cli-adapter.d.ts +20 -0
- package/dashboard/dist-server/server/agents/codex-cli-adapter.js +264 -0
- package/dashboard/dist-server/server/agents/codex-cli-adapter.js.map +1 -0
- package/dashboard/dist-server/server/agents/entry-normalizer.d.ts +16 -0
- package/dashboard/dist-server/server/agents/entry-normalizer.js +126 -0
- package/dashboard/dist-server/server/agents/entry-normalizer.js.map +1 -0
- package/dashboard/dist-server/server/agents/entry-normalizer.test.d.ts +1 -0
- package/dashboard/dist-server/server/agents/entry-normalizer.test.js +128 -0
- package/dashboard/dist-server/server/agents/entry-normalizer.test.js.map +1 -0
- package/dashboard/dist-server/server/agents/env-cleanup.d.ts +7 -0
- package/dashboard/dist-server/server/agents/env-cleanup.js +36 -0
- package/dashboard/dist-server/server/agents/env-cleanup.js.map +1 -0
- package/dashboard/dist-server/server/agents/env-file-loader.d.ts +6 -0
- package/dashboard/dist-server/server/agents/env-file-loader.js +55 -0
- package/dashboard/dist-server/server/agents/env-file-loader.js.map +1 -0
- package/dashboard/dist-server/server/agents/opencode-adapter.d.ts +15 -0
- package/dashboard/dist-server/server/agents/opencode-adapter.js +188 -0
- package/dashboard/dist-server/server/agents/opencode-adapter.js.map +1 -0
- package/dashboard/dist-server/server/agents/sdk-message-translator.d.ts +38 -0
- package/dashboard/dist-server/server/agents/sdk-message-translator.js +268 -0
- package/dashboard/dist-server/server/agents/sdk-message-translator.js.map +1 -0
- package/dashboard/dist-server/server/agents/sdk-message-translator.test.d.ts +1 -0
- package/dashboard/dist-server/server/agents/sdk-message-translator.test.js +327 -0
- package/dashboard/dist-server/server/agents/sdk-message-translator.test.js.map +1 -0
- package/dashboard/dist-server/server/agents/stream-json-adapter.d.ts +24 -0
- package/dashboard/dist-server/server/agents/stream-json-adapter.js +289 -0
- package/dashboard/dist-server/server/agents/stream-json-adapter.js.map +1 -0
- package/dashboard/dist-server/server/agents/stream-monitor.d.ts +16 -0
- package/dashboard/dist-server/server/agents/stream-monitor.js +34 -0
- package/dashboard/dist-server/server/agents/stream-monitor.js.map +1 -0
- package/dashboard/dist-server/server/agents/tools/issue-mcp-server.d.ts +2 -0
- package/dashboard/dist-server/server/agents/tools/issue-mcp-server.js +111 -0
- package/dashboard/dist-server/server/agents/tools/issue-mcp-server.js.map +1 -0
- package/dashboard/dist-server/server/agents/tools/issue-mcp-server.test.d.ts +1 -0
- package/dashboard/dist-server/server/agents/tools/issue-mcp-server.test.js +286 -0
- package/dashboard/dist-server/server/agents/tools/issue-mcp-server.test.js.map +1 -0
- package/dashboard/dist-server/server/commander/commander-agent.d.ts +49 -0
- package/dashboard/dist-server/server/commander/commander-agent.js +478 -0
- package/dashboard/dist-server/server/commander/commander-agent.js.map +1 -0
- package/dashboard/dist-server/server/commander/commander-agent.test.d.ts +1 -0
- package/dashboard/dist-server/server/commander/commander-agent.test.js +930 -0
- package/dashboard/dist-server/server/commander/commander-agent.test.js.map +1 -0
- package/dashboard/dist-server/server/commander/commander-config.d.ts +22 -0
- package/dashboard/dist-server/server/commander/commander-config.js +172 -0
- package/dashboard/dist-server/server/commander/commander-config.js.map +1 -0
- package/dashboard/dist-server/server/commander/commander-config.test.d.ts +1 -0
- package/dashboard/dist-server/server/commander/commander-config.test.js +253 -0
- package/dashboard/dist-server/server/commander/commander-config.test.js.map +1 -0
- package/dashboard/dist-server/server/commander/commander-prompts.d.ts +16 -0
- package/dashboard/dist-server/server/commander/commander-prompts.js +139 -0
- package/dashboard/dist-server/server/commander/commander-prompts.js.map +1 -0
- package/dashboard/dist-server/server/commander/commander-prompts.test.d.ts +1 -0
- package/dashboard/dist-server/server/commander/commander-prompts.test.js +183 -0
- package/dashboard/dist-server/server/commander/commander-prompts.test.js.map +1 -0
- package/dashboard/dist-server/server/commander/commander-routes.d.ts +12 -0
- package/dashboard/dist-server/server/commander/commander-routes.js +116 -0
- package/dashboard/dist-server/server/commander/commander-routes.js.map +1 -0
- package/dashboard/dist-server/server/commander/commander-routes.test.d.ts +1 -0
- package/dashboard/dist-server/server/commander/commander-routes.test.js +177 -0
- package/dashboard/dist-server/server/commander/commander-routes.test.js.map +1 -0
- package/dashboard/dist-server/server/config.d.ts +28 -0
- package/dashboard/dist-server/server/config.js +67 -0
- package/dashboard/dist-server/server/config.js.map +1 -0
- package/dashboard/dist-server/server/coordinator/agents/intent-classifier-agent.d.ts +5 -0
- package/dashboard/dist-server/server/coordinator/agents/intent-classifier-agent.js +97 -0
- package/dashboard/dist-server/server/coordinator/agents/intent-classifier-agent.js.map +1 -0
- package/dashboard/dist-server/server/coordinator/agents/quality-reviewer-agent.d.ts +5 -0
- package/dashboard/dist-server/server/coordinator/agents/quality-reviewer-agent.js +86 -0
- package/dashboard/dist-server/server/coordinator/agents/quality-reviewer-agent.js.map +1 -0
- package/dashboard/dist-server/server/coordinator/agents/state-analyzer-agent.d.ts +10 -0
- package/dashboard/dist-server/server/coordinator/agents/state-analyzer-agent.js +112 -0
- package/dashboard/dist-server/server/coordinator/agents/state-analyzer-agent.js.map +1 -0
- package/dashboard/dist-server/server/coordinator/chain-map.d.ts +16 -0
- package/dashboard/dist-server/server/coordinator/chain-map.js +163 -0
- package/dashboard/dist-server/server/coordinator/chain-map.js.map +1 -0
- package/dashboard/dist-server/server/coordinator/chain-map.test.d.ts +1 -0
- package/dashboard/dist-server/server/coordinator/chain-map.test.js +230 -0
- package/dashboard/dist-server/server/coordinator/chain-map.test.js.map +1 -0
- package/dashboard/dist-server/server/coordinator/coordinate-runner.d.ts +41 -0
- package/dashboard/dist-server/server/coordinator/coordinate-runner.js +511 -0
- package/dashboard/dist-server/server/coordinator/coordinate-runner.js.map +1 -0
- package/dashboard/dist-server/server/coordinator/coordinator-routes.d.ts +12 -0
- package/dashboard/dist-server/server/coordinator/coordinator-routes.js +84 -0
- package/dashboard/dist-server/server/coordinator/coordinator-routes.js.map +1 -0
- package/dashboard/dist-server/server/coordinator/coordinator-routes.test.d.ts +1 -0
- package/dashboard/dist-server/server/coordinator/coordinator-routes.test.js +233 -0
- package/dashboard/dist-server/server/coordinator/coordinator-routes.test.js.map +1 -0
- package/dashboard/dist-server/server/coordinator/dashboard-executor.d.ts +13 -0
- package/dashboard/dist-server/server/coordinator/dashboard-executor.js +98 -0
- package/dashboard/dist-server/server/coordinator/dashboard-executor.js.map +1 -0
- package/dashboard/dist-server/server/coordinator/dashboard-step-analyzer.d.ts +7 -0
- package/dashboard/dist-server/server/coordinator/dashboard-step-analyzer.js +34 -0
- package/dashboard/dist-server/server/coordinator/dashboard-step-analyzer.js.map +1 -0
- package/dashboard/dist-server/server/coordinator/graph-walker-factory.d.ts +22 -0
- package/dashboard/dist-server/server/coordinator/graph-walker-factory.js +53 -0
- package/dashboard/dist-server/server/coordinator/graph-walker-factory.js.map +1 -0
- package/dashboard/dist-server/server/coordinator/prompts/index.d.ts +18 -0
- package/dashboard/dist-server/server/coordinator/prompts/index.js +82 -0
- package/dashboard/dist-server/server/coordinator/prompts/index.js.map +1 -0
- package/dashboard/dist-server/server/coordinator/tools/workflow-mcp-server.d.ts +3 -0
- package/dashboard/dist-server/server/coordinator/tools/workflow-mcp-server.js +109 -0
- package/dashboard/dist-server/server/coordinator/tools/workflow-mcp-server.js.map +1 -0
- package/dashboard/dist-server/server/coordinator/types.d.ts +51 -0
- package/dashboard/dist-server/server/coordinator/types.js +5 -0
- package/dashboard/dist-server/server/coordinator/types.js.map +1 -0
- package/dashboard/dist-server/server/coordinator/walker-event-bridge.d.ts +9 -0
- package/dashboard/dist-server/server/coordinator/walker-event-bridge.js +61 -0
- package/dashboard/dist-server/server/coordinator/walker-event-bridge.js.map +1 -0
- package/dashboard/dist-server/server/coordinator/workflow-coordinator.d.ts +39 -0
- package/dashboard/dist-server/server/coordinator/workflow-coordinator.js +250 -0
- package/dashboard/dist-server/server/coordinator/workflow-coordinator.js.map +1 -0
- package/dashboard/dist-server/server/coordinator/workflow-coordinator.test.d.ts +1 -0
- package/dashboard/dist-server/server/coordinator/workflow-coordinator.test.js +247 -0
- package/dashboard/dist-server/server/coordinator/workflow-coordinator.test.js.map +1 -0
- package/dashboard/dist-server/server/execution/dispatch-strategy.d.ts +33 -0
- package/dashboard/dist-server/server/execution/dispatch-strategy.js +5 -0
- package/dashboard/dist-server/server/execution/dispatch-strategy.js.map +1 -0
- package/dashboard/dist-server/server/execution/execution-journal.d.ts +16 -0
- package/dashboard/dist-server/server/execution/execution-journal.js +100 -0
- package/dashboard/dist-server/server/execution/execution-journal.js.map +1 -0
- package/dashboard/dist-server/server/execution/execution-scheduler.d.ts +126 -0
- package/dashboard/dist-server/server/execution/execution-scheduler.js +1101 -0
- package/dashboard/dist-server/server/execution/execution-scheduler.js.map +1 -0
- package/dashboard/dist-server/server/execution/execution-scheduler.test.d.ts +1 -0
- package/dashboard/dist-server/server/execution/execution-scheduler.test.js +129 -0
- package/dashboard/dist-server/server/execution/execution-scheduler.test.js.map +1 -0
- package/dashboard/dist-server/server/execution/strategies/commander-strategy.d.ts +8 -0
- package/dashboard/dist-server/server/execution/strategies/commander-strategy.js +24 -0
- package/dashboard/dist-server/server/execution/strategies/commander-strategy.js.map +1 -0
- package/dashboard/dist-server/server/execution/strategies/priority-strategy.d.ts +5 -0
- package/dashboard/dist-server/server/execution/strategies/priority-strategy.js +33 -0
- package/dashboard/dist-server/server/execution/strategies/priority-strategy.js.map +1 -0
- package/dashboard/dist-server/server/execution/strategies/smart-strategy.d.ts +5 -0
- package/dashboard/dist-server/server/execution/strategies/smart-strategy.js +53 -0
- package/dashboard/dist-server/server/execution/strategies/smart-strategy.js.map +1 -0
- package/dashboard/dist-server/server/execution/wave-executor.d.ts +32 -0
- package/dashboard/dist-server/server/execution/wave-executor.js +434 -0
- package/dashboard/dist-server/server/execution/wave-executor.js.map +1 -0
- package/dashboard/dist-server/server/execution/workspace-manager.d.ts +49 -0
- package/dashboard/dist-server/server/execution/workspace-manager.js +155 -0
- package/dashboard/dist-server/server/execution/workspace-manager.js.map +1 -0
- package/dashboard/dist-server/server/index.d.ts +1 -0
- package/dashboard/dist-server/server/index.js +207 -0
- package/dashboard/dist-server/server/index.js.map +1 -0
- package/dashboard/dist-server/server/observability/observability-routes.d.ts +7 -0
- package/dashboard/dist-server/server/observability/observability-routes.js +41 -0
- package/dashboard/dist-server/server/observability/observability-routes.js.map +1 -0
- package/dashboard/dist-server/server/observability/observability-service.d.ts +19 -0
- package/dashboard/dist-server/server/observability/observability-service.js +107 -0
- package/dashboard/dist-server/server/observability/observability-service.js.map +1 -0
- package/dashboard/dist-server/server/prompt/builders/assessment-builder.d.ts +5 -0
- package/dashboard/dist-server/server/prompt/builders/assessment-builder.js +72 -0
- package/dashboard/dist-server/server/prompt/builders/assessment-builder.js.map +1 -0
- package/dashboard/dist-server/server/prompt/builders/decompose-builder.d.ts +5 -0
- package/dashboard/dist-server/server/prompt/builders/decompose-builder.js +44 -0
- package/dashboard/dist-server/server/prompt/builders/decompose-builder.js.map +1 -0
- package/dashboard/dist-server/server/prompt/builders/direct-builder.d.ts +5 -0
- package/dashboard/dist-server/server/prompt/builders/direct-builder.js +51 -0
- package/dashboard/dist-server/server/prompt/builders/direct-builder.js.map +1 -0
- package/dashboard/dist-server/server/prompt/builders/skill-builder.d.ts +5 -0
- package/dashboard/dist-server/server/prompt/builders/skill-builder.js +30 -0
- package/dashboard/dist-server/server/prompt/builders/skill-builder.js.map +1 -0
- package/dashboard/dist-server/server/prompt/builders/template-builder.d.ts +5 -0
- package/dashboard/dist-server/server/prompt/builders/template-builder.js +26 -0
- package/dashboard/dist-server/server/prompt/builders/template-builder.js.map +1 -0
- package/dashboard/dist-server/server/prompt/prompt-builder.d.ts +21 -0
- package/dashboard/dist-server/server/prompt/prompt-builder.js +5 -0
- package/dashboard/dist-server/server/prompt/prompt-builder.js.map +1 -0
- package/dashboard/dist-server/server/prompt/prompt-registry.d.ts +8 -0
- package/dashboard/dist-server/server/prompt/prompt-registry.js +30 -0
- package/dashboard/dist-server/server/prompt/prompt-registry.js.map +1 -0
- package/dashboard/dist-server/server/requirement/requirement-expander.d.ts +38 -0
- package/dashboard/dist-server/server/requirement/requirement-expander.js +384 -0
- package/dashboard/dist-server/server/requirement/requirement-expander.js.map +1 -0
- package/dashboard/dist-server/server/requirement/requirement-prompts.d.ts +7 -0
- package/dashboard/dist-server/server/requirement/requirement-prompts.js +200 -0
- package/dashboard/dist-server/server/requirement/requirement-prompts.js.map +1 -0
- package/dashboard/dist-server/server/routes/agents.d.ts +13 -0
- package/dashboard/dist-server/server/routes/agents.js +124 -0
- package/dashboard/dist-server/server/routes/agents.js.map +1 -0
- package/dashboard/dist-server/server/routes/artifacts.d.ts +2 -0
- package/dashboard/dist-server/server/routes/artifacts.js +109 -0
- package/dashboard/dist-server/server/routes/artifacts.js.map +1 -0
- package/dashboard/dist-server/server/routes/board-state.integration.test.d.ts +1 -0
- package/dashboard/dist-server/server/routes/board-state.integration.test.js +240 -0
- package/dashboard/dist-server/server/routes/board-state.integration.test.js.map +1 -0
- package/dashboard/dist-server/server/routes/board.d.ts +9 -0
- package/dashboard/dist-server/server/routes/board.js +18 -0
- package/dashboard/dist-server/server/routes/board.js.map +1 -0
- package/dashboard/dist-server/server/routes/cli-history.d.ts +8 -0
- package/dashboard/dist-server/server/routes/cli-history.js +85 -0
- package/dashboard/dist-server/server/routes/cli-history.js.map +1 -0
- package/dashboard/dist-server/server/routes/events.d.ts +13 -0
- package/dashboard/dist-server/server/routes/events.js +52 -0
- package/dashboard/dist-server/server/routes/events.js.map +1 -0
- package/dashboard/dist-server/server/routes/events.test.d.ts +1 -0
- package/dashboard/dist-server/server/routes/events.test.js +127 -0
- package/dashboard/dist-server/server/routes/events.test.js.map +1 -0
- package/dashboard/dist-server/server/routes/execution.d.ts +12 -0
- package/dashboard/dist-server/server/routes/execution.integration.test.d.ts +1 -0
- package/dashboard/dist-server/server/routes/execution.integration.test.js +280 -0
- package/dashboard/dist-server/server/routes/execution.integration.test.js.map +1 -0
- package/dashboard/dist-server/server/routes/execution.js +103 -0
- package/dashboard/dist-server/server/routes/execution.js.map +1 -0
- package/dashboard/dist-server/server/routes/health.d.ts +3 -0
- package/dashboard/dist-server/server/routes/health.js +84 -0
- package/dashboard/dist-server/server/routes/health.js.map +1 -0
- package/dashboard/dist-server/server/routes/index.d.ts +28 -0
- package/dashboard/dist-server/server/routes/index.js +97 -0
- package/dashboard/dist-server/server/routes/index.js.map +1 -0
- package/dashboard/dist-server/server/routes/install-utils.d.ts +55 -0
- package/dashboard/dist-server/server/routes/install-utils.js +278 -0
- package/dashboard/dist-server/server/routes/install-utils.js.map +1 -0
- package/dashboard/dist-server/server/routes/install.d.ts +8 -0
- package/dashboard/dist-server/server/routes/install.js +191 -0
- package/dashboard/dist-server/server/routes/install.js.map +1 -0
- package/dashboard/dist-server/server/routes/issues.d.ts +13 -0
- package/dashboard/dist-server/server/routes/issues.js +328 -0
- package/dashboard/dist-server/server/routes/issues.js.map +1 -0
- package/dashboard/dist-server/server/routes/issues.test.d.ts +1 -0
- package/dashboard/dist-server/server/routes/issues.test.js +346 -0
- package/dashboard/dist-server/server/routes/issues.test.js.map +1 -0
- package/dashboard/dist-server/server/routes/linear.d.ts +2 -0
- package/dashboard/dist-server/server/routes/linear.js +341 -0
- package/dashboard/dist-server/server/routes/linear.js.map +1 -0
- package/dashboard/dist-server/server/routes/mcp-templates-store.d.ts +30 -0
- package/dashboard/dist-server/server/routes/mcp-templates-store.js +110 -0
- package/dashboard/dist-server/server/routes/mcp-templates-store.js.map +1 -0
- package/dashboard/dist-server/server/routes/mcp.d.ts +2 -0
- package/dashboard/dist-server/server/routes/mcp.js +718 -0
- package/dashboard/dist-server/server/routes/mcp.js.map +1 -0
- package/dashboard/dist-server/server/routes/phases.d.ts +10 -0
- package/dashboard/dist-server/server/routes/phases.js +40 -0
- package/dashboard/dist-server/server/routes/phases.js.map +1 -0
- package/dashboard/dist-server/server/routes/requirements.d.ts +12 -0
- package/dashboard/dist-server/server/routes/requirements.js +130 -0
- package/dashboard/dist-server/server/routes/requirements.js.map +1 -0
- package/dashboard/dist-server/server/routes/scratch.d.ts +8 -0
- package/dashboard/dist-server/server/routes/scratch.js +15 -0
- package/dashboard/dist-server/server/routes/scratch.js.map +1 -0
- package/dashboard/dist-server/server/routes/settings.d.ts +2 -0
- package/dashboard/dist-server/server/routes/settings.js +450 -0
- package/dashboard/dist-server/server/routes/settings.js.map +1 -0
- package/dashboard/dist-server/server/routes/specs.d.ts +21 -0
- package/dashboard/dist-server/server/routes/specs.integration.test.d.ts +1 -0
- package/dashboard/dist-server/server/routes/specs.integration.test.js +613 -0
- package/dashboard/dist-server/server/routes/specs.integration.test.js.map +1 -0
- package/dashboard/dist-server/server/routes/specs.js +419 -0
- package/dashboard/dist-server/server/routes/specs.js.map +1 -0
- package/dashboard/dist-server/server/routes/supervisor.d.ts +22 -0
- package/dashboard/dist-server/server/routes/supervisor.js +195 -0
- package/dashboard/dist-server/server/routes/supervisor.js.map +1 -0
- package/dashboard/dist-server/server/routes/supervisor.test.d.ts +1 -0
- package/dashboard/dist-server/server/routes/supervisor.test.js +473 -0
- package/dashboard/dist-server/server/routes/supervisor.test.js.map +1 -0
- package/dashboard/dist-server/server/routes/teams.d.ts +2 -0
- package/dashboard/dist-server/server/routes/teams.js +418 -0
- package/dashboard/dist-server/server/routes/teams.js.map +1 -0
- package/dashboard/dist-server/server/routes/workspace.d.ts +2 -0
- package/dashboard/dist-server/server/routes/workspace.js +92 -0
- package/dashboard/dist-server/server/routes/workspace.js.map +1 -0
- package/dashboard/dist-server/server/sse/sse-hub.d.ts +33 -0
- package/dashboard/dist-server/server/sse/sse-hub.js +112 -0
- package/dashboard/dist-server/server/sse/sse-hub.js.map +1 -0
- package/dashboard/dist-server/server/sse/sse-hub.test.d.ts +1 -0
- package/dashboard/dist-server/server/sse/sse-hub.test.js +128 -0
- package/dashboard/dist-server/server/sse/sse-hub.test.js.map +1 -0
- package/dashboard/dist-server/server/state/event-bus.d.ts +97 -0
- package/dashboard/dist-server/server/state/event-bus.js +110 -0
- package/dashboard/dist-server/server/state/event-bus.js.map +1 -0
- package/dashboard/dist-server/server/state/file-reader.d.ts +9 -0
- package/dashboard/dist-server/server/state/file-reader.js +54 -0
- package/dashboard/dist-server/server/state/file-reader.js.map +1 -0
- package/dashboard/dist-server/server/state/fs-watcher.d.ts +19 -0
- package/dashboard/dist-server/server/state/fs-watcher.js +94 -0
- package/dashboard/dist-server/server/state/fs-watcher.js.map +1 -0
- package/dashboard/dist-server/server/state/state-manager.d.ts +31 -0
- package/dashboard/dist-server/server/state/state-manager.js +297 -0
- package/dashboard/dist-server/server/state/state-manager.js.map +1 -0
- package/dashboard/dist-server/server/state/state-manager.test.d.ts +1 -0
- package/dashboard/dist-server/server/state/state-manager.test.js +258 -0
- package/dashboard/dist-server/server/state/state-manager.test.js.map +1 -0
- package/dashboard/dist-server/server/supervisor/extension-manager.d.ts +18 -0
- package/dashboard/dist-server/server/supervisor/extension-manager.js +62 -0
- package/dashboard/dist-server/server/supervisor/extension-manager.js.map +1 -0
- package/dashboard/dist-server/server/supervisor/extension-manager.test.d.ts +1 -0
- package/dashboard/dist-server/server/supervisor/extension-manager.test.js +160 -0
- package/dashboard/dist-server/server/supervisor/extension-manager.test.js.map +1 -0
- package/dashboard/dist-server/server/supervisor/self-learning-service.d.ts +29 -0
- package/dashboard/dist-server/server/supervisor/self-learning-service.js +291 -0
- package/dashboard/dist-server/server/supervisor/self-learning-service.js.map +1 -0
- package/dashboard/dist-server/server/supervisor/self-learning-service.test.d.ts +1 -0
- package/dashboard/dist-server/server/supervisor/self-learning-service.test.js +430 -0
- package/dashboard/dist-server/server/supervisor/self-learning-service.test.js.map +1 -0
- package/dashboard/dist-server/server/supervisor/supervisor.integration.test.d.ts +1 -0
- package/dashboard/dist-server/server/supervisor/supervisor.integration.test.js +226 -0
- package/dashboard/dist-server/server/supervisor/supervisor.integration.test.js.map +1 -0
- package/dashboard/dist-server/server/supervisor/task-scheduler-service.d.ts +60 -0
- package/dashboard/dist-server/server/supervisor/task-scheduler-service.js +345 -0
- package/dashboard/dist-server/server/supervisor/task-scheduler-service.js.map +1 -0
- package/dashboard/dist-server/server/supervisor/task-scheduler-service.test.d.ts +1 -0
- package/dashboard/dist-server/server/supervisor/task-scheduler-service.test.js +707 -0
- package/dashboard/dist-server/server/supervisor/task-scheduler-service.test.js.map +1 -0
- package/dashboard/dist-server/server/utils/issue-store.d.ts +10 -0
- package/dashboard/dist-server/server/utils/issue-store.js +71 -0
- package/dashboard/dist-server/server/utils/issue-store.js.map +1 -0
- package/dashboard/dist-server/server/utils/issue-store.test.d.ts +1 -0
- package/dashboard/dist-server/server/utils/issue-store.test.js +100 -0
- package/dashboard/dist-server/server/utils/issue-store.test.js.map +1 -0
- package/dashboard/dist-server/server/ws/handlers/agent-handler.d.ts +19 -0
- package/dashboard/dist-server/server/ws/handlers/agent-handler.js +93 -0
- package/dashboard/dist-server/server/ws/handlers/agent-handler.js.map +1 -0
- package/dashboard/dist-server/server/ws/handlers/commander-handler.d.ts +10 -0
- package/dashboard/dist-server/server/ws/handlers/commander-handler.js +41 -0
- package/dashboard/dist-server/server/ws/handlers/commander-handler.js.map +1 -0
- package/dashboard/dist-server/server/ws/handlers/coordinate-handler.d.ts +10 -0
- package/dashboard/dist-server/server/ws/handlers/coordinate-handler.js +34 -0
- package/dashboard/dist-server/server/ws/handlers/coordinate-handler.js.map +1 -0
- package/dashboard/dist-server/server/ws/handlers/execution-handler.d.ts +24 -0
- package/dashboard/dist-server/server/ws/handlers/execution-handler.js +157 -0
- package/dashboard/dist-server/server/ws/handlers/execution-handler.js.map +1 -0
- package/dashboard/dist-server/server/ws/handlers/requirement-handler.d.ts +10 -0
- package/dashboard/dist-server/server/ws/handlers/requirement-handler.js +50 -0
- package/dashboard/dist-server/server/ws/handlers/requirement-handler.js.map +1 -0
- package/dashboard/dist-server/server/ws/handlers/supervisor-handler.d.ts +12 -0
- package/dashboard/dist-server/server/ws/handlers/supervisor-handler.js +35 -0
- package/dashboard/dist-server/server/ws/handlers/supervisor-handler.js.map +1 -0
- package/dashboard/dist-server/server/ws/handlers/supervisor-handler.test.d.ts +1 -0
- package/dashboard/dist-server/server/ws/handlers/supervisor-handler.test.js +127 -0
- package/dashboard/dist-server/server/ws/handlers/supervisor-handler.test.js.map +1 -0
- package/dashboard/dist-server/server/ws/ws-handler.d.ts +8 -0
- package/dashboard/dist-server/server/ws/ws-handler.js +2 -0
- package/dashboard/dist-server/server/ws/ws-handler.js.map +1 -0
- package/dashboard/dist-server/server/ws/ws-manager.d.ts +33 -0
- package/dashboard/dist-server/server/ws/ws-manager.js +124 -0
- package/dashboard/dist-server/server/ws/ws-manager.js.map +1 -0
- package/dashboard/dist-server/shared/agent-types.d.ts +143 -0
- package/dashboard/dist-server/shared/agent-types.js +5 -0
- package/dashboard/dist-server/shared/agent-types.js.map +1 -0
- package/dashboard/dist-server/shared/commander-types.d.ts +86 -0
- package/dashboard/dist-server/shared/commander-types.js +37 -0
- package/dashboard/dist-server/shared/commander-types.js.map +1 -0
- package/dashboard/dist-server/shared/constants.d.ts +110 -0
- package/dashboard/dist-server/shared/constants.js +293 -0
- package/dashboard/dist-server/shared/constants.js.map +1 -0
- package/dashboard/dist-server/shared/constants.test.d.ts +1 -0
- package/dashboard/dist-server/shared/constants.test.js +126 -0
- package/dashboard/dist-server/shared/constants.test.js.map +1 -0
- package/dashboard/dist-server/shared/coordinate-types.d.ts +55 -0
- package/dashboard/dist-server/shared/coordinate-types.js +5 -0
- package/dashboard/dist-server/shared/coordinate-types.js.map +1 -0
- package/dashboard/dist-server/shared/execution-types.d.ts +86 -0
- package/dashboard/dist-server/shared/execution-types.js +23 -0
- package/dashboard/dist-server/shared/execution-types.js.map +1 -0
- package/dashboard/dist-server/shared/extension-types.d.ts +30 -0
- package/dashboard/dist-server/shared/extension-types.js +5 -0
- package/dashboard/dist-server/shared/extension-types.js.map +1 -0
- package/dashboard/dist-server/shared/issue-types.d.ts +79 -0
- package/dashboard/dist-server/shared/issue-types.js +16 -0
- package/dashboard/dist-server/shared/issue-types.js.map +1 -0
- package/dashboard/dist-server/shared/issue-types.test.d.ts +1 -0
- package/dashboard/dist-server/shared/issue-types.test.js +124 -0
- package/dashboard/dist-server/shared/issue-types.test.js.map +1 -0
- package/dashboard/dist-server/shared/journal-types.d.ts +57 -0
- package/dashboard/dist-server/shared/journal-types.js +5 -0
- package/dashboard/dist-server/shared/journal-types.js.map +1 -0
- package/dashboard/dist-server/shared/learning-types.d.ts +31 -0
- package/dashboard/dist-server/shared/learning-types.js +5 -0
- package/dashboard/dist-server/shared/learning-types.js.map +1 -0
- package/dashboard/dist-server/shared/linear-types.d.ts +59 -0
- package/dashboard/dist-server/shared/linear-types.js +18 -0
- package/dashboard/dist-server/shared/linear-types.js.map +1 -0
- package/dashboard/dist-server/shared/requirement-types.d.ts +73 -0
- package/dashboard/dist-server/shared/requirement-types.js +5 -0
- package/dashboard/dist-server/shared/requirement-types.js.map +1 -0
- package/dashboard/dist-server/shared/schedule-types.d.ts +18 -0
- package/dashboard/dist-server/shared/schedule-types.js +5 -0
- package/dashboard/dist-server/shared/schedule-types.js.map +1 -0
- package/dashboard/dist-server/shared/team-types.d.ts +65 -0
- package/dashboard/dist-server/shared/team-types.js +54 -0
- package/dashboard/dist-server/shared/team-types.js.map +1 -0
- package/dashboard/dist-server/shared/types.d.ts +219 -0
- package/dashboard/dist-server/shared/types.js +2 -0
- package/dashboard/dist-server/shared/types.js.map +1 -0
- package/dashboard/dist-server/shared/utils.d.ts +2 -0
- package/dashboard/dist-server/shared/utils.js +6 -0
- package/dashboard/dist-server/shared/utils.js.map +1 -0
- package/dashboard/dist-server/shared/utils.test.d.ts +1 -0
- package/dashboard/dist-server/shared/utils.test.js +22 -0
- package/dashboard/dist-server/shared/utils.test.js.map +1 -0
- package/dashboard/dist-server/shared/wave-types.d.ts +41 -0
- package/dashboard/dist-server/shared/wave-types.js +5 -0
- package/dashboard/dist-server/shared/wave-types.js.map +1 -0
- package/dashboard/dist-server/shared/ws-protocol.d.ts +154 -0
- package/dashboard/dist-server/shared/ws-protocol.js +8 -0
- package/dashboard/dist-server/shared/ws-protocol.js.map +1 -0
- package/dashboard/package.json +59 -0
- package/dist/agents/cli-agent-runner.d.ts +20 -0
- package/dist/agents/cli-agent-runner.d.ts.map +1 -0
- package/dist/agents/cli-agent-runner.js +269 -0
- package/dist/agents/cli-agent-runner.js.map +1 -0
- package/dist/agents/cli-history-store.d.ts +47 -0
- package/dist/agents/cli-history-store.d.ts.map +1 -0
- package/dist/agents/cli-history-store.js +212 -0
- package/dist/agents/cli-history-store.js.map +1 -0
- package/dist/agents/dashboard-bridge.d.ts +34 -0
- package/dist/agents/dashboard-bridge.d.ts.map +1 -0
- package/dist/agents/dashboard-bridge.js +63 -0
- package/dist/agents/dashboard-bridge.js.map +1 -0
- package/dist/cli.d.ts +2 -0
- package/dist/cli.d.ts.map +1 -0
- package/dist/cli.js +34 -0
- package/dist/cli.js.map +1 -0
- package/dist/commands/cli.d.ts +3 -0
- package/dist/commands/cli.d.ts.map +1 -0
- package/dist/commands/cli.js +262 -0
- package/dist/commands/cli.js.map +1 -0
- package/dist/commands/coordinate.d.ts +3 -0
- package/dist/commands/coordinate.d.ts.map +1 -0
- package/dist/commands/coordinate.js +243 -0
- package/dist/commands/coordinate.js.map +1 -0
- package/dist/commands/ext.d.ts +3 -0
- package/dist/commands/ext.d.ts.map +1 -0
- package/dist/commands/ext.js +28 -0
- package/dist/commands/ext.js.map +1 -0
- package/dist/commands/hooks.d.ts +3 -0
- package/dist/commands/hooks.d.ts.map +1 -0
- package/dist/commands/hooks.js +119 -0
- package/dist/commands/hooks.js.map +1 -0
- package/dist/commands/install.d.ts +3 -0
- package/dist/commands/install.d.ts.map +1 -0
- package/dist/commands/install.js +583 -0
- package/dist/commands/install.js.map +1 -0
- package/dist/commands/launcher.d.ts +3 -0
- package/dist/commands/launcher.d.ts.map +1 -0
- package/dist/commands/launcher.js +635 -0
- package/dist/commands/launcher.js.map +1 -0
- package/dist/commands/link-coordinate.d.ts +3 -0
- package/dist/commands/link-coordinate.d.ts.map +1 -0
- package/dist/commands/link-coordinate.js +225 -0
- package/dist/commands/link-coordinate.js.map +1 -0
- package/dist/commands/run.d.ts +3 -0
- package/dist/commands/run.d.ts.map +1 -0
- package/dist/commands/run.js +15 -0
- package/dist/commands/run.js.map +1 -0
- package/dist/commands/serve.d.ts +3 -0
- package/dist/commands/serve.d.ts.map +1 -0
- package/dist/commands/serve.js +16 -0
- package/dist/commands/serve.js.map +1 -0
- package/dist/commands/spec.d.ts +8 -0
- package/dist/commands/spec.d.ts.map +1 -0
- package/dist/commands/spec.js +147 -0
- package/dist/commands/spec.js.map +1 -0
- package/dist/commands/stop.d.ts +3 -0
- package/dist/commands/stop.d.ts.map +1 -0
- package/dist/commands/stop.js +218 -0
- package/dist/commands/stop.js.map +1 -0
- package/dist/commands/tool.d.ts +3 -0
- package/dist/commands/tool.d.ts.map +1 -0
- package/dist/commands/tool.js +29 -0
- package/dist/commands/tool.js.map +1 -0
- package/dist/commands/uninstall.d.ts +3 -0
- package/dist/commands/uninstall.d.ts.map +1 -0
- package/dist/commands/uninstall.js +72 -0
- package/dist/commands/uninstall.js.map +1 -0
- package/dist/commands/view.d.ts +3 -0
- package/dist/commands/view.d.ts.map +1 -0
- package/dist/commands/view.js +337 -0
- package/dist/commands/view.js.map +1 -0
- package/dist/config/cli-tools-config.d.ts +26 -0
- package/dist/config/cli-tools-config.d.ts.map +1 -0
- package/dist/config/cli-tools-config.js +49 -0
- package/dist/config/cli-tools-config.js.map +1 -0
- package/dist/config/cli-tools-config.test.d.ts +2 -0
- package/dist/config/cli-tools-config.test.d.ts.map +1 -0
- package/dist/config/cli-tools-config.test.js +59 -0
- package/dist/config/cli-tools-config.test.js.map +1 -0
- package/dist/config/index.d.ts +4 -0
- package/dist/config/index.d.ts.map +1 -0
- package/dist/config/index.js +27 -0
- package/dist/config/index.js.map +1 -0
- package/dist/config/paths.d.ts +15 -0
- package/dist/config/paths.d.ts.map +1 -0
- package/dist/config/paths.js +27 -0
- package/dist/config/paths.js.map +1 -0
- package/dist/config/template-discovery.d.ts +32 -0
- package/dist/config/template-discovery.d.ts.map +1 -0
- package/dist/config/template-discovery.js +128 -0
- package/dist/config/template-discovery.js.map +1 -0
- package/dist/coordinator/cli-executor.d.ts +22 -0
- package/dist/coordinator/cli-executor.d.ts.map +1 -0
- package/dist/coordinator/cli-executor.js +49 -0
- package/dist/coordinator/cli-executor.js.map +1 -0
- package/dist/coordinator/expr-evaluator.d.ts +11 -0
- package/dist/coordinator/expr-evaluator.d.ts.map +1 -0
- package/dist/coordinator/expr-evaluator.js +351 -0
- package/dist/coordinator/expr-evaluator.js.map +1 -0
- package/dist/coordinator/graph-loader.d.ts +16 -0
- package/dist/coordinator/graph-loader.d.ts.map +1 -0
- package/dist/coordinator/graph-loader.js +190 -0
- package/dist/coordinator/graph-loader.js.map +1 -0
- package/dist/coordinator/graph-types.d.ts +287 -0
- package/dist/coordinator/graph-types.d.ts.map +1 -0
- package/dist/coordinator/graph-types.js +6 -0
- package/dist/coordinator/graph-types.js.map +1 -0
- package/dist/coordinator/graph-walker.d.ts +49 -0
- package/dist/coordinator/graph-walker.d.ts.map +1 -0
- package/dist/coordinator/graph-walker.js +527 -0
- package/dist/coordinator/graph-walker.js.map +1 -0
- package/dist/coordinator/index.d.ts +11 -0
- package/dist/coordinator/index.d.ts.map +1 -0
- package/dist/coordinator/index.js +13 -0
- package/dist/coordinator/index.js.map +1 -0
- package/dist/coordinator/intent-router.d.ts +11 -0
- package/dist/coordinator/intent-router.d.ts.map +1 -0
- package/dist/coordinator/intent-router.js +65 -0
- package/dist/coordinator/intent-router.js.map +1 -0
- package/dist/coordinator/link-session.d.ts +29 -0
- package/dist/coordinator/link-session.d.ts.map +1 -0
- package/dist/coordinator/link-session.js +192 -0
- package/dist/coordinator/link-session.js.map +1 -0
- package/dist/coordinator/link-walker.d.ts +56 -0
- package/dist/coordinator/link-walker.d.ts.map +1 -0
- package/dist/coordinator/link-walker.js +548 -0
- package/dist/coordinator/link-walker.js.map +1 -0
- package/dist/coordinator/output-parser.d.ts +5 -0
- package/dist/coordinator/output-parser.d.ts.map +1 -0
- package/dist/coordinator/output-parser.js +110 -0
- package/dist/coordinator/output-parser.js.map +1 -0
- package/dist/coordinator/prompt-assembler.d.ts +15 -0
- package/dist/coordinator/prompt-assembler.d.ts.map +1 -0
- package/dist/coordinator/prompt-assembler.js +228 -0
- package/dist/coordinator/prompt-assembler.js.map +1 -0
- package/dist/coordinator/step-analyzer.d.ts +8 -0
- package/dist/coordinator/step-analyzer.d.ts.map +1 -0
- package/dist/coordinator/step-analyzer.js +82 -0
- package/dist/coordinator/step-analyzer.js.map +1 -0
- package/dist/core/extension-loader.d.ts +11 -0
- package/dist/core/extension-loader.d.ts.map +1 -0
- package/dist/core/extension-loader.js +54 -0
- package/dist/core/extension-loader.js.map +1 -0
- package/dist/core/manifest.d.ts +24 -0
- package/dist/core/manifest.d.ts.map +1 -0
- package/dist/core/manifest.js +139 -0
- package/dist/core/manifest.js.map +1 -0
- package/dist/core/mcp-tool-registry.integration.test.d.ts +2 -0
- package/dist/core/mcp-tool-registry.integration.test.d.ts.map +1 -0
- package/dist/core/mcp-tool-registry.integration.test.js +220 -0
- package/dist/core/mcp-tool-registry.integration.test.js.map +1 -0
- package/dist/core/tool-registry.d.ts +10 -0
- package/dist/core/tool-registry.d.ts.map +1 -0
- package/dist/core/tool-registry.js +29 -0
- package/dist/core/tool-registry.js.map +1 -0
- package/dist/core/tool-registry.test.d.ts +2 -0
- package/dist/core/tool-registry.test.d.ts.map +1 -0
- package/dist/core/tool-registry.test.js +78 -0
- package/dist/core/tool-registry.test.js.map +1 -0
- package/dist/hooks/constants.d.ts +38 -0
- package/dist/hooks/constants.d.ts.map +1 -0
- package/dist/hooks/constants.js +51 -0
- package/dist/hooks/constants.js.map +1 -0
- package/dist/hooks/context-monitor.d.ts +33 -0
- package/dist/hooks/context-monitor.d.ts.map +1 -0
- package/dist/hooks/context-monitor.js +117 -0
- package/dist/hooks/context-monitor.js.map +1 -0
- package/dist/hooks/index.d.ts +4 -0
- package/dist/hooks/index.d.ts.map +1 -0
- package/dist/hooks/index.js +4 -0
- package/dist/hooks/index.js.map +1 -0
- package/dist/hooks/statusline.d.ts +29 -0
- package/dist/hooks/statusline.d.ts.map +1 -0
- package/dist/hooks/statusline.js +134 -0
- package/dist/hooks/statusline.js.map +1 -0
- package/dist/index.d.ts +8 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +6 -0
- package/dist/index.js.map +1 -0
- package/dist/mcp/server.d.ts +2 -0
- package/dist/mcp/server.d.ts.map +1 -0
- package/dist/mcp/server.js +41 -0
- package/dist/mcp/server.js.map +1 -0
- package/dist/tools/core-memory.d.ts +12 -0
- package/dist/tools/core-memory.d.ts.map +1 -0
- package/dist/tools/core-memory.js +276 -0
- package/dist/tools/core-memory.js.map +1 -0
- package/dist/tools/edit-file.d.ts +25 -0
- package/dist/tools/edit-file.d.ts.map +1 -0
- package/dist/tools/edit-file.js +462 -0
- package/dist/tools/edit-file.js.map +1 -0
- package/dist/tools/index.d.ts +3 -0
- package/dist/tools/index.d.ts.map +1 -0
- package/dist/tools/index.js +147 -0
- package/dist/tools/index.js.map +1 -0
- package/dist/tools/read-file.d.ts +13 -0
- package/dist/tools/read-file.d.ts.map +1 -0
- package/dist/tools/read-file.js +91 -0
- package/dist/tools/read-file.js.map +1 -0
- package/dist/tools/read-many-files.d.ts +15 -0
- package/dist/tools/read-many-files.d.ts.map +1 -0
- package/dist/tools/read-many-files.js +187 -0
- package/dist/tools/read-many-files.js.map +1 -0
- package/dist/tools/spec-index-builder.d.ts +58 -0
- package/dist/tools/spec-index-builder.d.ts.map +1 -0
- package/dist/tools/spec-index-builder.js +211 -0
- package/dist/tools/spec-index-builder.js.map +1 -0
- package/dist/tools/spec-init.d.ts +17 -0
- package/dist/tools/spec-init.d.ts.map +1 -0
- package/dist/tools/spec-init.js +215 -0
- package/dist/tools/spec-init.js.map +1 -0
- package/dist/tools/spec-keyword-extractor.d.ts +24 -0
- package/dist/tools/spec-keyword-extractor.d.ts.map +1 -0
- package/dist/tools/spec-keyword-extractor.js +84 -0
- package/dist/tools/spec-keyword-extractor.js.map +1 -0
- package/dist/tools/spec-keyword-extractor.test.d.ts +2 -0
- package/dist/tools/spec-keyword-extractor.test.d.ts.map +1 -0
- package/dist/tools/spec-keyword-extractor.test.js +99 -0
- package/dist/tools/spec-keyword-extractor.test.js.map +1 -0
- package/dist/tools/spec-loader.d.ts +15 -0
- package/dist/tools/spec-loader.d.ts.map +1 -0
- package/dist/tools/spec-loader.js +93 -0
- package/dist/tools/spec-loader.js.map +1 -0
- package/dist/tools/team-msg.d.ts +52 -0
- package/dist/tools/team-msg.d.ts.map +1 -0
- package/dist/tools/team-msg.js +449 -0
- package/dist/tools/team-msg.js.map +1 -0
- package/dist/tools/write-file.d.ts +19 -0
- package/dist/tools/write-file.d.ts.map +1 -0
- package/dist/tools/write-file.js +165 -0
- package/dist/tools/write-file.js.map +1 -0
- package/dist/types/index.d.ts +47 -0
- package/dist/types/index.d.ts.map +1 -0
- package/dist/types/index.js +2 -0
- package/dist/types/index.js.map +1 -0
- package/dist/types/tool-schema.d.ts +37 -0
- package/dist/types/tool-schema.d.ts.map +1 -0
- package/dist/types/tool-schema.js +24 -0
- package/dist/types/tool-schema.js.map +1 -0
- package/dist/utils/file-reader.d.ts +74 -0
- package/dist/utils/file-reader.d.ts.map +1 -0
- package/dist/utils/file-reader.js +217 -0
- package/dist/utils/file-reader.js.map +1 -0
- package/dist/utils/path-validator.d.ts +52 -0
- package/dist/utils/path-validator.d.ts.map +1 -0
- package/dist/utils/path-validator.js +151 -0
- package/dist/utils/path-validator.js.map +1 -0
- package/package.json +56 -0
- package/templates/cli/prompts/analysis-analyze-code-patterns.txt +37 -0
- package/templates/cli/prompts/analysis-analyze-performance.txt +29 -0
- package/templates/cli/prompts/analysis-analyze-technical-document.txt +33 -0
- package/templates/cli/prompts/analysis-assess-security-risks.txt +29 -0
- package/templates/cli/prompts/analysis-diagnose-bug-root-cause.txt +127 -0
- package/templates/cli/prompts/analysis-review-architecture.txt +29 -0
- package/templates/cli/prompts/analysis-review-code-quality.txt +28 -0
- package/templates/cli/prompts/analysis-review-quality-standards.txt +29 -0
- package/templates/cli/prompts/analysis-trace-code-execution.txt +115 -0
- package/templates/cli/prompts/coordinate-step-v2.md +38 -0
- package/templates/cli/prompts/coordinate-step.txt +26 -0
- package/templates/cli/prompts/development-debug-runtime-issues.txt +55 -0
- package/templates/cli/prompts/development-generate-tests.txt +70 -0
- package/templates/cli/prompts/development-implement-component-ui.txt +55 -0
- package/templates/cli/prompts/development-implement-feature.txt +58 -0
- package/templates/cli/prompts/development-refactor-codebase.txt +55 -0
- package/templates/cli/prompts/documentation-api.txt +15 -0
- package/templates/cli/prompts/documentation-folder-navigation.txt +27 -0
- package/templates/cli/prompts/documentation-module-readme.txt +49 -0
- package/templates/cli/prompts/documentation-project-architecture.txt +41 -0
- package/templates/cli/prompts/documentation-project-examples.txt +35 -0
- package/templates/cli/prompts/documentation-project-readme.txt +35 -0
- package/templates/cli/prompts/documentation-swagger-api.txt +266 -0
- package/templates/cli/prompts/memory-document-module-structure.txt +165 -0
- package/templates/cli/prompts/planning-breakdown-task-steps.txt +30 -0
- package/templates/cli/prompts/planning-design-component-spec.txt +28 -0
- package/templates/cli/prompts/planning-evaluate-concept-feasibility.txt +127 -0
- package/templates/cli/prompts/planning-plan-architecture-design.txt +109 -0
- package/templates/cli/prompts/planning-plan-migration-strategy.txt +30 -0
- package/templates/cli/prompts/rules-rule-api.txt +122 -0
- package/templates/cli/prompts/rules-rule-components.txt +122 -0
- package/templates/cli/prompts/rules-rule-config.txt +89 -0
- package/templates/cli/prompts/rules-rule-core.txt +60 -0
- package/templates/cli/prompts/rules-rule-patterns.txt +70 -0
- package/templates/cli/prompts/rules-rule-testing.txt +81 -0
- package/templates/cli/prompts/rules-tech-rules-agent-prompt.txt +89 -0
- package/templates/cli/prompts/tech-tech-module-format.txt +359 -0
- package/templates/cli/prompts/tech-tech-skill-index.txt +185 -0
- package/templates/cli/prompts/test-suggestions-enhancement.txt +38 -0
- package/templates/cli/prompts/test-test-concept-analysis.txt +179 -0
- package/templates/cli/prompts/universal-universal-creative-style.txt +95 -0
- package/templates/cli/prompts/universal-universal-rigorous-style.txt +92 -0
- package/templates/cli/prompts/verification-codex-technical.txt +28 -0
- package/templates/cli/prompts/verification-cross-validation.txt +28 -0
- package/templates/cli/prompts/verification-gemini-strategic.txt +27 -0
- package/templates/cli/prompts/workflow-analysis-results-structure.txt +224 -0
- package/templates/cli/prompts/workflow-codex-feasibility-validation.txt +176 -0
- package/templates/cli/prompts/workflow-gemini-solution-design.txt +131 -0
- package/templates/cli/prompts/workflow-impl-plan-template.txt +286 -0
- package/templates/cli/prompts/workflow-skill-aggregation.txt +172 -0
- package/templates/cli/prompts/workflow-skill-conflict-patterns.txt +94 -0
- package/templates/cli/prompts/workflow-skill-index.txt +224 -0
- package/templates/cli/prompts/workflow-skill-lessons-learned.txt +94 -0
- package/templates/cli/prompts/workflow-skill-sessions-timeline.txt +53 -0
- package/templates/cli/prompts/workflow-task-json-agent-mode.txt +123 -0
- package/templates/cli/prompts/workflow-task-json-cli-mode.txt +182 -0
- package/templates/cli/protocols/analysis-protocol.md +121 -0
- package/templates/cli/protocols/write-protocol.md +138 -0
- package/templates/config.json +53 -0
- package/templates/context.md +16 -0
- package/templates/doc-index.json +11 -0
- package/templates/index.json +68 -0
- package/templates/issue.json +36 -0
- package/templates/plan.json +38 -0
- package/templates/planning-roles/data-architect.md +72 -0
- package/templates/planning-roles/product-manager.md +70 -0
- package/templates/planning-roles/product-owner.md +68 -0
- package/templates/planning-roles/scrum-master.md +71 -0
- package/templates/planning-roles/subject-matter-expert.md +76 -0
- package/templates/planning-roles/system-architect.md +71 -0
- package/templates/planning-roles/test-strategist.md +74 -0
- package/templates/planning-roles/ui-designer.md +99 -0
- package/templates/planning-roles/ux-expert.md +79 -0
- package/templates/project.md +60 -0
- package/templates/reflection-log.md +20 -0
- package/templates/roadmap.md +39 -0
- package/templates/scratch-index.json +19 -0
- package/templates/search-tool.json +1 -0
- package/templates/search-tools.md +31 -0
- package/templates/state.json +38 -0
- package/templates/task-summary.md +21 -0
- package/templates/task.json +89 -0
- package/templates/terminology-template.json +22 -0
- package/templates/uat.md +21 -0
- package/templates/validation.json +31 -0
- package/templates/verification.json +37 -0
- package/templates/workflow.md +14 -0
- package/workflows/analyze.md +766 -0
- package/workflows/brainstorm.md +491 -0
- package/workflows/chinese-response.md +25 -0
- package/workflows/cli-tools-usage.md +220 -0
- package/workflows/codebase-rebuild.md +332 -0
- package/workflows/codebase-refresh.md +240 -0
- package/workflows/coding-philosophy.md +70 -0
- package/workflows/debug.md +459 -0
- package/workflows/execute.md +413 -0
- package/workflows/init.md +157 -0
- package/workflows/integration-test.md +343 -0
- package/workflows/issue-analyze.md +226 -0
- package/workflows/issue-discover.md +414 -0
- package/workflows/issue-execute.md +286 -0
- package/workflows/issue-plan.md +228 -0
- package/workflows/issue.md +441 -0
- package/workflows/maestro-coordinate.md +525 -0
- package/workflows/maestro-link-coordinate.md +153 -0
- package/workflows/maestro.md +754 -0
- package/workflows/map.md +111 -0
- package/workflows/memory.md +495 -0
- package/workflows/milestone-audit.md +130 -0
- package/workflows/milestone-complete.md +222 -0
- package/workflows/phase-add.md +252 -0
- package/workflows/phase-transition.md +380 -0
- package/workflows/plan.md +482 -0
- package/workflows/quick.md +497 -0
- package/workflows/refactor.md +300 -0
- package/workflows/review.md +614 -0
- package/workflows/roadmap.md +327 -0
- package/workflows/spec-generate.md +631 -0
- package/workflows/specs-add.md +132 -0
- package/workflows/specs-load.md +65 -0
- package/workflows/specs-setup.md +372 -0
- package/workflows/status.md +241 -0
- package/workflows/sync.md +244 -0
- package/workflows/test-gen.md +275 -0
- package/workflows/test.md +566 -0
- package/workflows/ui-design.md +715 -0
- package/workflows/ui-style.md +385 -0
- package/workflows/verify.md +641 -0
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"fs-watcher.js","sourceRoot":"","sources":["../../../src/server/state/fs-watcher.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
import type { BoardState, PhaseCard, TaskCard, ProjectState } from '../../shared/types.js';
|
|
2
|
+
import type { DashboardEventBus } from './event-bus.js';
|
|
3
|
+
export declare class StateManager {
|
|
4
|
+
private workflowRoot;
|
|
5
|
+
private readonly eventBus;
|
|
6
|
+
private board;
|
|
7
|
+
/** Cache: phase number → directory path for O(1) lookups */
|
|
8
|
+
private phaseDirCache;
|
|
9
|
+
private isSwitching;
|
|
10
|
+
constructor(workflowRoot: string, eventBus: DashboardEventBus);
|
|
11
|
+
/** Return current workspace project root (parent of .workflow/) */
|
|
12
|
+
getWorkspaceRoot(): string;
|
|
13
|
+
/** Return current .workflow/ directory path (updates on workspace switch) */
|
|
14
|
+
getWorkflowRoot(): string;
|
|
15
|
+
/** Return current board state snapshot */
|
|
16
|
+
getBoard(): BoardState;
|
|
17
|
+
/** Return project state */
|
|
18
|
+
getProject(): ProjectState;
|
|
19
|
+
/** Return a specific phase by number, or undefined */
|
|
20
|
+
getPhase(n: number): PhaseCard | undefined;
|
|
21
|
+
/** Return tasks for a given phase number */
|
|
22
|
+
getTasks(phaseNum: number): Promise<TaskCard[]>;
|
|
23
|
+
buildInitialState(): Promise<BoardState>;
|
|
24
|
+
get switching(): boolean;
|
|
25
|
+
resetForNewWorkspace(newRoot: string): Promise<void>;
|
|
26
|
+
applyFileChange(filePath: string): Promise<void>;
|
|
27
|
+
private upsertPhase;
|
|
28
|
+
private upsertScratch;
|
|
29
|
+
private readAllPhases;
|
|
30
|
+
private readAllScratch;
|
|
31
|
+
}
|
|
@@ -0,0 +1,297 @@
|
|
|
1
|
+
import { readdir } from 'node:fs/promises';
|
|
2
|
+
import { join, relative, resolve } from 'node:path';
|
|
3
|
+
import { SSE_EVENT_TYPES } from '../../shared/constants.js';
|
|
4
|
+
import { readJsonSafe } from './file-reader.js';
|
|
5
|
+
import { toForwardSlash } from '../../shared/utils.js';
|
|
6
|
+
// ---------------------------------------------------------------------------
|
|
7
|
+
// StateManager — in-memory projection of .workflow/ directory
|
|
8
|
+
// ---------------------------------------------------------------------------
|
|
9
|
+
export class StateManager {
|
|
10
|
+
workflowRoot;
|
|
11
|
+
eventBus;
|
|
12
|
+
board;
|
|
13
|
+
/** Cache: phase number → directory path for O(1) lookups */
|
|
14
|
+
phaseDirCache = new Map();
|
|
15
|
+
isSwitching = false;
|
|
16
|
+
constructor(workflowRoot, eventBus) {
|
|
17
|
+
this.workflowRoot = workflowRoot;
|
|
18
|
+
this.eventBus = eventBus;
|
|
19
|
+
this.board = emptyBoard();
|
|
20
|
+
}
|
|
21
|
+
/** Return current workspace project root (parent of .workflow/) */
|
|
22
|
+
getWorkspaceRoot() {
|
|
23
|
+
return resolve(this.workflowRoot, '..');
|
|
24
|
+
}
|
|
25
|
+
/** Return current .workflow/ directory path (updates on workspace switch) */
|
|
26
|
+
getWorkflowRoot() {
|
|
27
|
+
return this.workflowRoot;
|
|
28
|
+
}
|
|
29
|
+
/** Return current board state snapshot */
|
|
30
|
+
getBoard() {
|
|
31
|
+
return this.board;
|
|
32
|
+
}
|
|
33
|
+
/** Return project state */
|
|
34
|
+
getProject() {
|
|
35
|
+
return this.board.project;
|
|
36
|
+
}
|
|
37
|
+
/** Return a specific phase by number, or undefined */
|
|
38
|
+
getPhase(n) {
|
|
39
|
+
return this.board.phases.find((p) => p.phase === n);
|
|
40
|
+
}
|
|
41
|
+
/** Return tasks for a given phase number */
|
|
42
|
+
async getTasks(phaseNum) {
|
|
43
|
+
// Use cached directory path if available
|
|
44
|
+
const cached = this.phaseDirCache.get(phaseNum);
|
|
45
|
+
if (cached)
|
|
46
|
+
return readPhaseTasks(cached);
|
|
47
|
+
const phaseDir = await findPhaseDir(this.workflowRoot, phaseNum);
|
|
48
|
+
if (!phaseDir)
|
|
49
|
+
return [];
|
|
50
|
+
this.phaseDirCache.set(phaseNum, phaseDir);
|
|
51
|
+
return readPhaseTasks(phaseDir);
|
|
52
|
+
}
|
|
53
|
+
// -------------------------------------------------------------------------
|
|
54
|
+
// Full state build — scans the entire .workflow/ directory
|
|
55
|
+
// -------------------------------------------------------------------------
|
|
56
|
+
async buildInitialState() {
|
|
57
|
+
const project = await readJsonSafe(join(this.workflowRoot, 'state.json'));
|
|
58
|
+
const phases = await this.readAllPhases();
|
|
59
|
+
const scratch = await this.readAllScratch();
|
|
60
|
+
this.board = {
|
|
61
|
+
project: project ?? emptyProject(),
|
|
62
|
+
phases,
|
|
63
|
+
scratch,
|
|
64
|
+
lastUpdated: new Date().toISOString(),
|
|
65
|
+
};
|
|
66
|
+
this.eventBus.emit(SSE_EVENT_TYPES.BOARD_FULL, this.board);
|
|
67
|
+
return this.board;
|
|
68
|
+
}
|
|
69
|
+
// -------------------------------------------------------------------------
|
|
70
|
+
// Workspace switch — replace root, rebuild state, broadcast switch event
|
|
71
|
+
// -------------------------------------------------------------------------
|
|
72
|
+
get switching() {
|
|
73
|
+
return this.isSwitching;
|
|
74
|
+
}
|
|
75
|
+
async resetForNewWorkspace(newRoot) {
|
|
76
|
+
if (this.isSwitching) {
|
|
77
|
+
throw new Error('Workspace switch already in progress.');
|
|
78
|
+
}
|
|
79
|
+
this.isSwitching = true;
|
|
80
|
+
try {
|
|
81
|
+
this.phaseDirCache.clear();
|
|
82
|
+
this.workflowRoot = newRoot;
|
|
83
|
+
await this.buildInitialState();
|
|
84
|
+
this.eventBus.emit(SSE_EVENT_TYPES.WORKSPACE_SWITCHED, { workspace: resolve(newRoot, '..') });
|
|
85
|
+
}
|
|
86
|
+
finally {
|
|
87
|
+
this.isSwitching = false;
|
|
88
|
+
}
|
|
89
|
+
}
|
|
90
|
+
// -------------------------------------------------------------------------
|
|
91
|
+
// Delta update — re-read a single changed file and emit event
|
|
92
|
+
// -------------------------------------------------------------------------
|
|
93
|
+
async applyFileChange(filePath) {
|
|
94
|
+
const rel = toForwardSlash(relative(this.workflowRoot, filePath));
|
|
95
|
+
// state.json — project-level change
|
|
96
|
+
if (rel === 'state.json') {
|
|
97
|
+
const project = await readJsonSafe(filePath);
|
|
98
|
+
if (project) {
|
|
99
|
+
this.board.project = project;
|
|
100
|
+
this.board.lastUpdated = new Date().toISOString();
|
|
101
|
+
this.eventBus.emit(SSE_EVENT_TYPES.PROJECT_UPDATED, this.board.project);
|
|
102
|
+
}
|
|
103
|
+
return;
|
|
104
|
+
}
|
|
105
|
+
// phases/<slug>/index.json — phase updated
|
|
106
|
+
const phaseIndexMatch = rel.match(/^phases\/[^/]+\/index\.json$/);
|
|
107
|
+
if (phaseIndexMatch) {
|
|
108
|
+
const phase = await readJsonSafe(filePath);
|
|
109
|
+
if (phase) {
|
|
110
|
+
this.upsertPhase(phase);
|
|
111
|
+
this.board.lastUpdated = new Date().toISOString();
|
|
112
|
+
this.eventBus.emit(SSE_EVENT_TYPES.PHASE_UPDATED, phase);
|
|
113
|
+
}
|
|
114
|
+
return;
|
|
115
|
+
}
|
|
116
|
+
// phases/<slug>/.task/TASK-*.json — task updated
|
|
117
|
+
const taskMatch = rel.match(/^phases\/[^/]+\/\.task\/TASK-.*\.json$/);
|
|
118
|
+
if (taskMatch) {
|
|
119
|
+
const task = await readJsonSafe(filePath);
|
|
120
|
+
if (task) {
|
|
121
|
+
this.board.lastUpdated = new Date().toISOString();
|
|
122
|
+
this.eventBus.emit(SSE_EVENT_TYPES.TASK_UPDATED, task);
|
|
123
|
+
}
|
|
124
|
+
return;
|
|
125
|
+
}
|
|
126
|
+
// scratch/<slug>/index.json — scratch task updated
|
|
127
|
+
const scratchMatch = rel.match(/^scratch\/[^/]+\/index\.json$/);
|
|
128
|
+
if (scratchMatch) {
|
|
129
|
+
const scratch = await readJsonSafe(filePath);
|
|
130
|
+
if (scratch) {
|
|
131
|
+
this.upsertScratch(scratch);
|
|
132
|
+
this.board.lastUpdated = new Date().toISOString();
|
|
133
|
+
this.eventBus.emit(SSE_EVENT_TYPES.SCRATCH_UPDATED, scratch);
|
|
134
|
+
}
|
|
135
|
+
return;
|
|
136
|
+
}
|
|
137
|
+
}
|
|
138
|
+
// -------------------------------------------------------------------------
|
|
139
|
+
// Internal helpers
|
|
140
|
+
// -------------------------------------------------------------------------
|
|
141
|
+
upsertPhase(phase) {
|
|
142
|
+
phase = normalizePhase(phase);
|
|
143
|
+
const idx = this.board.phases.findIndex((p) => p.phase === phase.phase);
|
|
144
|
+
if (idx >= 0) {
|
|
145
|
+
this.board.phases[idx] = phase;
|
|
146
|
+
}
|
|
147
|
+
else {
|
|
148
|
+
this.board.phases.push(phase);
|
|
149
|
+
this.board.phases.sort((a, b) => a.phase - b.phase);
|
|
150
|
+
}
|
|
151
|
+
}
|
|
152
|
+
upsertScratch(card) {
|
|
153
|
+
const idx = this.board.scratch.findIndex((s) => s.id === card.id);
|
|
154
|
+
if (idx >= 0) {
|
|
155
|
+
this.board.scratch[idx] = card;
|
|
156
|
+
}
|
|
157
|
+
else {
|
|
158
|
+
this.board.scratch.push(card);
|
|
159
|
+
}
|
|
160
|
+
}
|
|
161
|
+
async readAllPhases() {
|
|
162
|
+
const phasesDir = join(this.workflowRoot, 'phases');
|
|
163
|
+
const slugs = await safeReaddir(phasesDir);
|
|
164
|
+
const phases = [];
|
|
165
|
+
this.phaseDirCache.clear();
|
|
166
|
+
for (const slug of slugs) {
|
|
167
|
+
const dirPath = join(phasesDir, slug);
|
|
168
|
+
const indexPath = join(dirPath, 'index.json');
|
|
169
|
+
const phase = await readJsonSafe(indexPath);
|
|
170
|
+
if (phase) {
|
|
171
|
+
phases.push(normalizePhase(phase));
|
|
172
|
+
this.phaseDirCache.set(phase.phase, dirPath);
|
|
173
|
+
}
|
|
174
|
+
}
|
|
175
|
+
phases.sort((a, b) => a.phase - b.phase);
|
|
176
|
+
return phases;
|
|
177
|
+
}
|
|
178
|
+
async readAllScratch() {
|
|
179
|
+
const scratchDir = join(this.workflowRoot, 'scratch');
|
|
180
|
+
const slugs = await safeReaddir(scratchDir);
|
|
181
|
+
const cards = [];
|
|
182
|
+
for (const slug of slugs) {
|
|
183
|
+
const indexPath = join(scratchDir, slug, 'index.json');
|
|
184
|
+
const card = await readJsonSafe(indexPath);
|
|
185
|
+
if (card) {
|
|
186
|
+
cards.push(card);
|
|
187
|
+
}
|
|
188
|
+
}
|
|
189
|
+
return cards;
|
|
190
|
+
}
|
|
191
|
+
}
|
|
192
|
+
// ---------------------------------------------------------------------------
|
|
193
|
+
// Module-level helpers
|
|
194
|
+
// ---------------------------------------------------------------------------
|
|
195
|
+
async function findPhaseDir(workflowRoot, phaseNum) {
|
|
196
|
+
const phasesDir = join(workflowRoot, 'phases');
|
|
197
|
+
const slugs = await safeReaddir(phasesDir);
|
|
198
|
+
for (const slug of slugs) {
|
|
199
|
+
const indexPath = join(phasesDir, slug, 'index.json');
|
|
200
|
+
const phase = await readJsonSafe(indexPath);
|
|
201
|
+
if (phase && phase.phase === phaseNum) {
|
|
202
|
+
return join(phasesDir, slug);
|
|
203
|
+
}
|
|
204
|
+
}
|
|
205
|
+
return null;
|
|
206
|
+
}
|
|
207
|
+
async function readPhaseTasks(phaseDir) {
|
|
208
|
+
const taskDir = join(phaseDir, '.task');
|
|
209
|
+
const entries = await safeReaddirFiles(taskDir);
|
|
210
|
+
const tasks = [];
|
|
211
|
+
for (const entry of entries) {
|
|
212
|
+
if (!entry.startsWith('TASK-') || !entry.endsWith('.json'))
|
|
213
|
+
continue;
|
|
214
|
+
const task = await readJsonSafe(join(taskDir, entry));
|
|
215
|
+
if (task) {
|
|
216
|
+
tasks.push(task);
|
|
217
|
+
}
|
|
218
|
+
}
|
|
219
|
+
return tasks;
|
|
220
|
+
}
|
|
221
|
+
async function safeReaddir(dir) {
|
|
222
|
+
try {
|
|
223
|
+
const entries = await readdir(dir, { withFileTypes: true });
|
|
224
|
+
return entries.filter((e) => e.isDirectory()).map((e) => e.name);
|
|
225
|
+
}
|
|
226
|
+
catch {
|
|
227
|
+
return [];
|
|
228
|
+
}
|
|
229
|
+
}
|
|
230
|
+
async function safeReaddirFiles(dir) {
|
|
231
|
+
try {
|
|
232
|
+
const entries = await readdir(dir, { withFileTypes: true });
|
|
233
|
+
return entries.filter((e) => e.isFile()).map((e) => e.name);
|
|
234
|
+
}
|
|
235
|
+
catch {
|
|
236
|
+
return [];
|
|
237
|
+
}
|
|
238
|
+
}
|
|
239
|
+
function emptyProject() {
|
|
240
|
+
return {
|
|
241
|
+
version: '1.0',
|
|
242
|
+
project_name: '',
|
|
243
|
+
current_milestone: '',
|
|
244
|
+
current_phase: 0,
|
|
245
|
+
status: 'idle',
|
|
246
|
+
phases_summary: { total: 0, completed: 0, in_progress: 0, pending: 0 },
|
|
247
|
+
last_updated: new Date().toISOString(),
|
|
248
|
+
accumulated_context: { key_decisions: [], blockers: [], deferred: [] },
|
|
249
|
+
};
|
|
250
|
+
}
|
|
251
|
+
function emptyBoard() {
|
|
252
|
+
return {
|
|
253
|
+
project: emptyProject(),
|
|
254
|
+
phases: [],
|
|
255
|
+
scratch: [],
|
|
256
|
+
lastUpdated: new Date().toISOString(),
|
|
257
|
+
};
|
|
258
|
+
}
|
|
259
|
+
/** Fill missing fields in PhaseCard so components never crash on partial data */
|
|
260
|
+
function normalizePhase(p) {
|
|
261
|
+
const raw = p;
|
|
262
|
+
if (p.execution && raw.verification && raw.validation && raw.uat && raw.reflection
|
|
263
|
+
&& Array.isArray(p.success_criteria) && Array.isArray(p.requirements)
|
|
264
|
+
&& Array.isArray(raw.verification?.must_haves))
|
|
265
|
+
return p;
|
|
266
|
+
return {
|
|
267
|
+
...p,
|
|
268
|
+
goal: p.goal ?? '',
|
|
269
|
+
success_criteria: p.success_criteria ?? [],
|
|
270
|
+
requirements: p.requirements ?? [],
|
|
271
|
+
spec_ref: p.spec_ref ?? null,
|
|
272
|
+
plan: p.plan ?? { task_ids: [], task_count: 0, complexity: null, waves: [] },
|
|
273
|
+
execution: p.execution ?? { method: '', started_at: null, completed_at: null, tasks_completed: 0, tasks_total: 0, current_wave: 0, commits: [] },
|
|
274
|
+
verification: {
|
|
275
|
+
status: raw.verification?.status ?? 'pending',
|
|
276
|
+
verified_at: raw.verification?.verified_at ?? null,
|
|
277
|
+
must_haves: raw.verification?.must_haves ?? [],
|
|
278
|
+
gaps: raw.verification?.gaps ?? [],
|
|
279
|
+
},
|
|
280
|
+
validation: {
|
|
281
|
+
status: raw.validation?.status ?? 'pending',
|
|
282
|
+
test_coverage: raw.validation?.test_coverage ?? null,
|
|
283
|
+
gaps: raw.validation?.gaps ?? [],
|
|
284
|
+
},
|
|
285
|
+
uat: {
|
|
286
|
+
status: raw.uat?.status ?? 'pending',
|
|
287
|
+
test_count: raw.uat?.test_count ?? 0,
|
|
288
|
+
passed: raw.uat?.passed ?? 0,
|
|
289
|
+
gaps: raw.uat?.gaps ?? [],
|
|
290
|
+
},
|
|
291
|
+
reflection: {
|
|
292
|
+
rounds: raw.reflection?.rounds ?? 0,
|
|
293
|
+
strategy_adjustments: raw.reflection?.strategy_adjustments ?? [],
|
|
294
|
+
},
|
|
295
|
+
};
|
|
296
|
+
}
|
|
297
|
+
//# sourceMappingURL=state-manager.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"state-manager.js","sourceRoot":"","sources":["../../../src/server/state/state-manager.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,kBAAkB,CAAC;AAC3C,OAAO,EAAE,IAAI,EAAE,QAAQ,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AASpD,OAAO,EAAE,eAAe,EAAE,MAAM,2BAA2B,CAAC;AAC5D,OAAO,EAAE,YAAY,EAAE,MAAM,kBAAkB,CAAC;AAEhD,OAAO,EAAE,cAAc,EAAE,MAAM,uBAAuB,CAAC;AAEvD,8EAA8E;AAC9E,8DAA8D;AAC9D,8EAA8E;AAE9E,MAAM,OAAO,YAAY;IAOb;IACS;IAPX,KAAK,CAAa;IAC1B,4DAA4D;IACpD,aAAa,GAAG,IAAI,GAAG,EAAkB,CAAC;IAC1C,WAAW,GAAG,KAAK,CAAC;IAE5B,YACU,YAAoB,EACX,QAA2B;QADpC,iBAAY,GAAZ,YAAY,CAAQ;QACX,aAAQ,GAAR,QAAQ,CAAmB;QAE5C,IAAI,CAAC,KAAK,GAAG,UAAU,EAAE,CAAC;IAC5B,CAAC;IAED,mEAAmE;IACnE,gBAAgB;QACd,OAAO,OAAO,CAAC,IAAI,CAAC,YAAY,EAAE,IAAI,CAAC,CAAC;IAC1C,CAAC;IAED,6EAA6E;IAC7E,eAAe;QACb,OAAO,IAAI,CAAC,YAAY,CAAC;IAC3B,CAAC;IAED,0CAA0C;IAC1C,QAAQ;QACN,OAAO,IAAI,CAAC,KAAK,CAAC;IACpB,CAAC;IAED,2BAA2B;IAC3B,UAAU;QACR,OAAO,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC;IAC5B,CAAC;IAED,sDAAsD;IACtD,QAAQ,CAAC,CAAS;QAChB,OAAO,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,KAAK,KAAK,CAAC,CAAC,CAAC;IACtD,CAAC;IAED,4CAA4C;IAC5C,KAAK,CAAC,QAAQ,CAAC,QAAgB;QAC7B,yCAAyC;QACzC,MAAM,MAAM,GAAG,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;QAChD,IAAI,MAAM;YAAE,OAAO,cAAc,CAAC,MAAM,CAAC,CAAC;QAE1C,MAAM,QAAQ,GAAG,MAAM,YAAY,CAAC,IAAI,CAAC,YAAY,EAAE,QAAQ,CAAC,CAAC;QACjE,IAAI,CAAC,QAAQ;YAAE,OAAO,EAAE,CAAC;QACzB,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,QAAQ,EAAE,QAAQ,CAAC,CAAC;QAC3C,OAAO,cAAc,CAAC,QAAQ,CAAC,CAAC;IAClC,CAAC;IAED,4EAA4E;IAC5E,2DAA2D;IAC3D,4EAA4E;IAE5E,KAAK,CAAC,iBAAiB;QACrB,MAAM,OAAO,GAAG,MAAM,YAAY,CAChC,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE,YAAY,CAAC,CACtC,CAAC;QAEF,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,aAAa,EAAE,CAAC;QAC1C,MAAM,OAAO,GAAG,MAAM,IAAI,CAAC,cAAc,EAAE,CAAC;QAE5C,IAAI,CAAC,KAAK,GAAG;YACX,OAAO,EAAE,OAAO,IAAI,YAAY,EAAE;YAClC,MAAM;YACN,OAAO;YACP,WAAW,EAAE,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE;SACtC,CAAC;QAEF,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,eAAe,CAAC,UAAU,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC;QAC3D,OAAO,IAAI,CAAC,KAAK,CAAC;IACpB,CAAC;IAED,4EAA4E;IAC5E,yEAAyE;IACzE,4EAA4E;IAE5E,IAAI,SAAS;QACX,OAAO,IAAI,CAAC,WAAW,CAAC;IAC1B,CAAC;IAED,KAAK,CAAC,oBAAoB,CAAC,OAAe;QACxC,IAAI,IAAI,CAAC,WAAW,EAAE,CAAC;YACrB,MAAM,IAAI,KAAK,CAAC,uCAAuC,CAAC,CAAC;QAC3D,CAAC;QACD,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;QACxB,IAAI,CAAC;YACH,IAAI,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;YAC3B,IAAI,CAAC,YAAY,GAAG,OAAO,CAAC;YAC5B,MAAM,IAAI,CAAC,iBAAiB,EAAE,CAAC;YAC/B,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,eAAe,CAAC,kBAAkB,EAAE,EAAE,SAAS,EAAE,OAAO,CAAC,OAAO,EAAE,IAAI,CAAC,EAAE,CAAC,CAAC;QAChG,CAAC;gBAAS,CAAC;YACT,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC;QAC3B,CAAC;IACH,CAAC;IAED,4EAA4E;IAC5E,8DAA8D;IAC9D,4EAA4E;IAE5E,KAAK,CAAC,eAAe,CAAC,QAAgB;QACpC,MAAM,GAAG,GAAG,cAAc,CAAC,QAAQ,CAAC,IAAI,CAAC,YAAY,EAAE,QAAQ,CAAC,CAAC,CAAC;QAElE,oCAAoC;QACpC,IAAI,GAAG,KAAK,YAAY,EAAE,CAAC;YACzB,MAAM,OAAO,GAAG,MAAM,YAAY,CAAe,QAAQ,CAAC,CAAC;YAC3D,IAAI,OAAO,EAAE,CAAC;gBACZ,IAAI,CAAC,KAAK,CAAC,OAAO,GAAG,OAAO,CAAC;gBAC7B,IAAI,CAAC,KAAK,CAAC,WAAW,GAAG,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE,CAAC;gBAClD,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,eAAe,CAAC,eAAe,EAAE,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;YAC1E,CAAC;YACD,OAAO;QACT,CAAC;QAED,2CAA2C;QAC3C,MAAM,eAAe,GAAG,GAAG,CAAC,KAAK,CAAC,8BAA8B,CAAC,CAAC;QAClE,IAAI,eAAe,EAAE,CAAC;YACpB,MAAM,KAAK,GAAG,MAAM,YAAY,CAAY,QAAQ,CAAC,CAAC;YACtD,IAAI,KAAK,EAAE,CAAC;gBACV,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC;gBACxB,IAAI,CAAC,KAAK,CAAC,WAAW,GAAG,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE,CAAC;gBAClD,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,eAAe,CAAC,aAAa,EAAE,KAAK,CAAC,CAAC;YAC3D,CAAC;YACD,OAAO;QACT,CAAC;QAED,iDAAiD;QACjD,MAAM,SAAS,GAAG,GAAG,CAAC,KAAK,CAAC,wCAAwC,CAAC,CAAC;QACtE,IAAI,SAAS,EAAE,CAAC;YACd,MAAM,IAAI,GAAG,MAAM,YAAY,CAAW,QAAQ,CAAC,CAAC;YACpD,IAAI,IAAI,EAAE,CAAC;gBACT,IAAI,CAAC,KAAK,CAAC,WAAW,GAAG,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE,CAAC;gBAClD,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,eAAe,CAAC,YAAY,EAAE,IAAI,CAAC,CAAC;YACzD,CAAC;YACD,OAAO;QACT,CAAC;QAED,mDAAmD;QACnD,MAAM,YAAY,GAAG,GAAG,CAAC,KAAK,CAAC,+BAA+B,CAAC,CAAC;QAChE,IAAI,YAAY,EAAE,CAAC;YACjB,MAAM,OAAO,GAAG,MAAM,YAAY,CAAc,QAAQ,CAAC,CAAC;YAC1D,IAAI,OAAO,EAAE,CAAC;gBACZ,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC;gBAC5B,IAAI,CAAC,KAAK,CAAC,WAAW,GAAG,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE,CAAC;gBAClD,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,eAAe,CAAC,eAAe,EAAE,OAAO,CAAC,CAAC;YAC/D,CAAC;YACD,OAAO;QACT,CAAC;IACH,CAAC;IAED,4EAA4E;IAC5E,mBAAmB;IACnB,4EAA4E;IAEpE,WAAW,CAAC,KAAgB;QAClC,KAAK,GAAG,cAAc,CAAC,KAAK,CAAC,CAAC;QAC9B,MAAM,GAAG,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,KAAK,KAAK,KAAK,CAAC,KAAK,CAAC,CAAC;QACxE,IAAI,GAAG,IAAI,CAAC,EAAE,CAAC;YACb,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,GAAG,CAAC,GAAG,KAAK,CAAC;QACjC,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;YAC9B,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,KAAK,GAAG,CAAC,CAAC,KAAK,CAAC,CAAC;QACtD,CAAC;IACH,CAAC;IAEO,aAAa,CAAC,IAAiB;QACrC,MAAM,GAAG,GAAG,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,EAAE,KAAK,IAAI,CAAC,EAAE,CAAC,CAAC;QAClE,IAAI,GAAG,IAAI,CAAC,EAAE,CAAC;YACb,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC;QACjC,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAChC,CAAC;IACH,CAAC;IAEO,KAAK,CAAC,aAAa;QACzB,MAAM,SAAS,GAAG,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE,QAAQ,CAAC,CAAC;QACpD,MAAM,KAAK,GAAG,MAAM,WAAW,CAAC,SAAS,CAAC,CAAC;QAC3C,MAAM,MAAM,GAAgB,EAAE,CAAC;QAC/B,IAAI,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;QAE3B,KAAK,MAAM,IAAI,IAAI,KAAK,EAAE,CAAC;YACzB,MAAM,OAAO,GAAG,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC,CAAC;YACtC,MAAM,SAAS,GAAG,IAAI,CAAC,OAAO,EAAE,YAAY,CAAC,CAAC;YAC9C,MAAM,KAAK,GAAG,MAAM,YAAY,CAAY,SAAS,CAAC,CAAC;YACvD,IAAI,KAAK,EAAE,CAAC;gBACV,MAAM,CAAC,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC,CAAC;gBACnC,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,KAAK,CAAC,KAAK,EAAE,OAAO,CAAC,CAAC;YAC/C,CAAC;QACH,CAAC;QAED,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,KAAK,GAAG,CAAC,CAAC,KAAK,CAAC,CAAC;QACzC,OAAO,MAAM,CAAC;IAChB,CAAC;IAEO,KAAK,CAAC,cAAc;QAC1B,MAAM,UAAU,GAAG,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE,SAAS,CAAC,CAAC;QACtD,MAAM,KAAK,GAAG,MAAM,WAAW,CAAC,UAAU,CAAC,CAAC;QAC5C,MAAM,KAAK,GAAkB,EAAE,CAAC;QAEhC,KAAK,MAAM,IAAI,IAAI,KAAK,EAAE,CAAC;YACzB,MAAM,SAAS,GAAG,IAAI,CAAC,UAAU,EAAE,IAAI,EAAE,YAAY,CAAC,CAAC;YACvD,MAAM,IAAI,GAAG,MAAM,YAAY,CAAc,SAAS,CAAC,CAAC;YACxD,IAAI,IAAI,EAAE,CAAC;gBACT,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;YACnB,CAAC;QACH,CAAC;QAED,OAAO,KAAK,CAAC;IACf,CAAC;CACF;AAED,8EAA8E;AAC9E,uBAAuB;AACvB,8EAA8E;AAE9E,KAAK,UAAU,YAAY,CACzB,YAAoB,EACpB,QAAgB;IAEhB,MAAM,SAAS,GAAG,IAAI,CAAC,YAAY,EAAE,QAAQ,CAAC,CAAC;IAC/C,MAAM,KAAK,GAAG,MAAM,WAAW,CAAC,SAAS,CAAC,CAAC;IAE3C,KAAK,MAAM,IAAI,IAAI,KAAK,EAAE,CAAC;QACzB,MAAM,SAAS,GAAG,IAAI,CAAC,SAAS,EAAE,IAAI,EAAE,YAAY,CAAC,CAAC;QACtD,MAAM,KAAK,GAAG,MAAM,YAAY,CAAY,SAAS,CAAC,CAAC;QACvD,IAAI,KAAK,IAAI,KAAK,CAAC,KAAK,KAAK,QAAQ,EAAE,CAAC;YACtC,OAAO,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC,CAAC;QAC/B,CAAC;IACH,CAAC;IAED,OAAO,IAAI,CAAC;AACd,CAAC;AAED,KAAK,UAAU,cAAc,CAAC,QAAgB;IAC5C,MAAM,OAAO,GAAG,IAAI,CAAC,QAAQ,EAAE,OAAO,CAAC,CAAC;IACxC,MAAM,OAAO,GAAG,MAAM,gBAAgB,CAAC,OAAO,CAAC,CAAC;IAChD,MAAM,KAAK,GAAe,EAAE,CAAC;IAE7B,KAAK,MAAM,KAAK,IAAI,OAAO,EAAE,CAAC;QAC5B,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,OAAO,CAAC;YAAE,SAAS;QACrE,MAAM,IAAI,GAAG,MAAM,YAAY,CAAW,IAAI,CAAC,OAAO,EAAE,KAAK,CAAC,CAAC,CAAC;QAChE,IAAI,IAAI,EAAE,CAAC;YACT,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACnB,CAAC;IACH,CAAC;IAED,OAAO,KAAK,CAAC;AACf,CAAC;AAED,KAAK,UAAU,WAAW,CAAC,GAAW;IACpC,IAAI,CAAC;QACH,MAAM,OAAO,GAAG,MAAM,OAAO,CAAC,GAAG,EAAE,EAAE,aAAa,EAAE,IAAI,EAAE,CAAC,CAAC;QAC5D,OAAO,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,WAAW,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC;IACnE,CAAC;IAAC,MAAM,CAAC;QACP,OAAO,EAAE,CAAC;IACZ,CAAC;AACH,CAAC;AAED,KAAK,UAAU,gBAAgB,CAAC,GAAW;IACzC,IAAI,CAAC;QACH,MAAM,OAAO,GAAG,MAAM,OAAO,CAAC,GAAG,EAAE,EAAE,aAAa,EAAE,IAAI,EAAE,CAAC,CAAC;QAC5D,OAAO,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,MAAM,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC;IAC9D,CAAC;IAAC,MAAM,CAAC;QACP,OAAO,EAAE,CAAC;IACZ,CAAC;AACH,CAAC;AAED,SAAS,YAAY;IACnB,OAAO;QACL,OAAO,EAAE,KAAK;QACd,YAAY,EAAE,EAAE;QAChB,iBAAiB,EAAE,EAAE;QACrB,aAAa,EAAE,CAAC;QAChB,MAAM,EAAE,MAAM;QACd,cAAc,EAAE,EAAE,KAAK,EAAE,CAAC,EAAE,SAAS,EAAE,CAAC,EAAE,WAAW,EAAE,CAAC,EAAE,OAAO,EAAE,CAAC,EAAE;QACtE,YAAY,EAAE,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE;QACtC,mBAAmB,EAAE,EAAE,aAAa,EAAE,EAAE,EAAE,QAAQ,EAAE,EAAE,EAAE,QAAQ,EAAE,EAAE,EAAE;KACvE,CAAC;AACJ,CAAC;AAED,SAAS,UAAU;IACjB,OAAO;QACL,OAAO,EAAE,YAAY,EAAE;QACvB,MAAM,EAAE,EAAE;QACV,OAAO,EAAE,EAAE;QACX,WAAW,EAAE,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE;KACtC,CAAC;AACJ,CAAC;AAED,iFAAiF;AACjF,SAAS,cAAc,CAAC,CAAY;IAClC,MAAM,GAAG,GAAG,CAAuC,CAAC;IACpD,IAAI,CAAC,CAAC,SAAS,IAAI,GAAG,CAAC,YAAY,IAAI,GAAG,CAAC,UAAU,IAAI,GAAG,CAAC,GAAG,IAAI,GAAG,CAAC,UAAU;WAC7E,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,gBAAgB,CAAC,IAAI,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,YAAY,CAAC;WAClE,KAAK,CAAC,OAAO,CAAE,GAAG,CAAC,YAAwC,EAAE,UAAU,CAAC;QAAE,OAAO,CAAC,CAAC;IACxF,OAAO;QACL,GAAG,CAAC;QACJ,IAAI,EAAE,CAAC,CAAC,IAAI,IAAI,EAAE;QAClB,gBAAgB,EAAE,CAAC,CAAC,gBAAgB,IAAI,EAAE;QAC1C,YAAY,EAAE,CAAC,CAAC,YAAY,IAAI,EAAE;QAClC,QAAQ,EAAE,CAAC,CAAC,QAAQ,IAAI,IAAI;QAC5B,IAAI,EAAE,CAAC,CAAC,IAAI,IAAI,EAAE,QAAQ,EAAE,EAAE,EAAE,UAAU,EAAE,CAAC,EAAE,UAAU,EAAE,IAAI,EAAE,KAAK,EAAE,EAAE,EAAE;QAC5E,SAAS,EAAE,CAAC,CAAC,SAAS,IAAI,EAAE,MAAM,EAAE,EAAE,EAAE,UAAU,EAAE,IAAI,EAAE,YAAY,EAAE,IAAI,EAAE,eAAe,EAAE,CAAC,EAAE,WAAW,EAAE,CAAC,EAAE,YAAY,EAAE,CAAC,EAAE,OAAO,EAAE,EAAE,EAAE;QAChJ,YAAY,EAAE;YACZ,MAAM,EAAG,GAAG,CAAC,YAAoB,EAAE,MAAM,IAAI,SAAS;YACtD,WAAW,EAAG,GAAG,CAAC,YAAoB,EAAE,WAAW,IAAI,IAAI;YAC3D,UAAU,EAAG,GAAG,CAAC,YAAoB,EAAE,UAAU,IAAI,EAAE;YACvD,IAAI,EAAG,GAAG,CAAC,YAAoB,EAAE,IAAI,IAAI,EAAE;SAC5C;QACD,UAAU,EAAE;YACV,MAAM,EAAG,GAAG,CAAC,UAAkB,EAAE,MAAM,IAAI,SAAS;YACpD,aAAa,EAAG,GAAG,CAAC,UAAkB,EAAE,aAAa,IAAI,IAAI;YAC7D,IAAI,EAAG,GAAG,CAAC,UAAkB,EAAE,IAAI,IAAI,EAAE;SAC1C;QACD,GAAG,EAAE;YACH,MAAM,EAAG,GAAG,CAAC,GAAW,EAAE,MAAM,IAAI,SAAS;YAC7C,UAAU,EAAG,GAAG,CAAC,GAAW,EAAE,UAAU,IAAI,CAAC;YAC7C,MAAM,EAAG,GAAG,CAAC,GAAW,EAAE,MAAM,IAAI,CAAC;YACrC,IAAI,EAAG,GAAG,CAAC,GAAW,EAAE,IAAI,IAAI,EAAE;SACnC;QACD,UAAU,EAAE;YACV,MAAM,EAAG,GAAG,CAAC,UAAkB,EAAE,MAAM,IAAI,CAAC;YAC5C,oBAAoB,EAAG,GAAG,CAAC,UAAkB,EAAE,oBAAoB,IAAI,EAAE;SAC1E;KACF,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,258 @@
|
|
|
1
|
+
import { describe, it, expect, vi, beforeEach, afterEach } from 'vitest';
|
|
2
|
+
import { mkdtemp, rm, mkdir, writeFile } from 'node:fs/promises';
|
|
3
|
+
import { join } from 'node:path';
|
|
4
|
+
import { tmpdir } from 'node:os';
|
|
5
|
+
import { StateManager } from './state-manager.js';
|
|
6
|
+
import { DashboardEventBus } from './event-bus.js';
|
|
7
|
+
import { SSE_EVENT_TYPES } from '../../shared/constants.js';
|
|
8
|
+
describe('StateManager', () => {
|
|
9
|
+
let tempDir;
|
|
10
|
+
let eventBus;
|
|
11
|
+
let manager;
|
|
12
|
+
beforeEach(async () => {
|
|
13
|
+
tempDir = await mkdtemp(join(tmpdir(), 'state-mgr-'));
|
|
14
|
+
eventBus = new DashboardEventBus();
|
|
15
|
+
manager = new StateManager(tempDir, eventBus);
|
|
16
|
+
});
|
|
17
|
+
afterEach(async () => {
|
|
18
|
+
await rm(tempDir, { recursive: true, force: true });
|
|
19
|
+
});
|
|
20
|
+
describe('getBoard / getProject / getPhase', () => {
|
|
21
|
+
it('returns empty board initially', () => {
|
|
22
|
+
const board = manager.getBoard();
|
|
23
|
+
expect(board.project.project_name).toBe('');
|
|
24
|
+
expect(board.phases).toEqual([]);
|
|
25
|
+
expect(board.scratch).toEqual([]);
|
|
26
|
+
});
|
|
27
|
+
it('getProject returns empty project initially', () => {
|
|
28
|
+
const project = manager.getProject();
|
|
29
|
+
expect(project.status).toBe('idle');
|
|
30
|
+
expect(project.version).toBe('1.0');
|
|
31
|
+
});
|
|
32
|
+
it('getPhase returns undefined for non-existent phase', () => {
|
|
33
|
+
expect(manager.getPhase(1)).toBeUndefined();
|
|
34
|
+
});
|
|
35
|
+
});
|
|
36
|
+
describe('buildInitialState', () => {
|
|
37
|
+
it('reads state.json and emits board:full', async () => {
|
|
38
|
+
const emitSpy = vi.spyOn(eventBus, 'emit');
|
|
39
|
+
const stateJson = {
|
|
40
|
+
version: '1.0',
|
|
41
|
+
project_name: 'test-project',
|
|
42
|
+
current_milestone: 'M1',
|
|
43
|
+
current_phase: 1,
|
|
44
|
+
status: 'active',
|
|
45
|
+
phases_summary: { total: 1, completed: 0, in_progress: 1, pending: 0 },
|
|
46
|
+
last_updated: '2026-01-01T00:00:00Z',
|
|
47
|
+
accumulated_context: { key_decisions: [], blockers: [], deferred: [] },
|
|
48
|
+
};
|
|
49
|
+
await writeFile(join(tempDir, 'state.json'), JSON.stringify(stateJson));
|
|
50
|
+
const board = await manager.buildInitialState();
|
|
51
|
+
expect(board.project.project_name).toBe('test-project');
|
|
52
|
+
expect(board.project.status).toBe('active');
|
|
53
|
+
expect(emitSpy).toHaveBeenCalledWith(SSE_EVENT_TYPES.BOARD_FULL, board);
|
|
54
|
+
});
|
|
55
|
+
it('returns empty project when state.json is missing', async () => {
|
|
56
|
+
const board = await manager.buildInitialState();
|
|
57
|
+
expect(board.project.project_name).toBe('');
|
|
58
|
+
});
|
|
59
|
+
it('reads phases from phases/ directory', async () => {
|
|
60
|
+
await mkdir(join(tempDir, 'phases', 'phase-1-setup'), { recursive: true });
|
|
61
|
+
const phaseCard = {
|
|
62
|
+
phase: 1,
|
|
63
|
+
title: 'Setup',
|
|
64
|
+
slug: 'phase-1-setup',
|
|
65
|
+
status: 'executing',
|
|
66
|
+
tasks_summary: { total: 2, completed: 1, in_progress: 1, pending: 0, failed: 0 },
|
|
67
|
+
};
|
|
68
|
+
await writeFile(join(tempDir, 'phases', 'phase-1-setup', 'index.json'), JSON.stringify(phaseCard));
|
|
69
|
+
const board = await manager.buildInitialState();
|
|
70
|
+
expect(board.phases).toHaveLength(1);
|
|
71
|
+
expect(board.phases[0].title).toBe('Setup');
|
|
72
|
+
expect(manager.getPhase(1)?.title).toBe('Setup');
|
|
73
|
+
});
|
|
74
|
+
it('reads scratch cards from scratch/ directory', async () => {
|
|
75
|
+
await mkdir(join(tempDir, 'scratch', 'quick-fix'), { recursive: true });
|
|
76
|
+
const scratchCard = {
|
|
77
|
+
id: 'scratch-quick-fix',
|
|
78
|
+
title: 'Quick Fix',
|
|
79
|
+
slug: 'quick-fix',
|
|
80
|
+
status: 'active',
|
|
81
|
+
};
|
|
82
|
+
await writeFile(join(tempDir, 'scratch', 'quick-fix', 'index.json'), JSON.stringify(scratchCard));
|
|
83
|
+
const board = await manager.buildInitialState();
|
|
84
|
+
expect(board.scratch).toHaveLength(1);
|
|
85
|
+
expect(board.scratch[0].title).toBe('Quick Fix');
|
|
86
|
+
});
|
|
87
|
+
it('handles missing phases/ directory gracefully', async () => {
|
|
88
|
+
// phases/ directory does not exist
|
|
89
|
+
const board = await manager.buildInitialState();
|
|
90
|
+
expect(board.phases).toEqual([]);
|
|
91
|
+
});
|
|
92
|
+
it('sorts phases by phase number', async () => {
|
|
93
|
+
await mkdir(join(tempDir, 'phases', 'phase-2-impl'), { recursive: true });
|
|
94
|
+
await mkdir(join(tempDir, 'phases', 'phase-1-setup'), { recursive: true });
|
|
95
|
+
await writeFile(join(tempDir, 'phases', 'phase-2-impl', 'index.json'), JSON.stringify({ phase: 2, title: 'Impl', slug: 'phase-2-impl', status: 'pending' }));
|
|
96
|
+
await writeFile(join(tempDir, 'phases', 'phase-1-setup', 'index.json'), JSON.stringify({ phase: 1, title: 'Setup', slug: 'phase-1-setup', status: 'completed' }));
|
|
97
|
+
const board = await manager.buildInitialState();
|
|
98
|
+
expect(board.phases[0].phase).toBe(1);
|
|
99
|
+
expect(board.phases[1].phase).toBe(2);
|
|
100
|
+
});
|
|
101
|
+
});
|
|
102
|
+
describe('getTasks', () => {
|
|
103
|
+
it('reads tasks from phase .task/ directory', async () => {
|
|
104
|
+
await mkdir(join(tempDir, 'phases', 'phase-1-setup', '.task'), { recursive: true });
|
|
105
|
+
await writeFile(join(tempDir, 'phases', 'phase-1-setup', 'index.json'), JSON.stringify({ phase: 1, title: 'Setup', slug: 'phase-1-setup', status: 'executing' }));
|
|
106
|
+
await writeFile(join(tempDir, 'phases', 'phase-1-setup', '.task', 'TASK-001.json'), JSON.stringify({ id: 'TASK-001', title: 'Do stuff', status: 'pending' }));
|
|
107
|
+
// Build state first to populate phase dir cache
|
|
108
|
+
await manager.buildInitialState();
|
|
109
|
+
const tasks = await manager.getTasks(1);
|
|
110
|
+
expect(tasks).toHaveLength(1);
|
|
111
|
+
expect(tasks[0].id).toBe('TASK-001');
|
|
112
|
+
});
|
|
113
|
+
it('returns empty array for non-existent phase', async () => {
|
|
114
|
+
const tasks = await manager.getTasks(999);
|
|
115
|
+
expect(tasks).toEqual([]);
|
|
116
|
+
});
|
|
117
|
+
it('uses cached directory path on second call', async () => {
|
|
118
|
+
await mkdir(join(tempDir, 'phases', 'phase-1-setup', '.task'), { recursive: true });
|
|
119
|
+
await writeFile(join(tempDir, 'phases', 'phase-1-setup', 'index.json'), JSON.stringify({ phase: 1, title: 'Setup', slug: 'phase-1-setup', status: 'executing' }));
|
|
120
|
+
await writeFile(join(tempDir, 'phases', 'phase-1-setup', '.task', 'TASK-001.json'), JSON.stringify({ id: 'TASK-001', title: 'Task 1', status: 'pending' }));
|
|
121
|
+
await manager.buildInitialState();
|
|
122
|
+
// First call populates cache, second uses it
|
|
123
|
+
const tasks1 = await manager.getTasks(1);
|
|
124
|
+
const tasks2 = await manager.getTasks(1);
|
|
125
|
+
expect(tasks1).toEqual(tasks2);
|
|
126
|
+
});
|
|
127
|
+
it('skips non-TASK files in .task/ directory', async () => {
|
|
128
|
+
await mkdir(join(tempDir, 'phases', 'phase-1-setup', '.task'), { recursive: true });
|
|
129
|
+
await writeFile(join(tempDir, 'phases', 'phase-1-setup', 'index.json'), JSON.stringify({ phase: 1, title: 'Setup', slug: 'phase-1-setup', status: 'executing' }));
|
|
130
|
+
await writeFile(join(tempDir, 'phases', 'phase-1-setup', '.task', 'TASK-001.json'), JSON.stringify({ id: 'TASK-001', title: 'Task 1', status: 'pending' }));
|
|
131
|
+
await writeFile(join(tempDir, 'phases', 'phase-1-setup', '.task', 'README.md'), 'not a task');
|
|
132
|
+
await manager.buildInitialState();
|
|
133
|
+
const tasks = await manager.getTasks(1);
|
|
134
|
+
expect(tasks).toHaveLength(1);
|
|
135
|
+
});
|
|
136
|
+
});
|
|
137
|
+
describe('applyFileChange', () => {
|
|
138
|
+
it('updates project on state.json change', async () => {
|
|
139
|
+
const emitSpy = vi.spyOn(eventBus, 'emit');
|
|
140
|
+
await manager.buildInitialState();
|
|
141
|
+
const newState = {
|
|
142
|
+
version: '1.0',
|
|
143
|
+
project_name: 'updated-project',
|
|
144
|
+
current_milestone: 'M2',
|
|
145
|
+
current_phase: 2,
|
|
146
|
+
status: 'active',
|
|
147
|
+
phases_summary: { total: 2, completed: 1, in_progress: 1, pending: 0 },
|
|
148
|
+
last_updated: '2026-01-02T00:00:00Z',
|
|
149
|
+
accumulated_context: { key_decisions: [], blockers: [], deferred: [] },
|
|
150
|
+
};
|
|
151
|
+
await writeFile(join(tempDir, 'state.json'), JSON.stringify(newState));
|
|
152
|
+
await manager.applyFileChange(join(tempDir, 'state.json'));
|
|
153
|
+
expect(manager.getProject().project_name).toBe('updated-project');
|
|
154
|
+
expect(emitSpy).toHaveBeenCalledWith(SSE_EVENT_TYPES.PROJECT_UPDATED, expect.objectContaining({ project_name: 'updated-project' }));
|
|
155
|
+
});
|
|
156
|
+
it('updates phase on phase index.json change', async () => {
|
|
157
|
+
const emitSpy = vi.spyOn(eventBus, 'emit');
|
|
158
|
+
await manager.buildInitialState();
|
|
159
|
+
await mkdir(join(tempDir, 'phases', 'phase-1-setup'), { recursive: true });
|
|
160
|
+
const phaseCard = { phase: 1, title: 'Setup', slug: 'phase-1-setup', status: 'completed' };
|
|
161
|
+
await writeFile(join(tempDir, 'phases', 'phase-1-setup', 'index.json'), JSON.stringify(phaseCard));
|
|
162
|
+
await manager.applyFileChange(join(tempDir, 'phases', 'phase-1-setup', 'index.json'));
|
|
163
|
+
expect(manager.getPhase(1)?.status).toBe('completed');
|
|
164
|
+
expect(emitSpy).toHaveBeenCalledWith(SSE_EVENT_TYPES.PHASE_UPDATED, phaseCard);
|
|
165
|
+
});
|
|
166
|
+
it('upserts new phase into board', async () => {
|
|
167
|
+
await manager.buildInitialState();
|
|
168
|
+
expect(manager.getBoard().phases).toHaveLength(0);
|
|
169
|
+
await mkdir(join(tempDir, 'phases', 'phase-1-setup'), { recursive: true });
|
|
170
|
+
await writeFile(join(tempDir, 'phases', 'phase-1-setup', 'index.json'), JSON.stringify({ phase: 1, title: 'Setup', slug: 'phase-1-setup', status: 'pending' }));
|
|
171
|
+
await manager.applyFileChange(join(tempDir, 'phases', 'phase-1-setup', 'index.json'));
|
|
172
|
+
expect(manager.getBoard().phases).toHaveLength(1);
|
|
173
|
+
});
|
|
174
|
+
it('emits task:updated on TASK file change', async () => {
|
|
175
|
+
const emitSpy = vi.spyOn(eventBus, 'emit');
|
|
176
|
+
await manager.buildInitialState();
|
|
177
|
+
await mkdir(join(tempDir, 'phases', 'phase-1-setup', '.task'), { recursive: true });
|
|
178
|
+
const taskCard = { id: 'TASK-001', title: 'Do stuff', status: 'completed' };
|
|
179
|
+
await writeFile(join(tempDir, 'phases', 'phase-1-setup', '.task', 'TASK-001.json'), JSON.stringify(taskCard));
|
|
180
|
+
await manager.applyFileChange(join(tempDir, 'phases', 'phase-1-setup', '.task', 'TASK-001.json'));
|
|
181
|
+
expect(emitSpy).toHaveBeenCalledWith(SSE_EVENT_TYPES.TASK_UPDATED, taskCard);
|
|
182
|
+
});
|
|
183
|
+
it('emits scratch:updated on scratch index change', async () => {
|
|
184
|
+
const emitSpy = vi.spyOn(eventBus, 'emit');
|
|
185
|
+
await manager.buildInitialState();
|
|
186
|
+
await mkdir(join(tempDir, 'scratch', 'quick-fix'), { recursive: true });
|
|
187
|
+
const scratchCard = { id: 'scratch-quick-fix', title: 'Quick Fix', slug: 'quick-fix', status: 'active' };
|
|
188
|
+
await writeFile(join(tempDir, 'scratch', 'quick-fix', 'index.json'), JSON.stringify(scratchCard));
|
|
189
|
+
await manager.applyFileChange(join(tempDir, 'scratch', 'quick-fix', 'index.json'));
|
|
190
|
+
expect(emitSpy).toHaveBeenCalledWith(SSE_EVENT_TYPES.SCRATCH_UPDATED, scratchCard);
|
|
191
|
+
});
|
|
192
|
+
it('ignores unrecognized file paths', async () => {
|
|
193
|
+
const emitSpy = vi.spyOn(eventBus, 'emit');
|
|
194
|
+
await manager.buildInitialState();
|
|
195
|
+
// Clear the emit calls from buildInitialState
|
|
196
|
+
emitSpy.mockClear();
|
|
197
|
+
await manager.applyFileChange(join(tempDir, 'random', 'file.txt'));
|
|
198
|
+
expect(emitSpy).not.toHaveBeenCalled();
|
|
199
|
+
});
|
|
200
|
+
it('handles invalid JSON in state.json gracefully', async () => {
|
|
201
|
+
await manager.buildInitialState();
|
|
202
|
+
const originalName = manager.getProject().project_name;
|
|
203
|
+
await writeFile(join(tempDir, 'state.json'), '{invalid json');
|
|
204
|
+
// readJsonSafe will retry then throw, but applyFileChange should handle it
|
|
205
|
+
// The project should remain unchanged since parsing failed
|
|
206
|
+
// readJsonSafe returns null on ENOENT but throws on parse error after retries
|
|
207
|
+
// In this case the error propagates - let's verify it doesn't crash the manager
|
|
208
|
+
try {
|
|
209
|
+
await manager.applyFileChange(join(tempDir, 'state.json'));
|
|
210
|
+
}
|
|
211
|
+
catch {
|
|
212
|
+
// Parse errors may propagate - that's expected behavior
|
|
213
|
+
}
|
|
214
|
+
// Project should either be unchanged or updated (depending on error handling)
|
|
215
|
+
expect(manager.getProject()).toBeDefined();
|
|
216
|
+
});
|
|
217
|
+
});
|
|
218
|
+
describe('upsertPhase sorting', () => {
|
|
219
|
+
it('maintains sorted order when inserting phases out of order', async () => {
|
|
220
|
+
await manager.buildInitialState();
|
|
221
|
+
// Insert phase 3 first, then phase 1
|
|
222
|
+
await mkdir(join(tempDir, 'phases', 'phase-3-verify'), { recursive: true });
|
|
223
|
+
await writeFile(join(tempDir, 'phases', 'phase-3-verify', 'index.json'), JSON.stringify({ phase: 3, title: 'Verify', slug: 'phase-3-verify', status: 'pending' }));
|
|
224
|
+
await manager.applyFileChange(join(tempDir, 'phases', 'phase-3-verify', 'index.json'));
|
|
225
|
+
await mkdir(join(tempDir, 'phases', 'phase-1-setup'), { recursive: true });
|
|
226
|
+
await writeFile(join(tempDir, 'phases', 'phase-1-setup', 'index.json'), JSON.stringify({ phase: 1, title: 'Setup', slug: 'phase-1-setup', status: 'pending' }));
|
|
227
|
+
await manager.applyFileChange(join(tempDir, 'phases', 'phase-1-setup', 'index.json'));
|
|
228
|
+
const phases = manager.getBoard().phases;
|
|
229
|
+
expect(phases[0].phase).toBe(1);
|
|
230
|
+
expect(phases[1].phase).toBe(3);
|
|
231
|
+
});
|
|
232
|
+
it('replaces existing phase on update', async () => {
|
|
233
|
+
await manager.buildInitialState();
|
|
234
|
+
await mkdir(join(tempDir, 'phases', 'phase-1-setup'), { recursive: true });
|
|
235
|
+
await writeFile(join(tempDir, 'phases', 'phase-1-setup', 'index.json'), JSON.stringify({ phase: 1, title: 'Setup', slug: 'phase-1-setup', status: 'pending' }));
|
|
236
|
+
await manager.applyFileChange(join(tempDir, 'phases', 'phase-1-setup', 'index.json'));
|
|
237
|
+
expect(manager.getPhase(1)?.status).toBe('pending');
|
|
238
|
+
// Update same phase
|
|
239
|
+
await writeFile(join(tempDir, 'phases', 'phase-1-setup', 'index.json'), JSON.stringify({ phase: 1, title: 'Setup', slug: 'phase-1-setup', status: 'completed' }));
|
|
240
|
+
await manager.applyFileChange(join(tempDir, 'phases', 'phase-1-setup', 'index.json'));
|
|
241
|
+
expect(manager.getPhase(1)?.status).toBe('completed');
|
|
242
|
+
expect(manager.getBoard().phases).toHaveLength(1);
|
|
243
|
+
});
|
|
244
|
+
});
|
|
245
|
+
describe('upsertScratch', () => {
|
|
246
|
+
it('replaces existing scratch card on update', async () => {
|
|
247
|
+
await manager.buildInitialState();
|
|
248
|
+
await mkdir(join(tempDir, 'scratch', 'quick-fix'), { recursive: true });
|
|
249
|
+
await writeFile(join(tempDir, 'scratch', 'quick-fix', 'index.json'), JSON.stringify({ id: 'scratch-quick-fix', title: 'Quick Fix v1', slug: 'quick-fix', status: 'active' }));
|
|
250
|
+
await manager.applyFileChange(join(tempDir, 'scratch', 'quick-fix', 'index.json'));
|
|
251
|
+
await writeFile(join(tempDir, 'scratch', 'quick-fix', 'index.json'), JSON.stringify({ id: 'scratch-quick-fix', title: 'Quick Fix v2', slug: 'quick-fix', status: 'completed' }));
|
|
252
|
+
await manager.applyFileChange(join(tempDir, 'scratch', 'quick-fix', 'index.json'));
|
|
253
|
+
expect(manager.getBoard().scratch).toHaveLength(1);
|
|
254
|
+
expect(manager.getBoard().scratch[0].title).toBe('Quick Fix v2');
|
|
255
|
+
});
|
|
256
|
+
});
|
|
257
|
+
});
|
|
258
|
+
//# sourceMappingURL=state-manager.test.js.map
|