@templmf/temp-solf-lmf 0.0.61 → 0.0.62
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/fe-flow +37 -31
- package/package.json +1 -1
- package/ui-parser +13 -9
package/fe-flow
CHANGED
|
@@ -257,9 +257,21 @@ PHASE 1 - 需求质检与改写
|
|
|
257
257
|
|
|
258
258
|
目标:检查用户提交的需求文档是否完整规范,不符合则改写补全,保存到本地。
|
|
259
259
|
|
|
260
|
-
|
|
260
|
+
行动分三步:
|
|
261
|
+
Step 1 - 等待需求文档(等待节点):
|
|
262
|
+
必须等用户提交需求文档后才能继续,不得跳过此等待节点。
|
|
263
|
+
|
|
264
|
+
<ask_followup_question>
|
|
265
|
+
<question>请提交需求文档(可粘贴内容或提供文件路径)。</question>
|
|
266
|
+
<follow_up>
|
|
267
|
+
<suggest>接口文档已准备好,文件路径为:[文件路径]</suggest>
|
|
268
|
+
<suggest>接口文档内容如下:[粘贴内容]</suggest>
|
|
269
|
+
</follow_up>
|
|
270
|
+
</ask_followup_question>
|
|
271
|
+
|
|
272
|
+
|
|
273
|
+
Step 2 - 需求质检(Ask 模式):
|
|
261
274
|
|
|
262
|
-
Step 1 - 需求质检(Ask 模式):
|
|
263
275
|
提示用户切换到 Ask 模式,读取用户提交的需求文档,按以下标准质检:
|
|
264
276
|
- 是否包含新增页面清单或改动现有页面的明确说明
|
|
265
277
|
- 是否列出可复用的现有组件(含路径)
|
|
@@ -268,10 +280,10 @@ Step 1 - 需求质检(Ask 模式):
|
|
|
268
280
|
- 是否有歧义或缺失的交互细节
|
|
269
281
|
|
|
270
282
|
质检结果:
|
|
271
|
-
- 符合规范:直接进入 Step
|
|
272
|
-
- 不符合 / 不完整:列出所有问题,按规范标准改写补全,再进入 Step
|
|
283
|
+
- 符合规范:直接进入 Step 3
|
|
284
|
+
- 不符合 / 不完整:列出所有问题,按规范标准改写补全,再进入 Step 3
|
|
273
285
|
|
|
274
|
-
Step
|
|
286
|
+
Step 3 - 保存需求文档(Code 模式):
|
|
275
287
|
提示用户切换到 Code 模式,将改写后的需求文档保存到 `.roo-flow/requirements.md`。
|
|
276
288
|
|
|
277
289
|
完成标志:`.roo-flow/requirements.md` 已生成并经用户确认。
|
|
@@ -294,34 +306,36 @@ Step 2 - 保存需求文档(Code 模式):
|
|
|
294
306
|
|
|
295
307
|
---
|
|
296
308
|
|
|
297
|
-
PHASE 2 -
|
|
309
|
+
PHASE 2 - 视觉分析 + 组件代码生成
|
|
298
310
|
|
|
299
311
|
目标:先搭建页面整体可运行架构,再逐文件填充 UI 代码,最后对照需求文档整改补全,输出组件分析文档。
|
|
300
312
|
|
|
301
|
-
|
|
313
|
+
行动分五步:
|
|
302
314
|
|
|
303
|
-
Step 1 -
|
|
304
|
-
提示用户切换到
|
|
305
|
-
|
|
315
|
+
Step 1 - 填充 UI 代码(UI Parser 模式):
|
|
316
|
+
提示用户切换到 UI Parser 模式,并上传截图,每完成一个组件即可在浏览器中查看效果,边生成边验证。
|
|
317
|
+
|
|
318
|
+
Step 2 - 替换切图图片路径:
|
|
319
|
+
读取 `.roo-flow/requirements.md` 和 `.roo-flow/conventions.md`,
|
|
320
|
+
提示用户确认切图已按命名规范放入 conventions.md 中约定的切图目录后,往 Step 1 已创建的对应文件里填充真实图片路径。
|
|
321
|
+
|
|
322
|
+
Step 3 - 搭建页面整体架构(Code 模式):
|
|
323
|
+
提示用户切换到 Code 模式,根据用户指定的文件,按项目文件树结构抽取所有页面和组件,确保项目能跑起来、页面能正常打开:
|
|
324
|
+
- 根据用户指定的文件,按文件树的定义将文件对应的模块抽取出来
|
|
306
325
|
- 按需求中的页面清单注册路由(遵循现有路由写法)
|
|
307
|
-
- 按文件树结构创建页面入口文件(`index.vue` / `index.tsx
|
|
326
|
+
- 按文件树结构创建页面入口文件(`index.vue` / `index.tsx`),参考当前
|
|
308
327
|
- 按组件清单创建子组件目录和空文件占位
|
|
309
328
|
- 确认项目启动无报错,所有新增页面路由可正常访问
|
|
310
329
|
完成标志:项目可正常运行,所有新增页面可访问,用户确认。
|
|
311
330
|
|
|
312
|
-
Step
|
|
313
|
-
提示用户确认切图已按命名规范放入 conventions.md 中约定的切图目录后,切换到 UI Parser 模式。
|
|
314
|
-
UI Parser 自动扫描切图目录,按文件树顺序逐张读取图片,往 Step 1 已创建的对应文件里填充真实 UI 代码。
|
|
315
|
-
每完成一个组件即可在浏览器中查看效果,边生成边验证。
|
|
316
|
-
|
|
317
|
-
Step 3 - 对照需求整改(Code 模式):
|
|
331
|
+
Step 4 - 对照需求整改(Code 模式):
|
|
318
332
|
提示用户切换到 Code 模式,读取 `.roo-flow/requirements.md`,对 Step 2 填充的组件代码进行整改,
|
|
319
333
|
补充视觉稿未覆盖的交互细节:
|
|
320
334
|
- 权限控制、条件显示逻辑
|
|
321
335
|
- 边界状态(空态、错误态的展示方式)
|
|
322
336
|
- 需求文档中明确的字段显示规则和交互行为
|
|
323
337
|
|
|
324
|
-
Step
|
|
338
|
+
Step 5 - 输出组件分析文档(Code 模式):
|
|
325
339
|
将以下内容保存到 `.roo-flow/components.md`:
|
|
326
340
|
- 新增组件树(标注复用/新建,标注使用的 UI 组件)
|
|
327
341
|
- 新增或修改的状态清单
|
|
@@ -332,26 +346,18 @@ Step 4 - 输出组件分析文档(Code 模式):
|
|
|
332
346
|
|
|
333
347
|
切换提示(Step 1):
|
|
334
348
|
<ask_followup_question>
|
|
335
|
-
<question
|
|
336
|
-
<follow_up>
|
|
337
|
-
<suggest mode="code">切换到 Code 模式,按文件树结构搭建页面架构空壳并确保项目可运行</suggest>
|
|
338
|
-
</follow_up>
|
|
339
|
-
</ask_followup_question>
|
|
340
|
-
|
|
341
|
-
切换提示(Step 2):
|
|
342
|
-
<ask_followup_question>
|
|
343
|
-
<question>页面架构已搭建完毕,项目可正常运行。请确认视觉切图已按命名规范([路由名]-[组件名]-[图标名].ext)放入 conventions.md 中约定的目录,然后切换到 UI Parser 模式开始逐文件填充 UI 代码。</question>
|
|
349
|
+
<question>切换到 UI Parser 模式开始逐文件填充 UI 代码。</question>
|
|
344
350
|
<follow_up>
|
|
345
|
-
<suggest mode="ui-parser"
|
|
351
|
+
<suggest mode="ui-parser">切换到 UI Parser 模式逐文件填充 UI 代码</suggest>
|
|
346
352
|
<suggest>跳过此阶段(没有视觉稿)</suggest>
|
|
347
353
|
</follow_up>
|
|
348
354
|
</ask_followup_question>
|
|
349
355
|
|
|
350
|
-
切换提示(Step
|
|
356
|
+
切换提示(Step 2):
|
|
351
357
|
<ask_followup_question>
|
|
352
|
-
<question
|
|
358
|
+
<question>接下来替换图片路径。</question>
|
|
353
359
|
<follow_up>
|
|
354
|
-
<suggest mode="code">切换到 Code
|
|
360
|
+
<suggest mode="code">切换到 Code 模式,替换切图图片路径</suggest>
|
|
355
361
|
</follow_up>
|
|
356
362
|
</ask_followup_question>
|
|
357
363
|
|
package/package.json
CHANGED
package/ui-parser
CHANGED
|
@@ -236,14 +236,15 @@ OBJECTIVE
|
|
|
236
236
|
|
|
237
237
|
读取 `.roo-flow/conventions.md`,获取:
|
|
238
238
|
- 视觉切图存放目录路径
|
|
239
|
-
- 切图命名规范(格式:`[
|
|
239
|
+
- 切图命名规范(格式:`[页面名]-[组件名/区块名].[ext]`)
|
|
240
240
|
|
|
241
|
-
同时读取
|
|
241
|
+
同时读取 `.roo-flow/conventions.md` 下至文件,识别:
|
|
242
242
|
- 框架版本:Vue2 (Options API) / Vue3 (Composition API + <script setup>) / React
|
|
243
243
|
- 已安装的 UI 组件库及版本:Element UI / Element Plus / Ant Design Vue / Vant / Naive UI 等
|
|
244
244
|
- 是否使用 TypeScript
|
|
245
245
|
- 现有组件的文件后缀:.vue / .tsx / .jsx
|
|
246
246
|
- 现有组件的 import 风格和结构规范
|
|
247
|
+
- 路由所在路径结构
|
|
247
248
|
|
|
248
249
|
**Step 2 - 确认技术栈**
|
|
249
250
|
|
|
@@ -254,7 +255,8 @@ OBJECTIVE
|
|
|
254
255
|
- 组件库:[detected UI library + version]
|
|
255
256
|
- TypeScript:[yes/no]
|
|
256
257
|
- 文件后缀:[detected extension]
|
|
257
|
-
-
|
|
258
|
+
- 路由所在路径结构: [detected router path]
|
|
259
|
+
<!-- - 切图目录:[assets path from conventions.md] -->
|
|
258
260
|
</question>
|
|
259
261
|
<follow_up>
|
|
260
262
|
<suggest>确认,按此技术栈生成代码</suggest>
|
|
@@ -264,7 +266,7 @@ OBJECTIVE
|
|
|
264
266
|
|
|
265
267
|
如果无法从项目文件中判断技术栈,直接询问用户后再继续。
|
|
266
268
|
|
|
267
|
-
**Step 3 - 扫描切图目录**
|
|
269
|
+
<!-- **Step 3 - 扫描切图目录**
|
|
268
270
|
|
|
269
271
|
使用 list_files 扫描 conventions.md 中约定的切图目录,列出所有待处理图片,按文件名排序,告知用户将按此顺序逐张处理。
|
|
270
272
|
|
|
@@ -290,18 +292,19 @@ OBJECTIVE
|
|
|
290
292
|
<suggest>src/views/[page-name]/components/[ComponentName].vue</suggest>
|
|
291
293
|
<suggest>src/components/[ComponentName].vue</suggest>
|
|
292
294
|
</follow_up>
|
|
293
|
-
</ask_followup_question>
|
|
295
|
+
</ask_followup_question> -->
|
|
294
296
|
|
|
295
|
-
**
|
|
297
|
+
**4. 生成页面代码**
|
|
296
298
|
|
|
297
299
|
根据已确认的技术栈生成真实可运行的完整组件代码:
|
|
298
300
|
- Vue2:Options API,使用 Element UI 组件,data / methods / computed 结构
|
|
299
301
|
- Vue3:Composition API + <script setup>,使用 Element Plus 等已安装版本组件,ref / computed / defineProps
|
|
300
302
|
- React:hooks,useState / useEffect,使用 Ant Design 等已安装版本组件
|
|
301
303
|
- 所有组件标签、props、事件名称必须与已安装的组件库版本完全一致
|
|
302
|
-
- 数据获取留 `// TODO: 接口调用`,状态管理留 `// TODO:
|
|
304
|
+
- 数据获取留 `// TODO: 接口调用`,状态管理留 `// TODO: 状态管理`, 图片路径 `// TODO: 图片路径`
|
|
305
|
+
- 给生成的组件配置个路由,让用户可预览
|
|
303
306
|
|
|
304
|
-
使用 write_to_file
|
|
307
|
+
使用 write_to_file 写入完整组件代码文件,必须保证一个图片对应一个生成的组件文件,必须提供完整内容,不得截断或使用占位符。
|
|
305
308
|
|
|
306
309
|
**4. 确认并继续**
|
|
307
310
|
|
|
@@ -333,4 +336,5 @@ Language Preference:
|
|
|
333
336
|
You should always speak and think in the "简体中文" (zh-CN) language unless the user gives you instructions below to do otherwise.
|
|
334
337
|
|
|
335
338
|
Mode-specific Instructions:
|
|
336
|
-
激活时先读取 .roo-flow/conventions.md
|
|
339
|
+
激活时先读取 .roo-flow/conventions.md 获取技术栈与文件树结构,确认后扫描切图目录逐张处理。根据图片文件名(格式:路由名-组件名-图标名.ext)推断路由归属、组件名称和图标内容,按项目实际技术栈(Vue2/Vue3/React)和已安装的组件库生成真实可运行的组件代码并写入文件。每次只处理一张图。数据获取、状态管理、与图片路径留 TODO 注释。所有切图处理完毕后切换回 fe-flow 模式。
|
|
340
|
+
<!-- 激活时先读取 .roo-flow/conventions.md 获取切图目录和命名规范,再读取 package.json 和现有组件文件识别技术栈,确认后扫描切图目录逐张处理。根据图片文件名(格式:路由名-组件名-图标名.ext)推断路由归属、组件名称和图标内容,按项目实际技术栈(Vue2/Vue3/React)和已安装的组件库生成真实可运行的组件代码并写入文件。每次只处理一张图。数据获取和状态管理留 TODO 注释。所有切图处理完毕后切换回 fe-flow 模式。 -->
|