intention-coding 0.4.0 → 0.4.3

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 (51) hide show
  1. package/package.json +2 -3
  2. package/dist/db/file-storage.js +0 -638
  3. package/dist/index.js +0 -26
  4. package/dist/server/index.js +0 -88
  5. package/dist/services/bug-fix-agent/index.js +0 -320
  6. package/dist/services/change-summarizer/index.js +0 -123
  7. package/dist/services/change-summarizer/prompt/change-analysis.js +0 -56
  8. package/dist/services/code-generator/index.js +0 -403
  9. package/dist/services/code-generator/stages/execution-stage.js +0 -549
  10. package/dist/services/code-generator/stages/ideation-stage.js +0 -267
  11. package/dist/services/code-generator/stages/optimization-stage.js +0 -334
  12. package/dist/services/code-generator/stages/planning-stage.js +0 -295
  13. package/dist/services/code-generator/stages/research-stage.js +0 -283
  14. package/dist/services/code-generator/stages/review-stage.js +0 -270
  15. package/dist/services/code-generator/types.js +0 -37
  16. package/dist/services/code-generator/utils/instruction-executor.js +0 -207
  17. package/dist/services/code-generator/workflow-manager.js +0 -252
  18. package/dist/services/image-analysis/analyzer.js +0 -530
  19. package/dist/services/image-analysis/index.js +0 -406
  20. package/dist/services/image-analysis/types.js +0 -46
  21. package/dist/services/image-converter/converter.js +0 -310
  22. package/dist/services/image-converter/index.js +0 -262
  23. package/dist/services/image-converter/types.js +0 -31
  24. package/dist/services/integrated-generator/index.js +0 -1297
  25. package/dist/services/pdf2md/index.js +0 -180
  26. package/dist/services/project-template/index.js +0 -83
  27. package/dist/services/project-template/prompt/project-rules.js +0 -98
  28. package/dist/services/requirement-analyzer/chunk-reader.js +0 -218
  29. package/dist/services/requirement-analyzer/core/document-generator.js +0 -254
  30. package/dist/services/requirement-analyzer/core/intelligent-analyzer.js +0 -169
  31. package/dist/services/requirement-analyzer/core/project-analyzer.js +0 -199
  32. package/dist/services/requirement-analyzer/core/requirement-analyzer-service.js +0 -191
  33. package/dist/services/requirement-analyzer/core/template-selector.js +0 -124
  34. package/dist/services/requirement-analyzer/core/types.js +0 -23
  35. package/dist/services/requirement-analyzer/index.js +0 -177
  36. package/dist/services/requirement-analyzer/prompt/api-template.js +0 -302
  37. package/dist/services/requirement-analyzer/prompt/app-template.js +0 -455
  38. package/dist/services/requirement-analyzer/prompt/intelligent-requirement-analysis.js +0 -92
  39. package/dist/services/requirement-analyzer/prompt/pc-page-template.js +0 -582
  40. package/dist/services/requirement-analyzer/prompt/requirement-analysis.js +0 -664
  41. package/dist/services/requirement-analyzer/prompt/sdk-template.js +0 -582
  42. package/dist/services/requirement-analyzer/utils/file-reader.js +0 -169
  43. package/dist/services/world2md/index.js +0 -157
  44. package/dist/types/index.js +0 -2
  45. package/dist/utils/common.js +0 -72
  46. package/dist/utils/config.js +0 -163
  47. package/dist/utils/context-manager.js +0 -114
  48. package/dist/utils/dify.js +0 -243
  49. package/dist/utils/logger.js +0 -129
  50. package/dist/utils/openai.js +0 -225
  51. package/dist/utils/pack.js +0 -75
@@ -1,455 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.appTemplatePrompt = void 0;
4
- exports.appTemplatePrompt = `你是一位专业的移动端技术文档编写专家。请基于用户提供的输入内容,生成一份完整、详细的APP开发技术需求文档。
5
-
6
- ## 任务要求
7
- - 必须输出完整的Markdown格式技术需求文档
8
- - 不要只给出总结,要输出完整的文档内容
9
- - 每个章节都要有详细的内容,不能省略
10
- - 文档长度应该在3000字以上
11
- - 重点描述移动端页面布局、样式、交互逻辑等移动端相关内容
12
-
13
- ## 输入信息
14
- - **功能名称**: {featureName}
15
- - **业务领域**: {businessDomain}
16
- - **生成时序图**: {generateSequenceDiagram}
17
-
18
- ## 原始需求内容
19
- \`\`\`
20
- {inputContent}
21
- \`\`\`
22
-
23
- ## 文档结构要求
24
- 请严格按照以下结构输出完整的需求文档,每个章节都要有详实的内容:
25
-
26
- # {featureName} - APP开发技术需求文档
27
-
28
- > **生成时间**: {currentTime}
29
- > **业务领域**: {businessDomain}
30
- > **应用类型**: 移动端应用
31
-
32
- ---
33
-
34
- ## 1. 需求背景
35
-
36
- **背景**: [详细描述APP功能背景、业务需求和目标]
37
-
38
- **关键功能**: [列出APP的主要功能点]
39
-
40
- **涉及角色**: [列出所有相关用户角色]
41
-
42
- ## 2. {featureName}功能设计说明
43
-
44
- | | | | | |
45
- |---|---|---|---|---|
46
- |**流程编号**|F001|**流程名称**|{featureName}|
47
- |**业务功能编号**|BF001|**业务功能名称**|{featureName}|
48
- |**功能设计编号**|FD001|**系统功能名称**|{featureName}|
49
- |**前置条件**|[详细描述功能使用的前置条件]|
50
- |**角色(岗位)**|[详细描述用户角色及其权限]|
51
- |**入口渠道**|[描述功能访问入口,如Tab、按钮等]|
52
- |**功能描述**|[详细的功能描述]|
53
- |**调用能力域/中心**|[如适用的后端API接口]|
54
-
55
- ## 3. 页面布局设计
56
-
57
- ### 3.1 整体布局结构
58
- [详细描述页面的整体布局结构,包括导航栏、内容区、底部操作栏等区域的划分和功能]
59
-
60
- ### 3.2 页面区域划分
61
- [详细描述页面各个功能区域的布局,使用文字描述区域位置关系]
62
-
63
- ### 3.3 多屏幕适配要求
64
- [详细描述页面在不同屏幕尺寸和分辨率下的布局适配要求]
65
-
66
- ### 3.4 响应式布局规范
67
- [详细描述移动端响应式布局的设计规范和实现要求]
68
-
69
- ### 3.5 手势区域设计
70
- [详细描述页面中手势操作区域的设计和交互规范]
71
-
72
- ## 4. 样式规范说明
73
-
74
- ### 4.1 色彩规范
75
- [详细描述APP使用的主色调、辅助色、状态色等配色方案]
76
-
77
- ### 4.2 字体规范
78
- [详细描述APP使用的字体、字号、字重等规范,考虑iOS和Android差异]
79
-
80
- ### 4.3 组件样式
81
- [详细描述APP中各种UI组件的样式规范,如按钮、输入框、列表等]
82
-
83
- ### 4.4 间距规范
84
- [详细描述页面元素间的间距规范,包括内边距、外边距等]
85
-
86
- ### 4.5 图标规范
87
- [详细描述APP中图标的设计规范和使用要求]
88
-
89
- ### 4.6 主题规范
90
- [详细描述APP主题切换的设计规范和实现要求]
91
-
92
- ## 5. 交互逻辑说明
93
-
94
- ### 5.1 手势操作
95
- [详细描述页面支持的手势操作,如滑动、长按、双击等]
96
-
97
- ### 5.2 页面跳转逻辑
98
- [详细描述页面间的跳转关系和导航逻辑]
99
-
100
- ### 5.3 状态管理
101
- [详细描述页面的各种状态及其切换逻辑,如加载状态、空状态、错误状态等]
102
-
103
- ### 5.4 动效设计
104
- [详细描述页面中的动画效果和过渡效果,考虑平台特性]
105
-
106
- ### 5.5 表单验证规则
107
- [详细描述页面中表单元素的验证规则和错误提示]
108
-
109
- ### 5.6 用户反馈机制
110
- [详细描述用户操作后的反馈机制,如Toast、Loading等]
111
-
112
- ### 5.7 离线交互处理
113
- [详细描述应用在离线状态下的交互处理机制]
114
-
115
- ## 6. 界面字段说明
116
-
117
- ### 6.1 主要数据实体
118
- [描述页面涉及的主要数据实体]
119
-
120
- 实体一
121
- | | | | | |
122
- |---|---|---|---|---|
123
- |**字段名称**|**数据类型**|**长度**|**必填**|**说明**|
124
- |[字段1]|[类型]|[长度]|[是/否]|[详细说明]|
125
- |[字段2]|[类型]|[长度]|[是/否]|[详细说明]|
126
- |[添加更多相关字段...]|||
127
-
128
- ### 6.2 输入控件说明
129
- [详细描述页面中各种输入控件的使用规范]
130
-
131
- ### 6.3 展示控件说明
132
- [详细描述页面中各种展示控件的使用规范]
133
-
134
- ## 7. 界面操作说明
135
-
136
- | | | |
137
- |---|---|---|
138
- |**序号**|**业务操作**|**说明**|
139
- |1|[操作1]|[详细说明操作触发条件、执行过程和结果]|
140
- |2|[操作2]|[详细说明操作触发条件、执行过程和结果]|
141
- |[添加更多操作...]
142
-
143
- ## 8. 组件结构设计
144
-
145
- ### 8.1 页面组件树
146
- [使用树状结构描述页面的组件层次关系]
147
-
148
- ### 8.2 核心组件说明
149
- [详细描述页面中的核心组件功能、属性和使用方式]
150
-
151
- ### 8.3 组件通信机制
152
- [详细描述组件间的通信方式和数据流]
153
-
154
- ### 8.4 组件状态管理
155
- [详细描述组件内部状态和全局状态的管理方式]
156
-
157
- ## 9. 平台特性考虑
158
-
159
- ### 9.1 iOS平台适配
160
- [详细描述在iOS平台上的特殊适配要求]
161
-
162
- ### 9.2 Android平台适配
163
- [详细描述在Android平台上的特殊适配要求]
164
-
165
- ### 9.3 系统权限要求
166
- [详细描述APP需要申请的系统权限及其使用场景]
167
-
168
- ## 11. 业务对象时序图
169
-
170
- \`\`\`mermaid
171
- sequenceDiagram
172
- participant 用户
173
- participant 移动端APP
174
- participant 路由管理器
175
- participant 状态管理器
176
- participant 认证服务
177
- participant 权限服务
178
- participant 后端服务
179
- participant 数据库
180
- participant 缓存服务
181
- participant 消息队列
182
- participant 日志服务
183
- participant 监控服务
184
-
185
- %% 应用启动流程
186
- 用户->>移动端APP: 启动应用
187
- 移动端APP->>路由管理器: 解析初始路由
188
- 路由管理器-->>移动端APP: 返回路由信息
189
- 移动端APP->>状态管理器: 初始化应用状态
190
- 移动端APP->>认证服务: 验证用户身份
191
- 认证服务-->>移动端APP: 返回认证结果
192
- 移动端APP->>权限服务: 检查用户权限
193
- 权限服务-->>移动端APP: 返回权限信息
194
- 移动端APP->>状态管理器: 更新认证状态
195
- 移动端APP->>用户: 显示主界面
196
-
197
- %% 页面加载流程
198
- 用户->>移动端APP: 访问功能页面
199
- 移动端APP->>路由管理器: 解析页面路由
200
- 路由管理器-->>移动端APP: 返回路由信息
201
- 移动端APP->>状态管理器: 初始化页面状态
202
- 移动端APP->>缓存服务: 查询缓存数据
203
- alt 缓存中有数据
204
- 缓存服务-->>移动端APP: 返回缓存数据
205
- 移动端APP->>状态管理器: 更新页面状态
206
- 移动端APP->>用户: 渲染页面内容
207
- 移动端APP->>监控服务: 记录缓存命中
208
- else 缓存中无数据
209
- 移动端APP->>后端服务: 发起API请求
210
- 后端服务->>数据库: 查询数据
211
- 数据库-->>后端服务: 返回查询结果
212
- 后端服务-->>移动端APP: 返回响应数据
213
- 移动端APP->>缓存服务: 存储数据到缓存
214
- 移动端APP->>状态管理器: 更新页面状态
215
- 移动端APP->>用户: 渲染页面内容
216
- 移动端APP->>监控服务: 记录数据加载
217
- end
218
- 移动端APP->>日志服务: 记录页面访问日志
219
- \`\`\`
220
-
221
- ### 11.2 方案二:替代流程(不同有效路径)
222
-
223
- #### 11.2.1 手势交互设计流程
224
- \`\`\`mermaid
225
- sequenceDiagram
226
- participant 用户
227
- participant 移动端APP
228
- participant 手势识别器
229
- participant 交互处理器
230
- participant 状态管理器
231
-
232
- 用户->>移动端APP: 执行手势操作
233
- 移动端APP->>手势识别器: 识别手势类型
234
- 手势识别器-->>移动端APP: 返回手势识别结果
235
- 移动端APP->>交互处理器: 处理手势操作
236
- 交互处理器->>状态管理器: 更新应用状态
237
- 状态管理器-->>交互处理器: 返回状态更新结果
238
- 交互处理器-->>移动端APP: 返回处理结果
239
- 移动端APP->>用户: 反馈手势操作结果
240
- \`\`\`
241
-
242
- #### 11.2.2 组件设计规范流程
243
- \`\`\`mermaid
244
- sequenceDiagram
245
- participant 移动端APP
246
- participant 组件库
247
- participant 设计系统
248
- participant 样式管理器
249
- participant 布局引擎
250
- participant 日志服务
251
-
252
- 移动端APP->>组件库: 请求组件规范
253
- 组件库->>设计系统: 获取设计规范
254
- 设计系统-->>组件库: 返回设计规范
255
- 组件库->>样式管理器: 应用样式规则
256
- 样式管理器-->>组件库: 返回样式配置
257
- 组件库->>布局引擎: 计算布局
258
- 布局引擎-->>组件库: 返回布局信息
259
- 组件库-->>移动端APP: 返回组件实现
260
- 移动端APP->>日志服务: 记录组件使用日志
261
- \`\`\`
262
-
263
- ### 11.3 异常流程(错误处理)
264
-
265
- #### 11.3.1 设备兼容性错误
266
- \`\`\`mermaid
267
- sequenceDiagram
268
- participant 用户
269
- participant 移动端APP
270
- participant 设备兼容性检查器
271
- participant 错误处理器
272
- participant 日志服务
273
-
274
- 用户->>移动端APP: 启动应用
275
- 移动端APP->>设备兼容性检查器: 检查设备兼容性
276
- 设备兼容性检查器-->>移动端APP: 返回不兼容错误
277
- 移动端APP->>错误处理器: 处理兼容性错误
278
- 错误处理器->>日志服务: 记录兼容性错误
279
- 错误处理器-->>移动端APP: 返回错误处理结果
280
- 移动端APP->>用户: 显示兼容性提示
281
- \`\`\`
282
-
283
- #### 11.3.2 权限冲突错误
284
- \`\`\`mermaid
285
- sequenceDiagram
286
- participant 用户
287
- participant 移动端APP
288
- participant 权限服务
289
- participant 错误处理器
290
- participant 日志服务
291
- participant 设置管理器
292
-
293
- 用户->>移动端APP: 执行需要权限的操作
294
- 移动端APP->>权限服务: 检查所需权限
295
- 权限服务-->>移动端APP: 返回权限拒绝
296
- 移动端APP->>错误处理器: 处理权限错误
297
- 错误处理器->>日志服务: 记录权限错误
298
- 错误处理器->>设置管理器: 请求权限设置
299
- 设置管理器-->>错误处理器: 返回设置结果
300
- 错误处理器-->>移动端APP: 返回错误处理结果
301
- 移动端APP->>用户: 显示权限请求提示
302
- \`\`\`
303
-
304
- ### 11.4 边缘情况流程(并发、超时等)
305
-
306
- #### 11.4.1 离线功能处理
307
- \`\`\`mermaid
308
- sequenceDiagram
309
- participant 用户
310
- participant 移动端APP
311
- participant 网络状态检测器
312
- participant 离线数据管理器
313
- participant 本地数据库
314
-
315
- 用户->>移动端APP: 执行数据操作
316
- 移动端APP->>网络状态检测器: 检查网络状态
317
- 网络状态检测器-->>移动端APP: 返回无网络连接
318
- 移动端APP->>离线数据管理器: 处理离线操作
319
- 离线数据管理器->>本地数据库: 存储离线数据
320
- 本地数据库-->>离线数据管理器: 返回存储结果
321
- 离线数据管理器-->>移动端APP: 返回处理结果
322
- 移动端APP->>用户: 显示离线操作成功提示
323
- \`\`\`
324
-
325
- #### 11.4.2 复杂布局处理
326
- \`\`\`mermaid
327
- sequenceDiagram
328
- participant 移动端APP
329
- participant 布局引擎
330
- participant 性能优化器
331
- participant 缓存服务
332
- participant 日志服务
333
-
334
- 移动端APP->>布局引擎: 请求复杂布局计算
335
- 布局引擎->>布局引擎: 执行多区域布局算法
336
- alt 布局计算超时
337
- 布局引擎->>性能优化器: 请求优化策略
338
- 性能优化器-->>布局引擎: 返回简化策略
339
- 布局引擎->>布局引擎: 应用简化计算
340
- end
341
- 布局引擎-->>移动端APP: 返回优化布局
342
- 移动端APP->>缓存服务: 存储布局结果
343
- 移动端APP->>性能优化器: 记录布局性能
344
- 移动端APP->>日志服务: 记录布局日志
345
- \`\`\`
346
-
347
- ## 12. 业务状态描述
348
-
349
- | | | |
350
- |---|---|---|
351
- |**状态编号**|**状态名称**|**描述**|
352
- |01|待加载|页面初始化状态|
353
- |02|加载中|数据加载状态|
354
- |03|正常显示|页面正常显示状态|
355
- |04|数据为空|无数据状态|
356
- |05|加载失败|数据加载失败状态|
357
- |[添加更多状态...]
358
-
359
- ## 13. 移动端处理逻辑详细说明
360
-
361
- ### 13.1 页面初始化逻辑
362
- [详细描述页面加载时的初始化处理逻辑]
363
-
364
- ### 13.2 数据获取逻辑
365
- [详细描述页面数据获取的处理逻辑,包括API调用、数据处理等]
366
-
367
- ### 13.3 用户交互处理逻辑
368
- [详细描述用户各种交互操作的处理逻辑]
369
-
370
- ### 13.4 数据展示逻辑
371
- [详细描述数据在页面中的展示处理逻辑]
372
-
373
- ### 13.5 错误处理逻辑
374
- [详细描述页面中各种错误情况的处理逻辑]
375
-
376
- ### 13.6 离线处理逻辑
377
- [详细描述应用在离线状态下的处理逻辑]
378
-
379
- ### 13.7 缓存处理逻辑
380
- [详细描述应用中数据缓存的处理逻辑]
381
-
382
- ## 14. 伪代码示例
383
-
384
- \`\`\`gherkin
385
- Scenario Outline: 用户在APP中进行下拉刷新操作
386
- Given 用户在<page_name>页面
387
- When 用户执行下拉刷新手势
388
- Then 系统应重新加载数据并<result>
389
-
390
- Examples:
391
- | page_name | result |
392
- | 订单列表页 | 显示最新订单数据 |
393
- | 商品详情页 | 显示商品最新信息 |
394
-
395
- Scenario Outline: APP平台特性适配流程
396
- Given 用户使用<platform>设备
397
- When 应用启动时
398
- Then 系统应:
399
- 1. 检测设备平台类型
400
- 2. 应用相应平台的设计规范
401
- 3. 调整UI组件样式
402
- 4. 适配平台特有的交互方式
403
-
404
- Examples:
405
- | platform | 适配策略 |
406
- | iOS | 应用iOS设计语言,使用原生导航栏 |
407
- | Android | 应用Material Design,使用原生返回键 |
408
-
409
- Scenario Outline: APP手势操作处理流程
410
- Given 用户在<page_name>页面上执行<gesture_type>手势
411
- When 手势识别器检测到手势时
412
- Then 系统应:
413
- 1. 识别手势类型和参数
414
- 2. 验证手势操作的合法性
415
- 3. 执行相应的业务逻辑
416
- 4. 提供操作反馈
417
-
418
- Examples:
419
- | page_name | gesture_type | 处理逻辑 |
420
- | 商品列表页 | 下拉刷新 | 触发数据重新加载,显示刷新动画 |
421
- | 商品详情页 | 左右滑动 | 切换到上一个/下一个商品,支持边缘回弹效果 |
422
- | 购物车页 | 长按商品 | 显示商品操作菜单(删除、收藏、移动等) |
423
- | 订单页 | 双击订单项 | 快速查看订单详情,支持3D Touch预览(iOS) |
424
- | 设置页 | 捏合缩放 | 调整界面元素大小,适配用户视觉偏好 |
425
-
426
- Scenario Outline: APP导航与路由处理流程
427
- Given 用户在<current_page>页面执行<navigation_action>
428
- When 系统处理导航请求时
429
- Then 系统应:
430
- 1. 验证目标页面访问权限
431
- 2. 保存当前页面状态
432
- 3. 执行页面过渡动画
433
- 4. 加载目标页面并恢复状态
434
-
435
- Examples:
436
- | current_page | navigation_action | 处理流程 |
437
- | 首页 | 点击底部Tab | 平滑切换Tab页面,保持各页面状态 |
438
- | 商品详情页 | 点击返回按钮 | 返回上级页面,恢复滚动位置和筛选条件 |
439
- | 购物车页 | 点击商品图片 | 跳转到商品详情页,传递商品ID和来源信息 |
440
- | 订单确认页 | 页面刷新 | 保持表单数据,重新验证库存和价格信息 |
441
- | 设置页 | 深度链接跳转 | 解析链接参数,导航到指定设置项并高亮显示 |
442
- \`\`\`
443
-
444
- ---
445
-
446
- **重要提醒**:
447
- 1. 请输出完整的Markdown文档,不要省略任何章节
448
- 2. 每个章节都要有实质性的内容,不能只是模板
449
- 3. 根据输入的原始内容进行具体分析,不要使用通用模板
450
- 4. 文档总长度应该在3000字以上
451
- 5. 表格中的内容要填写具体信息,不要保留占位符
452
- 6. 重点关注移动端特有的布局、样式、交互逻辑等技术细节
453
- 7. 考虑iOS和Android平台的差异性
454
-
455
- 现在请开始生成完整的APP开发技术需求文档:`;
@@ -1,92 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.intelligentRequirementAnalysisPrompt = void 0;
4
- exports.intelligentRequirementAnalysisPrompt = `你是一位专业的软件需求分析师,擅长快速识别需求类型并进行精确的功能点分析。
5
-
6
- ## 任务要求
7
- - 快速识别需求的主要类型(接口、PC页面、APP、SDK集成、混合类型)
8
- - 根据需求类型,精确提取2-5个核心功能点
9
- - 避免过度拆分,确保每个功能点都具有独立的业务价值
10
- - 推荐最合适的技术模板
11
-
12
- ## 输入内容
13
-
14
- {inputContent}
15
-
16
- ## 需求类型识别标准
17
-
18
- **接口类型**:
19
- - 关键词:API、接口、REST、GraphQL、微服务、后端服务、数据接口、服务端
20
- - 特征:主要描述数据交互、业务逻辑处理、系统集成、数据库操作
21
- - 输出:数据结构、接口规范、业务逻辑
22
-
23
- **PC页面类型**:
24
- - 关键词:页面、界面、UI、网页、浏览器、前端、管理后台、Web应用
25
- - 特征:主要描述用户界面、表单操作、数据展示、用户交互
26
- - 输出:页面布局、交互逻辑、样式设计
27
-
28
- **APP类型**:
29
- - 关键词:App、移动应用、iOS、Android、移动端、小程序、原生应用
30
- - 特征:主要描述移动端功能、手势操作、移动设备特性、推送通知
31
- - 输出:移动端界面、手势交互、设备适配
32
-
33
- **SDK集成类型**:
34
- - 关键词:SDK、第三方、集成、对接、支付、地图、推送、统计、开放平台
35
- - 特征:主要描述与外部服务的对接、配置参数、回调处理
36
- - 输出:集成流程、配置说明、调用示例
37
-
38
- **混合类型**:
39
- - 同时包含上述多种类型的特征
40
- - 需要生成多种技术模板
41
-
42
- ## 功能点提取原则
43
-
44
- 1. **精确性原则**:只提取真正核心的、独立的功能点(通常2-5个)
45
- 2. **业务价值原则**:每个功能点都应该具有明确的业务价值
46
- 3. **技术匹配原则**:功能点应该与识别出的需求类型高度匹配
47
- 4. **避免过度拆分**:不要将一个完整的功能拆分成多个小功能点
48
-
49
- ## 输出格式
50
-
51
- 请输出一个JSON对象,格式如下:
52
-
53
- \`\`\`json
54
- {
55
- "analysisType": "single_general|multi_general|multi_specific_features",
56
- "requirementType": "接口|PC页面|APP|SDK集成|混合类型",
57
- "primaryTechnology": "主要技术栈描述",
58
- "confidence": "high|medium|low",
59
- "requirements": [
60
- {
61
- "id": "req_001",
62
- "title": "功能点名称",
63
- "fullContent": "功能点的详细描述",
64
- "priority": "high|medium|low",
65
- "complexity": "简单|中等|复杂",
66
- "type": "接口|PC页面|APP|SDK集成"
67
- }
68
- ],
69
- "templateRecommendation": {
70
- "primaryTemplate": "api|pc|app|sdk|multi",
71
- "reason": "选择该模板的原因",
72
- "additionalTemplates": ["如果是混合类型,列出需要的其他模板"]
73
- },
74
- "optimizationSuggestion": "针对功能点数量和类型的优化建议"
75
- }
76
- \`\`\`
77
-
78
- ## 分析步骤
79
-
80
- 1. **快速类型识别**:根据关键词和特征快速判断需求的主要类型
81
- 2. **核心功能提取**:提取2-5个真正核心的功能点,避免过度拆分
82
- 3. **模板推荐**:根据需求类型推荐最合适的技术模板
83
- 4. **优化建议**:提供功能点优化建议,确保精确性
84
-
85
- ## 重要提醒
86
-
87
- - **避免过度拆分**:一个完整的业务功能不要拆分成多个小功能点
88
- - **精确匹配**:确保功能点与需求类型高度匹配
89
- - **数量控制**:通常一个需求应该只有2-5个核心功能点
90
- - **模板导向**:优先考虑能够生成单一技术模板的功能点组合
91
-
92
- 请基于以上标准进行智能需求分析:`;