sillyspec 3.8.5 → 3.8.7
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +0 -6
- package/docs/.vitepress/config.mts +45 -0
- package/docs/.vitepress/dist/404.html +25 -0
- package/docs/.vitepress/dist/assets/app.YytxICdd.js +1 -0
- package/docs/.vitepress/dist/assets/chunks/framework.Czhw_PXq.js +19 -0
- package/docs/.vitepress/dist/assets/chunks/theme.DusTRZQk.js +1 -0
- package/docs/.vitepress/dist/assets/index.md.C3VCvtQA.js +1 -0
- package/docs/.vitepress/dist/assets/index.md.C3VCvtQA.lean.js +1 -0
- package/docs/.vitepress/dist/assets/inter-italic-cyrillic-ext.r48I6akx.woff2 +0 -0
- package/docs/.vitepress/dist/assets/inter-italic-cyrillic.By2_1cv3.woff2 +0 -0
- package/docs/.vitepress/dist/assets/inter-italic-greek-ext.1u6EdAuj.woff2 +0 -0
- package/docs/.vitepress/dist/assets/inter-italic-greek.DJ8dCoTZ.woff2 +0 -0
- package/docs/.vitepress/dist/assets/inter-italic-latin-ext.CN1xVJS-.woff2 +0 -0
- package/docs/.vitepress/dist/assets/inter-italic-latin.C2AdPX0b.woff2 +0 -0
- package/docs/.vitepress/dist/assets/inter-italic-vietnamese.BSbpV94h.woff2 +0 -0
- package/docs/.vitepress/dist/assets/inter-roman-cyrillic-ext.BBPuwvHQ.woff2 +0 -0
- package/docs/.vitepress/dist/assets/inter-roman-cyrillic.C5lxZ8CY.woff2 +0 -0
- package/docs/.vitepress/dist/assets/inter-roman-greek-ext.CqjqNYQ-.woff2 +0 -0
- package/docs/.vitepress/dist/assets/inter-roman-greek.BBVDIX6e.woff2 +0 -0
- package/docs/.vitepress/dist/assets/inter-roman-latin-ext.4ZJIpNVo.woff2 +0 -0
- package/docs/.vitepress/dist/assets/inter-roman-latin.Di8DUHzh.woff2 +0 -0
- package/docs/.vitepress/dist/assets/inter-roman-vietnamese.BjW4sHH5.woff2 +0 -0
- package/docs/.vitepress/dist/assets/sillyspec_commands.md.CXFFsj08.js +15 -0
- package/docs/.vitepress/dist/assets/sillyspec_commands.md.CXFFsj08.lean.js +1 -0
- package/docs/.vitepress/dist/assets/sillyspec_dashboard.md.BuPXHqjX.js +4 -0
- package/docs/.vitepress/dist/assets/sillyspec_dashboard.md.BuPXHqjX.lean.js +1 -0
- package/docs/.vitepress/dist/assets/sillyspec_file-io.md.Cz3x7llx.js +1 -0
- package/docs/.vitepress/dist/assets/sillyspec_file-io.md.Cz3x7llx.lean.js +1 -0
- package/docs/.vitepress/dist/assets/sillyspec_getting-started.md.ClcvV8k3.js +4 -0
- package/docs/.vitepress/dist/assets/sillyspec_getting-started.md.ClcvV8k3.lean.js +1 -0
- package/docs/.vitepress/dist/assets/sillyspec_install.md.CKuR2tiT.js +5 -0
- package/docs/.vitepress/dist/assets/sillyspec_install.md.CKuR2tiT.lean.js +1 -0
- package/docs/.vitepress/dist/assets/sillyspec_lifecycle.md.DY293cR1.js +28 -0
- package/docs/.vitepress/dist/assets/sillyspec_lifecycle.md.DY293cR1.lean.js +1 -0
- package/docs/.vitepress/dist/assets/sillyspec_structure.md.sVYS4zPs.js +30 -0
- package/docs/.vitepress/dist/assets/sillyspec_structure.md.sVYS4zPs.lean.js +1 -0
- package/docs/.vitepress/dist/assets/style.DFTx90Kk.css +1 -0
- package/docs/.vitepress/dist/hashmap.json +1 -0
- package/docs/.vitepress/dist/index.html +28 -0
- package/docs/.vitepress/dist/sillyspec/commands.html +42 -0
- package/docs/.vitepress/dist/sillyspec/dashboard.html +31 -0
- package/docs/.vitepress/dist/sillyspec/file-io.html +28 -0
- package/docs/.vitepress/dist/sillyspec/getting-started.html +31 -0
- package/docs/.vitepress/dist/sillyspec/install.html +32 -0
- package/docs/.vitepress/dist/sillyspec/lifecycle.html +55 -0
- package/docs/.vitepress/dist/sillyspec/structure.html +57 -0
- package/docs/.vitepress/dist/vp-icons.css +1 -0
- package/docs/index.md +34 -0
- package/docs/sillyspec/commands.md +218 -0
- package/docs/sillyspec/dashboard.md +51 -0
- package/docs/sillyspec/file-io.md +34 -0
- package/docs/sillyspec/getting-started.md +61 -0
- package/docs/sillyspec/install.md +51 -0
- package/docs/sillyspec/lifecycle.md +146 -0
- package/docs/sillyspec/structure.md +62 -0
- package/package.json +11 -9
- package/packages/dashboard/dist/assets/index-Bh-GPjKY.css +1 -0
- package/packages/dashboard/dist/assets/index-CrCn5Gg6.js +17 -0
- package/packages/dashboard/dist/index.html +2 -2
- package/packages/dashboard/package-lock.json +0 -220
- package/packages/dashboard/package.json +5 -8
- package/packages/dashboard/server/index.js +106 -255
- package/packages/dashboard/server/parser.js +29 -333
- package/packages/dashboard/server/watcher.js +131 -203
- package/packages/dashboard/src/App.vue +10 -181
- package/packages/dashboard/src/components/ActionBar.vue +42 -26
- package/packages/dashboard/src/components/CommandPalette.vue +65 -40
- package/packages/dashboard/src/components/DetailPanel.vue +53 -68
- package/packages/dashboard/src/components/LogStream.vue +33 -13
- package/packages/dashboard/src/components/PipelineStage.vue +8 -8
- package/packages/dashboard/src/components/PipelineView.vue +45 -80
- package/packages/dashboard/src/components/ProjectList.vue +45 -103
- package/packages/dashboard/src/components/StageBadge.vue +13 -13
- package/packages/dashboard/src/components/StepCard.vue +15 -15
- package/packages/dashboard/src/composables/useDashboard.js +6 -20
- package/packages/dashboard/src/composables/useKeyboard.js +4 -6
- package/packages/dashboard/src/main.js +1 -4
- package/packages/dashboard/src/style.css +17 -17
- package/src/index.js +12 -123
- package/src/init.js +227 -86
- package/src/setup.js +9 -1
- package/templates/archive.md +120 -0
- package/templates/brainstorm.md +170 -0
- package/{.claude/skills/sillyspec-commit/SKILL.md → templates/commit.md} +45 -29
- package/templates/continue.md +32 -0
- package/templates/execute.md +304 -0
- package/templates/explore.md +59 -0
- package/templates/export.md +21 -0
- package/templates/init.md +61 -0
- package/templates/plan.md +146 -0
- package/templates/quick.md +135 -0
- package/templates/scan-quick.md +49 -0
- package/templates/scan.md +156 -0
- package/templates/skills/playwright-e2e/SKILL.md +340 -0
- package/templates/status.md +75 -0
- package/templates/verify.md +236 -0
- package/templates/workspace-sync.md +99 -0
- package/templates/workspace.md +70 -0
- package/.claude/skills/sillyspec-archive/SKILL.md +0 -17
- package/.claude/skills/sillyspec-auto/SKILL.md +0 -77
- package/.claude/skills/sillyspec-brainstorm/SKILL.md +0 -17
- package/.claude/skills/sillyspec-continue/SKILL.md +0 -44
- package/.claude/skills/sillyspec-doctor/SKILL.md +0 -22
- package/.claude/skills/sillyspec-execute/SKILL.md +0 -17
- package/.claude/skills/sillyspec-explore/SKILL.md +0 -96
- package/.claude/skills/sillyspec-export/SKILL.md +0 -53
- package/.claude/skills/sillyspec-init/SKILL.md +0 -170
- package/.claude/skills/sillyspec-plan/SKILL.md +0 -52
- package/.claude/skills/sillyspec-propose/SKILL.md +0 -17
- package/.claude/skills/sillyspec-quick/SKILL.md +0 -17
- package/.claude/skills/sillyspec-resume/SKILL.md +0 -111
- package/.claude/skills/sillyspec-scan/SKILL.md +0 -17
- package/.claude/skills/sillyspec-state/SKILL.md +0 -54
- package/.claude/skills/sillyspec-status/SKILL.md +0 -17
- package/.claude/skills/sillyspec-verify/SKILL.md +0 -17
- package/.claude/skills/sillyspec-workspace/SKILL.md +0 -149
- package/.sillyspec/changes/archive/2026-04-08-derive-state/design.md +0 -97
- package/.sillyspec/changes/archive/2026-04-08-derive-state/plan.md +0 -51
- package/.sillyspec/changes/archive/2026-04-08-derive-state/proposal.md +0 -29
- package/.sillyspec/changes/archive/2026-04-08-derive-state/requirements.md +0 -34
- package/.sillyspec/changes/archive/2026-04-08-derive-state/tasks.md +0 -13
- package/.sillyspec/changes/archive/2026-04-08-derive-state/verify-result.md +0 -43
- package/.sillyspec/changes/auto-mode/design.md +0 -50
- package/.sillyspec/changes/auto-mode/proposal.md +0 -19
- package/.sillyspec/changes/auto-mode/requirements.md +0 -21
- package/.sillyspec/changes/auto-mode/tasks.md +0 -7
- package/.sillyspec/changes/brainstorm-archive/2026-04-05-unified-docs-design.md +0 -199
- package/.sillyspec/changes/dashboard/design.md.braindraft +0 -206
- package/.sillyspec/changes/run-command-design/design.md +0 -1230
- package/.sillyspec/changes/unified-docs-design/design.md +0 -199
- package/.sillyspec/docs/sillyspec/scan/.gitkeep +0 -0
- package/.sillyspec/knowledge/INDEX.md +0 -8
- package/.sillyspec/knowledge/uncategorized.md +0 -3
- package/.sillyspec/projects/sillyspec.yaml +0 -3
- package/packages/dashboard/dist/assets/index-D1EVTLmc.js +0 -7446
- package/packages/dashboard/dist/assets/index-DGe8CqeP.css +0 -1
- package/packages/dashboard/public/logo.jpg +0 -0
- package/packages/dashboard/src/components/DocPreview.vue +0 -160
- package/packages/dashboard/src/components/DocTree.vue +0 -58
- package/packages/dashboard/src/components/ProjectOverview.vue +0 -178
- package/packages/dashboard/src/components/detail/DocsDetail.vue +0 -48
- package/packages/dashboard/src/components/detail/GitDetail.vue +0 -61
- package/packages/dashboard/src/components/detail/TechDetail.vue +0 -43
- package/src/derive.js +0 -147
- package/src/migrate.js +0 -117
- package/src/progress.js +0 -495
- package/src/run.js +0 -640
- package/src/stages/archive.js +0 -54
- package/src/stages/brainstorm.js +0 -239
- package/src/stages/doctor.js +0 -312
- package/src/stages/execute.js +0 -259
- package/src/stages/index.js +0 -35
- package/src/stages/plan.js +0 -259
- package/src/stages/propose.js +0 -115
- package/src/stages/quick.js +0 -64
- package/src/stages/scan.js +0 -141
- package/src/stages/status.js +0 -65
- package/src/stages/verify.js +0 -135
- /package/.sillyspec/{changes/brainstorm-archive → specs}/2026-04-05-dashboard-design.md +0 -0
- /package/{packages/dashboard → docs/.vitepress}/dist/favicon.jpg +0 -0
- /package/{logo.jpg → docs/.vitepress/dist/logo.jpg} +0 -0
- /package/{packages/dashboard → docs}/public/favicon.jpg +0 -0
- /package/{packages/dashboard/dist → docs/public}/logo.jpg +0 -0
|
@@ -1,43 +0,0 @@
|
|
|
1
|
-
# derive-state 验证报告
|
|
2
|
-
|
|
3
|
-
author: qinyi
|
|
4
|
-
created_at: 2026-04-08 07:21:00
|
|
5
|
-
|
|
6
|
-
## 结论:✅ PASS
|
|
7
|
-
|
|
8
|
-
## 检查结果
|
|
9
|
-
|
|
10
|
-
### 1. 规范文件加载
|
|
11
|
-
- ✅ design.md
|
|
12
|
-
- ✅ proposal.md
|
|
13
|
-
- ✅ requirements.md
|
|
14
|
-
- ✅ tasks.md
|
|
15
|
-
- ✅ plan.md
|
|
16
|
-
|
|
17
|
-
### 2. 任务完成度:5/6 (83%)
|
|
18
|
-
- ✅ 实现 derive.js 核心函数
|
|
19
|
-
- ✅ 集成 run.js --done 轻量校验
|
|
20
|
-
- ✅ 集成 doctor.js 全量扫描
|
|
21
|
-
- ✅ 扩展 validate 支持 --deep
|
|
22
|
-
- ✅ CLI parse --deep 参数
|
|
23
|
-
- ⬜ 测试验证(本项目无自动化测试套件,通过手动验证替代)
|
|
24
|
-
|
|
25
|
-
### 3. 设计一致性
|
|
26
|
-
- ✅ derive.js 纯函数模块,零外部依赖(仅 fs/path)
|
|
27
|
-
- ✅ light/full 模式
|
|
28
|
-
- ✅ fix 参数 + 安全修复策略
|
|
29
|
-
- ✅ run.js --done 轻量校验集成
|
|
30
|
-
- ✅ doctor.js 全量扫描集成
|
|
31
|
-
- ✅ progress.js validate --deep 支持
|
|
32
|
-
- ✅ index.js CLI --deep 参数
|
|
33
|
-
- ✅ 改动文件范围与 design.md 一致
|
|
34
|
-
|
|
35
|
-
### 4. 测试和质量
|
|
36
|
-
- ✅ derive.js 模块导入正常
|
|
37
|
-
- ✅ sillyspec progress validate --deep 通过
|
|
38
|
-
- ✅ 无 TODO/FIXME/HACK/XXX 技术债务
|
|
39
|
-
- ✅ sillyspec run quick --status 正常
|
|
40
|
-
- ✅ sillyspec run doctor --status 正常
|
|
41
|
-
|
|
42
|
-
## 下一步
|
|
43
|
-
sillyspec run archive
|
|
@@ -1,50 +0,0 @@
|
|
|
1
|
-
# auto mode — 设计文档
|
|
2
|
-
|
|
3
|
-
author: qinyi
|
|
4
|
-
created_at: 2026-04-08 07:28:00
|
|
5
|
-
|
|
6
|
-
## 背景
|
|
7
|
-
|
|
8
|
-
当前 sillyspec 的每个阶段(brainstorm → plan → execute → verify)需要用户手动执行 `sillyspec run <stage>` 和 `sillyspec run <stage> --done`。用户希望一个自动模式,从 brainstorm 一路推进到 verify 完成。
|
|
9
|
-
|
|
10
|
-
## 需求
|
|
11
|
-
|
|
12
|
-
1. 用户启动一次,AI 自动循环所有阶段和步骤
|
|
13
|
-
2. 步骤内部的用户确认点保留不变
|
|
14
|
-
3. 不修改 CLI 代码,纯 skill 文件实现
|
|
15
|
-
|
|
16
|
-
## 设计
|
|
17
|
-
|
|
18
|
-
### 新增文件:`.claude/skills/sillyspec-auto/SKILL.md`
|
|
19
|
-
|
|
20
|
-
**核心逻辑:**
|
|
21
|
-
|
|
22
|
-
1. 读 `$ARGUMENTS` 作为用户需求
|
|
23
|
-
2. 阶段循环(brainstorm → plan → execute → verify)
|
|
24
|
-
3. 每个阶段内步骤循环:
|
|
25
|
-
- `sillyspec run <stage> --input "需求"` → 读 step prompt
|
|
26
|
-
- 执行 prompt 中的操作
|
|
27
|
-
- 需要用户确认的步骤 → 暂停等回复
|
|
28
|
-
- 完成后自动 `sillyspec run <stage> --done --output "摘要"`
|
|
29
|
-
- 读下一步 prompt,继续
|
|
30
|
-
4. 当前阶段全部完成 → 自动进入下一阶段
|
|
31
|
-
5. verify 完成 → 输出总结,停止
|
|
32
|
-
6. 命令失败 → 暂停,等用户介入
|
|
33
|
-
|
|
34
|
-
**确认点保留规则:**
|
|
35
|
-
- prompt 中有"请用户选择""等待用户回答""展示给用户"等字样 → 暂停
|
|
36
|
-
- prompt 中有"自审""检查"等纯内部操作 → 自动完成
|
|
37
|
-
|
|
38
|
-
### 同步到 npm 包
|
|
39
|
-
|
|
40
|
-
init.js 已有逻辑复制 `sillyspec-*` skills 到项目 `.claude/skills/`,新 skill 自动生效。
|
|
41
|
-
|
|
42
|
-
## 改动范围
|
|
43
|
-
|
|
44
|
-
- 新增:`.claude/skills/sillyspec-auto/SKILL.md`(~60 行)
|
|
45
|
-
|
|
46
|
-
## 不做的事
|
|
47
|
-
|
|
48
|
-
- 不修改任何 JS 源码
|
|
49
|
-
- 不改变现有阶段流程
|
|
50
|
-
- 不自动 commit 或发布
|
|
@@ -1,19 +0,0 @@
|
|
|
1
|
-
# auto mode — 提案
|
|
2
|
-
|
|
3
|
-
author: qinyi
|
|
4
|
-
created_at: 2026-04-08 07:29:00
|
|
5
|
-
|
|
6
|
-
## 动机
|
|
7
|
-
用户希望一次启动就自动完成 brainstorm → plan → execute → verify 全流程,不需要手动输入 `sillyspec run <stage>` 和 `--done`。
|
|
8
|
-
|
|
9
|
-
## 变更范围
|
|
10
|
-
新增 `.claude/skills/sillyspec-auto/SKILL.md`
|
|
11
|
-
|
|
12
|
-
## 不在范围内
|
|
13
|
-
- 不修改 JS 源码
|
|
14
|
-
- 不改变阶段流程
|
|
15
|
-
|
|
16
|
-
## 成功标准
|
|
17
|
-
1. `/sillyspec:auto "需求"` 能自动推进全流程
|
|
18
|
-
2. 步骤内部确认点正常暂停
|
|
19
|
-
3. 异常时暂停等用户介入
|
|
@@ -1,21 +0,0 @@
|
|
|
1
|
-
# auto mode — 需求
|
|
2
|
-
|
|
3
|
-
author: qinyi
|
|
4
|
-
created_at: 2026-04-08 07:29:00
|
|
5
|
-
|
|
6
|
-
## 功能需求
|
|
7
|
-
|
|
8
|
-
### FR1: 阶段自动推进
|
|
9
|
-
- 按 brainstorm → plan → execute → verify 顺序自动执行
|
|
10
|
-
- 当前阶段完成后自动进入下一阶段
|
|
11
|
-
|
|
12
|
-
### FR2: 步骤自动循环
|
|
13
|
-
- 每个步骤:读 prompt → 执行 → 自动 --done → 读下一步
|
|
14
|
-
- 不需要用户手动触发 --done
|
|
15
|
-
|
|
16
|
-
### FR3: 确认点保留
|
|
17
|
-
- prompt 中有用户确认要求时暂停等回复
|
|
18
|
-
- 纯内部操作步骤自动完成
|
|
19
|
-
|
|
20
|
-
### FR4: 异常处理
|
|
21
|
-
- 命令失败时暂停,展示错误,等用户介入
|
|
@@ -1,199 +0,0 @@
|
|
|
1
|
-
# 统一文档管理 + Dashboard 文档浏览
|
|
2
|
-
|
|
3
|
-
## 动机
|
|
4
|
-
|
|
5
|
-
### 现状问题
|
|
6
|
-
1. 文档散落在各子项目的 `.sillyspec/` 里,没有统一视角
|
|
7
|
-
2. Dashboard 只能发现项目,看不到文档内容
|
|
8
|
-
3. 扫描的 `codebase/` 文档只在子项目里,主项目看不到
|
|
9
|
-
4. 归档后文档沉入 `knowledge/`,跨项目复用不方便
|
|
10
|
-
5. 单项目模式和工作区模式两套逻辑,维护成本高
|
|
11
|
-
|
|
12
|
-
### 目标
|
|
13
|
-
- 文档只写一份,集中管理
|
|
14
|
-
- 默认工作区模式,去掉模式切换
|
|
15
|
-
- Dashboard 支持文档浏览
|
|
16
|
-
- 子项目保持干净(只有源代码)
|
|
17
|
-
|
|
18
|
-
## 方案
|
|
19
|
-
|
|
20
|
-
### 核心原则
|
|
21
|
-
- **文档只写一份**,在哪执行就写在哪
|
|
22
|
-
- **默认工作区模式**,每个项目天生就是"主项目"
|
|
23
|
-
- **子项目不生成文档**,文档全部在主项目的 `.sillyspec/docs/<project>/` 下
|
|
24
|
-
|
|
25
|
-
### 目录结构
|
|
26
|
-
|
|
27
|
-
```
|
|
28
|
-
my-project/.sillyspec/
|
|
29
|
-
├── STATE.md # 主项目状态(含当前操作的项目)
|
|
30
|
-
├── projects/ # 子项目注册表
|
|
31
|
-
│ ├── my-project.yaml # 默认注册自己
|
|
32
|
-
│ ├── frontend.yaml # { name, path, status }
|
|
33
|
-
│ └── backend.yaml
|
|
34
|
-
│
|
|
35
|
-
├── docs/ # 统一文档中心
|
|
36
|
-
│ └── my-project/ # 按子项目分目录
|
|
37
|
-
│ ├── scan/ # scan 产出
|
|
38
|
-
│ │ ├── ARCHITECTURE.md
|
|
39
|
-
│ │ └── CONVENTIONS.md
|
|
40
|
-
│ ├── brainstorm/ # brainstorm 设计文档
|
|
41
|
-
│ │ └── 2026-04-05-user-auth.md
|
|
42
|
-
│ ├── plan/ # plan 产出
|
|
43
|
-
│ │ └── 2026-04-05-user-auth.md
|
|
44
|
-
│ ├── changes/ # 当前变更(WIP)
|
|
45
|
-
│ │ └── user-auth/
|
|
46
|
-
│ │ ├── design.md
|
|
47
|
-
│ │ └── tasks.md
|
|
48
|
-
│ ├── archive/ # 归档
|
|
49
|
-
│ │ └── 2026-03-20-db-redesign.md
|
|
50
|
-
│ └── quicklog/ # quick 操作记录
|
|
51
|
-
│ └── 2026-04-05-fix-login.md
|
|
52
|
-
│
|
|
53
|
-
├── knowledge/ # 跨项目共享知识库(不变)
|
|
54
|
-
└── .runtime/
|
|
55
|
-
└── progress.json # 运行时数据(含子项目维度)
|
|
56
|
-
```
|
|
57
|
-
|
|
58
|
-
### 子项目保持干净
|
|
59
|
-
|
|
60
|
-
```
|
|
61
|
-
frontend/ # 只有源代码
|
|
62
|
-
├── src/
|
|
63
|
-
├── package.json
|
|
64
|
-
└── .gitignore
|
|
65
|
-
```
|
|
66
|
-
|
|
67
|
-
子项目不再有 `.sillyspec/` 目录。
|
|
68
|
-
|
|
69
|
-
## 命令变更
|
|
70
|
-
|
|
71
|
-
### --project 参数
|
|
72
|
-
|
|
73
|
-
所有产生文档的命令支持 `--project <name>` 参数:
|
|
74
|
-
|
|
75
|
-
```bash
|
|
76
|
-
/sillyspec:scan --project frontend
|
|
77
|
-
/sillyspec:brainstorm "用户认证" --project frontend
|
|
78
|
-
/sillyspec:plan --project frontend
|
|
79
|
-
/sillyspec:execute --project frontend
|
|
80
|
-
/sillyspec:archive --project frontend
|
|
81
|
-
/sillyspec:quick --project frontend --change "修复登录bug"
|
|
82
|
-
```
|
|
83
|
-
|
|
84
|
-
不指定 `--project` 时,默认使用 `STATE.md` 中记录的当前项目。
|
|
85
|
-
|
|
86
|
-
### 文档输出路径映射
|
|
87
|
-
|
|
88
|
-
| 命令 | 输出路径 |
|
|
89
|
-
|------|---------|
|
|
90
|
-
| scan | `.sillyspec/docs/<project>/scan/` |
|
|
91
|
-
| brainstorm | `.sillyspec/docs/<project>/brainstorm/<name>.md` |
|
|
92
|
-
| propose | `.sillyspec/docs/<project>/brainstorm/<name>.md` |
|
|
93
|
-
| plan | `.sillyspec/docs/<project>/plan/<name>.md` |
|
|
94
|
-
| execute | `.sillyspec/docs/<project>/changes/<name>/` (WIP) |
|
|
95
|
-
| archive | `.sillyspec/docs/<project>/archive/<name>.md` |
|
|
96
|
-
| quick | `.sillyspec/docs/<project>/quicklog/<name>.md` |
|
|
97
|
-
|
|
98
|
-
### init 变更
|
|
99
|
-
|
|
100
|
-
- `sillyspec init` 初始化时,`projects/` 默认注册当前目录自己
|
|
101
|
-
- 去掉 `--workspace` 参数(默认就是工作区模式)
|
|
102
|
-
- 去掉 `--interactive` 参数(默认零交互)
|
|
103
|
-
|
|
104
|
-
### STATE.md 变更
|
|
105
|
-
|
|
106
|
-
```markdown
|
|
107
|
-
# 项目状态
|
|
108
|
-
|
|
109
|
-
## 当前项目
|
|
110
|
-
- 名称:frontend
|
|
111
|
-
- 路径:./frontend
|
|
112
|
-
|
|
113
|
-
## 当前变更
|
|
114
|
-
- 名称:user-auth
|
|
115
|
-
- 当前阶段:execute ⏳
|
|
116
|
-
- 下一步:执行任务 3/8
|
|
117
|
-
```
|
|
118
|
-
|
|
119
|
-
### progress.json 变更
|
|
120
|
-
|
|
121
|
-
增加子项目维度:
|
|
122
|
-
|
|
123
|
-
```json
|
|
124
|
-
{
|
|
125
|
-
"_version": 1,
|
|
126
|
-
"schemaVersion": "1.0",
|
|
127
|
-
"currentProject": "frontend",
|
|
128
|
-
"currentStage": "execute",
|
|
129
|
-
"stages": {
|
|
130
|
-
"brainstorm": { "status": "completed", "steps": [...] },
|
|
131
|
-
"plan": { "status": "completed", "steps": [...] },
|
|
132
|
-
"execute": { "status": "in-progress", "steps": [...] },
|
|
133
|
-
"verify": { "status": "pending", "steps": [] }
|
|
134
|
-
}
|
|
135
|
-
}
|
|
136
|
-
```
|
|
137
|
-
|
|
138
|
-
## Dashboard 文档浏览
|
|
139
|
-
|
|
140
|
-
### 新增文档 Tab
|
|
141
|
-
|
|
142
|
-
选中项目后,中间区域顶部增加 Tab 切换:
|
|
143
|
-
|
|
144
|
-
```
|
|
145
|
-
[ 流水线 ] [ 文档 ]
|
|
146
|
-
```
|
|
147
|
-
|
|
148
|
-
### 文档 Tab 内容
|
|
149
|
-
|
|
150
|
-
左侧:文档树(按类型分组)
|
|
151
|
-
|
|
152
|
-
```
|
|
153
|
-
📋 设计文档
|
|
154
|
-
📄 用户认证功能设计
|
|
155
|
-
|
|
156
|
-
📐 实现计划
|
|
157
|
-
📄 用户认证功能计划
|
|
158
|
-
|
|
159
|
-
⚙️ 当前变更
|
|
160
|
-
📄 design.md
|
|
161
|
-
📄 tasks.md
|
|
162
|
-
|
|
163
|
-
📦 已归档
|
|
164
|
-
📄 数据库重设计
|
|
165
|
-
|
|
166
|
-
🔍 架构文档
|
|
167
|
-
📄 ARCHITECTURE.md
|
|
168
|
-
📄 CONVENTIONS.md
|
|
169
|
-
|
|
170
|
-
⚡ 快速修复
|
|
171
|
-
📄 修复登录bug
|
|
172
|
-
```
|
|
173
|
-
|
|
174
|
-
右侧:文档预览(Markdown 渲染)
|
|
175
|
-
|
|
176
|
-
点击左侧文档,右侧显示内容。
|
|
177
|
-
|
|
178
|
-
### 后端新增 API
|
|
179
|
-
|
|
180
|
-
```
|
|
181
|
-
GET /api/projects/:path/docs # 获取项目文档树
|
|
182
|
-
GET /api/projects/:path/docs/:filePath # 获取文档内容
|
|
183
|
-
```
|
|
184
|
-
|
|
185
|
-
## 兼容性
|
|
186
|
-
|
|
187
|
-
- 旧项目 `.sillyspec/codebase/`、`.sillyspec/specs/` 不受影响,只是新文档不再往那写
|
|
188
|
-
- 可加 `sillyspec docs migrate` 命令把旧文档迁移到新结构
|
|
189
|
-
- Dashboard 的项目发现逻辑不变(扫描 `.sillyspec` 目录)
|
|
190
|
-
|
|
191
|
-
## 验收标准
|
|
192
|
-
|
|
193
|
-
1. `sillyspec init` 生成 `projects/` 和 `docs/` 结构
|
|
194
|
-
2. `--project` 参数在所有命令中生效
|
|
195
|
-
3. 文档输出到 `.sillyspec/docs/<project>/` 对应子目录
|
|
196
|
-
4. 子项目目录不生成任何 `.sillyspec` 文件
|
|
197
|
-
5. Dashboard 文档 Tab 能展示文档树和预览内容
|
|
198
|
-
6. 旧项目不受影响
|
|
199
|
-
7. `sillyspec docs migrate` 能迁移旧文档
|
|
@@ -1,206 +0,0 @@
|
|
|
1
|
-
# SillySpec Dashboard 设计
|
|
2
|
-
|
|
3
|
-
## 概述
|
|
4
|
-
|
|
5
|
-
为 SillySpec CLI 工具添加可视化仪表盘(`sillyspec dashboard`),用户通过浏览器直观查看和管理项目进度、阶段流程、任务详情和实时日志。
|
|
6
|
-
|
|
7
|
-
## 目标用户
|
|
8
|
-
|
|
9
|
-
SillySpec 全部用户(官方功能,随 npm 包发布)。
|
|
10
|
-
|
|
11
|
-
## 分期计划
|
|
12
|
-
|
|
13
|
-
### 一期(MVP)
|
|
14
|
-
|
|
15
|
-
可视化仪表盘 + CLI 命令执行 + 实时日志流。
|
|
16
|
-
|
|
17
|
-
### 二期(进阶)
|
|
18
|
-
|
|
19
|
-
Web Terminal(xterm.js)+ 自定义命令 + AI 交互(视需求而定)。
|
|
20
|
-
|
|
21
|
-
## 架构
|
|
22
|
-
|
|
23
|
-
```
|
|
24
|
-
sillyspec dashboard
|
|
25
|
-
│
|
|
26
|
-
▼
|
|
27
|
-
Node.js HTTP Server (localhost:3456)
|
|
28
|
-
│
|
|
29
|
-
├─ chokidar: watch .sillyspec/ 目录
|
|
30
|
-
├─ WebSocket: 实时推送状态变更
|
|
31
|
-
└─ REST API: 项目列表、状态、日志、CLI 执行
|
|
32
|
-
│
|
|
33
|
-
▼
|
|
34
|
-
Vue 3 SPA (浏览器)
|
|
35
|
-
```
|
|
36
|
-
|
|
37
|
-
### 文件结构
|
|
38
|
-
|
|
39
|
-
```
|
|
40
|
-
sillyspec/packages/dashboard/
|
|
41
|
-
├── server/
|
|
42
|
-
│ ├── index.js # HTTP + WebSocket 服务启动
|
|
43
|
-
│ ├── watcher.js # chokidar 文件监听 + 增量解析
|
|
44
|
-
│ └── api.js # REST 路由
|
|
45
|
-
├── src/
|
|
46
|
-
│ ├── App.vue
|
|
47
|
-
│ ├── components/
|
|
48
|
-
│ │ ├── ProjectList.vue # 左栏:项目列表
|
|
49
|
-
│ │ ├── PipelineView.vue # 中栏:阶段 pipeline
|
|
50
|
-
│ │ ├── StepCard.vue # 步骤卡片(可展开折叠)
|
|
51
|
-
│ │ ├── DetailPanel.vue # 右栏:详情 + 日志
|
|
52
|
-
│ │ ├── LogStream.vue # 终端风格日志流
|
|
53
|
-
│ │ ├── CommandPalette.vue # Cmd+K 命令面板
|
|
54
|
-
│ │ └── StageBadge.vue # 阶段状态标签
|
|
55
|
-
│ ├── composables/
|
|
56
|
-
│ │ ├── useWebSocket.js # WebSocket 连接管理
|
|
57
|
-
│ │ └── useKeyboard.js # 键盘快捷键
|
|
58
|
-
│ └── styles/
|
|
59
|
-
│ └── theme.css # 深色主题变量
|
|
60
|
-
├── package.json
|
|
61
|
-
└── vite.config.js
|
|
62
|
-
```
|
|
63
|
-
|
|
64
|
-
## 核心页面设计
|
|
65
|
-
|
|
66
|
-
### 三栏布局
|
|
67
|
-
|
|
68
|
-
```
|
|
69
|
-
┌──────────┬─────────────────────────┬──────────────────┐
|
|
70
|
-
│ 项目列表 │ Pipeline 视图(中) │ 详情+日志(右) │
|
|
71
|
-
│ (200px) │ (flex-1) │ (320px,可收起) │
|
|
72
|
-
│ │ │ │
|
|
73
|
-
│ 📁 proj1 │ ✅ brainstorm │ Step 3 详情 │
|
|
74
|
-
│ 📁 proj2 │ ⏳ plan ← 当前 │ 结论:选择React │
|
|
75
|
-
│ 📁 proj3 │ ⬜ execute │ 决策:... │
|
|
76
|
-
│ │ ⬜ verify │ 📋 实时日志 │
|
|
77
|
-
└──────────┴─────────────────────────┴──────────────────┘
|
|
78
|
-
```
|
|
79
|
-
|
|
80
|
-
### 信息分层(三级密度)
|
|
81
|
-
|
|
82
|
-
1. **低密度(默认)**:阶段名 + 状态图标
|
|
83
|
-
2. **中密度(hover)**:步骤摘要(1-2 句话)
|
|
84
|
-
3. **高密度(点击)**:右侧面板展开完整详情 + 日志
|
|
85
|
-
|
|
86
|
-
### 异常高亮
|
|
87
|
-
|
|
88
|
-
失败/阻塞/超时步骤自动标红,视觉上突出,不需用户手动查找。
|
|
89
|
-
|
|
90
|
-
## 数据源与同步
|
|
91
|
-
|
|
92
|
-
### 数据文件
|
|
93
|
-
|
|
94
|
-
| 文件 | 用途 |
|
|
95
|
-
|---|---|
|
|
96
|
-
| `STATE.md` | 当前阶段、状态、下一步命令 |
|
|
97
|
-
| `.runtime/progress.json` | 步骤进度、摘要、时间戳 |
|
|
98
|
-
| `.runtime/user-inputs.md` | 用户输入记录 |
|
|
99
|
-
| `specs/*.md` | 设计文档 |
|
|
100
|
-
| `changes/*/design.md` | 技术方案 |
|
|
101
|
-
|
|
102
|
-
### 同步方案
|
|
103
|
-
|
|
104
|
-
- **启动时**:全量读取 `.sillyspec/` 目录,构建初始状态
|
|
105
|
-
- **运行时**:chokidar watch 文件变化 → 解析 → WebSocket 增量推送
|
|
106
|
-
- **不轮询,不做 diff**,文件变化直接读取推送
|
|
107
|
-
|
|
108
|
-
### CLI 命令执行(一期)
|
|
109
|
-
|
|
110
|
-
后端通过 `child_process.spawn` 执行 CLI 命令:
|
|
111
|
-
- "下一步"按钮 → `sillyspec next`
|
|
112
|
-
- 阶段切换按钮 → `sillyspec plan` / `sillyspec execute` 等
|
|
113
|
-
- 执行结果通过 WebSocket 实时推送到前端日志面板
|
|
114
|
-
|
|
115
|
-
## 交互设计
|
|
116
|
-
|
|
117
|
-
### 键盘快捷键
|
|
118
|
-
|
|
119
|
-
| 快捷键 | 功能 |
|
|
120
|
-
|---|---|
|
|
121
|
-
| `j/k` | 上下切换步骤 |
|
|
122
|
-
| `Enter` | 展开详情 |
|
|
123
|
-
| `Escape` | 收起面板 |
|
|
124
|
-
| `/` | 搜索日志 |
|
|
125
|
-
| `Cmd/Ctrl+K` | 命令面板 |
|
|
126
|
-
|
|
127
|
-
### 命令面板功能
|
|
128
|
-
|
|
129
|
-
- 搜索项目名
|
|
130
|
-
- 跳转到指定阶段
|
|
131
|
-
- 切换深色/浅色主题
|
|
132
|
-
|
|
133
|
-
### CLI 命令
|
|
134
|
-
|
|
135
|
-
```bash
|
|
136
|
-
sillyspec dashboard # 启动 + 自动开浏览器
|
|
137
|
-
sillyspec dashboard --port 8080 # 自定义端口
|
|
138
|
-
sillyspec dashboard --no-open # 不自动打开浏览器
|
|
139
|
-
```
|
|
140
|
-
|
|
141
|
-
## 视觉设计
|
|
142
|
-
|
|
143
|
-
### 配色
|
|
144
|
-
|
|
145
|
-
| 用途 | 色值 |
|
|
146
|
-
|---|---|
|
|
147
|
-
| 背景 | `#0D1117` |
|
|
148
|
-
| 主色(进行中) | `#00D4AA` |
|
|
149
|
-
| 阻塞 | `#F59E0B` |
|
|
150
|
-
| 失败 | `#F87171` |
|
|
151
|
-
| 未开始 | `#6B7280` |
|
|
152
|
-
|
|
153
|
-
### 动效
|
|
154
|
-
|
|
155
|
-
- 阶段完成:脉冲光效(CSS animation,200ms)
|
|
156
|
-
- 日志新行:淡入
|
|
157
|
-
- hover 过渡:100ms
|
|
158
|
-
- 进度条:弹性缓动
|
|
159
|
-
|
|
160
|
-
## 技术选型
|
|
161
|
-
|
|
162
|
-
| 层 | 技术 |
|
|
163
|
-
|---|---|
|
|
164
|
-
| 前端框架 | Vue 3 |
|
|
165
|
-
| 构建工具 | Vite |
|
|
166
|
-
| CSS | Tailwind CSS |
|
|
167
|
-
| 后端 | Node.js 原生 http + ws |
|
|
168
|
-
| 文件监听 | chokidar |
|
|
169
|
-
| 数据库 | 无,纯文件系统 |
|
|
170
|
-
|
|
171
|
-
## 约束和假设
|
|
172
|
-
|
|
173
|
-
- 用户本地已有 Node.js(SillySpec 前置依赖)
|
|
174
|
-
- 仪表盘为本地工具,不考虑多用户并发
|
|
175
|
-
- 前端构建产物嵌入 npm 包,无需额外 build
|
|
176
|
-
- 不引入 Express、数据库等重依赖
|
|
177
|
-
|
|
178
|
-
## 状态历史时间线
|
|
179
|
-
|
|
180
|
-
Pipeline 视图下方展示时间线,记录每个步骤的:
|
|
181
|
-
- 开始时间 / 结束时间 / 耗时
|
|
182
|
-
- 状态变化(进行中 → 完成/阻塞/失败)
|
|
183
|
-
- 可按时间排序,快速定位耗时最长或异常步骤
|
|
184
|
-
|
|
185
|
-
数据来源:`progress.json` 中的 `summaries` 和时间戳。
|
|
186
|
-
|
|
187
|
-
## 不在范围内(一期)
|
|
188
|
-
|
|
189
|
-
- 用户认证/权限
|
|
190
|
-
- 多人协作
|
|
191
|
-
- 数据持久化(纯文件系统)
|
|
192
|
-
- AI 对话交互(二期)
|
|
193
|
-
- Web Terminal(二期)
|
|
194
|
-
|
|
195
|
-
## 验收标准
|
|
196
|
-
|
|
197
|
-
- [ ] `sillyspec dashboard` 一键启动,自动打开浏览器
|
|
198
|
-
- [ ] 三栏布局正确渲染,响应式适配
|
|
199
|
-
- [ ] 文件变化后前端实时更新(<1s 延迟)
|
|
200
|
-
- [ ] 步骤卡片三级信息分层(默认/hover/点击)
|
|
201
|
-
- [ ] 实时日志流正常显示,可搜索可过滤
|
|
202
|
-
- [ ] 键盘快捷键可用(j/k/Enter/Escape/Cmd+K)
|
|
203
|
-
- [ ] 命令面板可搜索项目名和阶段
|
|
204
|
-
- [ ] CLI 命令执行按钮可用,结果实时显示
|
|
205
|
-
- [ ] 异常步骤自动高亮
|
|
206
|
-
- [ ] 深色/浅色主题切换
|