claude-coder 1.9.0 → 1.9.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (74) hide show
  1. package/README.md +214 -214
  2. package/bin/cli.js +155 -155
  3. package/package.json +55 -55
  4. package/recipes/_shared/roles/developer.md +11 -11
  5. package/recipes/_shared/roles/product.md +12 -12
  6. package/recipes/_shared/roles/tester.md +12 -12
  7. package/recipes/_shared/test/report-format.md +86 -86
  8. package/recipes/backend/base.md +27 -27
  9. package/recipes/backend/components/auth.md +18 -18
  10. package/recipes/backend/components/crud-api.md +18 -18
  11. package/recipes/backend/components/file-service.md +15 -15
  12. package/recipes/backend/manifest.json +20 -20
  13. package/recipes/backend/test/api-test.md +25 -25
  14. package/recipes/console/base.md +37 -37
  15. package/recipes/console/components/modal-form.md +20 -20
  16. package/recipes/console/components/pagination.md +17 -17
  17. package/recipes/console/components/search.md +17 -17
  18. package/recipes/console/components/table-list.md +18 -18
  19. package/recipes/console/components/tabs.md +14 -14
  20. package/recipes/console/components/tree.md +15 -15
  21. package/recipes/console/components/upload.md +15 -15
  22. package/recipes/console/manifest.json +24 -24
  23. package/recipes/console/test/crud-e2e.md +47 -47
  24. package/recipes/h5/base.md +26 -26
  25. package/recipes/h5/components/animation.md +11 -11
  26. package/recipes/h5/components/countdown.md +11 -11
  27. package/recipes/h5/components/share.md +11 -11
  28. package/recipes/h5/components/swiper.md +11 -11
  29. package/recipes/h5/manifest.json +21 -21
  30. package/recipes/h5/test/h5-e2e.md +20 -20
  31. package/src/commands/auth.js +420 -362
  32. package/src/commands/setup-modules/helpers.js +100 -100
  33. package/src/commands/setup-modules/index.js +25 -25
  34. package/src/commands/setup-modules/mcp.js +115 -115
  35. package/src/commands/setup-modules/provider.js +260 -260
  36. package/src/commands/setup-modules/safety.js +47 -47
  37. package/src/commands/setup-modules/simplify.js +52 -52
  38. package/src/commands/setup.js +172 -172
  39. package/src/common/assets.js +245 -245
  40. package/src/common/config.js +125 -125
  41. package/src/common/constants.js +55 -55
  42. package/src/common/indicator.js +260 -260
  43. package/src/common/interaction.js +170 -170
  44. package/src/common/logging.js +77 -77
  45. package/src/common/sdk.js +50 -50
  46. package/src/common/tasks.js +88 -88
  47. package/src/common/utils.js +213 -213
  48. package/src/core/coding.js +33 -33
  49. package/src/core/go.js +264 -264
  50. package/src/core/hooks.js +500 -500
  51. package/src/core/init.js +166 -165
  52. package/src/core/plan.js +188 -187
  53. package/src/core/prompts.js +247 -247
  54. package/src/core/repair.js +36 -36
  55. package/src/core/runner.js +471 -458
  56. package/src/core/scan.js +93 -93
  57. package/src/core/session.js +280 -271
  58. package/src/core/simplify.js +74 -74
  59. package/src/core/state.js +105 -105
  60. package/src/index.js +76 -76
  61. package/templates/bash-process.md +12 -12
  62. package/templates/codingSystem.md +65 -65
  63. package/templates/codingUser.md +17 -17
  64. package/templates/coreProtocol.md +29 -29
  65. package/templates/goSystem.md +130 -130
  66. package/templates/guidance.json +72 -72
  67. package/templates/planSystem.md +78 -78
  68. package/templates/planUser.md +8 -8
  69. package/templates/requirements.example.md +57 -57
  70. package/templates/scanSystem.md +120 -120
  71. package/templates/scanUser.md +10 -10
  72. package/templates/test_rule.md +194 -194
  73. package/templates/web-testing.md +17 -17
  74. package/types/index.d.ts +217 -217
@@ -1,86 +1,86 @@
1
- # 测试报告输出规范
2
-
3
- 测试任务完成后,必须输出两个报告文件。
4
-
5
- ## 1. 结构化数据:.claude-coder/test-report.json
6
-
7
- ```json
8
- {
9
- "project": "项目名",
10
- "timestamp": "ISO-8601 时间戳",
11
- "summary": {
12
- "total": 10,
13
- "passed": 8,
14
- "failed": 2,
15
- "skipped": 0
16
- },
17
- "duration_ms": 45000,
18
- "cases": [
19
- {
20
- "id": "TC-001",
21
- "name": "列表加载",
22
- "priority": "P0",
23
- "status": "passed",
24
- "duration_ms": 2300,
25
- "steps": [
26
- { "description": "导航到列表页", "status": "passed" },
27
- { "description": "验证表格存在", "status": "passed" }
28
- ],
29
- "error": null
30
- },
31
- {
32
- "id": "TC-002",
33
- "name": "新建功能",
34
- "priority": "P0",
35
- "status": "failed",
36
- "duration_ms": 5200,
37
- "steps": [
38
- { "description": "点击新建按钮", "status": "passed" },
39
- { "description": "填写表单", "status": "passed" },
40
- { "description": "提交", "status": "failed" }
41
- ],
42
- "error": "表单校验未触发,直接提交成功"
43
- }
44
- ],
45
- "environment": {
46
- "browser": "chromium",
47
- "baseUrl": "http://localhost:xxxx"
48
- }
49
- }
50
- ```
51
-
52
- ## 2. 可读报告:.claude-coder/test-report.md
53
-
54
- 格式模板:
55
-
56
- ```markdown
57
- # 测试报告 — {项目名}
58
-
59
- > 时间: {timestamp} | 通过率: {passed}/{total} | 耗时: {duration}s
60
-
61
- ## 摘要
62
-
63
- | 指标 | 数值 |
64
- |------|------|
65
- | 总用例 | {total} |
66
- | 通过 | {passed} |
67
- | 失败 | {failed} |
68
- | 跳过 | {skipped} |
69
-
70
- ## 详细结果
71
-
72
- ### ✅ [P0] 列表加载 — PASSED (2.3s)
73
- 1. 导航到列表页 ✓
74
- 2. 验证表格存在 ✓
75
-
76
- ### ❌ [P0] 新建功能 — FAILED (5.2s)
77
- 1. 点击新建按钮 ✓
78
- 2. 填写表单 ✓
79
- 3. 提交 ✗ — 表单校验未触发
80
-
81
- ## 失败用例汇总
82
-
83
- | 用例 | 优先级 | 失败原因 |
84
- |------|--------|----------|
85
- | 新建功能 | P0 | 表单校验未触发 |
86
- ```
1
+ # 测试报告输出规范
2
+
3
+ 测试任务完成后,必须输出两个报告文件。
4
+
5
+ ## 1. 结构化数据:.claude-coder/test-report.json
6
+
7
+ ```json
8
+ {
9
+ "project": "项目名",
10
+ "timestamp": "ISO-8601 时间戳",
11
+ "summary": {
12
+ "total": 10,
13
+ "passed": 8,
14
+ "failed": 2,
15
+ "skipped": 0
16
+ },
17
+ "duration_ms": 45000,
18
+ "cases": [
19
+ {
20
+ "id": "TC-001",
21
+ "name": "列表加载",
22
+ "priority": "P0",
23
+ "status": "passed",
24
+ "duration_ms": 2300,
25
+ "steps": [
26
+ { "description": "导航到列表页", "status": "passed" },
27
+ { "description": "验证表格存在", "status": "passed" }
28
+ ],
29
+ "error": null
30
+ },
31
+ {
32
+ "id": "TC-002",
33
+ "name": "新建功能",
34
+ "priority": "P0",
35
+ "status": "failed",
36
+ "duration_ms": 5200,
37
+ "steps": [
38
+ { "description": "点击新建按钮", "status": "passed" },
39
+ { "description": "填写表单", "status": "passed" },
40
+ { "description": "提交", "status": "failed" }
41
+ ],
42
+ "error": "表单校验未触发,直接提交成功"
43
+ }
44
+ ],
45
+ "environment": {
46
+ "browser": "chromium",
47
+ "baseUrl": "http://localhost:xxxx"
48
+ }
49
+ }
50
+ ```
51
+
52
+ ## 2. 可读报告:.claude-coder/test-report.md
53
+
54
+ 格式模板:
55
+
56
+ ```markdown
57
+ # 测试报告 — {项目名}
58
+
59
+ > 时间: {timestamp} | 通过率: {passed}/{total} | 耗时: {duration}s
60
+
61
+ ## 摘要
62
+
63
+ | 指标 | 数值 |
64
+ |------|------|
65
+ | 总用例 | {total} |
66
+ | 通过 | {passed} |
67
+ | 失败 | {failed} |
68
+ | 跳过 | {skipped} |
69
+
70
+ ## 详细结果
71
+
72
+ ### ✅ [P0] 列表加载 — PASSED (2.3s)
73
+ 1. 导航到列表页 ✓
74
+ 2. 验证表格存在 ✓
75
+
76
+ ### ❌ [P0] 新建功能 — FAILED (5.2s)
77
+ 1. 点击新建按钮 ✓
78
+ 2. 填写表单 ✓
79
+ 3. 提交 ✗ — 表单校验未触发
80
+
81
+ ## 失败用例汇总
82
+
83
+ | 用例 | 优先级 | 失败原因 |
84
+ |------|--------|----------|
85
+ | 新建功能 | P0 | 表单校验未触发 |
86
+ ```
@@ -1,27 +1,27 @@
1
- # 后端服务 — 基础食谱
2
-
3
- ## 任务分解模式
4
-
5
- 后端服务按以下标准拆分:
6
-
7
- 1. **infra**: 项目结构(如未有后端框架,需初始化)
8
- - steps:框架搭建、目录结构、数据库连接、中间件配置
9
- - 验证:服务启动成功,健康检查接口返回 200
10
-
11
- 2. **backend**: 数据模型 + API 接口
12
- - steps:Model 定义、CRUD Service、Controller/Router、参数校验
13
- - 验证:curl 测试所有接口返回正确响应
14
-
15
- 3. **backend**: 业务逻辑(复杂场景单独拆分)
16
- - steps:业务规则、数据转换、关联查询
17
- - 验证:curl 测试边界场景
18
-
19
- 4. **test**: API 测试
20
- - steps:正向流程、参数校验、权限校验、边界测试
21
-
22
- ## 通用规则
23
-
24
- - 一个资源(如 users)的完整 CRUD 合为一个 backend 任务
25
- - 认证鉴权如果与 CRUD 无关,拆为独立任务
26
- - 每个接口必须有参数校验
27
- - 错误响应格式统一
1
+ # 后端服务 — 基础食谱
2
+
3
+ ## 任务分解模式
4
+
5
+ 后端服务按以下标准拆分:
6
+
7
+ 1. **infra**: 项目结构(如未有后端框架,需初始化)
8
+ - steps:框架搭建、目录结构、数据库连接、中间件配置
9
+ - 验证:服务启动成功,健康检查接口返回 200
10
+
11
+ 2. **backend**: 数据模型 + API 接口
12
+ - steps:Model 定义、CRUD Service、Controller/Router、参数校验
13
+ - 验证:curl 测试所有接口返回正确响应
14
+
15
+ 3. **backend**: 业务逻辑(复杂场景单独拆分)
16
+ - steps:业务规则、数据转换、关联查询
17
+ - 验证:curl 测试边界场景
18
+
19
+ 4. **test**: API 测试
20
+ - steps:正向流程、参数校验、权限校验、边界测试
21
+
22
+ ## 通用规则
23
+
24
+ - 一个资源(如 users)的完整 CRUD 合为一个 backend 任务
25
+ - 认证鉴权如果与 CRUD 无关,拆为独立任务
26
+ - 每个接口必须有参数校验
27
+ - 错误响应格式统一
@@ -1,18 +1,18 @@
1
- # 认证鉴权
2
-
3
- ## 任务分解指导
4
- 认证鉴权拆为独立 backend 任务,不与 CRUD 混合。
5
-
6
- ## 实现要点
7
- - 注册:用户名/邮箱 + 密码,密码 hash 存储
8
- - 登录:验证凭证,返回 JWT token 或设置 session
9
- - Token 验证中间件:拦截受保护路由
10
- - 角色权限:admin / editor / viewer 等,按路由或按操作控制
11
- - Token 刷新/续期机制
12
-
13
- ## 验证策略
14
- - curl 注册 → 201
15
- - curl 登录 → 200 + token
16
- - curl 无 token 访问受保护路由 → 401
17
- - curl 带 token 访问 → 200
18
- - curl 权限不足 → 403
1
+ # 认证鉴权
2
+
3
+ ## 任务分解指导
4
+ 认证鉴权拆为独立 backend 任务,不与 CRUD 混合。
5
+
6
+ ## 实现要点
7
+ - 注册:用户名/邮箱 + 密码,密码 hash 存储
8
+ - 登录:验证凭证,返回 JWT token 或设置 session
9
+ - Token 验证中间件:拦截受保护路由
10
+ - 角色权限:admin / editor / viewer 等,按路由或按操作控制
11
+ - Token 刷新/续期机制
12
+
13
+ ## 验证策略
14
+ - curl 注册 → 201
15
+ - curl 登录 → 200 + token
16
+ - curl 无 token 访问受保护路由 → 401
17
+ - curl 带 token 访问 → 200
18
+ - curl 权限不足 → 403
@@ -1,18 +1,18 @@
1
- # RESTful CRUD API
2
-
3
- ## 任务分解指导
4
- 一个资源的完整 CRUD 合为一个 backend 任务。
5
-
6
- ## 实现要点
7
- - RESTful 风格:GET /资源(列表)、GET /资源/:id(详情)、POST(创建)、PUT(更新)、DELETE(删除)
8
- - 列表分页:`?page=1&pageSize=10`,返回 `{ data: [], total: N }`
9
- - 搜索过滤:`?keyword=xxx&status=active`
10
- - 排序:`?sortBy=createdAt&order=desc`
11
- - 参数校验:必填项、类型、长度、格式
12
- - 错误响应统一格式:`{ code: 400, message: "xxx" }`
13
-
14
- ## 验证策略
15
- - curl POST 创建 → 201 + 返回创建的数据
16
- - curl GET 列表 → 200 + 分页结构正确
17
- - curl PUT 更新 → 200 + 数据变更
18
- - curl DELETE → 200 + 再 GET 确认已删除
1
+ # RESTful CRUD API
2
+
3
+ ## 任务分解指导
4
+ 一个资源的完整 CRUD 合为一个 backend 任务。
5
+
6
+ ## 实现要点
7
+ - RESTful 风格:GET /资源(列表)、GET /资源/:id(详情)、POST(创建)、PUT(更新)、DELETE(删除)
8
+ - 列表分页:`?page=1&pageSize=10`,返回 `{ data: [], total: N }`
9
+ - 搜索过滤:`?keyword=xxx&status=active`
10
+ - 排序:`?sortBy=createdAt&order=desc`
11
+ - 参数校验:必填项、类型、长度、格式
12
+ - 错误响应统一格式:`{ code: 400, message: "xxx" }`
13
+
14
+ ## 验证策略
15
+ - curl POST 创建 → 201 + 返回创建的数据
16
+ - curl GET 列表 → 200 + 分页结构正确
17
+ - curl PUT 更新 → 200 + 数据变更
18
+ - curl DELETE → 200 + 再 GET 确认已删除
@@ -1,15 +1,15 @@
1
- # 文件服务
2
-
3
- ## 任务分解指导
4
- 文件服务如逻辑简单可合入 CRUD 任务,复杂时独立拆分。
5
-
6
- ## 实现要点
7
- - 上传接口:multipart/form-data,校验类型和大小
8
- - 存储:本地文件系统 / 对象存储(S3/OSS)
9
- - 下载/访问:静态文件服务或签名 URL
10
- - 文件元信息:原始名、大小、MIME 类型、上传时间
11
-
12
- ## 验证策略
13
- - curl 上传文件 → 200 + 返回 fileId/URL
14
- - curl 访问上传的文件 → 200 + 内容正确
15
- - curl 上传超限文件 → 400 + 错误提示
1
+ # 文件服务
2
+
3
+ ## 任务分解指导
4
+ 文件服务如逻辑简单可合入 CRUD 任务,复杂时独立拆分。
5
+
6
+ ## 实现要点
7
+ - 上传接口:multipart/form-data,校验类型和大小
8
+ - 存储:本地文件系统 / 对象存储(S3/OSS)
9
+ - 下载/访问:静态文件服务或签名 URL
10
+ - 文件元信息:原始名、大小、MIME 类型、上传时间
11
+
12
+ ## 验证策略
13
+ - curl 上传文件 → 200 + 返回 fileId/URL
14
+ - curl 访问上传的文件 → 200 + 内容正确
15
+ - curl 上传超限文件 → 400 + 错误提示
@@ -1,20 +1,20 @@
1
- {
2
- "id": "backend",
3
- "name": "后端服务",
4
- "description": "后端 API 服务开发(RESTful CRUD、认证鉴权、文件服务等)",
5
- "base": "base.md",
6
- "components": [
7
- { "id": "crud-api", "label": "CRUD API", "description": "RESTful 增删改查接口 + 分页 + 过滤", "file": "components/crud-api.md", "default": true },
8
- { "id": "auth", "label": "认证鉴权", "description": "登录注册、JWT/Session、角色权限", "file": "components/auth.md", "default": false },
9
- { "id": "file-service", "label": "文件服务", "description": "文件上传下载、存储、类型校验", "file": "components/file-service.md", "default": false }
10
- ],
11
- "test": {
12
- "file": "test/api-test.md",
13
- "defaultEnabled": true
14
- },
15
- "defaults": {
16
- "components": ["crud-api"],
17
- "role": "developer",
18
- "test": true
19
- }
20
- }
1
+ {
2
+ "id": "backend",
3
+ "name": "后端服务",
4
+ "description": "后端 API 服务开发(RESTful CRUD、认证鉴权、文件服务等)",
5
+ "base": "base.md",
6
+ "components": [
7
+ { "id": "crud-api", "label": "CRUD API", "description": "RESTful 增删改查接口 + 分页 + 过滤", "file": "components/crud-api.md", "default": true },
8
+ { "id": "auth", "label": "认证鉴权", "description": "登录注册、JWT/Session、角色权限", "file": "components/auth.md", "default": false },
9
+ { "id": "file-service", "label": "文件服务", "description": "文件上传下载、存储、类型校验", "file": "components/file-service.md", "default": false }
10
+ ],
11
+ "test": {
12
+ "file": "test/api-test.md",
13
+ "defaultEnabled": true
14
+ },
15
+ "defaults": {
16
+ "components": ["crud-api"],
17
+ "role": "developer",
18
+ "test": true
19
+ }
20
+ }
@@ -1,25 +1,25 @@
1
- # API 测试步骤模板
2
-
3
- ## 标准测试用例
4
-
5
- ### 【P0】CRUD 正向流程
6
- 1. POST 创建资源 → 验证 201 + 返回数据
7
- 2. GET 列表 → 验证新数据在列表中
8
- 3. GET 详情 → 验证数据正确
9
- 4. PUT 更新 → 验证数据变更
10
- 5. DELETE 删除 → 验证 GET 返回 404
11
-
12
- ### 【P0】分页和搜索
13
- 1. 创建多条数据
14
- 2. GET 列表 ?page=1&pageSize=2 → 验证分页字段正确
15
- 3. GET 列表 ?keyword=xxx → 验证过滤结果
16
-
17
- ### 【P1】参数校验
18
- 1. POST 缺少必填字段 → 验证 400
19
- 2. POST 字段格式错误 → 验证 400
20
- 3. PUT 不存在的 ID → 验证 404
21
-
22
- ### 【P1】认证鉴权(如适用)
23
- 1. 无 token 访问 → 验证 401
24
- 2. 错误 token → 验证 401
25
- 3. 权限不足 → 验证 403
1
+ # API 测试步骤模板
2
+
3
+ ## 标准测试用例
4
+
5
+ ### 【P0】CRUD 正向流程
6
+ 1. POST 创建资源 → 验证 201 + 返回数据
7
+ 2. GET 列表 → 验证新数据在列表中
8
+ 3. GET 详情 → 验证数据正确
9
+ 4. PUT 更新 → 验证数据变更
10
+ 5. DELETE 删除 → 验证 GET 返回 404
11
+
12
+ ### 【P0】分页和搜索
13
+ 1. 创建多条数据
14
+ 2. GET 列表 ?page=1&pageSize=2 → 验证分页字段正确
15
+ 3. GET 列表 ?keyword=xxx → 验证过滤结果
16
+
17
+ ### 【P1】参数校验
18
+ 1. POST 缺少必填字段 → 验证 400
19
+ 2. POST 字段格式错误 → 验证 400
20
+ 3. PUT 不存在的 ID → 验证 404
21
+
22
+ ### 【P1】认证鉴权(如适用)
23
+ 1. 无 token 访问 → 验证 401
24
+ 2. 错误 token → 验证 401
25
+ 3. 权限不足 → 验证 403
@@ -1,37 +1,37 @@
1
- # Console 管理后台 — 基础食谱
2
-
3
- ## 任务分解模式
4
-
5
- 管理后台 CRUD 页面按以下标准拆分任务(1 session = 1 task):
6
-
7
- 1. **backend**: API 接口层(RESTful CRUD + 分页 + 搜索过滤)
8
- - steps 包含:路由定义、Controller、Service、数据模型
9
- - 验证:curl 请求返回正确状态码和分页结构
10
-
11
- 2. **frontend**: 列表页面(表格 + 搜索栏 + 分页组件)
12
- - steps 包含:页面组件、数据请求、状态管理
13
- - 验证:Playwright snapshot 验证页面元素存在
14
-
15
- 3. **frontend**: 弹窗/表单(新建 + 编辑弹窗 + 表单校验)
16
- - steps 包含:弹窗组件、表单项、校验规则、提交逻辑
17
- - 验证:Playwright 点击按钮 → snapshot 验证弹窗打开
18
-
19
- 4. **fullstack**: 联调(前后端串通 + 错误处理 + loading 状态)
20
- - steps 包含:接口联调、错误提示、空状态处理
21
- - 验证:Playwright 完整 CRUD 流程
22
-
23
- 5. **test**: E2E 测试(可选,参考 test/crud-e2e.md)
24
-
25
- ## 通用规则
26
-
27
- - 搜索框 + 表格 + 分页合并为一个 frontend 任务(不要拆太碎)
28
- - 弹窗 + 表单作为独立 frontend 任务(UI 和逻辑较复杂)
29
- - 后端 API 作为独立 backend 任务
30
- - 前后端联调作为 fullstack 任务
31
- - 每个任务必须有可执行的验证步骤
32
-
33
- ## 反面案例
34
-
35
- - "搜索框"、"表格"、"分页"各拆为独立任务 → 太碎,合并
36
- - "全部前端"合为一个任务 → 太大(弹窗应独立)
37
- - 忽略验证步骤 → 每个 task 的 steps 最后一步必须是验证命令
1
+ # Console 管理后台 — 基础食谱
2
+
3
+ ## 任务分解模式
4
+
5
+ 管理后台 CRUD 页面按以下标准拆分任务(1 session = 1 task):
6
+
7
+ 1. **backend**: API 接口层(RESTful CRUD + 分页 + 搜索过滤)
8
+ - steps 包含:路由定义、Controller、Service、数据模型
9
+ - 验证:curl 请求返回正确状态码和分页结构
10
+
11
+ 2. **frontend**: 列表页面(表格 + 搜索栏 + 分页组件)
12
+ - steps 包含:页面组件、数据请求、状态管理
13
+ - 验证:Playwright snapshot 验证页面元素存在
14
+
15
+ 3. **frontend**: 弹窗/表单(新建 + 编辑弹窗 + 表单校验)
16
+ - steps 包含:弹窗组件、表单项、校验规则、提交逻辑
17
+ - 验证:Playwright 点击按钮 → snapshot 验证弹窗打开
18
+
19
+ 4. **fullstack**: 联调(前后端串通 + 错误处理 + loading 状态)
20
+ - steps 包含:接口联调、错误提示、空状态处理
21
+ - 验证:Playwright 完整 CRUD 流程
22
+
23
+ 5. **test**: E2E 测试(可选,参考 test/crud-e2e.md)
24
+
25
+ ## 通用规则
26
+
27
+ - 搜索框 + 表格 + 分页合并为一个 frontend 任务(不要拆太碎)
28
+ - 弹窗 + 表单作为独立 frontend 任务(UI 和逻辑较复杂)
29
+ - 后端 API 作为独立 backend 任务
30
+ - 前后端联调作为 fullstack 任务
31
+ - 每个任务必须有可执行的验证步骤
32
+
33
+ ## 反面案例
34
+
35
+ - "搜索框"、"表格"、"分页"各拆为独立任务 → 太碎,合并
36
+ - "全部前端"合为一个任务 → 太大(弹窗应独立)
37
+ - 忽略验证步骤 → 每个 task 的 steps 最后一步必须是验证命令
@@ -1,20 +1,20 @@
1
- # 弹窗 + 表单
2
-
3
- ## 任务分解指导
4
- 弹窗和表单作为独立的 frontend 任务。
5
- steps 中应包含:弹窗组件 → 表单项 → 校验规则 → 提交 → 关闭 → 列表刷新。
6
-
7
- ## 实现要点
8
- - 新建弹窗:表单为空,提交调用 POST API
9
- - 编辑弹窗:表单回填已有数据,提交调用 PUT API
10
- - 共用同一个弹窗组件(通过 mode 区分新建/编辑)
11
- - 表单校验:必填项、格式校验(邮箱、手机号等)、长度限制
12
- - 提交 loading:防重复提交
13
- - 提交成功后:关闭弹窗 + 刷新列表 + 提示消息
14
- - 提交失败:显示错误信息,不关闭弹窗
15
-
16
- ## 验证策略
17
- - 点击新建按钮 → snapshot 验证弹窗打开 + 表单元素存在
18
- - 不填必填项直接提交 → 验证校验提示出现
19
- - 正确填写并提交 → 验证弹窗关闭 + 列表数据更新
20
- - 点击编辑 → 验证弹窗打开 + 数据回填
1
+ # 弹窗 + 表单
2
+
3
+ ## 任务分解指导
4
+ 弹窗和表单作为独立的 frontend 任务。
5
+ steps 中应包含:弹窗组件 → 表单项 → 校验规则 → 提交 → 关闭 → 列表刷新。
6
+
7
+ ## 实现要点
8
+ - 新建弹窗:表单为空,提交调用 POST API
9
+ - 编辑弹窗:表单回填已有数据,提交调用 PUT API
10
+ - 共用同一个弹窗组件(通过 mode 区分新建/编辑)
11
+ - 表单校验:必填项、格式校验(邮箱、手机号等)、长度限制
12
+ - 提交 loading:防重复提交
13
+ - 提交成功后:关闭弹窗 + 刷新列表 + 提示消息
14
+ - 提交失败:显示错误信息,不关闭弹窗
15
+
16
+ ## 验证策略
17
+ - 点击新建按钮 → snapshot 验证弹窗打开 + 表单元素存在
18
+ - 不填必填项直接提交 → 验证校验提示出现
19
+ - 正确填写并提交 → 验证弹窗关闭 + 列表数据更新
20
+ - 点击编辑 → 验证弹窗打开 + 数据回填
@@ -1,17 +1,17 @@
1
- # 分页组件
2
-
3
- ## 任务分解指导
4
- 分页与表格合并为一个 frontend 任务,不单独拆分。
5
- steps 中应包含:分页参数 → 分页 UI → 翻页请求 → 总数显示。
6
-
7
- ## 实现要点
8
- - 分页模式:offset + limit(如 `?page=1&pageSize=10`)
9
- - 总数显示:从 API 响应中取 total 字段
10
- - 默认每页条数:10 条(可配置)
11
- - 页码变化触发重新请求
12
- - URL 同步:当前页码反映在 URL query 中(可选)
13
-
14
- ## 验证策略
15
- - 验证分页组件渲染(页码、上一页/下一页按钮)
16
- - 点击第 2 页 → 验证数据变化
17
- - 验证总数显示正确
1
+ # 分页组件
2
+
3
+ ## 任务分解指导
4
+ 分页与表格合并为一个 frontend 任务,不单独拆分。
5
+ steps 中应包含:分页参数 → 分页 UI → 翻页请求 → 总数显示。
6
+
7
+ ## 实现要点
8
+ - 分页模式:offset + limit(如 `?page=1&pageSize=10`)
9
+ - 总数显示:从 API 响应中取 total 字段
10
+ - 默认每页条数:10 条(可配置)
11
+ - 页码变化触发重新请求
12
+ - URL 同步:当前页码反映在 URL query 中(可选)
13
+
14
+ ## 验证策略
15
+ - 验证分页组件渲染(页码、上一页/下一页按钮)
16
+ - 点击第 2 页 → 验证数据变化
17
+ - 验证总数显示正确
@@ -1,17 +1,17 @@
1
- # 搜索组件
2
-
3
- ## 任务分解指导
4
- 搜索功能通常与列表任务合并为一个 frontend 任务,不单独拆分。
5
- steps 中应包含:搜索框 UI → 防抖处理 → API 请求参数拼接 → 列表刷新。
6
-
7
- ## 实现要点
8
- - 输入防抖 300ms,避免频繁请求
9
- - 搜索关键词作为 query 参数传给列表 API(如 `?keyword=xxx`)
10
- - 支持清空搜索恢复全量数据
11
- - 搜索时显示 loading 状态
12
- - 如有多个筛选条件,使用表单组合(日期范围、下拉选择、关键词等)
13
-
14
- ## 验证策略
15
- - 输入已知关键词 → snapshot 验证列表数据过滤
16
- - 清空搜索 → 验证恢复全量
17
- - 快速连续输入 → 验证只发一次请求(防抖生效)
1
+ # 搜索组件
2
+
3
+ ## 任务分解指导
4
+ 搜索功能通常与列表任务合并为一个 frontend 任务,不单独拆分。
5
+ steps 中应包含:搜索框 UI → 防抖处理 → API 请求参数拼接 → 列表刷新。
6
+
7
+ ## 实现要点
8
+ - 输入防抖 300ms,避免频繁请求
9
+ - 搜索关键词作为 query 参数传给列表 API(如 `?keyword=xxx`)
10
+ - 支持清空搜索恢复全量数据
11
+ - 搜索时显示 loading 状态
12
+ - 如有多个筛选条件,使用表单组合(日期范围、下拉选择、关键词等)
13
+
14
+ ## 验证策略
15
+ - 输入已知关键词 → snapshot 验证列表数据过滤
16
+ - 清空搜索 → 验证恢复全量
17
+ - 快速连续输入 → 验证只发一次请求(防抖生效)
@@ -1,18 +1,18 @@
1
- # 数据表格
2
-
3
- ## 任务分解指导
4
- 表格是列表页的核心,与搜索和分页合并为一个 frontend 任务。
5
- steps 中应包含:列定义 → 数据请求 → 渲染 → 操作列按钮。
6
-
7
- ## 实现要点
8
- - 列定义清晰:字段名、显示名、宽度、对齐方式、渲染方式
9
- - 操作列:编辑、删除按钮(按业务需求扩展)
10
- - 空状态:无数据时显示友好提示
11
- - Loading 状态:请求中显示骨架屏或 spinner
12
- - 如需行选择:checkbox 列 + 批量操作栏
13
- - 如需排序:列头排序图标 + API 排序参数
14
-
15
- ## 验证策略
16
- - snapshot 验证表格元素存在(table/thead/tbody)
17
- - 验证至少有 1 行数据(或空状态文案)
18
- - 验证操作列按钮可点击
1
+ # 数据表格
2
+
3
+ ## 任务分解指导
4
+ 表格是列表页的核心,与搜索和分页合并为一个 frontend 任务。
5
+ steps 中应包含:列定义 → 数据请求 → 渲染 → 操作列按钮。
6
+
7
+ ## 实现要点
8
+ - 列定义清晰:字段名、显示名、宽度、对齐方式、渲染方式
9
+ - 操作列:编辑、删除按钮(按业务需求扩展)
10
+ - 空状态:无数据时显示友好提示
11
+ - Loading 状态:请求中显示骨架屏或 spinner
12
+ - 如需行选择:checkbox 列 + 批量操作栏
13
+ - 如需排序:列头排序图标 + API 排序参数
14
+
15
+ ## 验证策略
16
+ - snapshot 验证表格元素存在(table/thead/tbody)
17
+ - 验证至少有 1 行数据(或空状态文案)
18
+ - 验证操作列按钮可点击